| Summary: | erratic edge scrolling with ALPS touchpad | ||
|---|---|---|---|
| Product: | Wayland | Reporter: | Brett Kerwin <brett.kerwin> | 
| Component: | libinput | Assignee: | Wayland bug list <wayland-bugs> | 
| Status: | RESOLVED FIXED | QA Contact: | |
| Severity: | normal | ||
| Priority: | medium | CC: | peter.hutterer | 
| Version: | unspecified | ||
| Hardware: | x86-64 (AMD64) | ||
| OS: | Linux (All) | ||
| Whiteboard: | |||
| i915 platform: | i915 features: | ||
| Attachments: | evemu recording when edge scrolling with Xorg+synaptics evemu recording when edge scrolling with Wayland, successful attempt evemu recording when edge scrolling with Wayland, failed attempt | ||
| 
        
          Description
        
        
          Brett Kerwin
        
        
        
        
          2017-01-01 10:32:29 UTC
        
       Created attachment 128699 [details]
evemu recording when edge scrolling with Xorg+synapticsCreated attachment 128700 [details]
evemu recording when edge scrolling with Wayland, successful attemptCreated attachment 128701 [details]
evemu recording when edge scrolling with Wayland, failed attemptlooks like the edges on the touchpad are out. Please run the touchpad-edge-detector tool (part of libevdev) and follow the instructions there. It gives me this: Touchpad AlpsPS/2 ALPS DualPoint TouchPad on /dev/input/event6 Move one finger around the touchpad to detect the actual edges Kernel says: x [0..2000], y [0..1400] Touchpad sends: x [97..1823], y [177..1299] | ^C Touchpad has no resolution, size unknown User-specified touchpad size: 80x40mm Calculated ranges: 1726/1122 Suggested udev rule: # <Laptop model description goes here> evdev:name:AlpsPS/2 ALPS DualPoint TouchPad:dmi:bvnDellInc.:bvrA19:bd11/14/2013:svnDellInc.:pnLatitudeE6320:pvr01:rvnDellInc.:rn0GJF11:rvrA01:cvnDellInc.:ct9:cvr:* EVDEV_ABS_00=97:1823:22 EVDEV_ABS_01=177:1299:28 EVDEV_ABS_35=97:1823:22 EVDEV_ABS_36=177:1299:28 Another time I got this: Touchpad sends: x [73..1806], y [166..1307] if you get different values, run your finger around the touchpad a number of times until the numbers stop changing. There's a clear discrepancy between the announced range and the effective range, that causes your edge scrolling to be too far in the middle to be detected. We don't have to be super precise but getting to the nearest millimeter is necessary. Running the finger around the touchpad until the figures don't change any more does not provide the same values consistently. The maximum/minimum values that I am typically able to obtain after trying really really hard are "x [79..1841], y [140..1325]". Once, I was able to get "x [0..1825], y [102..1320]" but I am completely unable to reproduce this. More generally, to get any value below 80 for the x coordinate, I have to center the finger off the touchpad, so that only the side of the finger brushes the touchpad. Typical values that I get by keeping the finger on the touchpad and going as far as I can (trying hard) in every direction are "x [87..1928], y [166..1316]" or "x [87..1832], y [170..1311]". I've just done this twice and the figures come out different, after stabilizing; that's how it is. ok, let's go with the typical data in comment 7. PR submitted to systemd https://github.com/systemd/systemd/pull/5022 Until this ends up in your distro you'll need a local override. The top of 60-evdev.hwdb has instructions on how to do this. See also https://wayland.freedesktop.org/libinput/doc/latest/faq.html#faq_hwdb_changes I'm closing this as fixed in the hope that it resolves the issue. Please re-open if the ranges don't get applied correctly (typo or something) or if the scrolling is still eratic afterwards. Though in the latter case it's probably better if you just open a new bug and indicate there that we already fixed the ranges here. I confirm this solves the problem with Wayland, thank you, though of course it breaks the currently correct behaviour of Xorg+synaptics, which probably had a specific workaround in its source code. It would make sense to locate this workaround and to see if there are other similar workarounds in the same place, instead of having to rediscover them on a case-by-case basis. synaptics should detect this model as alps and pick the right-most 15%. That's probably larger than what libinput picks, so I'm surprised it's broken now. In fact, I meant "broken" in the sense that the scrolling area seemed abnormally large. It may be somewhat larger than 15%, but if 15% is the normal area, I was probably just being biased by the habit of broken kernel values anyway, sorry. | 
Use of freedesktop.org services, including Bugzilla, is subject to our Code of Conduct. How we collect and use information is described in our Privacy Policy.