[PATCH weston v2] evdev: check for ABS_MT_POSITION_X/Y to determine mt devices
Kristian Høgsberg
hoegsberg at gmail.com
Thu Aug 8 13:44:48 PDT 2013
On Thu, Aug 08, 2013 at 12:03:08PM +1000, Peter Hutterer wrote:
> mtdev as currently used in weston is a noop. mtdev's purpose is to convert
> Protocol A devices (without ABS_MT_SLOT) to Protocol B devices (slots).
> For Protocol B devices mtdev merely routes the events, so checking for
> slots and then using mtdev based on that adds no functionality.
>
> Check for ABS_MT_POSITION_X/Y instead and use that to categorise a device
> as MT device. mtdev will provide us with a slotted protocol for all devices.
Ah, ok, makes sense. This should also fix
https://bugs.freedesktop.org/show_bug.cgi?id=54428
Committed, thanks.
Kristian
> ---
> Changes to v1:
> - comment added
>
> src/evdev.c | 6 +++++-
> 1 file changed, 5 insertions(+), 1 deletion(-)
>
> diff --git a/src/evdev.c b/src/evdev.c
> index b1a4b8c..c05bb78 100644
> --- a/src/evdev.c
> +++ b/src/evdev.c
> @@ -455,7 +455,11 @@ evdev_handle_device(struct evdev_device *device)
> device->abs.max_y = absinfo.maximum;
> device->caps |= EVDEV_MOTION_ABS;
> }
> - if (TEST_BIT(abs_bits, ABS_MT_SLOT)) {
> + /* We only handle the slotted Protocol B in weston.
> + Devices with ABS_MT_POSITION_* but not ABS_MT_SLOT
> + require mtdev for conversion. */
> + if (TEST_BIT(abs_bits, ABS_MT_POSITION_X) &&
> + TEST_BIT(abs_bits, ABS_MT_POSITION_Y)) {
> ioctl(device->fd, EVIOCGABS(ABS_MT_POSITION_X),
> &absinfo);
> device->abs.min_x = absinfo.minimum;
> --
> 1.8.2.1
>
> _______________________________________________
> wayland-devel mailing list
> wayland-devel at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/wayland-devel
More information about the wayland-devel
mailing list