misc: st_core: Error triggered by convert "char" to "int"
authorchanning <chao.bi@intel.com>
Thu, 10 Jan 2013 08:27:29 +0000 (16:27 +0800)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 17 Jan 2013 18:19:42 +0000 (10:19 -0800)
When st driver decodes protocol index received from raw data,
it does a value convert from "char" to "int". Because it's sign
extension from bit8 to bit32, the "int" value maybe minus, in
another word, the protocol index might be minus, but driver doesn't
filter such case and may continue access memory pointed by this
minus index.

This patch is to change the variable type of index from "int"
to "unsigned char", so that it avoids do such kind of type
conversion.

cc: liu chuansheng <chuansheng.liu@intel.com>
Signed-off-by: channing <chao.bi@intel.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/misc/ti-st/st_core.c

index b90a2241d79c41cab2b551736cc9e2a56315a7b3..0a1428016350a6f6cb0946188d5b5e8366207426 100644 (file)
@@ -240,7 +240,8 @@ void st_int_recv(void *disc_data,
        char *ptr;
        struct st_proto_s *proto;
        unsigned short payload_len = 0;
-       int len = 0, type = 0;
+       int len = 0;
+       unsigned char type = 0;
        unsigned char *plen;
        struct st_data_s *st_gdata = (struct st_data_s *)disc_data;
        unsigned long flags;