evdev: init pointer acceleration for any device with pointer cap and rel x/y
authorPeter Hutterer <peter.hutterer@who-t.net>
Tue, 27 Oct 2015 23:13:24 +0000 (09:13 +1000)
committerPeter Hutterer <peter.hutterer@who-t.net>
Fri, 30 Oct 2015 01:18:18 +0000 (11:18 +1000)
The Asus RoG Gladius exposes two event nodes, one mouse, one keyboard. The
keyboard node has REL_X/Y and REL_HWHEEL on top of the various key bits and
ABS_VOLUME.

The keyboard node does not have BTN_* set, udev tags this device as a
keyboard only, not as a pointer but we still initialize the pointer caps for
it because of the wheel.

When moving this mouse, some deltas (ca "1 in every 20") are sent through the
keyboard node, causing a crash because we never initialized pointer
acceleration.

https://bugzilla.redhat.com/show_bug.cgi?id=1275407

Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net>
Reviewed-by: Hans de Goede <hdegoede@redhat.com>
src/evdev.c
test/Makefile.am
test/litest-device-asus-rog-gladius.c [new file with mode: 0644]
test/litest.c
test/litest.h

index ba1b56892c7e68b83c437d860881368568ad3165..ec3abc6c403d3e5267aa1fc101a2fd5f00284c11 100644 (file)
@@ -2062,11 +2062,6 @@ evdev_configure_device(struct evdev_device *device)
                evdev_tag_trackpoint(device, device->udev_device);
                device->dpi = evdev_read_dpi_prop(device);
 
-               if (libevdev_has_event_code(evdev, EV_REL, REL_X) &&
-                   libevdev_has_event_code(evdev, EV_REL, REL_Y) &&
-                   evdev_init_accel(device, LIBINPUT_CONFIG_ACCEL_PROFILE_ADAPTIVE) == -1)
-                       return -1;
-
                device->seat_caps |= EVDEV_DEVICE_POINTER;
 
                log_info(libinput,
@@ -2104,6 +2099,16 @@ evdev_configure_device(struct evdev_device *device)
                         device->devname, devnode);
        }
 
+       if (device->seat_caps & EVDEV_DEVICE_POINTER &&
+           libevdev_has_event_code(evdev, EV_REL, REL_X) &&
+           libevdev_has_event_code(evdev, EV_REL, REL_Y) &&
+           evdev_init_accel(device, LIBINPUT_CONFIG_ACCEL_PROFILE_ADAPTIVE) == -1) {
+               log_error(libinput,
+                         "failed to initialize pointer acceleration for %s\n",
+                         device->devname);
+               return -1;
+       }
+
        return 0;
 }
 
index cde93b36d31f2461c026ba9378a267290a4f4cd2..ff1acdad348153c36833ea68c9f7d5c2595185f9 100644 (file)
@@ -15,6 +15,7 @@ liblitest_la_SOURCES = \
        litest-int.h \
        litest-device-alps-semi-mt.c \
        litest-device-alps-dualpoint.c \
+       litest-device-asus-rog-gladius.c \
        litest-device-atmel-hover.c \
        litest-device-bcm5974.c \
        litest-device-elantech-touchpad.c \
diff --git a/test/litest-device-asus-rog-gladius.c b/test/litest-device-asus-rog-gladius.c
new file mode 100644 (file)
index 0000000..a44396f
--- /dev/null
@@ -0,0 +1,334 @@
+/*
+ * Copyright © 2015 Red Hat, Inc.
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a
+ * copy of this software and associated documentation files (the "Software"),
+ * to deal in the Software without restriction, including without limitation
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ * and/or sell copies of the Software, and to permit persons to whom the
+ * Software is furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice (including the next
+ * paragraph) shall be included in all copies or substantial portions of the
+ * Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
+ * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+ * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
+ * DEALINGS IN THE SOFTWARE.
+ */
+
+#if HAVE_CONFIG_H
+#include "config.h"
+#endif
+
+#include "litest.h"
+#include "litest-int.h"
+
+/* Note: this is the second event node of this mouse only, the first event
+ * node is just a normal mouse */
+
+static void litest_mouse_gladius_setup(void)
+{
+       struct litest_device *d = litest_create_device(LITEST_MOUSE_GLADIUS);
+       litest_set_current_device(d);
+}
+
+static struct input_id input_id = {
+       .bustype = 0x3,
+       .vendor = 0x0b05,
+       .product = 0x181a,
+};
+
+static int events[] = {
+       EV_REL, REL_X,
+       EV_REL, REL_Y,
+       EV_REL, REL_HWHEEL,
+       EV_KEY, KEY_ESC,
+       EV_KEY, KEY_1,
+       EV_KEY, KEY_2,
+       EV_KEY, KEY_3,
+       EV_KEY, KEY_4,
+       EV_KEY, KEY_5,
+       EV_KEY, KEY_6,
+       EV_KEY, KEY_7,
+       EV_KEY, KEY_8,
+       EV_KEY, KEY_9,
+       EV_KEY, KEY_0,
+       EV_KEY, KEY_MINUS,
+       EV_KEY, KEY_EQUAL,
+       EV_KEY, KEY_BACKSPACE,
+       EV_KEY, KEY_TAB,
+       EV_KEY, KEY_Q,
+       EV_KEY, KEY_W,
+       EV_KEY, KEY_E,
+       EV_KEY, KEY_R,
+       EV_KEY, KEY_T,
+       EV_KEY, KEY_Y,
+       EV_KEY, KEY_U,
+       EV_KEY, KEY_I,
+       EV_KEY, KEY_O,
+       EV_KEY, KEY_P,
+       EV_KEY, KEY_LEFTBRACE,
+       EV_KEY, KEY_RIGHTBRACE,
+       EV_KEY, KEY_ENTER,
+       EV_KEY, KEY_LEFTCTRL,
+       EV_KEY, KEY_A,
+       EV_KEY, KEY_S,
+       EV_KEY, KEY_D,
+       EV_KEY, KEY_F,
+       EV_KEY, KEY_G,
+       EV_KEY, KEY_H,
+       EV_KEY, KEY_J,
+       EV_KEY, KEY_K,
+       EV_KEY, KEY_L,
+       EV_KEY, KEY_SEMICOLON,
+       EV_KEY, KEY_APOSTROPHE,
+       EV_KEY, KEY_GRAVE,
+       EV_KEY, KEY_LEFTSHIFT,
+       EV_KEY, KEY_BACKSLASH,
+       EV_KEY, KEY_Z,
+       EV_KEY, KEY_X,
+       EV_KEY, KEY_C,
+       EV_KEY, KEY_V,
+       EV_KEY, KEY_B,
+       EV_KEY, KEY_N,
+       EV_KEY, KEY_M,
+       EV_KEY, KEY_COMMA,
+       EV_KEY, KEY_DOT,
+       EV_KEY, KEY_SLASH,
+       EV_KEY, KEY_RIGHTSHIFT,
+       EV_KEY, KEY_KPASTERISK,
+       EV_KEY, KEY_LEFTALT,
+       EV_KEY, KEY_SPACE,
+       EV_KEY, KEY_CAPSLOCK,
+       EV_KEY, KEY_F1,
+       EV_KEY, KEY_F2,
+       EV_KEY, KEY_F3,
+       EV_KEY, KEY_F4,
+       EV_KEY, KEY_F5,
+       EV_KEY, KEY_F6,
+       EV_KEY, KEY_F7,
+       EV_KEY, KEY_F8,
+       EV_KEY, KEY_F9,
+       EV_KEY, KEY_F10,
+       EV_KEY, KEY_NUMLOCK,
+       EV_KEY, KEY_SCROLLLOCK,
+       EV_KEY, KEY_KP7,
+       EV_KEY, KEY_KP8,
+       EV_KEY, KEY_KP9,
+       EV_KEY, KEY_KPMINUS,
+       EV_KEY, KEY_KP4,
+       EV_KEY, KEY_KP5,
+       EV_KEY, KEY_KP6,
+       EV_KEY, KEY_KPPLUS,
+       EV_KEY, KEY_KP1,
+       EV_KEY, KEY_KP2,
+       EV_KEY, KEY_KP3,
+       EV_KEY, KEY_KP0,
+       EV_KEY, KEY_KPDOT,
+       EV_KEY, KEY_ZENKAKUHANKAKU,
+       EV_KEY, KEY_102ND,
+       EV_KEY, KEY_F11,
+       EV_KEY, KEY_F12,
+       EV_KEY, KEY_RO,
+       EV_KEY, KEY_KATAKANA,
+       EV_KEY, KEY_HIRAGANA,
+       EV_KEY, KEY_HENKAN,
+       EV_KEY, KEY_KATAKANAHIRAGANA,
+       EV_KEY, KEY_MUHENKAN,
+       EV_KEY, KEY_KPJPCOMMA,
+       EV_KEY, KEY_KPENTER,
+       EV_KEY, KEY_RIGHTCTRL,
+       EV_KEY, KEY_KPSLASH,
+       EV_KEY, KEY_SYSRQ,
+       EV_KEY, KEY_RIGHTALT,
+       EV_KEY, KEY_HOME,
+       EV_KEY, KEY_UP,
+       EV_KEY, KEY_PAGEUP,
+       EV_KEY, KEY_LEFT,
+       EV_KEY, KEY_RIGHT,
+       EV_KEY, KEY_END,
+       EV_KEY, KEY_DOWN,
+       EV_KEY, KEY_PAGEDOWN,
+       EV_KEY, KEY_INSERT,
+       EV_KEY, KEY_DELETE,
+       EV_KEY, KEY_MUTE,
+       EV_KEY, KEY_VOLUMEDOWN,
+       EV_KEY, KEY_VOLUMEUP,
+       EV_KEY, KEY_POWER,
+       EV_KEY, KEY_KPEQUAL,
+       EV_KEY, KEY_PAUSE,
+       EV_KEY, KEY_KPCOMMA,
+       EV_KEY, KEY_HANGEUL,
+       EV_KEY, KEY_HANJA,
+       EV_KEY, KEY_YEN,
+       EV_KEY, KEY_LEFTMETA,
+       EV_KEY, KEY_RIGHTMETA,
+       EV_KEY, KEY_COMPOSE,
+       EV_KEY, KEY_STOP,
+       EV_KEY, KEY_AGAIN,
+       EV_KEY, KEY_PROPS,
+       EV_KEY, KEY_UNDO,
+       EV_KEY, KEY_FRONT,
+       EV_KEY, KEY_COPY,
+       EV_KEY, KEY_OPEN,
+       EV_KEY, KEY_PASTE,
+       EV_KEY, KEY_FIND,
+       EV_KEY, KEY_CUT,
+       EV_KEY, KEY_HELP,
+       EV_KEY, KEY_MENU,
+       EV_KEY, KEY_CALC,
+       EV_KEY, KEY_SLEEP,
+       EV_KEY, KEY_FILE,
+       EV_KEY, KEY_WWW,
+       EV_KEY, KEY_COFFEE,
+       EV_KEY, KEY_MAIL,
+       EV_KEY, KEY_BOOKMARKS,
+       EV_KEY, KEY_BACK,
+       EV_KEY, KEY_FORWARD,
+       EV_KEY, KEY_EJECTCD,
+       EV_KEY, KEY_NEXTSONG,
+       EV_KEY, KEY_PLAYPAUSE,
+       EV_KEY, KEY_PREVIOUSSONG,
+       EV_KEY, KEY_STOPCD,
+       EV_KEY, KEY_RECORD,
+       EV_KEY, KEY_REWIND,
+       EV_KEY, KEY_PHONE,
+       EV_KEY, KEY_CONFIG,
+       EV_KEY, KEY_HOMEPAGE,
+       EV_KEY, KEY_REFRESH,
+       EV_KEY, KEY_EXIT,
+       EV_KEY, KEY_EDIT,
+       EV_KEY, KEY_SCROLLUP,
+       EV_KEY, KEY_SCROLLDOWN,
+       EV_KEY, KEY_KPLEFTPAREN,
+       EV_KEY, KEY_KPRIGHTPAREN,
+       EV_KEY, KEY_NEW,
+       EV_KEY, KEY_REDO,
+       EV_KEY, KEY_F13,
+       EV_KEY, KEY_F14,
+       EV_KEY, KEY_F15,
+       EV_KEY, KEY_F16,
+       EV_KEY, KEY_F17,
+       EV_KEY, KEY_F18,
+       EV_KEY, KEY_F19,
+       EV_KEY, KEY_F20,
+       EV_KEY, KEY_F21,
+       EV_KEY, KEY_F22,
+       EV_KEY, KEY_F23,
+       EV_KEY, KEY_F24,
+       EV_KEY, KEY_CLOSE,
+       EV_KEY, KEY_PLAY,
+       EV_KEY, KEY_FASTFORWARD,
+       EV_KEY, KEY_BASSBOOST,
+       EV_KEY, KEY_PRINT,
+       EV_KEY, KEY_CAMERA,
+       EV_KEY, KEY_CHAT,
+       EV_KEY, KEY_SEARCH,
+       EV_KEY, KEY_FINANCE,
+       EV_KEY, KEY_CANCEL,
+       EV_KEY, KEY_BRIGHTNESSDOWN,
+       EV_KEY, KEY_BRIGHTNESSUP,
+       EV_KEY, KEY_KBDILLUMTOGGLE,
+       EV_KEY, KEY_SEND,
+       EV_KEY, KEY_REPLY,
+       EV_KEY, KEY_FORWARDMAIL,
+       EV_KEY, KEY_SAVE,
+       EV_KEY, KEY_DOCUMENTS,
+       EV_KEY, KEY_UNKNOWN,
+       EV_KEY, KEY_VIDEO_NEXT,
+       EV_KEY, KEY_BRIGHTNESS_AUTO,
+       EV_KEY, BTN_0,
+       EV_KEY, KEY_SELECT,
+       EV_KEY, KEY_GOTO,
+       EV_KEY, KEY_INFO,
+       EV_KEY, KEY_PROGRAM,
+       EV_KEY, KEY_PVR,
+       EV_KEY, KEY_SUBTITLE,
+       EV_KEY, KEY_ZOOM,
+       EV_KEY, KEY_KEYBOARD,
+       EV_KEY, KEY_PC,
+       EV_KEY, KEY_TV,
+       EV_KEY, KEY_TV2,
+       EV_KEY, KEY_VCR,
+       EV_KEY, KEY_VCR2,
+       EV_KEY, KEY_SAT,
+       EV_KEY, KEY_CD,
+       EV_KEY, KEY_TAPE,
+       EV_KEY, KEY_TUNER,
+       EV_KEY, KEY_PLAYER,
+       EV_KEY, KEY_DVD,
+       EV_KEY, KEY_AUDIO,
+       EV_KEY, KEY_VIDEO,
+       EV_KEY, KEY_MEMO,
+       EV_KEY, KEY_CALENDAR,
+       EV_KEY, KEY_RED,
+       EV_KEY, KEY_GREEN,
+       EV_KEY, KEY_YELLOW,
+       EV_KEY, KEY_BLUE,
+       EV_KEY, KEY_CHANNELUP,
+       EV_KEY, KEY_CHANNELDOWN,
+       EV_KEY, KEY_LAST,
+       EV_KEY, KEY_NEXT,
+       EV_KEY, KEY_RESTART,
+       EV_KEY, KEY_SLOW,
+       EV_KEY, KEY_SHUFFLE,
+       EV_KEY, KEY_PREVIOUS,
+       EV_KEY, KEY_VIDEOPHONE,
+       EV_KEY, KEY_GAMES,
+       EV_KEY, KEY_ZOOMIN,
+       EV_KEY, KEY_ZOOMOUT,
+       EV_KEY, KEY_ZOOMRESET,
+       EV_KEY, KEY_WORDPROCESSOR,
+       EV_KEY, KEY_EDITOR,
+       EV_KEY, KEY_SPREADSHEET,
+       EV_KEY, KEY_GRAPHICSEDITOR,
+       EV_KEY, KEY_PRESENTATION,
+       EV_KEY, KEY_DATABASE,
+       EV_KEY, KEY_NEWS,
+       EV_KEY, KEY_VOICEMAIL,
+       EV_KEY, KEY_ADDRESSBOOK,
+       EV_KEY, KEY_MESSENGER,
+       EV_KEY, KEY_DISPLAYTOGGLE,
+       EV_KEY, KEY_SPELLCHECK,
+       EV_KEY, KEY_LOGOFF,
+       EV_KEY, KEY_MEDIA_REPEAT,
+       EV_KEY, KEY_IMAGES,
+       EV_KEY, KEY_BUTTONCONFIG,
+       EV_KEY, KEY_TASKMANAGER,
+       EV_KEY, KEY_JOURNAL,
+       EV_KEY, KEY_CONTROLPANEL,
+       EV_KEY, KEY_APPSELECT,
+       EV_KEY, KEY_SCREENSAVER,
+       EV_KEY, KEY_VOICECOMMAND,
+       EV_KEY, KEY_BRIGHTNESS_MIN,
+       EV_KEY, KEY_BRIGHTNESS_MAX,
+       EV_LED, LED_NUML,
+       EV_LED, LED_CAPSL,
+       EV_LED, LED_SCROLLL,
+       EV_LED, LED_COMPOSE,
+       EV_LED, LED_KANA,
+       -1 , -1,
+};
+
+static struct input_absinfo absinfo[] = {
+       { ABS_VOLUME, 0, 668, 0, 0, 0 },
+       { .value = -1 }
+};
+
+struct litest_test_device litest_mouse_gladius_device = {
+       .type = LITEST_MOUSE_GLADIUS,
+       .features = LITEST_RELATIVE | LITEST_WHEEL | LITEST_KEYS,
+       .shortname = "mouse_gladius",
+       .setup = litest_mouse_gladius_setup,
+       .interface = NULL,
+
+       .name = "ASUS ROG GLADIUS",
+       .id = &input_id,
+       .absinfo = absinfo,
+       .events = events,
+};
index bfa28f44d64a159bacfc6cd56fe22c0935bdc6f8..c7cb2746770dd69e711ae7f5a4931944aae51fa8 100644 (file)
@@ -365,6 +365,7 @@ extern struct litest_test_device litest_generic_multitouch_screen_device;
 extern struct litest_test_device litest_nexus4_device;
 extern struct litest_test_device litest_magicpad_device;
 extern struct litest_test_device litest_elantech_touchpad_device;
+extern struct litest_test_device litest_mouse_gladius_device;
 
 struct litest_test_device* devices[] = {
        &litest_synaptics_clickpad_device,
@@ -396,6 +397,7 @@ struct litest_test_device* devices[] = {
        &litest_nexus4_device,
        &litest_magicpad_device,
        &litest_elantech_touchpad_device,
+       &litest_mouse_gladius_device,
        NULL,
 };
 
index 8a4b33d12cc90ed779b79e0f38b955f7735ad0f0..058057e283777f5f67f99ac619edc26281217535 100644 (file)
@@ -142,6 +142,7 @@ enum litest_device_type {
        LITEST_NEXUS4_TOUCH_SCREEN = -28,
        LITEST_MAGIC_TRACKPAD = -29,
        LITEST_ELANTECH_TOUCHPAD = -30,
+       LITEST_MOUSE_GLADIUS = -31,
 };
 
 enum litest_device_feature {