Received: by 2002:a05:6358:d09b:b0:dc:cd0c:909e with SMTP id jc27csp2178508rwb; Wed, 30 Nov 2022 03:30:44 -0800 (PST) X-Google-Smtp-Source: AA0mqf5G7sj3h51VJGE0lgxHYP6ZCA9+8i9SPnL6GMdtSVOqgqM/LQwVf1XaFOedgOp6x7iCm0/2 X-Received: by 2002:a63:4c63:0:b0:477:103:d1c4 with SMTP id m35-20020a634c63000000b004770103d1c4mr35367617pgl.369.1669807844601; Wed, 30 Nov 2022 03:30:44 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1669807844; cv=none; d=google.com; s=arc-20160816; b=M9fBKos19oQjDi+hfTKNEW76smLJubifL4T1XqTcNV4lsmhkgWpP1nvycC+E9gjliV eh7EYm7okaJPBMODhG3dUd19bSjqNtNbmoZiQpzjr3DBVdaGBfUzLAXkdEgXTIQBA/lC F7iurfDsaXyUyVIRt+4+DTFSslDWy0Sv3QC5YoUqLOsgB5vqJIGlcXKouIElfNjhvZpL OhyVL/fbWVDPGk2cAHXmwkDuGywYaZp/bGQvZ3ZWvQBKksfK5aQgFRREavspcAwpm8nu t0Tuowgb+Ikyvwn1jG7YvmXP0tCjU9kVqFXfeXoUPozMp3dU6grc4AbHfRQI/Jven4gj mQFQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-language:thread-index :content-transfer-encoding:mime-version:message-id:date:subject :in-reply-to:references:cc:to:from; bh=aZcgR4eOnYHzeqjS0PqKUSL5xXrre0LtMEiweLvhbVQ=; b=MwohjhKyyvi0msv+w2PnDR/Ew6VxkwJCEDr9oJsXMLevXOOrRkicQ40fDC4u+Ny5Ku QTAw/u59CgBytmJLzYszlDov8JD+oFGS996OA9XE83N02cTMkD8/C+tMT4A1O4Oxs74V 74mljHCE0cYkXXn4B8CvcvWrn8e9wXZ34RJ5FQciKslNAr9QcurwOeSFZp7AOKkA2HIz u3hHl31YpSGIv+u4qdw7euT4YhLUdHNNq6ctXG0jse7z4M/GluyYhjhFjpeNb6gkt6DD hwW8bZDg2WDkUrZYJg8SNvM1oKpvkyTeFBoX6oy4YxhQP9YPxbFsJARzM/Qft/K85P+z l7cQ== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id b15-20020a63714f000000b00477076948efsi1015159pgn.799.2022.11.30.03.30.33; Wed, 30 Nov 2022 03:30:44 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S235022AbiK3LXv (ORCPT + 85 others); Wed, 30 Nov 2022 06:23:51 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46660 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S234890AbiK3LXG (ORCPT ); Wed, 30 Nov 2022 06:23:06 -0500 Received: from emcscan.emc.com.tw (emcscan.emc.com.tw [192.72.220.5]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 5862A7B4FD for ; Wed, 30 Nov 2022 03:22:31 -0800 (PST) X-IronPort-AV: E=Sophos;i="5.96,206,1665417600"; d="scan'208";a="1046873" Received: from unknown (HELO webmail.emc.com.tw) ([192.168.10.1]) by emcscan.emc.com.tw with ESMTP; 30 Nov 2022 19:22:28 +0800 Received: from 192.168.10.23 by webmail.emc.com.tw with MailAudit ESMTP Server V5.0(32974:0:AUTH_RELAY) (envelope-from ); Wed, 30 Nov 2022 19:22:26 +0800 (CST) Received: from 192.168.33.13 by webmail.emc.com.tw with Mail2000 ESMTPA Server V7.00(128282:0:AUTH_LOGIN) (envelope-from ); Wed, 30 Nov 2022 19:22:25 +0800 (CST) From: "phoenix" To: "'Dmitry Torokhov'" , "'Eirin Nya'" Cc: , , "'Josh.Chen'" References: <20221014111533.908-1-nyanpasu256@gmail.com> <20221014111533.908-4-nyanpasu256@gmail.com> In-Reply-To: Subject: RE: [PATCH V2 3/3] Input: elantech - Fix incorrectly halved touchpad range on ELAN v3 touchpads Date: Wed, 30 Nov 2022 19:22:25 +0800 Message-ID: <003201d904ae$05d38870$117a9950$@emc.com.tw> MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit X-Mailer: Microsoft Outlook 15.0 Thread-Index: AQDbt+ppC1xC+keScPeVlOENSMuCUQN/vwKcAiwO8jQCAyhLLLASYmNwgAHaGDA= Content-Language: zh-tw x-dg-ref: PG1ldGE+PGF0IG5tPSJib2R5LnR4dCIgcD0iYzpcdXNlcnNcODgwNTFcYXBwZGF0YVxyb2FtaW5nXDA5ZDg0OWI2LTMyZDMtNGE0MC04NWVlLTZiODRiYTI5ZTM1Ylxtc2dzXG1zZy00MzI0ZDdhMS03MGExLTExZWQtYTkzZi04OGQ3ZjY1ODJkZmNcYW1lLXRlc3RcNDMyNGQ3YTItNzBhMS0xMWVkLWE5M2YtODhkN2Y2NTgyZGZjYm9keS50eHQiIHN6PSI2MjQzIiB0PSIxMzMxNDI4MDk0NDc2NDQ0ODciIGg9IldZY2RwMGVrWDI1aDFBS24vSGJTdmFJMytBYz0iIGlkPSIiIGJsPSIwIiBibz0iMSIvPjwvbWV0YT4= x-dg-rorf: true X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00,SPF_HELO_NONE, SPF_NONE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Consulted with FW team, we suggest re-querying x/y resolution after setting absolute mode. -----Original Message----- From: phoenix [mailto:phoenix@emc.com.tw] Sent: Tuesday, November 29, 2022 11:47 AM To: 'Dmitry Torokhov' ; 'Eirin Nya' Cc: 'linux-input@vger.kernel.org' ; 'linux-kernel@vger.kernel.org' ; 'Josh.Chen' Subject: RE: [PATCH V2 3/3] Input: elantech - Fix incorrectly halved touchpad range on ELAN v3 touchpads Loop Josh -----Original Message----- From: Dmitry Torokhov [mailto:dmitry.torokhov@gmail.com] Sent: Tuesday, November 29, 2022 1:59 AM To: Eirin Nya ; Phoenix Huang Cc: linux-input@vger.kernel.org; linux-kernel@vger.kernel.org Subject: Re: [PATCH V2 3/3] Input: elantech - Fix incorrectly halved touchpad range on ELAN v3 touchpads On Mon, Nov 28, 2022 at 09:57:51AM -0800, Dmitry Torokhov wrote: > On Fri, Oct 14, 2022 at 04:15:33AM -0700, Eirin Nya wrote: > > On Linux 5.19.10, on my laptop (Dell Inspiron 15R SE 7520) with an > > Elan > > v3 touchpad (dmesg says "with firmware version 0x450f02"), the > > reported size of my touchpad (in userspace by calling > > mtdev_configure() and libevdev_get_abs_maximum(), in kernel space > > elantech_device_info::x_max/y_max, either way 1470 by 700) is half > > that of the actual touch range (2940 by 1400), and the upper half of > > my touchpad reports negative values. As a result, with the Synaptics > > or libinput X11 driver set to edge scrolling mode, the entire right > > half of my touchpad has x-values past evdev's reported maximum size, > > and acts as a giant scrollbar! > > > > The problem is that elantech_setup_ps2() -> > > elantech_set_absolute_mode() sets up absolute mode and doubles the > > hardware resolution (doubling the hardware's maximum reported x/y > > coordinates and its response to ETP_FW_ID_QUERY), *after* > > elantech_query_info() fetches the touchpad coordinate system size > > using ETP_FW_ID_QUERY, which gets cached and reported to userspace > > through ioctl(fd, EVIOCGABS(ABS_X/Y), ...). So the touchpad size > > reported to userspace (and used to subtract vertical coordinates from) is half the maximum position of actual touches. > > > > This patch splits out a function elantech_query_range_v3() which > > fetches > > *only* ETP_FW_ID_QUERY (touchpad size), and calls it a second time > > if > > elantech_set_absolute_mode() enables double-size mode. This means > > the first call is redundant and wasted if a second call occurs, but > > this minimizes the need to restructure the driver. > > If the setting is indeed double resolution, can we simply multiply > x_max and y_max by 2 instead of re-querying it? > > Also let's try adding one of Elan engineers for their take in this. > Phoenix, do you have any suggestions please? Argh, adding Phoenix for real now. > > > > > Link: > > https://lore.kernel.org/linux-input/CAL57YxZNutUVxBtvbVWKMw-V2kqeVB5 > > kTQ5BFdJmN=mdPq8Q8Q@mail.gmail.com/ > > Link: > > https://lore.kernel.org/linux-input/20221008093437.72d0f6b0@dell-voi > > d.nyanpasu256.gmail.com.beta.tailscale.net/ > > Fixes: 37548659bb22 ("Input: elantech - query the min/max > > information beforehand too") > > Signed-off-by: Eirin Nya > > --- > > > > Notes: > > Should we move (elantech_set_absolute_mode -> > > elantech_write_reg(...0x0b or 0x01)) *earlier* into elantech_query_info() > > before "query range information"? See discussion at > > > > https://lore.kernel.org/linux-input/20221008093437.72d0f6b0@dell-voi > > d.nyanpasu256.gmail.com.beta.tailscale.net/ > > > > drivers/input/mouse/elantech.c | 30 ++++++++++++++++++++++++++---- > > 1 file changed, 26 insertions(+), 4 deletions(-) > > > > diff --git a/drivers/input/mouse/elantech.c > > b/drivers/input/mouse/elantech.c index 263779c031..a2176f0fd3 100644 > > --- a/drivers/input/mouse/elantech.c > > +++ b/drivers/input/mouse/elantech.c > > @@ -1006,6 +1006,9 @@ static void elantech_set_rate_restore_reg_07(struct psmouse *psmouse, > > psmouse_err(psmouse, "restoring reg_07 failed\n"); } > > > > +static int elantech_query_range_v3(struct psmouse *psmouse, > > + struct elantech_device_info *info); > > + > > /* > > * Put the touchpad into absolute mode > > */ > > @@ -1047,6 +1050,14 @@ static int elantech_set_absolute_mode(struct psmouse *psmouse) > > if (elantech_write_reg(psmouse, 0x10, etd->reg_10)) > > rc = -1; > > > > + /* > > + * If we boost hardware resolution, we have to re-query > > + * info->x_max and y_max. > > + */ > > + if (etd->info.set_hw_resolution) > > + if (elantech_query_range_v3(psmouse, &etd->info)) > > + rc = -1; > > + > > break; > > > > case 4: > > @@ -1671,6 +1682,20 @@ static int elantech_set_properties(struct elantech_device_info *info) > > return 0; > > } > > > > +static int elantech_query_range_v3(struct psmouse *psmouse, > > + struct elantech_device_info *info) { > > + unsigned char param[3]; > > + > > + if (info->send_cmd(psmouse, ETP_FW_ID_QUERY, param)) > > + return -EINVAL; > > + > > + info->x_max = (0x0f & param[0]) << 8 | param[1]; > > + info->y_max = (0xf0 & param[0]) << 4 | param[2]; > > + > > + return 0; > > +} > > + > > static int elantech_query_info(struct psmouse *psmouse, > > struct elantech_device_info *info) { @@ -1826,11 +1851,8 > > @@ static int elantech_query_info(struct psmouse *psmouse, > > break; > > > > case 3: > > - if (info->send_cmd(psmouse, ETP_FW_ID_QUERY, param)) > > + if (elantech_query_range_v3(psmouse, info)) > > return -EINVAL; > > - > > - info->x_max = (0x0f & param[0]) << 8 | param[1]; > > - info->y_max = (0xf0 & param[0]) << 4 | param[2]; > > break; > > > > case 4: > > -- > > 2.38.0 > > > > Thanks. > > -- > Dmitry -- Dmitry