diff options
| author | polyphemus <rolfmorel@gmail.com> | 2013-08-09 17:38:51 +0200 |
|---|---|---|
| committer | Peter Hutterer <peter.hutterer@who-t.net> | 2013-08-26 09:52:27 +1000 |
| commit | f29e4118fcbc58ad79561e64f7ede15f59224240 (patch) | |
| tree | a61041d7083233bd814ad66ce3ae430664deec32 /libevdev/libevdev.c | |
| parent | 4d4293a65b604e0bf8d02dc729803f142fc665aa (diff) | |
| download | libevdev-f29e4118fcbc58ad79561e64f7ede15f59224240.tar.gz | |
write EV_SYN input_event along with led events to device
Other clients of an evdev device need to have the events they receive
be separated, in moment in time, from other events by an EV_SYN/
SYN_REPORT. This is the responsibility of the client who writes events
into the stream.
Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net>
Reviewed-by: Benjamin Tissoires <benjamin.tissoires@gmail.com>
Diffstat (limited to 'libevdev/libevdev.c')
| -rw-r--r-- | libevdev/libevdev.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/libevdev/libevdev.c b/libevdev/libevdev.c index 25d33e7..ba5b17f 100644 --- a/libevdev/libevdev.c +++ b/libevdev/libevdev.c @@ -1189,7 +1189,7 @@ libevdev_kernel_set_led_value(struct libevdev *dev, unsigned int code, enum Evde int libevdev_kernel_set_led_values(struct libevdev *dev, ...) { - struct input_event ev[LED_MAX]; + struct input_event ev[LED_MAX + 1]; enum EvdevLEDValues val; va_list args; int code; @@ -1228,8 +1228,12 @@ libevdev_kernel_set_led_values(struct libevdev *dev, ...) va_end(args); if (rc == 0 && nleds > 0) { + ev[nleds].type = EV_SYN; + ev[nleds++].code = SYN_REPORT; + rc = write(libevdev_get_fd(dev), ev, nleds * sizeof(ev[0])); if (rc > 0) { + nleds--; /* last is EV_SYN */ while (nleds--) update_led_state(dev, &ev[nleds]); } |
