]> git.karo-electronics.de Git - karo-tx-linux.git/commitdiff
keyboard: integer underflow bug
authorDan Carpenter <error27@gmail.com>
Thu, 3 Mar 2011 16:56:06 +0000 (17:56 +0100)
committerPaul Gortmaker <paul.gortmaker@windriver.com>
Sun, 26 Jun 2011 16:46:56 +0000 (12:46 -0400)
commit b652277b09d3d030cb074cc6a98ba80b34244c03 upstream.

The "ct" variable should be an unsigned int.  Both struct kbdiacrs
->kb_cnt and struct kbd_data ->accent_table_size are unsigned ints.

Making it signed causes a problem in KBDIACRUC because the user could
set the signed bit and cause a buffer overflow.

Signed-off-by: Dan Carpenter <error27@gmail.com>
Signed-off-by: Martin Schwidefsky <schwidefsky@de.ibm.com>
Signed-off-by: Paul Gortmaker <paul.gortmaker@windriver.com>
drivers/s390/char/keyboard.c

index cb6bffe7141a948feb3f8f370f360eb941861991..84d08f9cfe265935400333bdf745c5ce9d0882d2 100644 (file)
@@ -463,7 +463,8 @@ kbd_ioctl(struct kbd_data *kbd, struct file *file,
          unsigned int cmd, unsigned long arg)
 {
        void __user *argp;
-       int ct, perm;
+       unsigned int ct;
+       int perm;
 
        argp = (void __user *)arg;