Staging: vt6655: memory corruption in check in wpa_set_wpadev()
authorDan Carpenter <dan.carpenter@oracle.com>
Tue, 18 Oct 2011 06:27:25 +0000 (09:27 +0300)
committerGreg Kroah-Hartman <gregkh@suse.de>
Wed, 19 Oct 2011 20:42:48 +0000 (13:42 -0700)
The original code left it up to the user to decide how much data to
copy, but that doesn't work with a fixed size array.

Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
drivers/staging/vt6655/wpactl.c

index a0f994ed58feaa8dd29817bab181b8370375bf2f..732ba88dc796e1da187fd624255fadc5096a4b12 100644 (file)
@@ -213,7 +213,9 @@ int wpa_set_wpadev(PSDevice pDevice, int val)
        int uu, ii;
 
 
-       if (param->u.wpa_key.alg_name > WPA_ALG_CCMP)
+       if (param->u.wpa_key.alg_name > WPA_ALG_CCMP ||
+                       param->u.wpa_key.key_len >= MAX_KEY_LEN ||
+                       param->u.wpa_key.seq_len >= MAX_KEY_LEN)
                return -EINVAL;
 
     DBG_PRT(MSG_LEVEL_DEBUG, KERN_INFO "param->u.wpa_key.alg_name = %d \n", param->u.wpa_key.alg_name);