Blame SOURCES/0554-udev-builtin-keyboard-immediately-EVIOCSKEYCODE-when.patch

17b0f1
From 4f9b03c28555799f8672b905323bf6d1f95eb13f Mon Sep 17 00:00:00 2001
17b0f1
From: Peter Hutterer <peter.hutterer@who-t.net>
17b0f1
Date: Fri, 20 Mar 2015 12:52:46 +1000
17b0f1
Subject: [PATCH] udev: builtin-keyboard: immediately EVIOCSKEYCODE when we
17b0f1
 have a pair
17b0f1
17b0f1
Rather than building a map and looping through the map, immediately call the
17b0f1
ioctl when we have a successfully parsed property.
17b0f1
17b0f1
This has a side-effect: before the maximum number of ioctls was limited to the
17b0f1
size of the map (1024), now it is unlimited.
17b0f1
17b0f1
(cherry picked from commit cfba2656e3b4a9c5e03db4ec0a8f76c3762d35a8)
17b0f1
17b0f1
Resolves: #1500119
17b0f1
---
17b0f1
 src/udev/udev-builtin-keyboard.c | 45 +++++++++++++-------------------
17b0f1
 1 file changed, 18 insertions(+), 27 deletions(-)
17b0f1
17b0f1
diff --git a/src/udev/udev-builtin-keyboard.c b/src/udev/udev-builtin-keyboard.c
17b0f1
index bde7bf07fb..515edd45ce 100644
17b0f1
--- a/src/udev/udev-builtin-keyboard.c
17b0f1
+++ b/src/udev/udev-builtin-keyboard.c
17b0f1
@@ -71,10 +71,10 @@ static int builtin_keyboard(struct udev_device *dev, int argc, char *argv[], boo
17b0f1
         struct {
17b0f1
                 unsigned scan;
17b0f1
                 unsigned key;
17b0f1
-        } map[1024];
17b0f1
-        unsigned map_count = 0;
17b0f1
+        } map;
17b0f1
         unsigned release[1024];
17b0f1
         unsigned release_count = 0;
17b0f1
+        _cleanup_close_ int fd = -1;
17b0f1
         const char *node;
17b0f1
 
17b0f1
         node = udev_device_get_devnode(dev);
17b0f1
@@ -128,37 +128,28 @@ static int builtin_keyboard(struct udev_device *dev, int argc, char *argv[], boo
17b0f1
                         }
17b0f1
                 }
17b0f1
 
17b0f1
-                map[map_count].scan = scancode;
17b0f1
-                map[map_count].key = keycode_num;
17b0f1
-                if (map_count < ELEMENTSOF(map)-1)
17b0f1
-                        map_count++;
17b0f1
-        }
17b0f1
-
17b0f1
-        if (map_count > 0 || release_count > 0) {
17b0f1
-                int fd;
17b0f1
-                unsigned i;
17b0f1
-
17b0f1
-                fd = open(node, O_RDWR|O_CLOEXEC|O_NONBLOCK|O_NOCTTY);
17b0f1
-                if (fd < 0) {
17b0f1
-                        log_error_errno(errno, "Error, opening device '%s': %m", node);
17b0f1
-                        return EXIT_FAILURE;
17b0f1
+                if (fd == -1) {
17b0f1
+                        fd = open(node, O_RDWR|O_CLOEXEC|O_NONBLOCK|O_NOCTTY);
17b0f1
+                        if (fd < 0) {
17b0f1
+                                log_error_errno(errno, "Error, opening device '%s': %m", node);
17b0f1
+                                return EXIT_FAILURE;
17b0f1
+                        }
17b0f1
                 }
17b0f1
 
17b0f1
-                /* install list of map codes */
17b0f1
-                for (i = 0; i < map_count; i++) {
17b0f1
-                        log_debug("keyboard: mapping scan code %d (0x%x) to key code %d (0x%x)",
17b0f1
-                                  map[i].scan, map[i].scan, map[i].key, map[i].key);
17b0f1
-                        if (ioctl(fd, EVIOCSKEYCODE, &map[i]) < 0)
17b0f1
-                                log_error_errno(errno, "Error calling EVIOCSKEYCODE on device node '%s' (scan code 0x%x, key code %d): %m", node, map[i].scan, map[i].key);
17b0f1
-                }
17b0f1
+                map.scan = scancode;
17b0f1
+                map.key = keycode_num;
17b0f1
 
17b0f1
-                /* install list of force-release codes */
17b0f1
-                if (release_count > 0)
17b0f1
-                        install_force_release(dev, release, release_count);
17b0f1
+                log_debug("keyboard: mapping scan code %d (0x%x) to key code %d (0x%x)",
17b0f1
+                          map.scan, map.scan, map.key, map.key);
17b0f1
 
17b0f1
-                close(fd);
17b0f1
+                if (ioctl(fd, EVIOCSKEYCODE, &map) < 0)
17b0f1
+                        log_error_errno(errno, "Error calling EVIOCSKEYCODE on device node '%s' (scan code 0x%x, key code %d): %m", node, map.scan, map.key);
17b0f1
         }
17b0f1
 
17b0f1
+        /* install list of force-release codes */
17b0f1
+        if (release_count > 0)
17b0f1
+                install_force_release(dev, release, release_count);
17b0f1
+
17b0f1
         return EXIT_SUCCESS;
17b0f1
 }
17b0f1