diff options
| author | Peter Hutterer <peter.hutterer@who-t.net> | 2020-02-19 13:18:48 +1000 |
|---|---|---|
| committer | Peter Hutterer <peter.hutterer@who-t.net> | 2020-02-19 13:24:21 +1000 |
| commit | 6ccee710bd60fe9d0bc058cf7f7dbe960b3891dd (patch) | |
| tree | 07bebc15dc3c46d1f4dede43b495a26d6a24660c /libevdev | |
| parent | e9ecb5cabc85e0737356d4c64d87eba03161bca4 (diff) | |
| download | libevdev-6ccee710bd60fe9d0bc058cf7f7dbe960b3891dd.tar.gz | |
Ignore slot sync for slots > 256
Clang doesn't support variable length arrays inside a struct so we could
either make our life complicated or just assume no-one is using more than 256
slots and hard-code that. Let's go for the easy solution until someone
notices.
Signed-off-by: Peter Hutterer <peter.hutterer@who-t.net>
Diffstat (limited to 'libevdev')
| -rw-r--r-- | libevdev/libevdev.c | 11 |
1 files changed, 5 insertions, 6 deletions
diff --git a/libevdev/libevdev.c b/libevdev/libevdev.c index 98645bb..bd6fc96 100644 --- a/libevdev/libevdev.c +++ b/libevdev/libevdev.c @@ -677,16 +677,15 @@ static int sync_mt_state(struct libevdev *dev, struct slot_change_state changes_out[dev->num_slots]) { +#define MAX_SLOTS 256 int rc; - struct slot_change_state changes[dev->num_slots]; - - memset(changes, 0, sizeof(changes)); + struct slot_change_state changes[MAX_SLOTS] = {0}; for (int axis = ABS_MT_MIN; axis <= ABS_MT_MAX; axis++) { /* EVIOCGMTSLOTS required format */ struct mt_sync_state { uint32_t code; - int32_t val[dev->num_slots]; + int32_t val[MAX_SLOTS]; } mt_state; if (axis == ABS_MT_SLOT || @@ -698,7 +697,7 @@ sync_mt_state(struct libevdev *dev, if (rc < 0) goto out; - for (int slot = 0; slot < dev->num_slots; slot++) { + for (int slot = 0; slot < min(MAX_SLOTS, dev->num_slots); slot++) { int val_before = *slot_value(dev, slot, axis), val_after = mt_state.val[slot]; @@ -729,7 +728,7 @@ sync_mt_state(struct libevdev *dev, } } - memcpy(changes_out, changes, sizeof(changes)); + memcpy(changes_out, changes, sizeof(*changes) * dev->num_slots); out: return rc; } |
