diff options
author | Kenichi Nagai <kenichi3.nagai@toshiba.co.jp> | 2007-05-11 01:12:15 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@woody.linux-foundation.org> | 2007-05-11 09:08:04 -0700 |
commit | bf61f8d357e5d71d74a3ca3be3cce52bf1a2c01a (patch) | |
tree | c27279afbee1b9927f992938587db09f061398f5 /drivers | |
parent | 435b71be20f2ad3688acd94c05e968e029464d60 (diff) | |
download | lwn-bf61f8d357e5d71d74a3ca3be3cce52bf1a2c01a.tar.gz lwn-bf61f8d357e5d71d74a3ca3be3cce52bf1a2c01a.zip |
Input: evdev - fix overflow in compat_ioctl
When exporting input device bitmaps via compat_ioctl on BIG_ENDIAN
platforms evdev calculates data size incorrectly. This causes buffer
overflow if user specifies buffer smaller than maxlen.
Signed-off-by: Kenichi Nagai <kenichi3.nagai@toshiba.co.jp>
Signed-off-by: Dmitry Torokhov <dtor@mail.ru>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/input/evdev.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/input/evdev.c b/drivers/input/evdev.c index 55a72592704c..b234729706be 100644 --- a/drivers/input/evdev.c +++ b/drivers/input/evdev.c @@ -336,7 +336,7 @@ static int bits_to_user(unsigned long *bits, unsigned int maxbit, if (compat) { len = NBITS_COMPAT(maxbit) * sizeof(compat_long_t); - if (len < maxlen) + if (len > maxlen) len = maxlen; for (i = 0; i < len / sizeof(compat_long_t); i++) |