From patchwork Tue Dec 31 17:34:11 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: Aditya Garg X-Patchwork-Id: 13923919 X-Patchwork-Delegate: jikos@jikos.cz Received: from PNYPR01CU001.outbound.protection.outlook.com (mail-centralindiaazolkn19010009.outbound.protection.outlook.com [52.103.68.9]) (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 B845442A8C; Tue, 31 Dec 2024 17:34:16 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=52.103.68.9 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1735666459; cv=fail; b=LKZ3N0daHWXSzq8RRXh4/u8xkM98V9VfpiHcJXf3MgjywiQ7Fr41p7uebN4qD4RknnpohR+TwHRztE0Dwn9N5qLlHXnG38O7bD1SRZNoH8p4LU7LbnzystSAnvA84IqXUjH8fL2gUQ4cRqkFlN6pcLLMICuw4ppxJOHaAVhi9Ac= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1735666459; c=relaxed/simple; bh=qHd3VxxlhFBnSZTfhCruMFqhdAwZy9WgJgF+lh7YNkQ=; h=From:To:CC:Subject:Date:Message-ID:References:In-Reply-To: Content-Type:MIME-Version; b=dLVeL2LO7JDSrQcFiBAyINxjIbD0vIVo98WytP9FeDYii3imlon1ssg3qrb54nG1NKThNPqCLUMkjqK/3+AmhVIvWxkt1O0sELLFBmInGfy18Lw5ZkNmuZWiuY0V8IV+kcjnjtfaVzihx7g+WS6G1tGq2D7IaFBb/3+Uj5ZGPOw= 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=DUmJyk72; arc=fail smtp.client-ip=52.103.68.9 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="DUmJyk72" ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=nyOd+xkvGDe8GBo/ohBFAqbj34i/JCxV5QpB5N15Ti68ePKtqhIsjOjD+1cCh3nv7/iYIrJs5ReNEWTHuUJS0Yx3JxdtXoyvAwmhfYpg2g8RwMw9BCgIOMhFZoFJVtJmQHsPv2CfgXb88e15nFI42mOpDD+TLQI3EsFNdY1XYFdz8W/PorKBrkDWD1vZwtYETlGl+mjtoVJeG8T4gAFN1gr/bE+HFBNgKybKrT5vR6H3QAK9r+LmR7a6dVtR/qLQ/radYJxyjV16stuApIfr/Cb+0zJZVG9x9G+iUmvsQfrPX8MdYtNzat3lNr3o0/8h+MgQbBal8VDeOFI9HAJXhQ== 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=qHd3VxxlhFBnSZTfhCruMFqhdAwZy9WgJgF+lh7YNkQ=; b=nadHTxMuaKPryQD5nNb0yiLAOgDPDmpDhB1Ta15Q4CuIMSrRYA++OR4Mpu3x+WyaNEHKocSFrDreaAqPE1o2yGGUc8hdOyDE3rmZxcnQNZaGpL4Y3F7g0S/X0YgI6S5o87ZOToZO07JVxwGBAWmEraXfkuYTJZ3WW7N+a+MdyekG6vrwiksAMnCQO87sgXHusK9sNHJm/sfcCjhTJxVOs6W/cein9z65lV05bE4DMsYxD7/eZ0dkamo9UaQWQ9gWpqKaekMT/W8ZyEx1lXrlq/t8V3z/5HZ810Q+oxmxHKrvTxF41/qyfN7P9ppbQw7q7PBQAC+uAy5kgcnz2ndDdg== 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=qHd3VxxlhFBnSZTfhCruMFqhdAwZy9WgJgF+lh7YNkQ=; b=DUmJyk721zAhiHSXMeP5OGuYKe5DKD1KGslfiv5o+2t31Ci4vXHnx9mkzpjtsWuTMfaiO2tM8csZVlcVQZVeNDYrhcbri//AJBvO+q0VGi7DdsQk6Z3m48FH1lKrXXeEIklCOQXUNMDRSqPqSC7q66bpbdqWkcuRtmvedY73FQNpyOQWlEQvvCoLBWOE83N8G7rFm5rySro738EMet0jlRxRcPIFUZEWR6M23JmgokSBih3MkE5shexOmBQB+5kdUy7iGX3aZOdOhHCgAp+B80QUPS+hOKxQLrwycA/O/63Ow/4+K6q229wQpeBzRq6ViSbmyFrHoca3LgSt13ua4g== Received: from PN3PR01MB7728.INDPRD01.PROD.OUTLOOK.COM (2603:1096:c01:cd::12) by MAXPR01MB4261.INDPRD01.PROD.OUTLOOK.COM (2603:1096:a01:8::14) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.8293.20; Tue, 31 Dec 2024 17:34:12 +0000 Received: from PN3PR01MB7728.INDPRD01.PROD.OUTLOOK.COM ([fe80::d3b7:2498:cd95:5d06]) by PN3PR01MB7728.INDPRD01.PROD.OUTLOOK.COM ([fe80::d3b7:2498:cd95:5d06%4]) with mapi id 15.20.8314.012; Tue, 31 Dec 2024 17:34:11 +0000 From: Aditya Garg To: "jkosina@suse.cz" , Jiri Kosina , Benjamin Tissoires , "bentiss@kernel.org" CC: Kerem Karabay , Orlando Chamberlain , "linux-input@vger.kernel.org" , Linux Kernel Mailing List Subject: [PATCH v2 1/4] HID: hid-appletb-bl: add driver for the backlight of Apple Touch Bars Thread-Topic: [PATCH v2 1/4] HID: hid-appletb-bl: add driver for the backlight of Apple Touch Bars Thread-Index: AQHbW6o0Q1WSXeSqf0qV0fay1F0rNA== Date: Tue, 31 Dec 2024 17:34:11 +0000 Message-ID: <42D62BAB-8F95-4A9E-B545-A1FC7E8B6F74@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-ms-publictraffictype: Email x-ms-traffictypediagnostic: PN3PR01MB7728:EE_|MAXPR01MB4261:EE_ x-ms-office365-filtering-correlation-id: a100ee8a-0f0d-4c59-1607-08dd29c156df x-microsoft-antispam: BCL:0;ARA:14566002|19110799003|15080799006|8062599003|7092599003|8060799006|461199028|440099028|3412199025|102099032; x-microsoft-antispam-message-info: =?utf-8?q?Tdt0ZCDpUzqiajjzl6GNxFhq56FUkFB?= =?utf-8?q?EUegK0Saah1LkAwrD39JvKSzny4oj+hgK0vLPcYhik0hTMu0Mrcz6WtUryTCINInM?= =?utf-8?q?zb4C7T4ChJrmSfJXuEAyfLildlZ7D/iQCBDqrAeDQbI6obru4JnuJk85n6qNceE37?= =?utf-8?q?V7Ybi7/zCReAdvmoCciAd/nqEY1boSsLz2p1PuvEmBpzyPceAO0236uJhPFUKfC+Q?= =?utf-8?q?oUH4F/EI9r2uF1vuJ2jhy4pVK1FV3rzZy9zuNJRsBzVQ21SHnB9QnF3lUA2Wh/XOQ?= =?utf-8?q?sz8GINFnpVnvdZHK3WF/4ZaLRNXJTK0WnV0yI+Px5L5B0rop0ofjAK5w6HO7qSh2r?= =?utf-8?q?WKGjoDr1YgslhQDmUNEyLAUpYNXxFRliCPRgexHpQJA0xjy7gA5ma4Xxp9kAAXudj?= =?utf-8?q?b+kdHEcI6dt6Kp51EWgWjZdIHwO94aJeiGxIZnfTHYyIOICdXCB3O+JHeKoxrcc5r?= =?utf-8?q?jyMSgh6z4QgRnfX2HjutSLCGxGBro80ZElaOjiai+wSGznRz/sU0fzctNVKQA/Uzw?= =?utf-8?q?M8azsnOS3fNz5wjm2Tf7SENXUMTM/H2RCWRNUt7I2jLCy4HAVJGEs0+GxOrydG6Lb?= =?utf-8?q?626PxGyRV/AbB7G674Vx4IofS0Xmp1HWppipx+RS8ep4QynR3+CwWJ6hwB5nkdNZW?= =?utf-8?q?Lyj0/V0mCN7bI+0YHHfERbn32Hdflu7IsN1oCEAAoaFLekl0ptCPvAhK3XllEgEeH?= =?utf-8?q?d/uTn/Kz+0KuHxv5jsdJz2vN4hs3tDuztjbxi0nlqefABn6vXCF8WtgoaEsc5bEns?= =?utf-8?q?aL733EYiNYz+44GpL5c8NyAEk6HhnjEz/LH6HEp8s4qyPpkN+4AjIGfYVbtFtLeAP?= =?utf-8?q?+mz40HwsZzuLNgfbyDVtCMCSypjo9E8ieKSQNfChWx+7zG97ZmlwcWADsPJYFJDNh?= =?utf-8?q?lCBYPtw0YYQb7r+G7rm4hdRFLLqq5uoPH3x2pgs37g2N5xSQwJsAqBkBsLvV7J5ii?= =?utf-8?q?GSw47+RNdwbtsQVSz8vNOXwqbouaBFraRnX7fg4fn7eEif/efQpNXR7F8k2fNGHV4?= =?utf-8?q?KziFLqDYpc3y6yE9qnGu39RPraljc8mVl9Y7sMw=3D=3D?= x-ms-exchange-antispam-messagedata-chunkcount: 1 x-ms-exchange-antispam-messagedata-0: =?utf-8?q?apD4ewXFw7BNdu5qByDgTPBA0gx6?= =?utf-8?q?/mkx8daiXk8xgABDytsHiW+EkRXbjd/YbGhCMLDyYdT+dS3V4moQuxSzcx89sPcoI?= =?utf-8?q?p7dgATzg1r6Y6A2/L47iPHfST0y89xAVt8UhKebwkLyLC4rIZVamEpbVoreDIhxcj?= =?utf-8?q?H9wDPaG5DLBl66Ngt+Wh1Xnsl3JYmJ1LKweMuxxFzD79lfpG2GWWv1QhK0BL8PKap?= =?utf-8?q?4wcw87xJuGIYR4X2+kB6mBAyJ0JguxANYUkNg+WNvoqgVJNCvqDgsr5HJh4d4miq0?= =?utf-8?q?HGcsBByxsIFs6SGAcA+bRjP6r5vEKpqWKgwqmzREmwPgFfEOtuZTfqVVg6gopGlH2?= =?utf-8?q?Z5RU36CmQM2YQkRoQ31U3rOF2gONQaUc1etcfoA13mC9rhudPjPQPX8SxKGCH+zO+?= =?utf-8?q?bP/QxwoJjr2SYRSNa0+wvyMJgKusBJhpAMqe5ISVIEkaxke3p8wJkCmv87qUHNX1O?= =?utf-8?q?Hx50sKVc+wQiyQD/TVf3JXEQIWhqh+ZMZs6XvntL5gNFQ4ONesO2lC7xw+QOWXr5J?= =?utf-8?q?wHB2N/YkRRPb5FhR8nWLfUabNbaTSJa4u6O1w2L3OKN6GUfC32ohDhABvR5CUCsS9?= =?utf-8?q?fnCmcRIgfFy/wxK+3hR8FDqydKHLxsJUBRAjVa+CG2MODBSdGN5dWGU2WtoBD8FAw?= =?utf-8?q?14A5rDe8bHb6OFNwww33fkU/YZZJgE42v3TCvH4yLrSiKxcg15lHDbIbaBDogJuS8?= =?utf-8?q?NL1tSnqEiz37zU7+5ZvXB76c1Jxk9KWTZwdV5n5dFzYGrMl4/5j9f378HCWvDB+ve?= =?utf-8?q?AIZY9UMOximYDXAXSvhwler4p37uvaOqo4lecXaxOG6xdpZGwm5kW5sshYhNPWYCT?= =?utf-8?q?fNKh3n9hzuWlTODMzEj2OT6nqQ/KO0nZ9auNQyzNuDmEE0Kby7MH4j/NmARFxnDER?= =?utf-8?q?KEVYBkUld7DqOWaEqpw8jpMRxE/ivhZBmaBzqofWaX5JmgGEty9Qff8/5Hc5MxNhC?= =?utf-8?q?htpzKYFAQ8ir2JQ8XMqkloQbr9ttxVbsYvOEmgOy6CWKtG9hG/r2KY4IRMwbfoLeb?= =?utf-8?q?3gYOMd23ps5mAzgUpjNQ0oZom7x+7F/6WclrmSQI3cNepd0fqgAw/lvTSvDMk4rPy?= =?utf-8?q?dENM2AaLYkQ3gaRIAd0/p3vyVp4lvCjT+C6mTLVpGumrv1hxaXOIfz6WgG3OlVZcZ?= =?utf-8?q?8XSoyf39o00wK13gondgneld8QWdjBjgI9kfujz0zoJaKoRU4AiAtQkV8+bavtZfn?= =?utf-8?q?0323U4nAt9oBl/l2kKq0sNElKsHNbViE7r+dYmeWsgME4o9VRhozxQo6jziZEImLB?= =?utf-8?q?0TY3hZ8wZEw0rmSo?= Content-ID: <9AF130527A9154428BFE5F75510C22FA@INDPRD01.PROD.OUTLOOK.COM> Precedence: bulk X-Mailing-List: linux-input@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-OriginatorOrg: sct-15-20-7719-20-msonline-outlook-ae5c4.templateTenant X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-AuthSource: PN3PR01MB7728.INDPRD01.PROD.OUTLOOK.COM X-MS-Exchange-CrossTenant-RMS-PersistedConsumerOrg: 00000000-0000-0000-0000-000000000000 X-MS-Exchange-CrossTenant-Network-Message-Id: a100ee8a-0f0d-4c59-1607-08dd29c156df X-MS-Exchange-CrossTenant-rms-persistedconsumerorg: 00000000-0000-0000-0000-000000000000 X-MS-Exchange-CrossTenant-originalarrivaltime: 31 Dec 2024 17:34:11.9103 (UTC) X-MS-Exchange-CrossTenant-fromentityheader: Hosted X-MS-Exchange-CrossTenant-id: 84df9e7f-e9f6-40af-b435-aaaaaaaaaaaa X-MS-Exchange-Transport-CrossTenantHeadersStamped: MAXPR01MB4261 From: Kerem Karabay This commit adds a driver for the backlight of Apple Touch Bars on x86 Macs. Note that currently only T2 Macs are supported. This driver is based on previous work done by Ronald Tschalär . Signed-off-by: Kerem Karabay Co-developed-by: Aditya Garg Signed-off-by: Aditya Garg --- drivers/hid/Kconfig | 10 ++ drivers/hid/Makefile | 1 + drivers/hid/hid-appletb-bl.c | 207 +++++++++++++++++++++++++++++++++++ drivers/hid/hid-quirks.c | 4 +- 4 files changed, 221 insertions(+), 1 deletion(-) create mode 100644 drivers/hid/hid-appletb-bl.c diff --git a/drivers/hid/Kconfig b/drivers/hid/Kconfig index 4d2a89d65..f6678db27 100644 --- a/drivers/hid/Kconfig +++ b/drivers/hid/Kconfig @@ -148,6 +148,16 @@ config HID_APPLEIR Say Y here if you want support for Apple infrared remote control. +config HID_APPLETB_BL + tristate "Apple Touch Bar Backlight" + depends on BACKLIGHT_CLASS_DEVICE + help + Say Y here if you want support for the backlight of Touch Bars on x86 + MacBook Pros. + + To compile this driver as a module, choose M here: the + module will be called hid-appletb-bl. + config HID_ASUS tristate "Asus" depends on USB_HID diff --git a/drivers/hid/Makefile b/drivers/hid/Makefile index 24de45f36..444d24cec 100644 --- a/drivers/hid/Makefile +++ b/drivers/hid/Makefile @@ -29,6 +29,7 @@ obj-$(CONFIG_HID_ALPS) += hid-alps.o obj-$(CONFIG_HID_ACRUX) += hid-axff.o obj-$(CONFIG_HID_APPLE) += hid-apple.o obj-$(CONFIG_HID_APPLEIR) += hid-appleir.o +obj-$(CONFIG_HID_APPLETB_BL) += hid-appletb-bl.o obj-$(CONFIG_HID_CREATIVE_SB0540) += hid-creative-sb0540.o obj-$(CONFIG_HID_ASUS) += hid-asus.o obj-$(CONFIG_HID_AUREAL) += hid-aureal.o diff --git a/drivers/hid/hid-appletb-bl.c b/drivers/hid/hid-appletb-bl.c new file mode 100644 index 000000000..819157686 --- /dev/null +++ b/drivers/hid/hid-appletb-bl.c @@ -0,0 +1,207 @@ +// SPDX-License-Identifier: GPL-2.0 +/* + * Apple Touch Bar Backlight Driver + * + * Copyright (c) 2017-2018 Ronald Tschalär + * Copyright (c) 2022-2023 Kerem Karabay + */ + +#define pr_fmt(fmt) KBUILD_MODNAME ": " fmt + +#include +#include +#include + +#include "hid-ids.h" + +#define APPLETB_BL_ON 1 +#define APPLETB_BL_DIM 3 +#define APPLETB_BL_OFF 4 + +#define HID_UP_APPLEVENDOR_TB_BL 0xff120000 + +#define HID_VD_APPLE_TB_BRIGHTNESS 0xff120001 +#define HID_USAGE_AUX1 0xff120020 +#define HID_USAGE_BRIGHTNESS 0xff120021 + +static int appletb_bl_def_brightness = 2; +module_param_named(brightness, appletb_bl_def_brightness, int, 0444); +MODULE_PARM_DESC(brightness, "Default brightness:\n" + " 0 - Touchbar is off\n" + " 1 - Dim brightness\n" + " [2] - Full brightness"); + +struct appletb_bl { + struct hid_field *aux1_field, *brightness_field; + struct backlight_device *bdev; + + bool full_on; +}; + +static const u8 appletb_bl_brightness_map[] = { + APPLETB_BL_OFF, + APPLETB_BL_DIM, + APPLETB_BL_ON, +}; + +static int appletb_bl_set_brightness(struct appletb_bl *bl, u8 brightness) +{ + struct hid_report *report = bl->brightness_field->report; + struct hid_device *hdev = report->device; + int ret; + + ret = hid_set_field(bl->aux1_field, 0, 1); + if (ret) { + hid_err(hdev, "Failed to set auxiliary field (%pe)\n", ERR_PTR(ret)); + return ret; + } + + ret = hid_set_field(bl->brightness_field, 0, brightness); + if (ret) { + hid_err(hdev, "Failed to set brightness field (%pe)\n", ERR_PTR(ret)); + return ret; + } + + if (!bl->full_on) { + ret = hid_hw_power(hdev, PM_HINT_FULLON); + if (ret < 0) { + hid_err(hdev, "Device didn't power on (%pe)\n", ERR_PTR(ret)); + return ret; + } + + bl->full_on = true; + } + + hid_hw_request(hdev, report, HID_REQ_SET_REPORT); + + if (brightness == APPLETB_BL_OFF) { + hid_hw_power(hdev, PM_HINT_NORMAL); + bl->full_on = false; + } + + return 0; +} + +static int appletb_bl_update_status(struct backlight_device *bdev) +{ + struct appletb_bl *bl = bl_get_data(bdev); + u8 brightness; + + if (backlight_is_blank(bdev)) + brightness = APPLETB_BL_OFF; + else + brightness = appletb_bl_brightness_map[backlight_get_brightness(bdev)]; + + return appletb_bl_set_brightness(bl, brightness); +} + +static const struct backlight_ops appletb_bl_backlight_ops = { + .options = BL_CORE_SUSPENDRESUME, + .update_status = appletb_bl_update_status, +}; + +static int appletb_bl_probe(struct hid_device *hdev, const struct hid_device_id *id) +{ + struct hid_field *aux1_field, *brightness_field; + struct backlight_properties bl_props = { 0 }; + struct device *dev = &hdev->dev; + struct appletb_bl *bl; + int ret; + + ret = hid_parse(hdev); + if (ret) + return dev_err_probe(dev, ret, "HID parse failed\n"); + + aux1_field = hid_find_field(hdev, HID_FEATURE_REPORT, + HID_VD_APPLE_TB_BRIGHTNESS, HID_USAGE_AUX1); + + brightness_field = hid_find_field(hdev, HID_FEATURE_REPORT, + HID_VD_APPLE_TB_BRIGHTNESS, HID_USAGE_BRIGHTNESS); + + if (!aux1_field || !brightness_field) + return -ENODEV; + + if (aux1_field->report != brightness_field->report) + return dev_err_probe(dev, -ENODEV, "Encountered unexpected report structure\n"); + + bl = devm_kzalloc(dev, sizeof(*bl), GFP_KERNEL); + if (!bl) + return -ENOMEM; + + ret = hid_hw_start(hdev, HID_CONNECT_DRIVER); + if (ret) + return dev_err_probe(dev, ret, "HID hardware start failed\n"); + + ret = hid_hw_open(hdev); + if (ret) { + dev_err_probe(dev, ret, "HID hardware open failed\n"); + goto stop_hw; + } + + bl->aux1_field = aux1_field; + bl->brightness_field = brightness_field; + + if (appletb_bl_def_brightness == 0) + ret = appletb_bl_set_brightness(bl, APPLETB_BL_OFF); + else if (appletb_bl_def_brightness == 1) + ret = appletb_bl_set_brightness(bl, APPLETB_BL_DIM); + else + ret = appletb_bl_set_brightness(bl, APPLETB_BL_ON); + + if (ret) { + dev_err_probe(dev, ret, "Failed to set touch bar brightness to off\n"); + goto close_hw; + } + + bl_props.type = BACKLIGHT_RAW; + bl_props.max_brightness = ARRAY_SIZE(appletb_bl_brightness_map) - 1; + + bl->bdev = devm_backlight_device_register(dev, "appletb_backlight", dev, bl, + &appletb_bl_backlight_ops, &bl_props); + if (IS_ERR(bl->bdev)) { + ret = PTR_ERR(bl->bdev); + dev_err_probe(dev, ret, "Failed to register backlight device\n"); + goto close_hw; + } + + hid_set_drvdata(hdev, bl); + + return 0; + +close_hw: + hid_hw_close(hdev); +stop_hw: + hid_hw_stop(hdev); + + return ret; +} + +static void appletb_bl_remove(struct hid_device *hdev) +{ + struct appletb_bl *bl = hid_get_drvdata(hdev); + + appletb_bl_set_brightness(bl, APPLETB_BL_OFF); + + hid_hw_close(hdev); + hid_hw_stop(hdev); +} + +static const struct hid_device_id appletb_bl_hid_ids[] = { + /* MacBook Pro's 2018, 2019, with T2 chip: iBridge DFR Brightness */ + { HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_TOUCHBAR_BACKLIGHT) }, + { } +}; +MODULE_DEVICE_TABLE(hid, appletb_bl_hid_ids); + +static struct hid_driver appletb_bl_hid_driver = { + .name = "hid-appletb-bl", + .id_table = appletb_bl_hid_ids, + .probe = appletb_bl_probe, + .remove = appletb_bl_remove, +}; +module_hid_driver(appletb_bl_hid_driver); + +MODULE_AUTHOR("Ronald Tschalär"); +MODULE_AUTHOR("Kerem Karabay "); +MODULE_DESCRIPTION("MacBookPro Touch Bar Backlight Driver"); +MODULE_LICENSE("GPL"); diff --git a/drivers/hid/hid-quirks.c b/drivers/hid/hid-quirks.c index e0bbf0c63..818d41a35 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_driver[] = { { 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_BACKLIGHT) }, { HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_TOUCHBAR_DISPLAY) }, #endif #if IS_ENABLED(CONFIG_HID_APPLEIR) @@ -338,6 +337,9 @@ static const struct hid_device_id hid_have_special_driver[] = { { HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_IRCONTROL4) }, { HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_IRCONTROL5) }, #endif +#if IS_ENABLED(CONFIG_HID_APPLETB_BL) + { HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_TOUCHBAR_BACKLIGHT) }, +#endif #if IS_ENABLED(CONFIG_HID_ASUS) { HID_I2C_DEVICE(USB_VENDOR_ID_ASUSTEK, USB_DEVICE_ID_ASUSTEK_I2C_KEYBOARD) }, { HID_I2C_DEVICE(USB_VENDOR_ID_ASUSTEK, USB_DEVICE_ID_ASUSTEK_I2C_TOUCHPAD) }, From patchwork Tue Dec 31 17:35:04 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: Aditya Garg X-Patchwork-Id: 13923920 Received: from PNYPR01CU001.outbound.protection.outlook.com (mail-centralindiaazolkn19010007.outbound.protection.outlook.com [52.103.68.7]) (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 4873B42A8C; Tue, 31 Dec 2024 17:35:08 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=52.103.68.7 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1735666511; cv=fail; b=pcSuSPebJpQ3IOFVs3i3YCrnVwBMI9XWAnieUSRND9IUxOMHHUyMY2yR/gSGLTMjWJS+7MNhE+fPk5xc7+QQkJE898ncZSzqLY7tkiGy+WsY9qqQhjZEnNOpG5l0C6dT9t2gLwmjtnQNqMpUzSNvzwIzWt6qr6at1QuCw2Q3qQo= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1735666511; c=relaxed/simple; bh=nQ/DwVgFVO3Vllcf1AzVKw4C/c+9cDooz0F7eTtoE7Q=; h=From:To:CC:Subject:Date:Message-ID:References:In-Reply-To: Content-Type:MIME-Version; b=Etl7cIpXjkqScNDhH9rqnaWwyn5XAhaRUqTiGnL2wUllM7vc1ZaFvqMTHfmax3CA3QSg0WLHVohCFy1JoanCQKi1jhVKadId0wnJZYyqoXmCR4BHQno/BGKuxsyis3P+/RbEbSDJx3ti/SGz8sgQ1o6ePPmCp2xrKpVdDvOsBok= 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=cxe79DZI; arc=fail smtp.client-ip=52.103.68.7 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="cxe79DZI" ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=hizNd5vba9r6Kd8X79DJ070syeYO9US/97Ni7ZARBk0O5lBPR7Ka8+BfoTcPIgVp5AM+vU36Paz8ieKCBZ7wR3iDdDCMRfXdQF1kzMsJiI0gQ4QnOfC9aKccv59kAEyFRKtJ10ysS+BVM23mPu6+zKMxlpf7ISLbjk6AkRYg5304id+6rIH3MT1tFjAx2YK7bVrZIRVzWAcaDT8tE+uWwEjp9WIGWAWqhnTK1r/Dl0ZiAfHbGh6I9jpTdC/6+kr2Su3HSlBUPnWhWnJ9/U00eCnsEQC4G9xbbfdvTxcf6fA89cfeTY4E1myVSqrxWKHdQ6CLJnCYO1UAVdW/wXPwbA== 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=nQ/DwVgFVO3Vllcf1AzVKw4C/c+9cDooz0F7eTtoE7Q=; b=wiH6U0lCWvpq+HqW+TF4H5orj6NuGl98lyEs7Fu0wchgNk2H4opYA0C7LGEOJuP2GJlpKNdBSYiaGY3RK0eG95gnYj6mWMcgkNkoSqWD09/uqzMYKsJySZFqbEN13fX/1tgw1yS8GeTnpAqsvd4WeOGREMw4cj6fNwIMDWnfM1ahmB64HCeo4asvYdHF0USt2yYMcKGpcgHMH/CdD0AkHE91XXCDrUI9CLOMuNl6usOm9ANFXwmKK+ITzBogByRHpssPLSBxz63O4P+exeuMDvqDN+MrkbBCuDTfvAn3OJDFtYiRfPnMZGy51VmKnp9Grzc3b7O3GdGqlgeij8c4NQ== 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=nQ/DwVgFVO3Vllcf1AzVKw4C/c+9cDooz0F7eTtoE7Q=; b=cxe79DZI9Vt+a6+PT2L4hzcPtCl5KSCyzmzr4upJD6MpZ/3xsgDQ1BIcwIqXBF38KZxwtM/HUWiXa1TlUZHAQGLQl5m4QksN9oj74OkIqqvo5F1KjuhYFwb27sCfgbTA6JnViRCcx9R9xRfaT9asg6kz4dO0t2UMOuvfDESim0zc9kzW73CgiPDnNfR7dxOijPlstsgrd4W232F5fAL0I+ta783o+kciJE5QHDEGoSZcHA80+DdmBN9nqQVaoY/h/UU0nm7v+JqFg1uejwjmIQj87lOxZd46EpjsI4F3dn5Rwi3PqAr/RTlwInDz9pZpZAKjzZ6jWe988ZyGyR3JOQ== Received: from PN3PR01MB7728.INDPRD01.PROD.OUTLOOK.COM (2603:1096:c01:cd::12) by MAXPR01MB4261.INDPRD01.PROD.OUTLOOK.COM (2603:1096:a01:8::14) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.8293.20; Tue, 31 Dec 2024 17:35:04 +0000 Received: from PN3PR01MB7728.INDPRD01.PROD.OUTLOOK.COM ([fe80::d3b7:2498:cd95:5d06]) by PN3PR01MB7728.INDPRD01.PROD.OUTLOOK.COM ([fe80::d3b7:2498:cd95:5d06%4]) with mapi id 15.20.8314.012; Tue, 31 Dec 2024 17:35:04 +0000 From: Aditya Garg To: "jkosina@suse.cz" , Jiri Kosina , Benjamin Tissoires , "bentiss@kernel.org" CC: Kerem Karabay , Orlando Chamberlain , "linux-input@vger.kernel.org" , Linux Kernel Mailing List Subject: [PATCH v2 2/4] HID: hid-appletb-kbd: add driver for the keyboard mode of Apple Touch Bars Thread-Topic: [PATCH v2 2/4] HID: hid-appletb-kbd: add driver for the keyboard mode of Apple Touch Bars Thread-Index: AQHbW6pTv7SHMKd5hEW30wbjIbp+VQ== Date: Tue, 31 Dec 2024 17:35:04 +0000 Message-ID: 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-ms-publictraffictype: Email x-ms-traffictypediagnostic: PN3PR01MB7728:EE_|MAXPR01MB4261:EE_ x-ms-office365-filtering-correlation-id: 7b9ff9ad-94c5-4dda-8e19-08dd29c1762c x-microsoft-antispam: BCL:0;ARA:14566002|19110799003|15080799006|8062599003|7092599003|8060799006|461199028|440099028|3412199025|102099032; x-microsoft-antispam-message-info: =?utf-8?q?gdNzvxRNQ9Dh1JiSvd8FLOagK9UT41z?= =?utf-8?q?weULSGDqOlq70gXlNQ7F6HPtcBUnoENeFUYz0QY5YOJHUEh5BQzxk0yfyB8YvyS1P?= =?utf-8?q?EkoDJv1osKlCMF3FjBHy6oaYOHMcIkPy4IL28MhtAVPoK1d64qZxi1ryDdEznA71m?= =?utf-8?q?B6frAOIRI/hU6TGnWT8MQ9cZsNABHUEPvifY4n4+CmKCSQofsGjsLXcT1xHxbZ0Nb?= =?utf-8?q?QCrwJWrpmpJ1PlyKRpKmirIiQNEA/spGyICPQtcg7lnXwwvilugMXR1IuNR5Gd8V7?= =?utf-8?q?LZawZn5dEtmzi4rMpPEY5VduccTYC8chZrJBnEE+eB1LC2RuesM85sn8XA1+YDztl?= =?utf-8?q?SbpZeSkYd/PpylIfewW48p/EDDwODQBfcY35PeMPiwHUAH5wr74LTQ+sJwnzcVuTJ?= =?utf-8?q?nCuPiC4eMYoPc4vcUbXe+B6laVhp/fBFqyZXZc+TC42zyHYjpy0dTLHuH4rRdR/tM?= =?utf-8?q?EbBJEpfWQ4W2ReiGj4suYg7XSSO85zO+RLnkYIMO7JHEqMJlgioV2HRB7X9h/sNV9?= =?utf-8?q?MSEPQqpgnTwqLYjvikfKyPIZITrD/yVhr77AtmhztuXMcRKpFjKFWbD3hDDfGPrsN?= =?utf-8?q?g8tM5/r3TIlx56i8xr7HNFwsYRAMGtxdxe4RbTYNtYY+i2g7Dcmk9f9ycqJKLF+O3?= =?utf-8?q?VenVk72T1aoHHlMpCbWB9EB/Gwop0+HRWASvii5TU3WO/oN+XjJxKA5bigPcqmnnj?= =?utf-8?q?/yu6IrYDkkOrx5Q6IpobuSTIZH/oR91JJoWOX3zeUtF4XnRlB7kG3BTdre6NZVT4S?= =?utf-8?q?cElHRgZZ7+RYt6DU8RCEgeH86kNzwUOKbg6YBRRVAkhSyWe/WE0S5yXxMGcpvs/Dc?= =?utf-8?q?8IU4PkjOIMsKRbKcq5Fmn9Eh6vtg7Lf5DygCbEZTELo7W3+B2X5oKkMN37BAZAma2?= =?utf-8?q?voALHz+cTVi34DbVfVebHqDKLF6+3qa+D9IH56/i5Di/ZjluOZ50g6Tz2jdLWM9YF?= =?utf-8?q?EH/LwpT25W2rKykMr6skieAHeQkbCAFqLw7ISgXF48XbNxadB7fQQdAGBhuWDSkF6?= =?utf-8?q?gv79xmHdF+Su8qrJNo899TSTsGRV9d9NHrzJzpQ=3D=3D?= x-ms-exchange-antispam-messagedata-chunkcount: 1 x-ms-exchange-antispam-messagedata-0: =?utf-8?q?cy9pudy2Gq9QLvNDfJkfOgJtYKNY?= =?utf-8?q?sqLlcti/Qchm6VagW49bj/zF9p5wbI2VDLf5ZS59P2P5mm3VDEcX/urGiwDq0X9hH?= =?utf-8?q?tp2fSw0FabU8R5/tAIBu+vSODC+6A8BxUXKvArxLVO4CrlVU2OW7f0NRNrFqNYDMg?= =?utf-8?q?FIkd80qzL3l5+8wA9qHeRzSbH894oN9gFJwhulRlXAT8DyomVeic1S97cruLjd5Oq?= =?utf-8?q?RJothBmQdOqXWN5GcAJFVFO0WlszoMsK4OmfD2vYCUb68noM94X9JJJ6egt9Vt5jD?= =?utf-8?q?j8SOzO1tt3FehxbUVD93BUDPPFDubO11fpD8V8bBBBQ0z+u3nuqmfNWUmWT25IBrw?= =?utf-8?q?3SZJOS4allu+NCuvsRsXEVY1dcFh5nEzhslBU8UGtYrSPQDZ4TkhPurkDOyUpl2FC?= =?utf-8?q?hKUc8Dlh4L2hoj19PdTTnNXzK+u83L8ZETgzE/wFn/60VWel3RDjLiuTC0Fr4bBNu?= =?utf-8?q?y53yQ3ufEJFDmRLAtuHXabZYfsJZobJDuIbbZBjBbFsFTPtmqGkIr4PCpDHIlbK6L?= =?utf-8?q?ADCcC9jyO8ymHRVHsB6IIyNVP2sehfGGDsVvVzNa14yOKFno1LpICea5HgrFuaWMC?= =?utf-8?q?iBRj3cZRExS+tb2jOCsZMvp55Bw4K4TS0+6a5kljxaLIAYYyEKNX25OxRfnsClyYV?= =?utf-8?q?clU1fWlm430awPvYD+oUoLSXqwi4kZCXZhz/nGdaSfwsnpD1d6fNEeadDlRyBThyV?= =?utf-8?q?18ftdaYYtJXHQZjynlcalImbqQVJE/VPCtEK/XkkMCAhB8rN4ZDUJW3X4lr//FMzG?= =?utf-8?q?a9NtTnLErpowwEApc/Ej6G00Mkt/OE9aYQKO8AEM55zG8D9YE0R85LFEjX41QUr4E?= =?utf-8?q?PJElsf9NHemqgvUCbYhcWdoz77D8a3a3/FCEuxDDzNWeo/m7ZLHA65LR4OoLpksdD?= =?utf-8?q?jsxDzIUvqpTJhlpkVS4F50UZdXwBgE+K8+ZAP0hTdDHoncvXIlufOSZAQBZDU+6vL?= =?utf-8?q?GYnlDTPWJaUPvmq8tqgeAmoJzonBQU7CeblB+dsgpdN8c1Gdc4+RSI/H1zlwMXcyL?= =?utf-8?q?APEuD3hyF3Ec/kAOVqBwQ+E5W8903QXEC60KJNNvmCMx9O3lO7kkLW8I8ZoOYfFQJ?= =?utf-8?q?QDxIwkSfbH9RmpRBYqfvj05x8Xcfw6Wo0Rso7XocBi1P3SMadp7e0ZMZmK60uyWTR?= =?utf-8?q?4EkLk1p/A/+wsp1fXQvJ+JwF1KOLgTgiiUE5JDmbDXpzIVg4NpRklETD7gSvD7/ip?= =?utf-8?q?+JFps8W0uVi2hhqmzB9VHctW2lBL55lGetj7NACL1WkR+h6neuD6TubCg1k6rz89j?= =?utf-8?q?+724q387OcFsXIub?= Content-ID: <6EDB1BBD2DB7E34FA102C2A005001234@INDPRD01.PROD.OUTLOOK.COM> Precedence: bulk X-Mailing-List: linux-input@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-OriginatorOrg: sct-15-20-7719-20-msonline-outlook-ae5c4.templateTenant X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-AuthSource: PN3PR01MB7728.INDPRD01.PROD.OUTLOOK.COM X-MS-Exchange-CrossTenant-RMS-PersistedConsumerOrg: 00000000-0000-0000-0000-000000000000 X-MS-Exchange-CrossTenant-Network-Message-Id: 7b9ff9ad-94c5-4dda-8e19-08dd29c1762c X-MS-Exchange-CrossTenant-rms-persistedconsumerorg: 00000000-0000-0000-0000-000000000000 X-MS-Exchange-CrossTenant-originalarrivaltime: 31 Dec 2024 17:35:04.4053 (UTC) X-MS-Exchange-CrossTenant-fromentityheader: Hosted X-MS-Exchange-CrossTenant-id: 84df9e7f-e9f6-40af-b435-aaaaaaaaaaaa X-MS-Exchange-Transport-CrossTenantHeadersStamped: MAXPR01MB4261 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är . 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 | 13 + drivers/hid/Makefile | 1 + drivers/hid/hid-appletb-kbd.c | 303 ++++++++++++++++++ drivers/hid/hid-quirks.c | 4 +- 5 files changed, 333 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/Documentation/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: + == ================= + 0 Escape key only + 1 Function keys + 2 Media/brightness keys + 3 None + == ================= diff --git a/drivers/hid/Kconfig b/drivers/hid/Kconfig index f6678db27..5b16bfadc 100644 --- a/drivers/hid/Kconfig +++ b/drivers/hid/Kconfig @@ -158,6 +158,19 @@ config HID_APPLETB_BL To compile this driver as a module, choose M here: the module will be called hid-appletb-bl. +config HID_APPLETB_KBD + tristate "Apple Touch Bar Keyboard Mode" + depends on USB_HID + depends on INPUT + select INPUT_SPARSEKMAP + 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 444d24cec..1989288e0 100644 --- a/drivers/hid/Makefile +++ b/drivers/hid/Makefile @@ -30,6 +30,7 @@ obj-$(CONFIG_HID_ACRUX) += hid-axff.o obj-$(CONFIG_HID_APPLE) += hid-apple.o obj-$(CONFIG_HID_APPLEIR) += hid-appleir.o obj-$(CONFIG_HID_APPLETB_BL) += hid-appletb-bl.o +obj-$(CONFIG_HID_APPLETB_KBD) += hid-appletb-kbd.o obj-$(CONFIG_HID_CREATIVE_SB0540) += hid-creative-sb0540.o obj-$(CONFIG_HID_ASUS) += hid-asus.o obj-$(CONFIG_HID_AUREAL) += 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..80c87396f --- /dev/null +++ b/drivers/hid/hid-appletb-kbd.c @@ -0,0 +1,303 @@ +// SPDX-License-Identifier: GPL-2.0 +/* + * Apple Touch Bar Keyboard Mode Driver + * + * Copyright (c) 2017-2018 Ronald Tschalär + * 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 = 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[] = { + { 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 = kbd->mode_field->report; + struct hid_device *hdev = report->device; + int ret; + + ret = hid_hw_power(hdev, PM_HINT_FULLON); + if (ret) { + hid_err(hdev, "Device didn't resume (%pe)\n", ERR_PTR(ret)); + return ret; + } + + ret = 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(ret)); + goto power_normal; + } + + hid_hw_request(hdev, report, HID_REQ_SET_REPORT); + + kbd->current_mode = 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 = 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 = dev_get_drvdata(dev); + u8 mode; + int ret; + + ret = kstrtou8(buf, 0, &mode); + if (ret) + return ret; + + if (mode > APPLETB_KBD_MODE_MAX) + return -EINVAL; + + ret = appletb_kbd_set_mode(kbd, mode); + + return ret < 0 ? ret : size; +} +static DEVICE_ATTR_RW(mode); + +struct attribute *appletb_kbd_attrs[] = { + &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 = hid_get_drvdata(hdev); + struct key_entry *translation; + struct input_dev *input; + int slot; + + if ((usage->hid & HID_USAGE_PAGE) != HID_UP_KEYBOARD || usage->type != EV_KEY) + return 0; + + input = 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 = appletb_tb_key_to_slot(usage->code); + if (slot < 0) + return 0; + + translation = sparse_keymap_entry_from_scancode(input, usage->code); + + if (translation && kbd->current_mode == APPLETB_KBD_MODE_SPCL) { + input_event(input, usage->type, translation->keycode, value); + + return 1; + } + + return kbd->current_mode == APPLETB_KBD_MODE_OFF; +} + +static int appletb_kbd_input_configured(struct hid_device *hdev, struct hid_input *hidinput) +{ + int idx; + struct input_dev *input = 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 = 0; appletb_kbd_keymap[idx].type != 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_device_id *id) +{ + struct appletb_kbd *kbd; + struct device *dev = &hdev->dev; + struct hid_field *mode_field; + int ret; + + ret = hid_parse(hdev); + if (ret) + return dev_err_probe(dev, ret, "HID parse failed\n"); + + mode_field = hid_find_field(hdev, HID_OUTPUT_REPORT, + HID_GD_KEYBOARD, HID_USAGE_MODE); + if (!mode_field) + return -ENODEV; + + kbd = devm_kzalloc(dev, sizeof(*kbd), GFP_KERNEL); + if (!kbd) + return -ENOMEM; + + kbd->mode_field = mode_field; + + ret = hid_hw_start(hdev, HID_CONNECT_HIDINPUT); + if (ret) + return dev_err_probe(dev, ret, "HID hw start failed\n"); + + ret = hid_hw_open(hdev); + if (ret) { + dev_err_probe(dev, ret, "HID hw open failed\n"); + goto stop_hw; + } + + ret = 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 = 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 = hid_get_drvdata(hdev); + + kbd->saved_mode = 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 = 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[] = { + /* MacBook Pro's 2018, 2019, with T2 chip: iBridge Display */ + { HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_TOUCHBAR_DISPLAY) }, + { } +}; +MODULE_DEVICE_TABLE(hid, appletb_kbd_hid_ids); + +static struct hid_driver appletb_kbd_hid_driver = { + .name = "hid-appletb-kbd", + .id_table = appletb_kbd_hid_ids, + .probe = appletb_kbd_probe, + .remove = appletb_kbd_remove, + .event = appletb_kbd_hid_event, + .input_configured = appletb_kbd_input_configured, +#ifdef CONFIG_PM + .suspend = appletb_kbd_suspend, + .reset_resume = appletb_kbd_reset_resume, +#endif + .driver.dev_groups = appletb_kbd_groups, +}; +module_hid_driver(appletb_kbd_hid_driver); + +MODULE_AUTHOR("Ronald Tschalär"); +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_driver[] = { { 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_DISPLAY) }, #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_driver[] = { #if IS_ENABLED(CONFIG_HID_APPLETB_BL) { HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_TOUCHBAR_BACKLIGHT) }, #endif +#if IS_ENABLED(CONFIG_HID_APPLETB_KBD) + { HID_USB_DEVICE(USB_VENDOR_ID_APPLE, USB_DEVICE_ID_APPLE_TOUCHBAR_DISPLAY) }, +#endif #if IS_ENABLED(CONFIG_HID_ASUS) { HID_I2C_DEVICE(USB_VENDOR_ID_ASUSTEK, USB_DEVICE_ID_ASUSTEK_I2C_KEYBOARD) }, { HID_I2C_DEVICE(USB_VENDOR_ID_ASUSTEK, USB_DEVICE_ID_ASUSTEK_I2C_TOUCHPAD) }, From patchwork Tue Dec 31 17:36:02 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Aditya Garg X-Patchwork-Id: 13923921 X-Patchwork-Delegate: jikos@jikos.cz Received: from PNZPR01CU001.outbound.protection.outlook.com (mail-centralindiaazolkn19011029.outbound.protection.outlook.com [52.103.68.29]) (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 9BB6E42A8C; Tue, 31 Dec 2024 17:36:07 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=52.103.68.29 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1735666569; cv=fail; b=b3GCaEhkDmg1kLfhT3MZ7lCbLGX7EQJLhTx0BpkU0UiFQSLqT/VQY0MwZCOlUjwZBAY0mN+Xp++fDVIBpqxt7u8fbsV8rJq0qns8qJvo3yIN2i6tueUCs+PuDSUaIH7QjjdyVzKIc0Y/18J+cjBeYRJN8VG2lF1+30JV88aJv2Q= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1735666569; c=relaxed/simple; bh=3mz6Axn8y/+plncvXp/+66j7MYDyHlf4AYZpWN7weFg=; h=From:To:CC:Subject:Date:Message-ID:References:In-Reply-To: Content-Type:MIME-Version; b=PtEX21sGBZ/Y4XEQHR8XhoRKC2GHAtw95/P6JNL2iMllZsmyFZNkeNJLSyLjyw14UJD5QWl6bqBvSdWBfSR5jlhJSpLuf+lyHJvj5OqULhkXqKpG7DkJz1kqEOg8mb1dOQJ1UkuoFNayFXNNNNZrRZvr5J5B4Wwpa/u09FQL9Fs= 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=MxSiPPDL; arc=fail smtp.client-ip=52.103.68.29 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="MxSiPPDL" ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=uNON09VtJgLlpTa+0hkeSvIogle8q6P/5/N88CvFAdx27m2KeY2Nor7CfCuK3LVhd3PrN2ULo/D/TAPofbVSCJiH+mChP5NHebVdq/ril4xKUtC3bCimnCwwzHedXpqX4VTe5InzQMbrk2/4dgHvm947S7kzsdZuT2YjO68OEwCxiHACO5AWw3fblUT2wkVZG/JSJt083tFB/vjUCH4705NdfG96XicEfsx6DUyrd1B0pEUvG8CQzKZy+fxvco9rcRuC/ZIs64eZR3Cgq1sCL/0uC15/WQV1JyiFJMmxTGBWFwh6SCzoh8PZzNfMHJvDI18draRoKzfC2CTUKuWlTg== 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=1VBoik1et6ZCxTD6sE8zAbSU02w5p31wr/Vj6VJ2+EQ=; b=LaDAsIek2QdT58ORygBVL64cfGG9m3cihcbtHjoKp6fcw1BEXJJ7uXlZ016idiiEe4VmEJoE5/Hs0Z47meIYSHXxeqJS7ZHJ+Qy1CQj5jMQVhp2UV/mNqSybuepEP6jV2SLmv/f8vCkwMqodMdbmlM0rOgcjoZ+u+sBkxXZOh5aMnDCvRxwN6oc9j6TEluAmXIQj6rGZV/6abQsNq+hLyTQW0hCR8L/T01fqYh1iwUHLVQO9uV9ow5fuj4Xc0t0ZH8CFQdCx9BjXtEKikEqVSUzloBsk+S96pUMdtWvQXB7Nj3pGRm7+YGCWTt1GuaJaNHBHlcL1bbTSBiN86TnYdA== 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=1VBoik1et6ZCxTD6sE8zAbSU02w5p31wr/Vj6VJ2+EQ=; b=MxSiPPDL7lnnIZb5Dp06tywGGlIJ0+mxSgg/MgLIfRKTQfqndGbyKGCRGJiFA0Ik1OAbu3RqwLuMHID3HNId+6KbEjXCeCA9lonnlrMAGF3V6kKkq/+75I5vgst/131YE6cZuo99ZzvCjKGjAIm8/IlkzjS3BdrYOJ7asmDSWWZDVo9kGsfRUQq08cwUAy58m9135hYV1szhqum5qfOci1z62MhxZOLQh4V9YSe3477sVB0ocnsiQs3awOU4Az00ggPfH922DPN59hSiRAYrXWtHjg+BHCpsFvWUmIhiCXtATzsjg/PD+8chqwaCoSpdVFfUx//k7F1I1OxMwPwvAQ== Received: from PN3PR01MB7728.INDPRD01.PROD.OUTLOOK.COM (2603:1096:c01:cd::12) by MAXPR01MB4261.INDPRD01.PROD.OUTLOOK.COM (2603:1096:a01:8::14) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.8293.20; Tue, 31 Dec 2024 17:36:03 +0000 Received: from PN3PR01MB7728.INDPRD01.PROD.OUTLOOK.COM ([fe80::d3b7:2498:cd95:5d06]) by PN3PR01MB7728.INDPRD01.PROD.OUTLOOK.COM ([fe80::d3b7:2498:cd95:5d06%4]) with mapi id 15.20.8314.012; Tue, 31 Dec 2024 17:36:03 +0000 From: Aditya Garg To: "jkosina@suse.cz" , Jiri Kosina , Benjamin Tissoires , "bentiss@kernel.org" CC: Kerem Karabay , Orlando Chamberlain , "linux-input@vger.kernel.org" , Linux Kernel Mailing List Subject: [PATCH v2 3/4] HID: hid-appletb-kbd: add support for fn toggle between media and function mode Thread-Topic: [PATCH v2 3/4] HID: hid-appletb-kbd: add support for fn toggle between media and function mode Thread-Index: AQHbW6p2kmozRkQSh06ZIEJXS4FGsA== Date: Tue, 31 Dec 2024 17:36:02 +0000 Message-ID: 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-ms-publictraffictype: Email x-ms-traffictypediagnostic: PN3PR01MB7728:EE_|MAXPR01MB4261:EE_ x-ms-office365-filtering-correlation-id: cecccd3b-9602-480d-f5a1-08dd29c1990a x-microsoft-antispam: BCL:0;ARA:14566002|19110799003|15080799006|8062599003|7092599003|8060799006|461199028|440099028|3412199025|102099032; x-microsoft-antispam-message-info: Pw8VNQHgadkV3+A3STWhuVPqZU6gGDBIK8kNFbJLIOEKRZ1vfUtUrcr+LHEiKRugLMcoR04m9JYW8QXWe8QJW5cNxTNw9mFk5DYNcY3dr4MT7cT9vj2/uMMB1sDysw8YNk07XcnXnpok/9yipjREFsNODIiTVCiITYzcI/tUsE+ACi43kq23qJLwpFkLqesJhddHQlghTXwLbsJQIiGyFiswvPw4mfBptRRfoUBGVEcSrV7rsrpa5WfClBi141xNK4vwDJDFNol/NF4nEemZTGJMVkv4nkLnQ61Qz1YqhKfwjem61F4z95Og5D00HeIy10Mn5TVOo1SMAHGjuUbOiWqeg0UtALsd7GxkVvw05EZ817XCT/6MpEBADXAHkBfnnJAepJHP6BTdykgkP3HRYwan5BnMbxez/jPVxwmWkF9Y+KYNHoZswG0aI1OrtZ8hxlD1hHsbHEEOVYdsH0gdzHTammkFHDFVk0CkHebBcTqrEyAILfLPGnRI0PnP9yJgh/PSzN93rIjsPyp/GhwzxWFhwsPECQLwLqfT3TlmsIy0sfP5W8Y92dT1qzUqrmNSD01aMVyMu3+077CYtkWd0dIQp+u4ZYRILBgQlL8UEFy8kELIPbG9vwH5APXofd3COj6OpPfTd/MFvUvJ2sfEFQTVE2NEUYJyPYgio9hlmMWjefdpNUc3S7FtgLYgfVrQelIo1yc7xAnpxPzp3BxE5XxpolSsN76wem4/u0o8Bxw6LEjNYM6Wum4tNqK9RLN9enH6VnOWGZO6D+hbIh6GbuBESyXxk/a01MU4y8t+XM7CEegF6Hk7RGNREiI1oeNTicv/CEjEBd8OPQ9A63SMRpbPvryxfVi7FNQhd+Ksx5CpXkB3oNyx5zfvtN6q+ubii0sApmw06tiVFBP4C8rkAw5npUzyMXoxUPTHfioHdL3k3QxqVdwDVPeKzP+SGySeNy7MJGacOiIImrye8qezAcszY+Mr8UmHgjYhDx5iRJVp3af541fOmDbin0JD5c3ucXfeNfkGXJ1od2aFWFyzVQf5aYGIJEaSc6uqwLrECkpfxZ9xmhcI3K6XrZmhdWJ65Wf0OAw0idQWL8kXPI3aXQ== x-ms-exchange-antispam-messagedata-chunkcount: 1 x-ms-exchange-antispam-messagedata-0: h835CnYIY3S5LkLiBDiTritrDlB8s1UIVGjmqvzOjLMW8Sd95EuKbEk4SSS0WBEPmErzi50A1r6l5rfkaEZ346MVzFwbXQUB8LrBcWBqyfE68j+nDvugVlED9Tv4IHgNdEpg3UXSxzd5wPcByOTtRQlhln6G63UzDtOKXzrE9SZfsa2lzNBrPEv5Pi7j8s8SvbCp4deg+FU1u0KW23j4HTHNADWiPuWSUdkAANz1ue/2bFONvQApQZWKEi8qCszAxIV5AbM6MfWaNeTs73AjWauB71RZYHMi5DGqLhywUN90bZzs9hPdnzCEyZiryJ67+NisX7k+fRsRxkyWjt5CmZkrC7AK9Pu0ziGLxW/YfNVE/rFDnZ0iZJUyXaUxknitVPXZQga7q9Y2Hrwk3HExvf9hP484AGHL5eTdQTmBRJdTNmUVYYk7vp2hz1J5d2sS0uJb0RP/NtvzmWl+tDgcn44LOTfgNeNZf0cmsFdPgmkduJAlXwWfZ6gnHRhSVDvwxg0Gyzbe40Tp3P3KuDOziVWwhHpWKzIgqtprDnKkFZWXt8QUGmkDvfHA8RZgxyWDq7SMLqrwc9TvKYLJklX/xW40JLJJGN4Y/3wgOKFOcEYEFJrxSWyKSb9P9ZzZDrZ814bUl3KecV0KgIgeGGedhziwQq99yzhbqXiwyIsEOYAj9/IWU0xSzJPFjR0kTlnXxy5UvGc9sREZdscH3NZiIeVuGyJWzV+d/qWuTJker8348o39LQU33mGjrQrtTrpPbiARTQyPLC526+tsAxESEvdMzZtY/IX+5lair+WLLmSTHlz2RUHM4eAfyHIjlAjnirjlNDsmB6rLF68bvLdBvsJyJG3quwN1utVaWAziWgww3X4hDU9x46ISssmg3a0spbko4wV2dIdjnfH+2tchCzwSNL+j8XKafwdFvNxY+cor5hUKMzPcTJOPMRf0D9xxx/fN1Px9MF1lJqYx3F6nL5Rz27qcjtOXbUY6zGy+hsLByMaxdc/+wOw3MMZrgDMlY6YMFvAVz0Gs+YMsJPRUUSdsBFvr3EKG4hLhPhyJFieRMNdWoyy8wTSQsM3QLyTdDRiLv6sRgjCKa3tOjaCTfHUittC+628hqC6QP6Q7V2io6KKwBkpd45yshuJvCE0O9WmaEOoNLVWovw9zqbc3k3+rHTAntc2Q8Mu26Vfvhu/vBCNmuXrEXQuD6/7jW7oY31x6Afp9ybtjSSHgPjKHoLp/BICai3ibW4oNesItOuZRR2nGU2TvEsnnFwB6225Nupyvq7ozXPSvRCvGmB3YqVJRjQ614eLqjHq0xNd9yvOS1UXsKO3L5ox0e0+4qNVm Content-ID: <3E7F56D00E5CA64AA2D4D0A5858729C1@INDPRD01.PROD.OUTLOOK.COM> Precedence: bulk X-Mailing-List: linux-input@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-OriginatorOrg: sct-15-20-7719-20-msonline-outlook-ae5c4.templateTenant X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-AuthSource: PN3PR01MB7728.INDPRD01.PROD.OUTLOOK.COM X-MS-Exchange-CrossTenant-RMS-PersistedConsumerOrg: 00000000-0000-0000-0000-000000000000 X-MS-Exchange-CrossTenant-Network-Message-Id: cecccd3b-9602-480d-f5a1-08dd29c1990a X-MS-Exchange-CrossTenant-rms-persistedconsumerorg: 00000000-0000-0000-0000-000000000000 X-MS-Exchange-CrossTenant-originalarrivaltime: 31 Dec 2024 17:36:02.9487 (UTC) X-MS-Exchange-CrossTenant-fromentityheader: Hosted X-MS-Exchange-CrossTenant-id: 84df9e7f-e9f6-40af-b435-aaaaaaaaaaaa X-MS-Exchange-Transport-CrossTenantHeadersStamped: MAXPR01MB4261 From: Aditya Garg This patch adds support for the switching between the Media and Function keys on the touchbar by pressing the Fn key on Apple Internal Keyboard. Signed-off-by: Aditya Garg --- drivers/hid/hid-appletb-kbd.c | 128 ++++++++++++++++++++++++++++++++++ 1 file changed, 128 insertions(+) diff --git a/drivers/hid/hid-appletb-kbd.c b/drivers/hid/hid-appletb-kbd.c index 80c87396f..de5770500 100644 --- a/drivers/hid/hid-appletb-kbd.c +++ b/drivers/hid/hid-appletb-kbd.c @@ -26,6 +26,8 @@ #define APPLETB_KBD_MODE_OFF 3 #define APPLETB_KBD_MODE_MAX APPLETB_KBD_MODE_OFF +#define APPLETB_DEVID_KEYBOARD 1 + #define HID_USAGE_MODE 0x00ff0004 static int appletb_tb_def_mode = APPLETB_KBD_MODE_SPCL; @@ -35,11 +37,18 @@ MODULE_PARM_DESC(mode, "Default touchbar mode:\n" " 1 - function-keys\n" " [2] - special keys"); +static bool appletb_tb_fn_toggle = true; +module_param_named(fntoggle, appletb_tb_fn_toggle, bool, 0644); +MODULE_PARM_DESC(fntoggle, "Switch between Fn and media controls on pressing Fn key"); + struct appletb_kbd { struct hid_field *mode_field; u8 saved_mode; u8 current_mode; + struct input_handler inp_handler; + struct input_handle kbd_handle; + }; static const struct key_entry appletb_kbd_keymap[] = { @@ -172,6 +181,75 @@ static int appletb_kbd_hid_event(struct hid_device *hdev, struct hid_field *fiel return kbd->current_mode == APPLETB_KBD_MODE_OFF; } +static void appletb_kbd_inp_event(struct input_handle *handle, unsigned int type, + unsigned int code, int value) +{ + struct appletb_kbd *kbd = handle->private; + + if (type == EV_KEY && code == KEY_FN && appletb_tb_fn_toggle) { + if (value == 1) { + kbd->saved_mode = kbd->current_mode; + if (kbd->current_mode == APPLETB_KBD_MODE_SPCL) + appletb_kbd_set_mode(kbd, APPLETB_KBD_MODE_FN); + else if (kbd->current_mode == APPLETB_KBD_MODE_FN) + appletb_kbd_set_mode(kbd, APPLETB_KBD_MODE_SPCL); + } else if (value == 0) { + if (kbd->saved_mode != kbd->current_mode) + appletb_kbd_set_mode(kbd, kbd->saved_mode); + } + } +} + +static int appletb_kbd_inp_connect(struct input_handler *handler, + struct input_dev *dev, + const struct input_device_id *id) +{ + struct appletb_kbd *kbd = handler->private; + struct input_handle *handle; + int rc; + + if (id->driver_info == APPLETB_DEVID_KEYBOARD) { + handle = &kbd->kbd_handle; + handle->name = "tbkbd"; + } else { + return -ENOENT; + } + + if (handle->dev) + return -EEXIST; + + handle->open = 0; + handle->dev = input_get_device(dev); + handle->handler = handler; + handle->private = kbd; + + rc = input_register_handle(handle); + if (rc) + goto err_free_dev; + + rc = input_open_device(handle); + if (rc) + goto err_unregister_handle; + + return 0; + + err_unregister_handle: + input_unregister_handle(handle); + err_free_dev: + input_put_device(handle->dev); + handle->dev = NULL; + return rc; +} + +static void appletb_kbd_inp_disconnect(struct input_handle *handle) +{ + input_close_device(handle); + input_unregister_handle(handle); + + input_put_device(handle->dev); + handle->dev = NULL; +} + static int appletb_kbd_input_configured(struct hid_device *hdev, struct hid_input *hidinput) { int idx; @@ -195,6 +273,40 @@ static int appletb_kbd_input_configured(struct hid_device *hdev, struct hid_inpu return 0; } +static const struct input_device_id appletb_kbd_input_devices[] = { + { + .flags = INPUT_DEVICE_ID_MATCH_BUS | + INPUT_DEVICE_ID_MATCH_VENDOR | + INPUT_DEVICE_ID_MATCH_KEYBIT, + .bustype = BUS_USB, + .vendor = USB_VENDOR_ID_APPLE, + .keybit = { [BIT_WORD(KEY_FN)] = BIT_MASK(KEY_FN) }, + .driver_info = APPLETB_DEVID_KEYBOARD, + }, + { } +}; + +static bool appletb_kbd_match_internal_device(struct input_handler *handler, + struct input_dev *inp_dev) +{ + struct device *dev = &inp_dev->dev; + + /* in kernel: dev && !is_usb_device(dev) */ + while (dev && !(dev->type && dev->type->name && + !strcmp(dev->type->name, "usb_device"))) + dev = dev->parent; + + /* + * Apple labels all their internal keyboards and trackpads as such, + * instead of maintaining an ever expanding list of product-id's we + * just look at the device's product name. + */ + if (dev) + return !!strstr(to_usb_device(dev)->product, "Internal Keyboard"); + + return false; +} + static int appletb_kbd_probe(struct hid_device *hdev, const struct hid_device_id *id) { struct appletb_kbd *kbd; @@ -227,6 +339,20 @@ static int appletb_kbd_probe(struct hid_device *hdev, const struct hid_device_id goto stop_hw; } + kbd->inp_handler.event = appletb_kbd_inp_event; + kbd->inp_handler.connect = appletb_kbd_inp_connect; + kbd->inp_handler.disconnect = appletb_kbd_inp_disconnect; + kbd->inp_handler.name = "appletb"; + kbd->inp_handler.id_table = appletb_kbd_input_devices; + kbd->inp_handler.match = appletb_kbd_match_internal_device; + kbd->inp_handler.private = kbd; + + ret = input_register_handler(&kbd->inp_handler); + if (ret) { + dev_err_probe(dev, ret, "Unable to register keyboard handler\n"); + goto close_hw; + } + ret = appletb_kbd_set_mode(kbd, appletb_tb_def_mode); if (ret) { dev_err_probe(dev, ret, "Failed to set touchbar mode\n"); @@ -250,6 +376,8 @@ static void appletb_kbd_remove(struct hid_device *hdev) appletb_kbd_set_mode(kbd, APPLETB_KBD_MODE_OFF); + input_unregister_handler(&kbd->inp_handler); + hid_hw_close(hdev); hid_hw_stop(hdev); } From patchwork Tue Dec 31 17:37:17 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-Patchwork-Submitter: Aditya Garg X-Patchwork-Id: 13923922 X-Patchwork-Delegate: jikos@jikos.cz Received: from MA0PR01CU009.outbound.protection.outlook.com (mail-southindiaazolkn19010000.outbound.protection.outlook.com [52.103.67.0]) (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 7E0B11A4E77; Tue, 31 Dec 2024 17:37:21 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=52.103.67.0 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1735666643; cv=fail; b=feLX5cSkqb/HCRXHoSpGAb2qtIAm3l81jEQ3Fio6ZzePee7tQI1jMKuRZNc9r7Awy6BMURFm5EZY3NNx1XSMjhRhncmN1xIuW7xIDr2sAH3pg/nDTHQxYwToOOAcUdtdzSFUhOVVgcZ87kY+dXxH3KOkCJPWeSStv6bMhoWjVk0= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1735666643; c=relaxed/simple; bh=EB3/WAvxa7z8KPZBJE4SWavdtXmW2xBFffjI3oE8F1U=; h=From:To:CC:Subject:Date:Message-ID:References:In-Reply-To: Content-Type:MIME-Version; b=CtiD5tgEKSPDMq6WKBvYaIb+UOnV6ZNijSgm+8eX8sMV9Jvh2QwSyU13ok8jRHzX/u/H3c1neti6D5bK+n7+gQaKw/4fwFZDXXZQhl1RcUlxh2Hdtgn1IUfm+18BDamXbRGz5qHsRA4Eo0w70F3stuYEu99YUEOsFwU4pOw4zrY= 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=bv6gNxio; arc=fail smtp.client-ip=52.103.67.0 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="bv6gNxio" ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=y1GpPTUZ0pgQvGjMgKBC2fuLSsG8hcoQlGi1YOM1vNoIvKdZhG4NitNJt6wLUU3gkzKEDN5oLk8/ZHEKFLEf4gs72NncHIoJzz09xa3jTyYUK+3nH1JQZiFO69pCdfxyfF/cVeW2AVGf/zza+9SZmPfNGc8Tgb+a+z+raB92BRLD8NTdwLF8oZVbQmvHVNBvMK/ITsW5meitVrtKiukgzMe2p5OCSOJe/7ZT1EdgS0JHwfjcpHHHVlZPm2b2kQ0HHw5flYVzj+Spce+MU+SUpUVmZWKtsdJB2kGcuQ0SxMJ7SL85JX+ZX0B3iv1O8StrN3vnUhTge9pHKO5gEnpHRg== 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=EB3/WAvxa7z8KPZBJE4SWavdtXmW2xBFffjI3oE8F1U=; b=ospmkjKifk5QDV3V+M+T5mXi9nQVUcwNUuAgMbZ3+b1EVLxGoXEGFSyH4uF2tCWpOeLiNJ/jMeetMeSMVfrVWcsSAcfe4a5vZQwDyny4xC/jm5Y+WNodqdqNdCsczfNYgB1nPL4yhVXxYqQJGRanc8BSZpti1h86Ss3XsZpAM5jRU7Q7fcOJEOv7awpds/BHj+UgPii6RJ5T5ptlbogRmW0WVCkGRhDtzq6/9t2Vs2lzm2VGdmkdltq0SAAyThm0/BQmgM/pUlBRBlUdle4g+1bDgyIZkgklUYcd+p0uQ2Ig9Y0unvBvuE7abYIzcBeZ0vOaV8HQzSrtjMJ1e0DyLQ== 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=EB3/WAvxa7z8KPZBJE4SWavdtXmW2xBFffjI3oE8F1U=; b=bv6gNxiow3l269++J508FT1RlnlvxfyXfDqh9SZDj+zQ//52A4VF4O0vbyfyNZRbuidv15J5BeJWN/W1q/XmvujYEPqxdqrfostBdjjxpKn/YHY9rgR9o7kz/gLGQMvFo5n1MgkvuCD7HjaHaWC9JK+BWZfw189ogPUtWV2hwPnCGsDXOVlZHjRqoWRPHWPDRl9RwZfTk2dJeUSPuW9V/TXCvQyltyb6R+5p7aqL0bXdVDifGe+tC3OBx1w6Pl9GGbyLA5vh7koBZEutMne+tb9Koew61qrbszODuMHCFtRrlDVVl8i9SwEFW1kSk36Eb2z3PYNmXjWnoKxyV4cVgA== Received: from PN3PR01MB7728.INDPRD01.PROD.OUTLOOK.COM (2603:1096:c01:cd::12) by MAXPR01MB4261.INDPRD01.PROD.OUTLOOK.COM (2603:1096:a01:8::14) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.8293.20; Tue, 31 Dec 2024 17:37:17 +0000 Received: from PN3PR01MB7728.INDPRD01.PROD.OUTLOOK.COM ([fe80::d3b7:2498:cd95:5d06]) by PN3PR01MB7728.INDPRD01.PROD.OUTLOOK.COM ([fe80::d3b7:2498:cd95:5d06%4]) with mapi id 15.20.8314.012; Tue, 31 Dec 2024 17:37:17 +0000 From: Aditya Garg To: "jkosina@suse.cz" , Jiri Kosina , Benjamin Tissoires , "bentiss@kernel.org" CC: Kerem Karabay , Orlando Chamberlain , "linux-input@vger.kernel.org" , Linux Kernel Mailing List Subject: [PATCH v2 4/4] HID: hid-appletb-kbd: add support for automatic brightness control while using the touchbar Thread-Topic: [PATCH v2 4/4] HID: hid-appletb-kbd: add support for automatic brightness control while using the touchbar Thread-Index: AQHbW6qiH3CE2+eB+UqAojbreyuqGQ== Date: Tue, 31 Dec 2024 17:37:17 +0000 Message-ID: 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-ms-publictraffictype: Email x-ms-traffictypediagnostic: PN3PR01MB7728:EE_|MAXPR01MB4261:EE_ x-ms-office365-filtering-correlation-id: eff42b84-a7e4-4b2a-05c5-08dd29c1c535 x-microsoft-antispam: BCL:0;ARA:14566002|19110799003|15080799006|8062599003|7092599003|8060799006|461199028|440099028|3412199025|102099032; x-microsoft-antispam-message-info: =?utf-8?q?9BxD7+LWDEECaVrYz9dRruKFHSTAw2Y?= =?utf-8?q?gJx71KtvKfjZGZLwMkqKjMa4I9oYRBqwRMn6e5tNuh4GGlgdi1H5NyYhcioqzccOj?= =?utf-8?q?mthrGS9L2qJtqn5ZO7VBvZG7wIr+Dw3VD1exVe83VQuWB/c3N/NWTc+wkyi5FC0+A?= =?utf-8?q?yEngMkv9Urf9nzehaKrJdDWEOuzWmgLRwWWjr2v5IUrywjRyVRf0BLJVa5znEoE2s?= =?utf-8?q?8nPM2cdWFPJDgUYMqdxpgd1HW1dBbqgTKNC3ye8jyHqgoxJD6lddSyOgFTgzCnZ3P?= =?utf-8?q?dts4sZX8cHpCdcl622RCFbYSpJC7zOQiMcxuYkRU+atcBJ/uk3Kra985wu2oCz6so?= =?utf-8?q?dcUudwX60hrR7mK2D3OHL29lo/MmZqML3HUX7dvPewqHIy5nGzNGGYM92LOvSetrb?= =?utf-8?q?SlJJcwPWsmaRghjejHiHxI07Sd+LgnnM944TiWyN9DxSXijrQ6MS5+asKbOcBWXh1?= =?utf-8?q?a3FYozesAA4R+TkwpnNaYkzuFfrQqAQ0rPsyXlhQfvSrjkEITa1gfIKXlwB8xg4vl?= =?utf-8?q?qSyS/Ha1oE1Gpd4voQDM/uz6FCNrJe/n36bRDDigLrOUhWJubTXqT3z168rhxNTeo?= =?utf-8?q?Gpj1jEgyS6SJwHTko4ywlSQP03BvneEKguGgG9EQXaN6USOlmjlcWqoun4JvtxMzh?= =?utf-8?q?DrHgsWxnIjr52VMtCj6kwHDinHo0hVItTGwyZENEdnwFFovP6BqAIeGin6bsDllst?= =?utf-8?q?3OXLn1Z4nXQPFJPzdkteKb/YLwlyx9qSCgN6yRkX8pAXMlQaVO12fc1sraAeLCEDh?= =?utf-8?q?EM+ffEhzP3p3JzYrtDFP6cVMH+onIlyunSv8Y55A3Om4Pa7cIJI+G9IOBD+U8KlgI?= =?utf-8?q?uJAwSCiUV8Qq1yXh39INiwYxn1MBLKmp4vKRQPjI62vZWuRx0R87W+VuQwyi5dp63?= =?utf-8?q?J9QoZfKIXgscQaK7B1gvyQMgWT0HEAnPfw6QJ9uMiDxxvs7XE4uDhM7oS77v42xoq?= =?utf-8?q?cY3DHrvyK+WJMICiS7jCvqtU46r/0mu2VbmwaOu6sTS6qf14DaG6YxbJCL26x2yT7?= =?utf-8?q?WpfWr+1HgC/qrKSNZFVZjCs9nNbzDPz6oiP9v9Q=3D=3D?= x-ms-exchange-antispam-messagedata-chunkcount: 1 x-ms-exchange-antispam-messagedata-0: =?utf-8?q?3I2xMdUrC3mEFbhS9iPjvjnlDMJB?= =?utf-8?q?bCdjsm8QUdWzH2lsrag8RRoYLvaTpnnQHQZGyo0JDHh/k+2IC1N6ViWG4yhry53ia?= =?utf-8?q?aHo3+9DgGC/zOV9eEvZnqVfw0vg1VeLqmAorO+KLuSi+FZ5a37Tgm9lrhYve8f+FL?= =?utf-8?q?OR4F5Xn3dbNsjyk6Tmkef9WWjdEkpyIU6AqiUb0Cmqpqg74MPcVlXl/ok3kffRtMG?= =?utf-8?q?Ir+Nd3qj+pUAkknNqwXfGkLBJmIEGmET6e2qMtUAvFuqWrcZnJ3foYzMAMokEqVmh?= =?utf-8?q?PJ//eWj8cGYTxpooec5KB+nnno466Glil1hOzF1jHVP6RXENuYoF6zd0Yjq3WTjtm?= =?utf-8?q?mw8l2GpagQb4qAMlUcCtNoSB7PJ3YVisfb6GIPFOT4hkcUk21DUTqugvGX/ZTwXKK?= =?utf-8?q?55D2jIpXdOHDgu+u8iY7iFNmb/exoyJl3z1ScuPLDckxFbqIPHD0YImXubs8ak75u?= =?utf-8?q?gvoR1qDdLPxnt2XqoqX1TQGghHdHIUbDvkO6jKq61Vx5YE/BUD+bgdLzks08mZgg3?= =?utf-8?q?JWIe9kW7VUJ2CWY8eG5sL9SWkBf0jWdhbMRm1cvCV3Tqy/W+/Ea1xU2sJxZ9TjA0F?= =?utf-8?q?dODL3ircV2OZEjKkmoNSrrx45RxEAV8L+38eZEnSi3wspv9LcUIO7S2/Gsbs6nYQR?= =?utf-8?q?eC/ch/yzrdzhAdbcVUdgRyYXJE5PP+1Yw7/rOnxNoJTFrfaEJBPNDSOaQ0UvkjeJe?= =?utf-8?q?ja9rrn+4q9hAJGQ9e3xAAk0DNIFbbu20UISldwzG78Eaqfwu9SVAQ5iGiXeVUnQ67?= =?utf-8?q?FPLNFD62eFjAHZV9b6pxYzxxz2/qiuSqCExRKnJlmw/1WNMihhFL4lyvSUzyysIjU?= =?utf-8?q?e4CFm5f+ZIEyJtn86k7w3E2egry2bdXGcbldGPMmuCBloCVG6B4IP7uqaY0Mg1crH?= =?utf-8?q?M9wC4mTN7dROPtYYA4y+loSIBEoy+tXbFbxEXbgAPftjKbwwtt0dPgezlmbyozMzZ?= =?utf-8?q?JjqkKBPJzgghsTlZp3zutouGpX+bTMELmDgM+KmxPOTW+5UbKEelUSgiujaXpnm1Q?= =?utf-8?q?zn7T5b1PE7Mn9dWWv/Ufzga5IsRIQuCU8weBWaUhoTXHTj/VB34xVaOrnXiRfe8O4?= =?utf-8?q?eo3XlFVdXDHi5jk/umNx/0EB06ETEDQBS4s7FJvwWZbl2YlL8F9MlNW8hGi5DqCZW?= =?utf-8?q?ULk5uzQyjAafkN8DzMw09Gwg4JFbn12gbQZGaX4CP5vP11yvf5cNNGQvNxQ22Vf5Y?= =?utf-8?q?rNNYe6JvCl9WVj5MxKBpSNVWt6Zb5toWeP9E6wQjJebhLqyMtA7S2yFPnx9Oh7EyS?= =?utf-8?q?KCPA1hf6//SFzMc6?= Content-ID: Precedence: bulk X-Mailing-List: linux-input@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-OriginatorOrg: sct-15-20-7719-20-msonline-outlook-ae5c4.templateTenant X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-AuthSource: PN3PR01MB7728.INDPRD01.PROD.OUTLOOK.COM X-MS-Exchange-CrossTenant-RMS-PersistedConsumerOrg: 00000000-0000-0000-0000-000000000000 X-MS-Exchange-CrossTenant-Network-Message-Id: eff42b84-a7e4-4b2a-05c5-08dd29c1c535 X-MS-Exchange-CrossTenant-rms-persistedconsumerorg: 00000000-0000-0000-0000-000000000000 X-MS-Exchange-CrossTenant-originalarrivaltime: 31 Dec 2024 17:37:17.0067 (UTC) X-MS-Exchange-CrossTenant-fromentityheader: Hosted X-MS-Exchange-CrossTenant-id: 84df9e7f-e9f6-40af-b435-aaaaaaaaaaaa X-MS-Exchange-Transport-CrossTenantHeadersStamped: MAXPR01MB4261 From: Aditya Garg On Windows, if there is no input by the user for 60 sec, the Touch Bar dims automatically, and after further 15 sec, it turns off. On receiving input, the Touch Bar resets the timer and goes back to full brightness. This patch implements the same functionality. Signed-off-by: Aditya Garg --- drivers/hid/Kconfig | 2 + drivers/hid/hid-appletb-kbd.c | 83 +++++++++++++++++++++++++++++++++-- 2 files changed, 81 insertions(+), 4 deletions(-) diff --git a/drivers/hid/Kconfig b/drivers/hid/Kconfig index 5b16bfadc..4dadf42a2 100644 --- a/drivers/hid/Kconfig +++ b/drivers/hid/Kconfig @@ -161,8 +161,10 @@ config HID_APPLETB_BL config HID_APPLETB_KBD tristate "Apple Touch Bar Keyboard Mode" depends on USB_HID + depends on BACKLIGHT_CLASS_DEVICE depends on INPUT select INPUT_SPARSEKMAP + select HID_APPLETB_BL help Say Y here if you want support for the keyboard mode (escape, function, media and brightness keys) of Touch Bars on x86 MacBook diff --git a/drivers/hid/hid-appletb-kbd.c b/drivers/hid/hid-appletb-kbd.c index de5770500..fa28a691d 100644 --- a/drivers/hid/hid-appletb-kbd.c +++ b/drivers/hid/hid-appletb-kbd.c @@ -16,6 +16,8 @@ #include #include #include +#include +#include #include #include "hid-ids.h" @@ -27,6 +29,7 @@ #define APPLETB_KBD_MODE_MAX APPLETB_KBD_MODE_OFF #define APPLETB_DEVID_KEYBOARD 1 +#define APPLETB_DEVID_TRACKPAD 2 #define HID_USAGE_MODE 0x00ff0004 @@ -41,14 +44,29 @@ static bool appletb_tb_fn_toggle = true; module_param_named(fntoggle, appletb_tb_fn_toggle, bool, 0644); MODULE_PARM_DESC(fntoggle, "Switch between Fn and media controls on pressing Fn key"); +static bool appletb_tb_autodim = true; +module_param_named(autodim, appletb_tb_autodim, bool, 0644); +MODULE_PARM_DESC(autodim, "Automatically dim and turn off the Touch Bar after some time"); + +static int appletb_tb_dim_timeout = 60; +module_param_named(dim_timeout, appletb_tb_dim_timeout, int, 0644); +MODULE_PARM_DESC(dim_timeout, "Dim timeout in sec"); + +static int appletb_tb_idle_timeout = 15; +module_param_named(idle_timeout, appletb_tb_idle_timeout, int, 0644); +MODULE_PARM_DESC(idle_timeout, "Idle timeout in sec"); + struct appletb_kbd { struct hid_field *mode_field; - - u8 saved_mode; - u8 current_mode; struct input_handler inp_handler; struct input_handle kbd_handle; - + struct input_handle tpd_handle; + struct backlight_device *backlight_dev; + struct timer_list inactivity_timer; + bool has_dimmed; + bool has_turned_off; + u8 saved_mode; + u8 current_mode; }; static const struct key_entry appletb_kbd_keymap[] = { @@ -146,6 +164,34 @@ static int appletb_tb_key_to_slot(unsigned int code) } } +static void appletb_inactivity_timer(struct timer_list *t) +{ + struct appletb_kbd *kbd = from_timer(kbd, t, inactivity_timer); + + if (kbd->backlight_dev && appletb_tb_autodim) { + if (!kbd->has_dimmed) { + backlight_device_set_brightness(kbd->backlight_dev, 1); + kbd->has_dimmed = true; + mod_timer(&kbd->inactivity_timer, jiffies + msecs_to_jiffies(appletb_tb_idle_timeout * 1000)); + } else if (!kbd->has_turned_off) { + backlight_device_set_brightness(kbd->backlight_dev, 0); + kbd->has_turned_off = true; + } + } +} + +static void reset_inactivity_timer(struct appletb_kbd *kbd) +{ + if (kbd->backlight_dev && appletb_tb_autodim) { + if (kbd->has_dimmed || kbd->has_turned_off) { + backlight_device_set_brightness(kbd->backlight_dev, 2); + kbd->has_dimmed = false; + kbd->has_turned_off = false; + } + mod_timer(&kbd->inactivity_timer, jiffies + msecs_to_jiffies(appletb_tb_dim_timeout * 1000)); + } +} + static int appletb_kbd_hid_event(struct hid_device *hdev, struct hid_field *field, struct hid_usage *usage, __s32 value) { @@ -170,6 +216,8 @@ static int appletb_kbd_hid_event(struct hid_device *hdev, struct hid_field *fiel if (slot < 0) return 0; + reset_inactivity_timer(kbd); + translation = sparse_keymap_entry_from_scancode(input, usage->code); if (translation && kbd->current_mode == APPLETB_KBD_MODE_SPCL) { @@ -186,6 +234,8 @@ static void appletb_kbd_inp_event(struct input_handle *handle, unsigned int type { struct appletb_kbd *kbd = handle->private; + reset_inactivity_timer(kbd); + if (type == EV_KEY && code == KEY_FN && appletb_tb_fn_toggle) { if (value == 1) { kbd->saved_mode = kbd->current_mode; @@ -211,6 +261,9 @@ static int appletb_kbd_inp_connect(struct input_handler *handler, if (id->driver_info == APPLETB_DEVID_KEYBOARD) { handle = &kbd->kbd_handle; handle->name = "tbkbd"; + } else if (id->driver_info == APPLETB_DEVID_TRACKPAD) { + handle = &kbd->tpd_handle; + handle->name = "tbtpd"; } else { return -ENOENT; } @@ -283,6 +336,15 @@ static const struct input_device_id appletb_kbd_input_devices[] = { .keybit = { [BIT_WORD(KEY_FN)] = BIT_MASK(KEY_FN) }, .driver_info = APPLETB_DEVID_KEYBOARD, }, + { + .flags = INPUT_DEVICE_ID_MATCH_BUS | + INPUT_DEVICE_ID_MATCH_VENDOR | + INPUT_DEVICE_ID_MATCH_KEYBIT, + .bustype = BUS_USB, + .vendor = USB_VENDOR_ID_APPLE, + .keybit = { [BIT_WORD(BTN_TOUCH)] = BIT_MASK(BTN_TOUCH) }, + .driver_info = APPLETB_DEVID_TRACKPAD, + }, { } }; @@ -339,6 +401,15 @@ static int appletb_kbd_probe(struct hid_device *hdev, const struct hid_device_id goto stop_hw; } + kbd->backlight_dev = backlight_device_get_by_name("appletb_backlight"); + if (!kbd->backlight_dev) + dev_err_probe(dev, ret, "Failed to get backlight device\n"); + else { + backlight_device_set_brightness(kbd->backlight_dev, 2); + timer_setup(&kbd->inactivity_timer, appletb_inactivity_timer, 0); + mod_timer(&kbd->inactivity_timer, jiffies + msecs_to_jiffies(appletb_tb_dim_timeout * 1000)); + } + kbd->inp_handler.event = appletb_kbd_inp_event; kbd->inp_handler.connect = appletb_kbd_inp_connect; kbd->inp_handler.disconnect = appletb_kbd_inp_disconnect; @@ -377,6 +448,7 @@ static void appletb_kbd_remove(struct hid_device *hdev) appletb_kbd_set_mode(kbd, APPLETB_KBD_MODE_OFF); input_unregister_handler(&kbd->inp_handler); + del_timer_sync(&kbd->inactivity_timer); hid_hw_close(hdev); hid_hw_stop(hdev); @@ -425,6 +497,9 @@ static struct hid_driver appletb_kbd_hid_driver = { }; module_hid_driver(appletb_kbd_hid_driver); +/* The backlight driver should be loaded before the keyboard driver is initialised*/ +MODULE_SOFTDEP("pre: hid_appletb_bl"); + MODULE_AUTHOR("Ronald Tschalär"); MODULE_AUTHOR("Kerem Karabay "); MODULE_DESCRIPTION("MacBookPro Touch Bar Keyboard Mode Driver");