summaryrefslogtreecommitdiffstats
path: root/drivers/auxdisplay
diff options
context:
space:
mode:
authorTim Sell <Timothy.Sell@unisys.com>2017-11-17 12:27:38 -0500
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2017-11-28 14:20:50 +0100
commita5eb2188f5c6cd81eede163157864484fb1d0e64 (patch)
tree7b35477567ebc46166ee327bf070e95e6b02f9cd /drivers/auxdisplay
parent1c0c275b11279a8305cf18a453e206d4891bbc48 (diff)
downloadlinux-a5eb2188f5c6cd81eede163157864484fb1d0e64.tar.gz
linux-a5eb2188f5c6cd81eede163157864484fb1d0e64.tar.bz2
linux-a5eb2188f5c6cd81eede163157864484fb1d0e64.zip
staging: unisys: visorbus: address theoretical int overflows
Add necessary casting to several places where we were doing 32-bit arithmetic (unsigned) to produce a 64-bit (unsigned long) result, to prevent the theoretical possibility of a 32-bit overflow during the arithmetic. FYI, these are unsigned long: ctx->param_bytes ctx->allocbytes These are unsigned int: bytes phdr->name_offset phdr->name_length Here is the test program demonstrating why we really need the casts: void main() { unsigned int i; unsigned long il; printf("sizeof(int) =%dn",sizeof(i)); printf("sizeof(long)=%dn",sizeof(il)); i = (unsigned int)((((unsigned long)(1)) << 32) - 1); printf("i = %un", i); il = i+1; printf("adding 1 withOUT cast = %lun", il); il = (unsigned long)i+1; printf("adding 1 WITH cast = %lun", il); } [selltc@mac tmp]$ gcc x.c -o x.out [selltc@mac tmp]$ ./x.out sizeof(int) =4 sizeof(long)=8 i = 4294967295 adding 1 withOUT cast = 0 adding 1 WITH cast = 4294967296 Signed-off-by: Tim Sell <Timothy.Sell@unisys.com> Reported-by: Dan Carpenter <dan.carpenter@oracle.com> Signed-off-by: David Kershner <david.kershner@unisys.com> Reviewed-by: David Binder <david.binder@unisys.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/auxdisplay')
0 files changed, 0 insertions, 0 deletions