mirror of
https://gitlab.freedesktop.org/libinput/libinput.git
synced 2025-12-20 12:40:05 +01:00
Signed-off-by: Eric Engestrom <eric@engestrom.ch> Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net>
104 lines
3.9 KiB
Text
104 lines
3.9 KiB
Text
/**
|
|
@page t440_support Lenovo *40 series touchpad support
|
|
|
|
The Lenovo *40 series emulates trackstick buttons on the top part of the
|
|
touchpads.
|
|
|
|
@section t440_support_overview Overview
|
|
|
|
The Lenovo *40 series introduced a new type of touchpad. Previously, all
|
|
laptops had a separate set of physical buttons for the
|
|
<a href="http://en.wikipedia.org/wiki/Pointing_stick">trackstick</a>. This
|
|
series removed these buttons, relying on a software emulation of the top
|
|
section of the touchpad. This is visually marked on the trackpad itself,
|
|
and clicks can be triggered by pressing the touchpad down with a finger in
|
|
the respective area:
|
|
|
|
@image html top-software-buttons.svg "Left, right and middle-button click with top software button areas"
|
|
|
|
This page only covers the top software buttons, the bottom button behavior
|
|
is covered in @ref clickpad_softbuttons "Clickpad software buttons".
|
|
|
|
Clickpads with a top button area are marked with the <a
|
|
href="https://www.kernel.org/doc/Documentation/input/event-codes.txt">INPUT_PROP_TOPBUTTONPAD</a>
|
|
property.
|
|
|
|
@section t440_support_btn_size Size of the buttons
|
|
|
|
The size of the buttons matches the visual markings on this touchpad.
|
|
The width of the left and right buttons is approximately 42% of the
|
|
touchpad's width, the middle button is centered and assigned 16% of the
|
|
touchpad width.
|
|
|
|
The line of the buttons is 5mm from the top edge of the touchpad,
|
|
measurements of button presses showed that the size of the buttons needs to
|
|
be approximately 10mm high to work reliable (especially when using the
|
|
thumb to press the button).
|
|
|
|
@section t440_support_btn_behavior Button behavior
|
|
|
|
Movement in the top button area does not generate pointer movement. These
|
|
buttons are not replacement buttons for the bottom button area but have
|
|
their own behavior. Semantically attached to the trackstick device, libinput
|
|
re-routes events from these buttons to appear through the trackstick device.
|
|
|
|
@dot
|
|
digraph top_button_routing
|
|
{
|
|
rankdir="LR";
|
|
node [shape="box";]
|
|
|
|
trackstick [label="trackstick kernel device"];
|
|
touchpad [label="touchpad kernel device"];
|
|
|
|
subgraph cluster0 {
|
|
bgcolor = floralwhite
|
|
label = "libinput"
|
|
|
|
libinput_ts [label="trackstick libinput_device"
|
|
style=filled
|
|
fillcolor=white];
|
|
libinput_tp [label="touchpad libinput_device"
|
|
style=filled
|
|
fillcolor=white];
|
|
|
|
libinput_tp -> libinput_ts [constraint=false
|
|
color="red4"];
|
|
}
|
|
|
|
trackstick -> libinput_ts [arrowhead="none"]
|
|
touchpad -> libinput_tp [color="red4"]
|
|
|
|
events_tp [label="other touchpad events"];
|
|
events_topbutton [label="top software button events"];
|
|
|
|
libinput_tp -> events_tp [arrowhead="none"]
|
|
libinput_ts -> events_topbutton [color="red4"]
|
|
}
|
|
@enddot
|
|
|
|
|
|
The top button areas work even if the touchpad is disabled but will be
|
|
disabled when the trackstick device is disabled. If the finger starts inside
|
|
the top area and moves outside the button area the finger is treated as dead
|
|
and must be lifted to generate future buttons. Likewise, movement into the
|
|
top button area does not trigger button events, a click has to start inside
|
|
this area to take effect.
|
|
|
|
@section t440_support_identification Kernel support
|
|
|
|
The firmware on the first generation of touchpads providing top software
|
|
buttons is buggy and announces wrong ranges.
|
|
<a href="https://lkml.org/lkml/2014/3/7/722">Kernel patches</a> are required;
|
|
these fixes are available in kernels 3.14.1, 3.15 and later but each
|
|
touchpad needs a separate fix.
|
|
|
|
The October 2014 refresh of these laptops do not have this firmware bug
|
|
anymore and should work without per-device patches, though
|
|
<a href="http://git.kernel.org/cgit/linux/kernel/git/torvalds/linux.git/commit/?id=02e07492cdfae9c86e3bd21c0beec88dbcc1e9e8">this kernel commit</a> is required.
|
|
|
|
For a complete list of supported touchpads check <a
|
|
href="http://git.kernel.org/cgit/linux/kernel/git/torvalds/linux.git/tree/drivers/input/mouse/synaptics.c">the
|
|
kernel source</a> (search for "topbuttonpad_pnp_ids").
|
|
|
|
*/
|