On Sat, Jan 20, 2024 at 11:15:11PM +0300, Sergey Shtylyov wrote: > In sddr55_{read|write}_data(), the address variables are needlessly typed > as *unsigned long* -- which is 32-bit type on the 32-bit arches and 64-bit > type on the 64-bit arches; those variables' value should fit into just 3 > command bytes and consists of 10-bit block # (or at least the max block # > seems to be 1023) and 4-/5-bit page # within a block, so 32-bit *unsigned* > *int* type should be more than enough... > > Found by Linux Verification Center (linuxtesting.org) with the Svace static > analysis tool. > > Signed-off-by: Karina Yankevich <k.yankevich@xxxxxx> > Signed-off-by: Sergey Shtylyov <s.shtylyov@xxxxxx> > > --- Reviewed-by: Alan Stern <stern@xxxxxxxxxxxxxxxxxxx> > This patch is against the 'usb-next' branch of Greg KH's usb.git repo... > > Changes in version 3: > - rewrote the patch subject and description. > > Changes in version 2: > - compeltely redid the patch. > > drivers/usb/storage/sddr55.c | 4 ++-- > 1 file changed, 2 insertions(+), 2 deletions(-) > > Index: usb/drivers/usb/storage/sddr55.c > =================================================================== > --- usb.orig/drivers/usb/storage/sddr55.c > +++ usb/drivers/usb/storage/sddr55.c > @@ -196,7 +196,7 @@ static int sddr55_read_data(struct us_da > unsigned char *buffer; > > unsigned int pba; > - unsigned long address; > + unsigned int address; > > unsigned short pages; > unsigned int len, offset; > @@ -316,7 +316,7 @@ static int sddr55_write_data(struct us_d > > unsigned int pba; > unsigned int new_pba; > - unsigned long address; > + unsigned int address; > > unsigned short pages; > int i; >