mirror of
https://gitlab.freedesktop.org/libinput/libinput.git
synced 2026-03-25 17:40:53 +01:00
Compare commits
16 commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
f42b8dd1ae | ||
|
|
4813e63f79 | ||
|
|
26c65758e9 | ||
|
|
a3103ded82 | ||
|
|
b8d79df696 | ||
|
|
eea702e30a | ||
|
|
0cfe00f493 | ||
|
|
0d3d885a1a | ||
|
|
6df5169229 | ||
|
|
4f2f1d29ec | ||
|
|
4c1862c1e4 | ||
|
|
a49826a7a8 | ||
|
|
f905054b5b | ||
|
|
b8f90d074e | ||
|
|
7624497df5 | ||
|
|
1ca2f11524 |
13 changed files with 184 additions and 11 deletions
|
|
@ -163,12 +163,35 @@ __all_seats()
|
||||||
':device:_files -W /dev/input/ -P /dev/input/'
|
':device:_files -W /dev/input/ -P /dev/input/'
|
||||||
}
|
}
|
||||||
|
|
||||||
|
(( $+functions[_libinput_analyze_per-slot-delta] )) || _libinput_analyze_per-slot-delta()
|
||||||
|
{
|
||||||
|
_arguments \
|
||||||
|
'--help[Show help message and exit]' \
|
||||||
|
':recording:_files'
|
||||||
|
}
|
||||||
|
|
||||||
|
(( $+functions[_libinput_analyze_touch-down-state] )) || _libinput_analyze_touch-down-state()
|
||||||
|
{
|
||||||
|
_arguments \
|
||||||
|
'--help[Show help message and exit]' \
|
||||||
|
':recording:_files'
|
||||||
|
}
|
||||||
|
|
||||||
|
(( $+functions[_libinput_analyze_recording] )) || _libinput_analyze_recording()
|
||||||
|
{
|
||||||
|
_arguments \
|
||||||
|
'--help[Show help message and exit]' \
|
||||||
|
':recording:_files'
|
||||||
|
}
|
||||||
|
|
||||||
(( $+functions[_libinput_analyze] )) || _libinput_analyze()
|
(( $+functions[_libinput_analyze] )) || _libinput_analyze()
|
||||||
{
|
{
|
||||||
local curcontext=$curcontext state line ret=1
|
local curcontext=$curcontext state line ret=1
|
||||||
local features
|
local features
|
||||||
features=(
|
features=(
|
||||||
"per-slot-delta:analyze relative movement per touch per slot"
|
"per-slot-delta:analyze relative movement per touch per slot"
|
||||||
|
"recording:analyze a recording by printing a pretty table"
|
||||||
|
"touch-down-state:analyze a recording for logical touch down states"
|
||||||
)
|
)
|
||||||
|
|
||||||
_arguments -C \
|
_arguments -C \
|
||||||
|
|
|
||||||
|
|
@ -27,6 +27,11 @@ libinput applies a dpi-dependent acceleration function. At low speeds, a
|
||||||
movement speed increases, acceleration is applied - at high speeds a low-dpi
|
movement speed increases, acceleration is applied - at high speeds a low-dpi
|
||||||
device will roughly feel the same as a higher-dpi mouse.
|
device will roughly feel the same as a higher-dpi mouse.
|
||||||
|
|
||||||
|
The reason for the normalization is convenience: a caller can assume that a
|
||||||
|
delta of 1 should result in a movement of 1 pixel on a traditional
|
||||||
|
(low-dpi) screen. On screens with high resolutions, the caller must scale
|
||||||
|
according to the UI scale factors.
|
||||||
|
|
||||||
This normalization only applies to accelerated coordinates, unaccelerated
|
This normalization only applies to accelerated coordinates, unaccelerated
|
||||||
coordinates are left in device-units. It is up to the caller to interpret
|
coordinates are left in device-units. It is up to the caller to interpret
|
||||||
those coordinates correctly.
|
those coordinates correctly.
|
||||||
|
|
|
||||||
|
|
@ -1,5 +1,5 @@
|
||||||
project('libinput', 'c',
|
project('libinput', 'c',
|
||||||
version : '1.17.0',
|
version : '1.17.2',
|
||||||
license : 'MIT/Expat',
|
license : 'MIT/Expat',
|
||||||
default_options : [ 'c_std=gnu99', 'warning_level=2' ],
|
default_options : [ 'c_std=gnu99', 'warning_level=2' ],
|
||||||
meson_version : '>= 0.47.0')
|
meson_version : '>= 0.47.0')
|
||||||
|
|
|
||||||
|
|
@ -14,6 +14,13 @@ MatchVendor=0x1532
|
||||||
MatchProduct=0x0233
|
MatchProduct=0x0233
|
||||||
AttrKeyboardIntegration=internal
|
AttrKeyboardIntegration=internal
|
||||||
|
|
||||||
|
[Razer Blade Stealth Keyboard]
|
||||||
|
MatchUdevType=keyboard
|
||||||
|
MatchBus=usb
|
||||||
|
MatchVendor=0x1532
|
||||||
|
MatchProduct=0x0252
|
||||||
|
AttrKeyboardIntegration=internal
|
||||||
|
|
||||||
[Razer Blade Lid Switch]
|
[Razer Blade Lid Switch]
|
||||||
MatchName=*Lid Switch*
|
MatchName=*Lid Switch*
|
||||||
MatchDMIModalias=dmi:*svnRazer:pnBlade*
|
MatchDMIModalias=dmi:*svnRazer:pnBlade*
|
||||||
|
|
|
||||||
|
|
@ -27,6 +27,12 @@ AttrTouchSizeRange=150:130
|
||||||
MatchName=*Apple Inc. Apple Internal Keyboard*
|
MatchName=*Apple Inc. Apple Internal Keyboard*
|
||||||
AttrKeyboardIntegration=internal
|
AttrKeyboardIntegration=internal
|
||||||
|
|
||||||
|
[Apple Internal Keyboard (SPI)]
|
||||||
|
MatchUdevType=keyboard
|
||||||
|
MatchBus=spi
|
||||||
|
MatchVendor=0x5AC
|
||||||
|
AttrKeyboardIntegration=internal
|
||||||
|
|
||||||
# The Apple MagicMouse has a touchpad built-in but the kernel still
|
# The Apple MagicMouse has a touchpad built-in but the kernel still
|
||||||
# emulates a full 2/3 button mouse for us. Ignore anything from the
|
# emulates a full 2/3 button mouse for us. Ignore anything from the
|
||||||
# ABS interface
|
# ABS interface
|
||||||
|
|
@ -89,3 +95,22 @@ MatchBus=usb
|
||||||
MatchVendor=0x5AC
|
MatchVendor=0x5AC
|
||||||
MatchProduct=0x0262
|
MatchProduct=0x0262
|
||||||
AttrPalmSizeThreshold=1600
|
AttrPalmSizeThreshold=1600
|
||||||
|
|
||||||
|
[Apple Laptop Touchpad (SPI)]
|
||||||
|
MatchUdevType=touchpad
|
||||||
|
MatchBus=spi
|
||||||
|
MatchVendor=0x5AC
|
||||||
|
ModelAppleTouchpad=1
|
||||||
|
AttrSizeHint=104x75
|
||||||
|
AttrTouchSizeRange=150:130
|
||||||
|
AttrPalmSizeThreshold=1600
|
||||||
|
|
||||||
|
# The Linux applespi driver currently uses the Synaptics vendor for some reason
|
||||||
|
[Apple Laptop Touchpad (SPI)]
|
||||||
|
MatchUdevType=touchpad
|
||||||
|
MatchBus=spi
|
||||||
|
MatchVendor=0x6CB
|
||||||
|
ModelAppleTouchpad=1
|
||||||
|
AttrSizeHint=104x75
|
||||||
|
AttrTouchSizeRange=150:130
|
||||||
|
AttrPalmSizeThreshold=1600
|
||||||
|
|
|
||||||
|
|
@ -82,6 +82,12 @@ MatchName=*DualPoint Stick
|
||||||
MatchDMIModalias=dmi:*svnDellInc.:pnLatitudeE7470*
|
MatchDMIModalias=dmi:*svnDellInc.:pnLatitudeE7470*
|
||||||
AttrTrackpointMultiplier=0.125
|
AttrTrackpointMultiplier=0.125
|
||||||
|
|
||||||
|
[Latitude 7490 Trackpoint]
|
||||||
|
MatchName=*Mouse
|
||||||
|
MatchUdevType=pointingstick
|
||||||
|
MatchDMIModalias=dmi:**bvnDellInc.:*:pnLatitude7490*
|
||||||
|
AttrTrackpointMultiplier=0.3
|
||||||
|
|
||||||
[Precision 7x50 Touchpad]
|
[Precision 7x50 Touchpad]
|
||||||
MatchBus=i2c
|
MatchBus=i2c
|
||||||
MatchUdevType=touchpad
|
MatchUdevType=touchpad
|
||||||
|
|
|
||||||
5
quirks/50-system-gigabyte.quirks
Normal file
5
quirks/50-system-gigabyte.quirks
Normal file
|
|
@ -0,0 +1,5 @@
|
||||||
|
[Gigabyte Aero 15 touchpad]
|
||||||
|
MatchUdevType=touchpad
|
||||||
|
MatchName=ETPS/2 Elantech Touchpad
|
||||||
|
MatchDMIModalias=dmi:*svnGIGABYTE:pnAERO15-XA*
|
||||||
|
AttrPalmSizeThreshold=800
|
||||||
|
|
@ -89,7 +89,7 @@ ModelChromebook=1
|
||||||
|
|
||||||
[Google Chromebook Eve]
|
[Google Chromebook Eve]
|
||||||
MatchUdevType=touchpad
|
MatchUdevType=touchpad
|
||||||
MatchName=ACPI0C50:00 18D1:5028
|
MatchName=ACPI0C50:00 18D1:5028*
|
||||||
MatchDMIModalias=dmi:*svnGoogle:pnEve*
|
MatchDMIModalias=dmi:*svnGoogle:pnEve*
|
||||||
ModelChromebook=1
|
ModelChromebook=1
|
||||||
AttrPressureRange=6:4
|
AttrPressureRange=6:4
|
||||||
|
|
|
||||||
|
|
@ -22,7 +22,7 @@ ModelHPPavilionDM4Touchpad=1
|
||||||
# Touchpad is a clickpad but INPUT_PROP_BUTTONPAD is not set, see
|
# Touchpad is a clickpad but INPUT_PROP_BUTTONPAD is not set, see
|
||||||
# https://bugs.freedesktop.org/show_bug.cgi?id=97147
|
# https://bugs.freedesktop.org/show_bug.cgi?id=97147
|
||||||
[HP Stream 11]
|
[HP Stream 11]
|
||||||
MatchName=SYN1EDE:00 06CB:7442
|
MatchName=SYN1EDE:00 06CB:7442*
|
||||||
MatchDMIModalias=dmi:*svnHewlett-Packard:pnHPStreamNotebookPC11*
|
MatchDMIModalias=dmi:*svnHewlett-Packard:pnHPStreamNotebookPC11*
|
||||||
AttrInputPropEnable=INPUT_PROP_BUTTONPAD
|
AttrInputPropEnable=INPUT_PROP_BUTTONPAD
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -205,3 +205,28 @@ ModelTabletModeNoSuspend=1
|
||||||
MatchName=AT Raw Set 2 keyboard
|
MatchName=AT Raw Set 2 keyboard
|
||||||
MatchDMIModalias=dmi:*svnLENOVO:*pvrThinkPadX1Tablet:*
|
MatchDMIModalias=dmi:*svnLENOVO:*pvrThinkPadX1Tablet:*
|
||||||
ModelTabletModeNoSuspend=1
|
ModelTabletModeNoSuspend=1
|
||||||
|
|
||||||
|
# Misidentified as an external keyboard by libinput
|
||||||
|
# Tested on Legion 5 15AR05H
|
||||||
|
[Lenovo Legion 5 Keyboard]
|
||||||
|
MatchUdevType=keyboard
|
||||||
|
MatchBus=usb
|
||||||
|
MatchVendor=0x048D
|
||||||
|
MatchProduct=0xC100
|
||||||
|
AttrKeyboardIntegration=internal
|
||||||
|
|
||||||
|
[Lenovo Legion 5 Keyboard]
|
||||||
|
MatchUdevType=keyboard
|
||||||
|
MatchBus=usb
|
||||||
|
MatchVendor=0x048D
|
||||||
|
MatchProduct=0xC955
|
||||||
|
AttrKeyboardIntegration=internal
|
||||||
|
|
||||||
|
# https://gitlab.freedesktop.org/libinput/libinput/-/issues/604
|
||||||
|
[Lenovo Yoga Slim 9 14ITL5 Pressurepad]
|
||||||
|
MatchBus=i2c
|
||||||
|
MatchVendor=0x27C6
|
||||||
|
MatchProduct=0x01E8
|
||||||
|
AttrEventCodeDisable=ABS_MT_PRESSURE;ABS_PRESSURE;
|
||||||
|
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -132,7 +132,7 @@ pad_led_new(struct libinput *libinput, const char *prefix, int group, int mode)
|
||||||
if (rc == -1)
|
if (rc == -1)
|
||||||
goto error;
|
goto error;
|
||||||
|
|
||||||
fd = open_restricted(libinput, path, O_RDONLY);
|
fd = open_restricted(libinput, path, O_RDONLY | O_NONBLOCK | O_CLOEXEC);
|
||||||
if (fd < 0) {
|
if (fd < 0) {
|
||||||
errno = -fd;
|
errno = -fd;
|
||||||
goto error;
|
goto error;
|
||||||
|
|
|
||||||
|
|
@ -1024,6 +1024,7 @@ evdev_note_time_delay(struct evdev_device *device,
|
||||||
{
|
{
|
||||||
struct libinput *libinput = evdev_libinput_context(device);
|
struct libinput *libinput = evdev_libinput_context(device);
|
||||||
uint32_t tdelta;
|
uint32_t tdelta;
|
||||||
|
uint64_t eventtime = input_event_time(ev);
|
||||||
|
|
||||||
/* if we have a current libinput_dispatch() snapshot, compare our
|
/* if we have a current libinput_dispatch() snapshot, compare our
|
||||||
* event time with the one from the snapshot. If we have more than
|
* event time with the one from the snapshot. If we have more than
|
||||||
|
|
@ -1031,10 +1032,11 @@ evdev_note_time_delay(struct evdev_device *device,
|
||||||
* where there is no steady event flow and thus SYN_DROPPED may not
|
* where there is no steady event flow and thus SYN_DROPPED may not
|
||||||
* get hit by the kernel despite us being too slow.
|
* get hit by the kernel despite us being too slow.
|
||||||
*/
|
*/
|
||||||
if (libinput->dispatch_time == 0)
|
if (libinput->dispatch_time == 0 ||
|
||||||
|
eventtime > libinput->dispatch_time)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
tdelta = us2ms(libinput->dispatch_time - input_event_time(ev));
|
tdelta = us2ms(libinput->dispatch_time - eventtime);
|
||||||
if (tdelta > 10) {
|
if (tdelta > 10) {
|
||||||
evdev_log_bug_client_ratelimit(device,
|
evdev_log_bug_client_ratelimit(device,
|
||||||
&device->delay_warning_limit,
|
&device->delay_warning_limit,
|
||||||
|
|
|
||||||
85
src/quirks.c
85
src/quirks.c
|
|
@ -35,6 +35,9 @@
|
||||||
#include <dirent.h>
|
#include <dirent.h>
|
||||||
#include <fnmatch.h>
|
#include <fnmatch.h>
|
||||||
#include <libgen.h>
|
#include <libgen.h>
|
||||||
|
#ifdef __FreeBSD__
|
||||||
|
#include <kenv.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "libinput-versionsort.h"
|
#include "libinput-versionsort.h"
|
||||||
#include "libinput-util.h"
|
#include "libinput-util.h"
|
||||||
|
|
@ -111,6 +114,7 @@ enum bustype {
|
||||||
BT_PS2,
|
BT_PS2,
|
||||||
BT_RMI,
|
BT_RMI,
|
||||||
BT_I2C,
|
BT_I2C,
|
||||||
|
BT_SPI,
|
||||||
};
|
};
|
||||||
|
|
||||||
enum udev_type {
|
enum udev_type {
|
||||||
|
|
@ -352,10 +356,11 @@ property_cleanup(struct property *p)
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return the dmi modalias from the udev device.
|
* Return the system DMI info in modalias format.
|
||||||
*/
|
*/
|
||||||
|
#ifdef __linux__
|
||||||
static inline char *
|
static inline char *
|
||||||
init_dmi(void)
|
init_dmi_linux(void)
|
||||||
{
|
{
|
||||||
struct udev *udev;
|
struct udev *udev;
|
||||||
struct udev_device *udev_device;
|
struct udev_device *udev_device;
|
||||||
|
|
@ -363,9 +368,6 @@ init_dmi(void)
|
||||||
char *copy = NULL;
|
char *copy = NULL;
|
||||||
const char *syspath = "/sys/devices/virtual/dmi/id";
|
const char *syspath = "/sys/devices/virtual/dmi/id";
|
||||||
|
|
||||||
if (getenv("LIBINPUT_RUNNING_TEST_SUITE"))
|
|
||||||
return safe_strdup("dmi:");
|
|
||||||
|
|
||||||
udev = udev_new();
|
udev = udev_new();
|
||||||
if (!udev)
|
if (!udev)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
@ -388,6 +390,73 @@ init_dmi(void)
|
||||||
|
|
||||||
return copy;
|
return copy;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#ifdef __FreeBSD__
|
||||||
|
static inline char *
|
||||||
|
init_dmi_freebsd(void)
|
||||||
|
{
|
||||||
|
#define LEN (KENV_MVALLEN + 1)
|
||||||
|
char *modalias;
|
||||||
|
char bios_vendor[LEN], bios_version[LEN], bios_date[LEN];
|
||||||
|
char sys_vendor[LEN], product_name[LEN], product_version[LEN];
|
||||||
|
char board_vendor[LEN], board_name[LEN], board_version[LEN];
|
||||||
|
char chassis_vendor[LEN], chassis_type[LEN], chassis_version[LEN];
|
||||||
|
int chassis_type_num = 0x2;
|
||||||
|
|
||||||
|
kenv(KENV_GET, "smbios.bios.vendor", bios_vendor, LEN);
|
||||||
|
kenv(KENV_GET, "smbios.bios.version", bios_version, LEN);
|
||||||
|
kenv(KENV_GET, "smbios.bios.reldate", bios_date, LEN);
|
||||||
|
kenv(KENV_GET, "smbios.system.maker", sys_vendor, LEN);
|
||||||
|
kenv(KENV_GET, "smbios.system.product", product_name, LEN);
|
||||||
|
kenv(KENV_GET, "smbios.system.version", product_version, LEN);
|
||||||
|
kenv(KENV_GET, "smbios.planar.maker", board_vendor, LEN);
|
||||||
|
kenv(KENV_GET, "smbios.planar.product", board_name, LEN);
|
||||||
|
kenv(KENV_GET, "smbios.planar.version", board_version, LEN);
|
||||||
|
kenv(KENV_GET, "smbios.chassis.vendor", chassis_vendor, LEN);
|
||||||
|
kenv(KENV_GET, "smbios.chassis.type", chassis_type, LEN);
|
||||||
|
kenv(KENV_GET, "smbios.chassis.version", chassis_version, LEN);
|
||||||
|
#undef LEN
|
||||||
|
|
||||||
|
if (strcmp(chassis_type, "Desktop") == 0)
|
||||||
|
chassis_type_num = 0x3;
|
||||||
|
else if (strcmp(chassis_type, "Portable") == 0)
|
||||||
|
chassis_type_num = 0x8;
|
||||||
|
else if (strcmp(chassis_type, "Laptop") == 0)
|
||||||
|
chassis_type_num = 0x9;
|
||||||
|
else if (strcmp(chassis_type, "Notebook") == 0)
|
||||||
|
chassis_type_num = 0xA;
|
||||||
|
else if (strcmp(chassis_type, "Tablet") == 0)
|
||||||
|
chassis_type_num = 0x1E;
|
||||||
|
else if (strcmp(chassis_type, "Convertible") == 0)
|
||||||
|
chassis_type_num = 0x1F;
|
||||||
|
else if (strcmp(chassis_type, "Detachable") == 0)
|
||||||
|
chassis_type_num = 0x20;
|
||||||
|
|
||||||
|
xasprintf(&modalias,
|
||||||
|
"dmi:bvn%s:bvr%s:bd%s:svn%s:pn%s:pvr%s:rvn%s:rn%s:rvr%s:cvn%s:ct%d:cvr%s:",
|
||||||
|
bios_vendor, bios_version, bios_date, sys_vendor, product_name,
|
||||||
|
product_version, board_vendor, board_name, board_version, chassis_vendor,
|
||||||
|
chassis_type_num, chassis_version);
|
||||||
|
|
||||||
|
return modalias;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
static inline char *
|
||||||
|
init_dmi(void)
|
||||||
|
{
|
||||||
|
if (getenv("LIBINPUT_RUNNING_TEST_SUITE"))
|
||||||
|
return safe_strdup("dmi:");
|
||||||
|
|
||||||
|
#if defined(__linux__)
|
||||||
|
return init_dmi_linux();
|
||||||
|
#elif defined(__FreeBSD__)
|
||||||
|
return init_dmi_freebsd();
|
||||||
|
#else
|
||||||
|
return NULL;
|
||||||
|
#endif
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return the dt compatible string
|
* Return the dt compatible string
|
||||||
|
|
@ -499,6 +568,8 @@ parse_match(struct quirks_context *ctx,
|
||||||
s->match.bus = BT_RMI;
|
s->match.bus = BT_RMI;
|
||||||
else if (streq(value, "i2c"))
|
else if (streq(value, "i2c"))
|
||||||
s->match.bus = BT_I2C;
|
s->match.bus = BT_I2C;
|
||||||
|
else if (streq(value, "spi"))
|
||||||
|
s->match.bus = BT_SPI;
|
||||||
else
|
else
|
||||||
goto out;
|
goto out;
|
||||||
} else if (streq(key, "MatchVendor")) {
|
} else if (streq(key, "MatchVendor")) {
|
||||||
|
|
@ -1241,6 +1312,10 @@ match_fill_bus_vid_pid(struct match *m,
|
||||||
m->bus = BT_I2C;
|
m->bus = BT_I2C;
|
||||||
m->bits |= M_BUS;
|
m->bits |= M_BUS;
|
||||||
break;
|
break;
|
||||||
|
case BUS_SPI:
|
||||||
|
m->bus = BT_SPI;
|
||||||
|
m->bits |= M_BUS;
|
||||||
|
break;
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Add table
Reference in a new issue