Received: by 2002:a25:31c3:0:0:0:0:0 with SMTP id x186csp436823ybx; Wed, 6 Nov 2019 03:04:30 -0800 (PST) X-Google-Smtp-Source: APXvYqzNeSJEaVDXe9D55gzXMepcEWPlcdnRSv10N7SvikMPhiVO5wyOWuF4FGz/lIKulCVg+Tt/ X-Received: by 2002:a50:ac2c:: with SMTP id v41mr1884172edc.11.1573038270320; Wed, 06 Nov 2019 03:04:30 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1573038270; cv=none; d=google.com; s=arc-20160816; b=RMlQtdqfa6cAaz1cgJpujHeZ+XQ3wOdUdIHHgtxbPQbbWzT7q615UcUvlaWNfyV0/K 5Yw3DuBunldFS4oBtQTbg/4j7F8th7QsazZfhFc+Ys6a64VhAei4X2OC01lT5VX5ShMP JyQnm+u+MHASnM13rEsPaAcRb+I2MW2YU7xw5f1DUDigUXdjBDNONpeitK5hPY4MRcB2 GjYoFJzS5eBKoVbX0kRg9NXpiMJZajbR0gi2Lf7xpVKWjpE4pOprQnE9jMNrOaGkJzJn J/Y4SESZ07jzyU9oAl5RMh8tKEefAbgU4/cd+tcW15vNnrfnJtcamUUTuh9ZyQLQpWJZ AhOA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:to:content-transfer-encoding:mime-version :message-id:date:subject:cc:from:dkim-signature:dkim-signature; bh=Ii2oxrWwPIXyOz9KTyWZWso10byGznburLcw9Zjh5ao=; b=N0WGs46cYf4h8eWpIJAHJ6OjxjE9WYaEcuNyk/GVN+a42Yp6iIogEUX7NKdHgBV+Gk cRHoAVCoYDsrdevp4d85FfxL3HtOw2QN0JGN3JN+U9Wq5yzV5PIn7sXXYGaLbxT+rOcI JUgR/9QXDhRVA2POJlBzjCeoAKHXDaZcNEy4+UrfWiXAWKKKvwbb9RVWpTdyGX62Y3px UAb8sgcU00B6d71N7BKnImFLCGpLs6SvE5P8o5pq/TE/qGBQ24idVWafe6hTuP7aRJFR 75tUYcIvqwsrTPE1HdxuiX8tBEI6Rzynke54kAVeIK46WxEZ4zvqfRieOzmK3nbUVA5R LF6w== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@mxxn.io header.s=fm3 header.b=BgZvCYSE; dkim=fail header.i=@messagingengine.com header.s=fm1 header.b=o87Av97m; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id r14si15534732eju.413.2019.11.06.03.04.06; Wed, 06 Nov 2019 03:04:30 -0800 (PST) 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; dkim=fail header.i=@mxxn.io header.s=fm3 header.b=BgZvCYSE; dkim=fail header.i=@messagingengine.com header.s=fm1 header.b=o87Av97m; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728099AbfKFLDZ (ORCPT + 99 others); Wed, 6 Nov 2019 06:03:25 -0500 Received: from wout5-smtp.messagingengine.com ([64.147.123.21]:35703 "EHLO wout5-smtp.messagingengine.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725890AbfKFLDY (ORCPT ); Wed, 6 Nov 2019 06:03:24 -0500 Received: from compute3.internal (compute3.nyi.internal [10.202.2.43]) by mailout.west.internal (Postfix) with ESMTP id 03D344D7; Wed, 6 Nov 2019 06:03:22 -0500 (EST) Received: from mailfrontend1 ([10.202.2.162]) by compute3.internal (MEProxy); Wed, 06 Nov 2019 06:03:23 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=mxxn.io; h=from :to:cc:subject:date:message-id:mime-version:content-type :content-transfer-encoding; s=fm3; bh=Ii2oxrWwPIXyOz9KTyWZWso10b yGznburLcw9Zjh5ao=; b=BgZvCYSEOWLQrLl7SRYAy5u+NZbovI1AEIFybvfyzt MQwfOWtqj1YDSsB1yOOdFxb/9M2Hen4rosBd2qEI1HzAnBqEL0sWG6APSv84W7gA Vf74wohU89kSvuOOFjIAofRDZrRpheoUnj8n8UiHbS4ZJK6q+KdgJkpc+OgOcVc7 DPfKL5G5YAk/wLATdYsL9cc0/g//EyUJc6U+7mcprQufGLyMiBYScQxdzPIDiVu+ M1/Zjrk1JWj9iaVW/8rObsmrUuxKDsw4n2EN4x2tEETgohv+gIUtzqFNQRpZFIix n40KUBcM7Nww4+yPFHuev/MEj6IFTwm+1IWlIGFNyzOQ== DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d= messagingengine.com; h=cc:content-transfer-encoding:content-type :date:from:message-id:mime-version:subject:to:x-me-proxy :x-me-proxy:x-me-sender:x-me-sender:x-sasl-enc; s=fm1; bh=Ii2oxr WwPIXyOz9KTyWZWso10byGznburLcw9Zjh5ao=; b=o87Av97mKTjX57VjcioQ3N la1PH9XaL3wB/G1Q/SaAmH9aNV6ximiqj1dgqJHrq/W8p0v01n7l+HE/16kVw4sp Br4/eJ8PcTng0/FZgKz+wAH+KWvDf36W1TG+AUiLTLXCJ97T30yZAWLEbLdl56ly DFX/Vq1K95YPHGkQQqZBkv83CRNlkcIBYu7kepkWNF+c9rSBbUsRy6c3KWvkVl5I iDVURqXaH+Zj4PeVda85VylY/1WKnu24dP858Ex6FXThbbMMUmDVdjX1JEh0RrG5 8DPD3L2M4wqynxtEMjNG+Yaw3niGIYtzMfB/Vv2E+p/eGc6Rr3oDi0ADvn1Dp7hw == X-ME-Sender: X-ME-Proxy-Cause: gggruggvucftvghtrhhoucdtuddrgedufedruddujedgvdefucetufdoteggodetrfdotf fvucfrrhhofhhilhgvmecuhfgrshhtofgrihhlpdfqfgfvpdfurfetoffkrfgpnffqhgen uceurghilhhouhhtmecufedttdenucesvcftvggtihhpihgvnhhtshculddquddttddmne hmihhsshhinhhgucfvqfcufhhivghlugculdeftddmnegoteeftdduqddtudculdduhedm necujfgurhephffvufffkffogggtgfesthekredtredtjeenucfhrhhomhepuehlrgkkuc fjrhgrshhtnhhikhcuoegslhgriiesmhiggihnrdhioheqnecukfhppeduuddurddutdej rddvtdelrddvvdehnecurfgrrhgrmhepmhgrihhlfhhrohhmpegslhgriiesmhiggihnrd hiohenucevlhhushhtvghrufhiiigvpedt X-ME-Proxy: Received: from localhost.localdomain (225.ec0279u.cyberhome.ne.jp [111.107.209.225]) by mail.messagingengine.com (Postfix) with ESMTPA id C271680062; Wed, 6 Nov 2019 06:03:20 -0500 (EST) From: =?UTF-8?q?Bla=C5=BE=20Hrastnik?= Cc: =?UTF-8?q?Bla=C5=BE=20Hrastnik?= , Jiri Kosina , Benjamin Tissoires , linux-input@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH] HID: Improve Windows Precision Touchpad detection. Date: Wed, 6 Nov 2019 20:02:46 +0900 Message-Id: <20191106110246.70937-1-blaz@mxxn.io> X-Mailer: git-send-email 2.23.0 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit To: unlisted-recipients:; (no To-header on input) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Per Microsoft spec, usage 0xC5 (page 0xFF) returns a blob containing data used to verify the touchpad as a Windows Precision Touchpad. 0x85, REPORTID_PTPHQA, // REPORT_ID (PTPHQA) 0x09, 0xC5, // USAGE (Vendor Usage 0xC5) 0x15, 0x00, // LOGICAL_MINIMUM (0) 0x26, 0xff, 0x00, // LOGICAL_MAXIMUM (0xff) 0x75, 0x08, // REPORT_SIZE (8) 0x96, 0x00, 0x01, // REPORT_COUNT (0x100 (256)) 0xb1, 0x02, // FEATURE (Data,Var,Abs) However, some devices, namely Microsoft's Surface line of products instead implement a "segmented device certification report" (usage 0xC6) which returns the same report, but in smaller chunks. 0x06, 0x00, 0xff, // USAGE_PAGE (Vendor Defined) 0x85, REPORTID_PTPHQA, // REPORT_ID (PTPHQA) 0x09, 0xC6, // USAGE (Vendor usage for segment #) 0x25, 0x08, // LOGICAL_MAXIMUM (8) 0x75, 0x08, // REPORT_SIZE (8) 0x95, 0x01, // REPORT_COUNT (1) 0xb1, 0x02, // FEATURE (Data,Var,Abs) 0x09, 0xC7, // USAGE (Vendor Usage) 0x26, 0xff, 0x00, // LOGICAL_MAXIMUM (0xff) 0x95, 0x20, // REPORT_COUNT (32) 0xb1, 0x02, // FEATURE (Data,Var,Abs) By expanding Win8 touchpad detection to also look for the segmented report, all Surface touchpads are now properly recognized by hid-multitouch. Signed-off-by: Blaž Hrastnik --- drivers/hid/hid-core.c | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/drivers/hid/hid-core.c b/drivers/hid/hid-core.c index 63fdbf09b044..2af597cd5d65 100644 --- a/drivers/hid/hid-core.c +++ b/drivers/hid/hid-core.c @@ -742,6 +742,10 @@ static void hid_scan_feature_usage(struct hid_parser *parser, u32 usage) if (usage == 0xff0000c5 && parser->global.report_count == 256 && parser->global.report_size == 8) parser->scan_flags |= HID_SCAN_FLAG_MT_WIN_8; + + if (usage == 0xff0000c6 && parser->global.report_count == 1 && + parser->global.report_size == 8) + parser->scan_flags |= HID_SCAN_FLAG_MT_WIN_8; } static void hid_scan_collection(struct hid_parser *parser, unsigned type) -- 2.23.0