Date: Sun, 2 Jun 2019 12:49:18 +0300 From: Vladimir Kondratyev <vladimir@kondratyev.su> To: Andrey Kosachenko <andrey.kosachenko@gmail.com> Cc: freebsd-drivers@freebsd.org, FreeBSD X11 mailing list <freebsd-x11@freebsd.org> Subject: Re: Thinkpad t480s elantech touchpad device is not recognized: unknown touchpad firmware (firmware v.0x7f3001) Message-ID: <de2f55b6-fd86-194a-f431-8b2b775f1b11@kondratyev.su> In-Reply-To: <279a4144-43d3-6921-2047-e7877bfd721d@kondratyev.su> References: <5f4e1f25-8c87-5fa5-1d7f-edbde63fde6e@gmail.com> <a179dbc9-3907-8c3d-c369-dd829896393b@gjunka.com> <279a4144-43d3-6921-2047-e7877bfd721d@kondratyev.su>
index | next in thread | previous in thread | raw e-mail
[-- Attachment #1 --]
On 30.05.2019 01:17, Vladimir Kondratyev wrote:
> I.e. after that simple modification system started to recognize fw
>>> version:
>>>
>>> ===
>>> [silent@beastie][/usr/src]dmesg | egrep psm
>>> psm0: <PS/2 Mouse> irq 12 on atkbdc0
>>> psm0: [GIANT-LOCKED]
>>> psm0: model Elantech Touchpad, device ID 0
>>> ===
>>>
>>> and all expected touchpad features (multi-tap gestures and scrolling,
>>> whatsoever) started to function properly under xorg+evdev. I'm happy
>>> with a touchpad now however trackpoint stopped to work. In particular
>>> attempt to use trackpoint causes strange flickering of the mice
>>> cursor (which lasts few fractions of the second) after which cursor
>>> jumps to the left-upper corner of the screen and it's impossible to
>>> move it (via trackpoint) anymore (though swiping touchpad surface
>>> moves cursor as expected). Also I found in Xorg.log messages emerging
>>> when a palm touches the surface of a touchpad:
> Andrey, please fill bugzilla PR and send me link to it. I believe
> Elantech's trackpoint support has never been tested yet.
>
Hi Andrey,
Could you try attached patch? It is only compile-tested.
[-- Attachment #2 --]
commit 3260a1a8ffc4af7a70296496860940436a93e9c4
Author: Vladimir Kondratyev <vladimir@kondratyev.su>
Date: Sun Jun 2 12:37:43 2019 +0300
psm(4): Add extra sanity checks to Elantech trackpoint support
diff --git a/sys/dev/atkbdc/psm.c b/sys/dev/atkbdc/psm.c
index 5da0c3f666d4..1f253c15d156 100644
--- a/sys/dev/atkbdc/psm.c
+++ b/sys/dev/atkbdc/psm.c
@@ -4640,22 +4640,34 @@ proc_elantech(struct psm_softc *sc, packetbuf_t *pb, mousestatus_t *ms,
* over 9 bits with SX/SY the relative top bit and
* X7..X0 and Y7..Y0 the lower bits.
*/
- *x = (pb->ipacket[0] & 0x20) ?
- pb->ipacket[4] - 256 : pb->ipacket[4];
- *y = (pb->ipacket[0] & 0x10) ?
- pb->ipacket[5] - 256 : pb->ipacket[5];
- trackpoint_button =
- ((pb->ipacket[0] & 0x01) ? MOUSE_BUTTON1DOWN : 0) |
- ((pb->ipacket[0] & 0x02) ? MOUSE_BUTTON3DOWN : 0) |
- ((pb->ipacket[0] & 0x04) ? MOUSE_BUTTON2DOWN : 0);
+ /* Check zeros for presence and sign bits for equality */
+ if (!(pb->ipacket[0] & 0xC8) && !(pb->ipacket[1] & 0x7F) &&
+ !(pb->ipacket[2] & 0x7F) && !(pb->ipacket[3] & 0xC9) &&
+ !(pb->ipacket[0] & 0x20) != !(pb->ipacket[1] & 0x80) &&
+ !(pb->ipacket[0] & 0x20) != !(pb->ipacket[3] & 0x10) &&
+ !(pb->ipacket[0] & 0x10) != !(pb->ipacket[2] & 0x80) &&
+ !(pb->ipacket[0] & 0x10) != !(pb->ipacket[3] & 0x20)) {
+
+ *x = (pb->ipacket[0] & 0x20) ?
+ pb->ipacket[4] - 256 : pb->ipacket[4];
+ *y = (pb->ipacket[0] & 0x10) ?
+ pb->ipacket[5] - 256 : pb->ipacket[5];
+
+ trackpoint_button =
+ ((pb->ipacket[0] & 0x01) ? MOUSE_BUTTON1DOWN : 0) |
+ ((pb->ipacket[0] & 0x02) ? MOUSE_BUTTON3DOWN : 0) |
+ ((pb->ipacket[0] & 0x04) ? MOUSE_BUTTON2DOWN : 0);
#ifdef EVDEV_SUPPORT
- evdev_push_rel(sc->evdev_r, REL_X, *x);
- evdev_push_rel(sc->evdev_r, REL_Y, -*y);
- evdev_push_mouse_btn(sc->evdev_r, trackpoint_button);
- evdev_sync(sc->evdev_r);
+ evdev_push_rel(sc->evdev_r, REL_X, *x);
+ evdev_push_rel(sc->evdev_r, REL_Y, -*y);
+ evdev_push_mouse_btn(sc->evdev_r, trackpoint_button);
+ evdev_sync(sc->evdev_r);
#endif
- ms->button = touchpad_button | trackpoint_button;
+ ms->button = touchpad_button | trackpoint_button;
+ } else
+ VLOG(3, (LOG_DEBUG, "elantech: "
+ "unexpected trackpoint packet skipped\n"));
return (0);
case ELANTECH_PKT_NOP:
home |
help
Want to link to this message? Use this
URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?de2f55b6-fd86-194a-f431-8b2b775f1b11>
