evdev: query position ranges for MT, too
authorPekka Paalanen <ppaalanen@gmail.com>
Tue, 31 Jul 2012 10:21:07 +0000 (13:21 +0300)
committerJonas Ådahl <jadahl@gmail.com>
Sun, 10 Nov 2013 16:51:29 +0000 (17:51 +0100)
For a true multi-touch input device, the code ended up using
uninitialised fields of evdev_input_device::abs.

Fix it by querying the corresponding MT ranges.

Signed-off-by: Pekka Paalanen <ppaalanen@gmail.com>
src/evdev.c

index 62f1bc1f5975825084154316d049f6396b0897d5..c294a3ae7184f600789761dca5c05b6350acff0c 100644 (file)
@@ -400,6 +400,14 @@ evdev_configure_device(struct evdev_input_device *device)
                        device->caps |= EVDEV_MOTION_ABS;
                }
                if (TEST_BIT(abs_bits, ABS_MT_SLOT)) {
+                       ioctl(device->fd, EVIOCGABS(ABS_MT_POSITION_X),
+                             &absinfo);
+                       device->abs.min_x = absinfo.minimum;
+                       device->abs.max_x = absinfo.maximum;
+                       ioctl(device->fd, EVIOCGABS(ABS_MT_POSITION_Y),
+                             &absinfo);
+                       device->abs.min_y = absinfo.minimum;
+                       device->abs.max_y = absinfo.maximum;
                        device->is_mt = 1;
                        device->mt.slot = 0;
                        device->caps |= EVDEV_TOUCH;