From nobody Fri Dec 19 20:58:38 2025 Received: from IND01-BMX-obe.outbound.protection.outlook.com (mail-bmxind01olkn2078.outbound.protection.outlook.com [40.92.103.78]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 5BDA586AE3; Sat, 17 Aug 2024 11:46:56 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.92.103.78 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1723895218; cv=fail; b=hRQnDFXj2q4kYtukMLHSq03Liwq0sFTf2Txmg5oZhpPTkrWiqa6nIzkw2B2FOuM9Za4w6SfqLvamBnNAk2CYXs2IHBmldOcUfcDlfJ7UpD8tScNoEttiis0Y+655sso/MLDxVv2jgYV9Iltsj28n3LgKlgz/Pnn5UEuf2sSpUJk= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1723895218; c=relaxed/simple; bh=gAzRv4angoY9W7kjB4Ys1D/UfSSDoHTJa292p/uqW8Q=; h=From:To:CC:Subject:Date:Message-ID:References:In-Reply-To: Content-Type:MIME-Version; b=TC/Uf8VKXhi0HgZGk3PWdODhhCYwpOpl69xEGQrm3L2DhwrdYoq2qcz7vG2rJktRJC5R67FUP5X2ZE7IN+M1abGuazDk75eVc8CEylyu+bBcBUgAhVmx8HBbWfC1G7Dde/+2AUZnXwUfEFo/cKT7G/B/GTbzKYR/QKz89D4N1/M= ARC-Authentication-Results: i=2; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=live.com; spf=pass smtp.mailfrom=live.com; dkim=pass (2048-bit key) header.d=live.com header.i=@live.com header.b=YDa6Y2R/; arc=fail smtp.client-ip=40.92.103.78 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=live.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=live.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=live.com header.i=@live.com header.b="YDa6Y2R/" ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=tF228ir6rJ1KjvEh2zjLPyzknHcWtbj89ZAAbEwPSMWP5Sozx6WhY/5hQqGvN4BWmh31eMSxPIuZ8cHwgekK0fSomMYKStK1Vrv9yuwoWI2ZOa10wE9ELVswfhFZ1JU/ZeAAzNM8t4qtkdf7y18Cr41svzCYMAZnR24GGU+Qr+rZizv1WI/Fan37Mhh1xUG1DUXYyYKm/KVHgYNm/vcrAgiS9SKCQfl6sA1px/gsbiw98U+xQVTn3VWcvgRw9X1C5vVPBDHoEb/0/OpW7eO5xgT6LvRGIguMkzCVs4eD5yXlgYv189BIoAIJeH4/ZQBRUz1qYL6JBoUCZKWCXeAWUw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector10001; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=gAzRv4angoY9W7kjB4Ys1D/UfSSDoHTJa292p/uqW8Q=; b=ObUgzuIGf8yn1cKBBkrFwcBqoJ82FhQ5pOQBgn1oGLnDW9ozK1Yvn1CbFCYAWenMe4bx7wTfKmVB4Ce+C3qed8GCwBzQ8O9zv2KdWCHY4MTbER1BQhMj+c6hjnbeT4OPqsd8M1EIFgoF923n1NkrNpPJpjLSGZyfe5IDQ4fz1e7XiUoMGmldYhua8DgIH6PlDucfl5YvjJByNhnOIMBuWINeINu5s0JcxUJ+8pQgXkABz/sLt92J8MaHVxxeAThPO6vQNKM9XhwST90MZGJ6xHmkHEf/Zk/QbKWgJ5qwO+6C4LZuCkoPFt65jAtQ2WykGGlaJ50DTSRXhIXfHEXi7g== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=none; dmarc=none; dkim=none; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=live.com; s=selector1; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=gAzRv4angoY9W7kjB4Ys1D/UfSSDoHTJa292p/uqW8Q=; b=YDa6Y2R/WlDammQJCLEN8p+oNToiiRbCLmIfvv7CGE+YyhE18OZMk61eXBDIo5u+Df5KtgUDJN8a4hMl/7H6WoWpwNce0M4+riGHusE44QuUk53JgYzU9YoocnVsKRs7uCLYM1WOTzxIm6tZGsKglUEoefe2cWSouZQpg6Ky+/wit/0HuHZDJM3T2PK1QTAYu29tAqdS+1nft12v+p28SVzsvIyc+ft+OXUn6c98R/jH6uuz8/BMuJiT5NfsAa7HzH8rJkAciccqBehPHAMEITk9CNwNKEXryQtEFkoyiW7n54ca0ngjnN5ylU5D+lNdF7eH3eE8oCwEuaLoRpWgQw== Received: from MA0P287MB0217.INDP287.PROD.OUTLOOK.COM (2603:1096:a01:b3::9) by PN3P287MB0241.INDP287.PROD.OUTLOOK.COM (2603:1096:c01:d2::12) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.7875.20; Sat, 17 Aug 2024 11:46:47 +0000 Received: from MA0P287MB0217.INDP287.PROD.OUTLOOK.COM ([fe80::98d2:3610:b33c:435a]) by MA0P287MB0217.INDP287.PROD.OUTLOOK.COM ([fe80::98d2:3610:b33c:435a%6]) with mapi id 15.20.7875.016; Sat, 17 Aug 2024 11:46:47 +0000 From: Aditya Garg To: "tzimmermann@suse.de" , "maarten.lankhorst@linux.intel.com" , "mripard@kernel.org" , "airlied@gmail.com" , "daniel@ffwll.ch" , Jiri Kosina , "bentiss@kernel.org" , =?utf-8?B?VGhvbWFzIFdlacOfc2NodWg=?= CC: Orlando Chamberlain , Kerem Karabay , Linux Kernel Mailing List , "linux-input@vger.kernel.org" , "dri-devel@lists.freedesktop.org" Subject: [PATCH v5 2/10] HID: hid-appletb-kbd: add driver for the keyboard mode Thread-Topic: [PATCH v5 2/10] HID: hid-appletb-kbd: add driver for the keyboard mode Thread-Index: AQHa8JsjpSogBIImykuNMN0RuvCLdg== Date: Sat, 17 Aug 2024 11:46:47 +0000 Message-ID: <0B505E00-A1D6-4D0E-BE04-311E231874C5@live.com> References: In-Reply-To: Accept-Language: en-IN, en-US Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: x-ms-exchange-messagesentrepresentingtype: 1 x-tmn: [ZF2ZqM3qYjTJg8io+3BzMQq+zUDbRw1Fixsy1pgPnWQafElTb9f/MPTzeo7Zz/zLT/A2Fu8rdBc=] x-ms-publictraffictype: Email x-ms-traffictypediagnostic: MA0P287MB0217:EE_|PN3P287MB0241:EE_ x-ms-office365-filtering-correlation-id: 2c4d06c1-5ff3-4aab-9cb9-08dcbeb24647 x-microsoft-antispam: BCL:0;ARA:14566002|461199028|15080799003|8060799006|19110799003|440099028|3412199025|102099032; x-microsoft-antispam-message-info: KQgPEox5ljSQ6S14BXtzd8aa8L+bo904wuSy1Qc9j2jUbSOr12AEdSX9PCV27PPYf3/VwXC0+I8L3NQMN1vzHeRRfnEQbyzyVdWyLG8Ozg/gi01Ibp5GEUhJBNk3rUluSaigShzszJ8qasHUe2+QGziV/ei3QU5rNQ4QDlFlt3FmL/1XQ5NGs9TW+p11T+cy1Fr5dLoLyp+3Z+mZQ8uXFq/bpypGtoqTFagMOmLFyCw/X02sDKpN2lIXl/XTgSAy/cbV1EO7LHKlOf2g8R9Ro6dhpK4jTNXYxAN6r+qhFbr+eE+Wz00K2kOMaAhtzfY/Q/7hak8eeYF1YKtDh2zxqUEECq4/3gpatkUzyY1/S9/8kkYoX3HeepSGao5/8+bS83lA5002QdDNUCFIQ3W0oPut/8bZ45E74ID11gyagIwQ0613Nv35slqKm7FDiOQyzkjNmngDZ6qC1Q8zeFcAdRTxgOPt3eSHrsE9PS2idTuQ44+B+eU9cP78YKxz1MTt2DoJBHkObQd47aYNwv0wIKT1LQcW3/cNEyvUmiu4JJCQ0bpFslbZgY8AGAo2W/Sm7yuAZJVeuDTcDU7ByX4LDbF3/H/0zI4CpWm7XYAsMOgh9yVL6K7kHOkCAM6Mci00vVrB9HhzlQuF5+lIx71WaFhT16wn8KLjLNNwDIXh0VYRUkGxFfdb4Syh6ZnXxYhF x-ms-exchange-antispam-messagedata-chunkcount: 1 x-ms-exchange-antispam-messagedata-0: =?utf-8?B?RWVYajlSNjRrOGJweTBiZVpucjByeWpuTmk4a3lHeTdiTUlQZ25TcDJ0Qk51?= =?utf-8?B?SFJJWmswcGV2S0ZNOVBicWhhRVRjcEFiTmpHdkp1NTVWMUhBbUpuQit3STFn?= =?utf-8?B?Nlg4dFZvMXVlVmU2V2hsN0hjQlJhRWtUYWczb3FGdklNUS92bjB4aEpVcGhC?= =?utf-8?B?azcvWkZqT2c3cHlYN291WXUwa1o3cmxlbWRRNUwyUUlZNHVoOEdBTVVQVkN3?= =?utf-8?B?UGJmU3d4ZFVZZGZFNm00NWJxK0sxMTFQR1d3dEc0T3p4K2ZaeGtuV2ZManMx?= =?utf-8?B?Z1VEQXdtQ3FDUFhTTGc1ZG1kNTFIaVVQcDhBR043T0FEZVNOdWZLVjJoaGtz?= =?utf-8?B?dkgvUHZwRERLeFhTT2dab3BqOFJyTjFFSGJDakJEZnVsNkpzV0gyTnl4VEtY?= =?utf-8?B?RytNWWU0M1lMSG51eCtVdndRZWdNZU9wR0w0eVU1VktRTnBmYjZFdTV4aTNO?= =?utf-8?B?bDUya3VHSDlab2tPNGpnUVZvcGpZd3RnM29jamt1WmJodytvVWpSd3JXbmEz?= =?utf-8?B?V2ZXY3liZWlWQ0xyQzlQVCtZbndQU0phakNvQWpCV29FZ1F3c3FOVXYwWmJh?= =?utf-8?B?c2NIblBhODB3WlRkSi9rbkNobFpNRGNKM2ttVU41ODN6VFNIOW5XQlN6cERC?= =?utf-8?B?S2YrbVRvaEpFdy96dkFyaUtxbElrcnc5b1B2VTVpOTdYbnJVYk8wb0lRWWRL?= =?utf-8?B?K2xsckxOVXI3OUd3OWcrN1VqeU1WRVBhb3RERkdDWXg5M3Z6QTU2bHVzNFJJ?= =?utf-8?B?clNCZmtXeGRJUkNPdHpWeWVGVVl1WFJ1T3orNU9zWk1Sa1BqZkgyc2gxbHRP?= =?utf-8?B?TFVVOWdDSzZ3QWVzczdwNEpTZUY0eFJUVm93L01lSURTOFlWY1JMWVRENXlD?= =?utf-8?B?UzVyNXQ1c1J2dGhLUzBUVFlEL1h3WkVsdzhXcXIvejdQQWQ0Ylh0ckxyN3Ra?= =?utf-8?B?bUtGZXE0L0lrVktIcmJ4WFBpc1BzbTFJVGNpalUydk9Fd0VHSFA3Q0NmYWdy?= =?utf-8?B?Zit6S3U2Qkl5dUFYOUZ3TjJxUDlYWGthRGRTL3U3UkNkT3B0bmk4QkNkVWcx?= =?utf-8?B?V3dSUUtxanBsaUtrTlJmWDg3NEtWbk5URzlXOXdhT0ZCZloxQUcvckxpQkcr?= =?utf-8?B?VVhUYTArdElmbWw2eTFhditWZW5DTVR6eW9wM3RrLzk2alg3OGRmbGlGaWNM?= =?utf-8?B?RjUxL2FyNHR3SkZhQXUxenVlaTdjQ01yWThIR0ZWREhKME1tYjJ4ekJTakdB?= =?utf-8?B?dW56MGIwWWJ4T2NtNnJEdlVydVJsZTZaTytUZ085K241Z0QrWERNRFNSSWNj?= =?utf-8?B?VyttK1F3Rjc1RjdqMW4zZ1dpSHJNbEhTeGdhcUdOeVJDemdGWkZuZ1RCVklH?= =?utf-8?B?VDdYVS83SzNlLzNSaEJXUXFSYUNUK1drK2FHbkd1SHpRVmpYMWRoMXlsVlZh?= =?utf-8?B?WXdHd3JNd1BkcnJ5UW5ILzF4N2E2R2pQeGJYeFRsemt4SjdIUVRGRG5PUFZE?= =?utf-8?B?bVlKTU5sekIyZWhGSHcxRGttUVFpYXhUcGRxck9waU1FV0lTQUJ4QlUzZU13?= =?utf-8?B?YW9WU0EyWCtQUFV5K2hvNFJqZC9lZVdKYTBrcmNkOFhxYTlnTHdSMjFlQS9k?= =?utf-8?B?MUp2S2RMc2tEZDZ3cHhNcW16QU1UR0NyZWlzdE8zMyt0YnZKK1JuWXp3dDhY?= =?utf-8?B?Q2NlUTBrcDFXWU56Nnc4YnFQSlE2cTQ2dHV2REJkR1RpakdGKzlHdmE2emtT?= =?utf-8?Q?Id3JgBagJvBbrmXh/zTw4/NTyksV5frIoNuOqsV?= Content-Type: text/plain; charset="utf-8" Content-ID: <1D45754A28ABFF4FBD64BB3D862D1E65@INDP287.PROD.OUTLOOK.COM> Content-Transfer-Encoding: quoted-printable Precedence: bulk X-Mailing-List: linux-kernel@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-OriginatorOrg: sct-15-20-7719-20-msonline-outlook-24072.templateTenant X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-AuthSource: MA0P287MB0217.INDP287.PROD.OUTLOOK.COM X-MS-Exchange-CrossTenant-RMS-PersistedConsumerOrg: 00000000-0000-0000-0000-000000000000 X-MS-Exchange-CrossTenant-Network-Message-Id: 2c4d06c1-5ff3-4aab-9cb9-08dcbeb24647 X-MS-Exchange-CrossTenant-rms-persistedconsumerorg: 00000000-0000-0000-0000-000000000000 X-MS-Exchange-CrossTenant-originalarrivaltime: 17 Aug 2024 11:46:47.2198 (UTC) X-MS-Exchange-CrossTenant-fromentityheader: Hosted X-MS-Exchange-CrossTenant-id: 84df9e7f-e9f6-40af-b435-aaaaaaaaaaaa X-MS-Exchange-Transport-CrossTenantHeadersStamped: PN3P287MB0241 From: Kerem Karabay The Touch Bars found on x86 Macs support two USB configurations: one where the device presents itself as a HID keyboard and can display predefined sets of keys, and one where the operating system has full control over what is displayed. This commit adds a driver for the display functionality of the first configuration. Note that currently only T2 Macs are supported. This driver is based on previous work done by Ronald Tschal=C3=A4r . Signed-off-by: Kerem Karabay Co-developed-by: Aditya Garg Signed-off-by: Aditya Garg --- .../ABI/testing/sysfs-driver-hid-appletb-kbd | 13 + drivers/hid/Kconfig | 11 + drivers/hid/Makefile | 1 + drivers/hid/hid-appletb-kbd.c | 304 ++++++++++++++++++ drivers/hid/hid-quirks.c | 4 +- 5 files changed, 332 insertions(+), 1 deletion(-) create mode 100644 Documentation/ABI/testing/sysfs-driver-hid-appletb-kbd create mode 100644 drivers/hid/hid-appletb-kbd.c diff --git a/Documentation/ABI/testing/sysfs-driver-hid-appletb-kbd b/Docum= entation/ABI/testing/sysfs-driver-hid-appletb-kbd new file mode 100644 index 000000000..2a19584d0 --- /dev/null +++ b/Documentation/ABI/testing/sysfs-driver-hid-appletb-kbd @@ -0,0 +1,13 @@ +What: /sys/bus/hid/drivers/hid-appletb-kbd//mode +Date: September, 2023 +KernelVersion: 6.5 +Contact: linux-input@vger.kernel.org +Description: + The set of keys displayed on the Touch Bar. + Valid values are: + =3D=3D =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D + 0 Escape key only + 1 Function keys + 2 Media/brightness keys + 3 None + =3D=3D =3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D=3D diff --git a/drivers/hid/Kconfig b/drivers/hid/Kconfig index 4988c1fb2..72b665eda 100644 --- a/drivers/hid/Kconfig +++ b/drivers/hid/Kconfig @@ -158,6 +158,17 @@ config HID_APPLETB_BL To compile this driver as a module, choose M here: the module will be called hid-appletb-bl. =20 +config HID_APPLETB_KBD + tristate "Apple Touch Bar Keyboard Mode" + depends on USB_HID + help + Say Y here if you want support for the keyboard mode (escape, + function, media and brightness keys) of Touch Bars on x86 MacBook + Pros. + + To compile this driver as a module, choose M here: the + module will be called hid-appletb-kbd. + config HID_ASUS tristate "Asus" depends on USB_HID diff --git a/drivers/hid/Makefile b/drivers/hid/Makefile index 1d825a474..d903c9a26 100644 --- a/drivers/hid/Makefile +++ b/drivers/hid/Makefile @@ -30,6 +30,7 @@ obj-$(CONFIG_HID_ACRUX) +=3D hid-axff.o obj-$(CONFIG_HID_APPLE) +=3D hid-apple.o obj-$(CONFIG_HID_APPLEIR) +=3D hid-appleir.o obj-$(CONFIG_HID_APPLETB_BL) +=3D hid-appletb-bl.o +obj-$(CONFIG_HID_APPLETB_KBD) +=3D hid-appletb-kbd.o obj-$(CONFIG_HID_CREATIVE_SB0540) +=3D hid-creative-sb0540.o obj-$(CONFIG_HID_ASUS) +=3D hid-asus.o obj-$(CONFIG_HID_AUREAL) +=3D hid-aureal.o diff --git a/drivers/hid/hid-appletb-kbd.c b/drivers/hid/hid-appletb-kbd.c new file mode 100644 index 000000000..ecac68fc7 --- /dev/null +++ b/drivers/hid/hid-appletb-kbd.c @@ -0,0 +1,304 @@ +// SPDX-License-Identifier: GPL-2.0 +/* + * Apple Touch Bar Keyboard Mode Driver + * + * Copyright (c) 2017-2018 Ronald Tschal=C3=A4r + * Copyright (c) 2022-2023 Kerem Karabay + * Copyright (c) 2024 Aditya Garg + */ + +#define pr_fmt(fmt) KBUILD_MODNAME ": " fmt + +#include +#include +#include +#include +#include +#include +#include +#include + +#include "hid-ids.h" + +#define APPLETB_KBD_MODE_ESC 0 +#define APPLETB_KBD_MODE_FN 1 +#define APPLETB_KBD_MODE_SPCL 2 +#define APPLETB_KBD_MODE_OFF 3 +#define APPLETB_KBD_MODE_MAX APPLETB_KBD_MODE_OFF + +#define HID_USAGE_MODE 0x00ff0004 + +static int appletb_tb_def_mode =3D APPLETB_KBD_MODE_SPCL; +module_param_named(mode, appletb_tb_def_mode, int, 0444); +MODULE_PARM_DESC(mode, "Default touchbar mode:\n" + " 0 - escape key only\n" + " 1 - function-keys\n" + " [2] - special keys"); + +struct appletb_kbd { + struct hid_field *mode_field; + + u8 saved_mode; + u8 current_mode; +}; + +static const struct key_entry appletb_kbd_keymap[] =3D { + { KE_KEY, KEY_ESC, { KEY_ESC } }, + { KE_KEY, KEY_F1, { KEY_BRIGHTNESSDOWN } }, + { KE_KEY, KEY_F2, { KEY_BRIGHTNESSUP } }, + { KE_KEY, KEY_F3, { KEY_RESERVED } }, + { KE_KEY, KEY_F4, { KEY_RESERVED } }, + { KE_KEY, KEY_F5, { KEY_KBDILLUMDOWN } }, + { KE_KEY, KEY_F6, { KEY_KBDILLUMUP } }, + { KE_KEY, KEY_F7, { KEY_PREVIOUSSONG } }, + { KE_KEY, KEY_F8, { KEY_PLAYPAUSE } }, + { KE_KEY, KEY_F9, { KEY_NEXTSONG } }, + { KE_KEY, KEY_F10, { KEY_MUTE } }, + { KE_KEY, KEY_F11, { KEY_VOLUMEDOWN } }, + { KE_KEY, KEY_F12, { KEY_VOLUMEUP } }, + { KE_END, 0 } +}; + +static int appletb_kbd_set_mode(struct appletb_kbd *kbd, u8 mode) +{ + struct hid_report *report =3D kbd->mode_field->report; + struct hid_device *hdev =3D report->device; + int ret; + + ret =3D hid_hw_power(hdev, PM_HINT_FULLON); + if (ret) { + hid_err(hdev, "Device didn't resume (%pe)\n", ERR_PTR(ret)); + return ret; + } + + ret =3D hid_set_field(kbd->mode_field, 0, mode); + if (ret) { + hid_err(hdev, "Failed to set mode field to %u (%pe)\n", mode, ERR_PTR(re= t)); + goto power_normal; + } + + hid_hw_request(hdev, report, HID_REQ_SET_REPORT); + + kbd->current_mode =3D mode; + +power_normal: + hid_hw_power(hdev, PM_HINT_NORMAL); + + return ret; +} + +static ssize_t mode_show(struct device *dev, + struct device_attribute *attr, char *buf) +{ + struct appletb_kbd *kbd =3D dev_get_drvdata(dev); + + return sysfs_emit(buf, "%d\n", kbd->current_mode); +} + +static ssize_t mode_store(struct device *dev, + struct device_attribute *attr, + const char *buf, size_t size) +{ + struct appletb_kbd *kbd =3D dev_get_drvdata(dev); + u8 mode; + int ret; + + ret =3D kstrtou8(buf, 0, &mode); + if (ret) + return ret; + + if (mode > APPLETB_KBD_MODE_MAX) + return -EINVAL; + + ret =3D appletb_kbd_set_mode(kbd, mode); + + return ret < 0 ? ret : size; +} +static DEVICE_ATTR_RW(mode); + +struct attribute *appletb_kbd_attrs[] =3D { + &dev_attr_mode.attr, + NULL +}; +ATTRIBUTE_GROUPS(appletb_kbd); + +static int appletb_tb_key_to_slot(unsigned int code) +{ + switch (code) { + case KEY_ESC: + return 0; + case KEY_F1 ... KEY_F10: + return code - KEY_F1 + 1; + case KEY_F11 ... KEY_F12: + return code - KEY_F11 + 11; + + default: + return -EINVAL; + } +} + +static int appletb_kbd_hid_event(struct hid_device *hdev, struct hid_field= *field, + struct hid_usage *usage, __s32 value) +{ + struct appletb_kbd *kbd =3D hid_get_drvdata(hdev); + struct key_entry *translation; + struct input_dev *input; + int slot; + + if ((usage->hid & HID_USAGE_PAGE) !=3D HID_UP_KEYBOARD || usage->type != =3D EV_KEY) + return 0; + + input =3D field->hidinput->input; + + /* + * Skip non-touch-bar keys. + * + * Either the touch bar itself or usbhid generate a slew of key-down + * events for all the meta keys. None of which we're at all interested + * in. + */ + slot =3D appletb_tb_key_to_slot(usage->code); + if (slot < 0) + return 0; + + translation =3D sparse_keymap_entry_from_scancode(input, usage->code); + + if (translation && kbd->current_mode =3D=3D APPLETB_KBD_MODE_SPCL) { + input_event(input, usage->type, translation->keycode, value); + + return 1; + } + + return kbd->current_mode =3D=3D APPLETB_KBD_MODE_OFF; +} + +static int appletb_kbd_input_configured(struct hid_device *hdev, struct hi= d_input *hidinput) +{ + int idx; + struct input_dev *input =3D hidinput->input; + + /* + * Clear various input capabilities that are blindly set by the hid + * driver (usbkbd.c) + */ + memset(input->evbit, 0, sizeof(input->evbit)); + memset(input->keybit, 0, sizeof(input->keybit)); + memset(input->ledbit, 0, sizeof(input->ledbit)); + + __set_bit(EV_REP, input->evbit); + + sparse_keymap_setup(input, appletb_kbd_keymap, NULL); + + for (idx =3D 0; appletb_kbd_keymap[idx].type !=3D KE_END; idx++) { + input_set_capability(input, EV_KEY, appletb_kbd_keymap[idx].code); + } + + return 0; +} + +static int appletb_kbd_probe(struct hid_device *hdev, const struct hid_dev= ice_id *id) +{ + struct appletb_kbd *kbd; + struct device *dev =3D &hdev->dev; + struct hid_field *mode_field; + int ret; + + ret =3D hid_parse(hdev); + if (ret) + return dev_err_probe(dev, ret, "HID parse failed\n"); + + mode_field =3D hid_find_field(hdev, HID_OUTPUT_REPORT, + HID_GD_KEYBOARD, HID_USAGE_MODE); + if (!mode_field) + return -ENODEV; + + kbd =3D devm_kzalloc(dev, sizeof(*kbd), GFP_KERNEL); + if (!kbd) + return -ENOMEM; + + kbd->mode_field =3D mode_field; + + ret =3D hid_hw_start(hdev, HID_CONNECT_HIDINPUT); + if (ret) + return dev_err_probe(dev, ret, "HID hw start failed\n"); + + ret =3D hid_hw_open(hdev); + if (ret) { + dev_err_probe(dev, ret, "HID hw open failed\n"); + goto stop_hw; + } + + ret =3D appletb_kbd_set_mode(kbd, appletb_tb_def_mode); + if (ret) { + dev_err_probe(dev, ret, "Failed to set touchbar mode\n"); + goto close_hw; + } + + hid_set_drvdata(hdev, kbd); + + return 0; + +close_hw: + hid_hw_close(hdev); +stop_hw: + hid_hw_stop(hdev); + return ret; +} + +static void appletb_kbd_remove(struct hid_device *hdev) +{ + struct appletb_kbd *kbd =3D hid_get_drvdata(hdev); + + appletb_kbd_set_mode(kbd, APPLETB_KBD_MODE_OFF); + + hid_hw_close(hdev); + hid_hw_stop(hdev); +} + +#ifdef CONFIG_PM +static int appletb_kbd_suspend(struct hid_device *hdev, pm_message_t msg) +{ + struct appletb_kbd *kbd =3D hid_get_drvdata(hdev); + + kbd->saved_mode =3D kbd->current_mode; + appletb_kbd_set_mode(kbd, APPLETB_KBD_MODE_OFF); + + return 0; +} + +static int appletb_kbd_reset_resume(struct hid_device *hdev) +{ + struct appletb_kbd *kbd =3D hid_get_drvdata(hdev); + + appletb_kbd_set_mode(kbd, kbd->saved_mode); + + return 0; +} +#endif + +static const struct hid_device_id appletb_kbd_hid_ids[] =3D { + /* MacBook Pro's 2018, 2019, with T2 chip: iBridge Display */ + { HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_TOUCHBAR_DISPLA= Y) }, + { } +}; +MODULE_DEVICE_TABLE(hid, appletb_kbd_hid_ids); + +static struct hid_driver appletb_kbd_hid_driver =3D { + .name =3D "hid-appletb-kbd", + .id_table =3D appletb_kbd_hid_ids, + .probe =3D appletb_kbd_probe, + .remove =3D appletb_kbd_remove, + .event =3D appletb_kbd_hid_event, + .input_configured =3D appletb_kbd_input_configured, +#ifdef CONFIG_PM + .suspend =3D appletb_kbd_suspend, + .reset_resume =3D appletb_kbd_reset_resume, +#endif + .driver.dev_groups =3D appletb_kbd_groups, +}; +module_hid_driver(appletb_kbd_hid_driver); + +MODULE_AUTHOR("Ronald Tschal=C3=A4r"); +MODULE_AUTHOR("Kerem Karabay "); +MODULE_DESCRIPTION("MacBookPro Touch Bar Keyboard Mode Driver"); +MODULE_LICENSE("GPL"); diff --git a/drivers/hid/hid-quirks.c b/drivers/hid/hid-quirks.c index 818d41a35..7c576d654 100644 --- a/drivers/hid/hid-quirks.c +++ b/drivers/hid/hid-quirks.c @@ -328,7 +328,6 @@ static const struct hid_device_id hid_have_special_driv= er[] =3D { { HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_GEYSER1_TP_ONLY= ) }, { HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_MAGIC_KEYBOARD_= 2021) }, { HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_MAGIC_KEYBOARD_= FINGERPRINT_2021) }, - { HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_TOUCHBAR_DISPLA= Y) }, #endif #if IS_ENABLED(CONFIG_HID_APPLEIR) { HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_IRCONTROL) }, @@ -340,6 +339,9 @@ static const struct hid_device_id hid_have_special_driv= er[] =3D { #if IS_ENABLED(CONFIG_HID_APPLETB_BL) { HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_TOUCHBAR_BACKLI= GHT) }, #endif +#if IS_ENABLED(CONFIG_HID_APPLETB_KBD) + { HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_TOUCHBAR_DISPLA= Y) }, +#endif #if IS_ENABLED(CONFIG_HID_ASUS) { HID_I2C_DEVICE(USB_VENDOR_ID_ASUSTEK, USB_DEVICE_ID_ASUSTEK_I2C_KEYBOAR= D) }, { HID_I2C_DEVICE(USB_VENDOR_ID_ASUSTEK, USB_DEVICE_ID_ASUSTEK_I2C_TOUCHPA= D) }, --=20 2.43.0