Hi

On Mon, Mar 23, 2015 at 2:30 AM, Peter Hutterer
<peter.hutte...@who-t.net> wrote:
> Rather than building a map and looping through the map, immediately call the
> ioctl when we have a successfully parsed property.
>
> This has a side-effect: before the maximum number of ioctls was limited to the
> size of the map (1024), now it is unlimited.
> ---
>  src/udev/udev-builtin-keyboard.c | 46 
> +++++++++++++++++-----------------------
>  1 file changed, 19 insertions(+), 27 deletions(-)
>
> diff --git a/src/udev/udev-builtin-keyboard.c 
> b/src/udev/udev-builtin-keyboard.c
> index b7c8791..b3396d5 100644
> --- a/src/udev/udev-builtin-keyboard.c
> +++ b/src/udev/udev-builtin-keyboard.c
> @@ -67,10 +67,10 @@ static int builtin_keyboard(struct udev_device *dev, int 
> argc, char *argv[], boo
>          struct {
>                  unsigned scan;
>                  unsigned key;
> -        } map[1024];
> -        unsigned map_count = 0;
> +        } map;
>          unsigned release[1024];
>          unsigned release_count = 0;
> +        _cleanup_close_ int fd = -1;
>          const char *node;
>
>          node = udev_device_get_devnode(dev);
> @@ -125,37 +125,29 @@ static int builtin_keyboard(struct udev_device *dev, 
> int argc, char *argv[], boo
>                          }
>                  }
>
> -                map[map_count].scan = scancode;
> -                map[map_count].key = keycode_num;
> -                if (map_count < ELEMENTSOF(map)-1)
> -                        map_count++;
> -        }
> -
> -        if (map_count > 0 || release_count > 0) {
> -                int fd;
> -                unsigned i;
> -
> -                fd = open(node, O_RDWR|O_CLOEXEC|O_NONBLOCK|O_NOCTTY);
> -                if (fd < 0) {
> -                        log_error_errno(errno, "Error, opening device '%s': 
> %m", node);
> -                        return EXIT_FAILURE;
> +                if (fd == -1) {
> +                        fd = open(node, 
> O_RDWR|O_CLOEXEC|O_NONBLOCK|O_NOCTTY);
> +                        if (fd < 0) {
> +                                log_error_errno(errno, "Error, opening 
> device '%s': %m", node);
> +                                return EXIT_FAILURE;
> +                        }
>                  }
>
> -                /* install list of map codes */
> -                for (i = 0; i < map_count; i++) {
> -                        log_debug("keyboard: mapping scan code %d (0x%x) to 
> key code %d (0x%x)",
> -                                  map[i].scan, map[i].scan, map[i].key, 
> map[i].key);
> -                        if (ioctl(fd, EVIOCSKEYCODE, &map[i]) < 0)
> -                                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);
> -                }
> +                map.scan = scancode;
> +                map.key = keycode_num;
> +
> +                log_debug("keyboard: mapping scan code %d (0x%x) to key code 
> %d (0x%x)",
> +                          map.scan, map.scan, map.key, map.key);
>
> -                /* install list of force-release codes */
> -                if (release_count > 0)
> -                        install_force_release(dev, release, release_count);
> +                if (ioctl(fd, EVIOCSKEYCODE, &map) < 0)

Man, this ioctl is ugly. Why has there never been a payload-struct? We
might convert this to EVIOCSKEYCODE_V2 some day.. but unrelated to
this change.

> +                        log_error_errno(errno, "Error calling EVIOCSKEYCODE 
> on device node '%s' (scan code 0x%x, key code %d): %m", node, map.scan, 
> map.key);
>

Weird empty line left?

Looks all good to me. Please push!
David

> -                close(fd);
>          }
>
> +        /* install list of force-release codes */
> +        if (release_count > 0)
> +                install_force_release(dev, release, release_count);
> +
>          return EXIT_SUCCESS;
>  }
>
> --
> 2.3.2
>
_______________________________________________
systemd-devel mailing list
systemd-devel@lists.freedesktop.org
http://lists.freedesktop.org/mailman/listinfo/systemd-devel

Reply via email to