Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp3199409imm; Tue, 29 May 2018 03:00:37 -0700 (PDT) X-Google-Smtp-Source: AB8JxZrcp4JqPnqGVj9LpM1u/fDCPL07jMmdDlQgShsWcJbKLDx+Y6VwLmUitArgzk4TuGZFvzny X-Received: by 2002:a62:da17:: with SMTP id c23-v6mr16852143pfh.128.1527588037402; Tue, 29 May 2018 03:00:37 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1527588037; cv=none; d=google.com; s=arc-20160816; b=cl/HuUolVZMDvkoMoYjeHYV6k3U+U3bUktVEBZgkMPxMbQdpOxatyx9QhQGr9okdo4 MQUfSfZvbwur1UJaJCdjFHHf3AJsTajl7oQTLqjcJBpsXF/VeubmerYJS4xAzycOanNw 4Z5BM/PsJRu97pwGtuLQWM+Mpid35T+XH3M0q+j8Ud4vSMBsPFhqNu6YAAPb0K2Pf2UY zBzDRh/0vZJ7E1JaTB2GnSbwCKw1AOspQ7gcHt9teVIS73Fpo/T3kRgzp5H7dLQSSN0m oQrdU5Yts5EGYD38FuuHFw04umUQVjuyf04eAfgtgYb0FEVCpNNaXxIeRi0xpAaA7jF0 qpYA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:arc-authentication-results; bh=M9aLEaaaZEizq+iJPPasssVMHYWxvt1Sa5S2sGyBnw0=; b=JNQn60sro1Jiya24zS/XgiiVZs7NSgQsZs3VdKzgzmpCXzdp+N7ECw4kDNTG71sfv/ AZhnm/jAu1bFOl9jf9jf5ezJiBft2OUN9r7ijtcL+sqEVe/cuRLL3RrSkwpW6IcbISNn vJo0AYvTTveIwr1DBB/Up9mg80HOMBNQ0U9i3O1OlWpAUUDrouEPKpj0eDw4zwuMYbOZ iVvWRXOZVjfJy5v0zRldSm0Yxiz8cNaFrzq2e9BTvMbDIQW9n3Shz2wCA5ElIOyg4lEl 3j1sVryD3gozKm+FgIV7Efv6GBc8R1IEJg4HXtJkA908kCNrtAYGRti/UIUa9NI24NYm mjOg== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id n20-v6si15512461plp.298.2018.05.29.03.00.23; Tue, 29 May 2018 03:00:37 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S932807AbeE2J7Z (ORCPT + 99 others); Tue, 29 May 2018 05:59:25 -0400 Received: from mx3-rdu2.redhat.com ([66.187.233.73]:42246 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S932900AbeE2J6W (ORCPT ); Tue, 29 May 2018 05:58:22 -0400 Received: from smtp.corp.redhat.com (int-mx03.intmail.prod.int.rdu2.redhat.com [10.11.54.3]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id BE834818F70A; Tue, 29 May 2018 09:58:21 +0000 (UTC) Received: from plouf.banquise.eu.com (ovpn-116-67.ams2.redhat.com [10.36.116.67]) by smtp.corp.redhat.com (Postfix) with ESMTP id 7CA9B11166E7; Tue, 29 May 2018 09:58:20 +0000 (UTC) From: Benjamin Tissoires To: Jiri Kosina , Dmitry Torokhov Cc: Mario.Limonciello@dell.com, Peter Hutterer , linux-input@vger.kernel.org, linux-kernel@vger.kernel.org, Benjamin Tissoires Subject: [PATCH 9/9] HID: microsoft: support the Surface Dial Date: Tue, 29 May 2018 11:58:00 +0200 Message-Id: <20180529095800.13504-10-benjamin.tissoires@redhat.com> In-Reply-To: <20180529095800.13504-1-benjamin.tissoires@redhat.com> References: <20180529095800.13504-1-benjamin.tissoires@redhat.com> X-Scanned-By: MIMEDefang 2.78 on 10.11.54.3 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.11.55.8]); Tue, 29 May 2018 09:58:21 +0000 (UTC) X-Greylist: inspected by milter-greylist-4.5.16 (mx1.redhat.com [10.11.55.8]); Tue, 29 May 2018 09:58:21 +0000 (UTC) for IP:'10.11.54.3' DOMAIN:'int-mx03.intmail.prod.int.rdu2.redhat.com' HELO:'smtp.corp.redhat.com' FROM:'benjamin.tissoires@redhat.com' RCPT:'' Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The tool works nicely with hid-generic, but it ends up creating 9 different input nodes with most of them only having ABS_MISC set. Filter the axis out, which reduces the amount of devices to 2. One is the proper System Multi-axis collection, the other exported device seems to provide SLEEP and POWER Key, not sure how one can trigger those events though. Filtering the ABS_X and ABS_Y axes also prevents udev to detect this as a touchscreen. Signed-off-by: Benjamin Tissoires --- drivers/hid/hid-microsoft.c | 49 +++++++++++++++++++++++++++++++++++++++------ 1 file changed, 43 insertions(+), 6 deletions(-) diff --git a/drivers/hid/hid-microsoft.c b/drivers/hid/hid-microsoft.c index 96e7d3231d2f..72d983626afd 100644 --- a/drivers/hid/hid-microsoft.c +++ b/drivers/hid/hid-microsoft.c @@ -22,12 +22,13 @@ #include "hid-ids.h" -#define MS_HIDINPUT 0x01 -#define MS_ERGONOMY 0x02 -#define MS_PRESENTER 0x04 -#define MS_RDESC 0x08 -#define MS_NOGET 0x10 -#define MS_DUPLICATE_USAGES 0x20 +#define MS_HIDINPUT BIT(0) +#define MS_ERGONOMY BIT(1) +#define MS_PRESENTER BIT(2) +#define MS_RDESC BIT(3) +#define MS_NOGET BIT(4) +#define MS_DUPLICATE_USAGES BIT(5) +#define MS_SURFACE_DIAL BIT(6) static __u8 *ms_report_fixup(struct hid_device *hdev, __u8 *rdesc, unsigned int *rsize) @@ -130,6 +131,30 @@ static int ms_presenter_8k_quirk(struct hid_input *hi, struct hid_usage *usage, return 1; } +static int ms_surface_dial_quirk(struct hid_input *hi, struct hid_field *field, + struct hid_usage *usage, unsigned long **bit, int *max) +{ + switch (usage->hid & HID_USAGE_PAGE) { + case 0xff070000: + /* fall-through */ + case HID_UP_DIGITIZER: + /* ignore those axis */ + return -1; + case HID_UP_GENDESK: + switch (usage->hid) { + case HID_GD_X: + /* fall-through */ + case HID_GD_Y: + /* fall-through */ + case HID_GD_RFKILL_BTN: + /* ignore those axis */ + return -1; + } + } + + return 0; +} + static int ms_input_mapping(struct hid_device *hdev, struct hid_input *hi, struct hid_field *field, struct hid_usage *usage, unsigned long **bit, int *max) @@ -146,6 +171,13 @@ static int ms_input_mapping(struct hid_device *hdev, struct hid_input *hi, ms_presenter_8k_quirk(hi, usage, bit, max)) return 1; + if (quirks & MS_SURFACE_DIAL) { + int ret = ms_surface_dial_quirk(hi, field, usage, bit, max); + + if (ret) + return ret; + } + return 0; } @@ -229,6 +261,9 @@ static int ms_probe(struct hid_device *hdev, const struct hid_device_id *id) if (quirks & MS_NOGET) hdev->quirks |= HID_QUIRK_NOGET; + if (quirks & MS_SURFACE_DIAL) + hdev->quirks |= HID_QUIRK_INPUT_PER_APP; + ret = hid_parse(hdev); if (ret) { hid_err(hdev, "parse failed\n"); @@ -281,6 +316,8 @@ static const struct hid_device_id ms_devices[] = { { HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_MICROSOFT, USB_DEVICE_ID_MS_PRESENTER_8K_BT), .driver_data = MS_PRESENTER }, + { HID_BLUETOOTH_DEVICE(USB_VENDOR_ID_MICROSOFT, 0x091B), + .driver_data = MS_SURFACE_DIAL }, { } }; MODULE_DEVICE_TABLE(hid, ms_devices); -- 2.14.3