aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--drivers/usb/storage/usb.c15
1 files changed, 8 insertions, 7 deletions
diff --git a/drivers/usb/storage/usb.c b/drivers/usb/storage/usb.c
index f5c0264caa33..5a53d4f0dd11 100644
--- a/drivers/usb/storage/usb.c
+++ b/drivers/usb/storage/usb.c
@@ -232,6 +232,7 @@ void fill_inquiry_response(struct us_data *us, unsigned char *data,
232 if (data_len<36) // You lose. 232 if (data_len<36) // You lose.
233 return; 233 return;
234 234
235 memset(data+8, ' ', 28);
235 if(data[0]&0x20) { /* USB device currently not connected. Return 236 if(data[0]&0x20) { /* USB device currently not connected. Return
236 peripheral qualifier 001b ("...however, the 237 peripheral qualifier 001b ("...however, the
237 physical device is not currently connected 238 physical device is not currently connected
@@ -241,15 +242,15 @@ void fill_inquiry_response(struct us_data *us, unsigned char *data,
241 device, it may return zeros or ASCII spaces 242 device, it may return zeros or ASCII spaces
242 (20h) in those fields until the data is 243 (20h) in those fields until the data is
243 available from the device."). */ 244 available from the device."). */
244 memset(data+8,0,28);
245 } else { 245 } else {
246 u16 bcdDevice = le16_to_cpu(us->pusb_dev->descriptor.bcdDevice); 246 u16 bcdDevice = le16_to_cpu(us->pusb_dev->descriptor.bcdDevice);
247 memcpy(data+8, us->unusual_dev->vendorName, 247 int n;
248 strlen(us->unusual_dev->vendorName) > 8 ? 8 : 248
249 strlen(us->unusual_dev->vendorName)); 249 n = strlen(us->unusual_dev->vendorName);
250 memcpy(data+16, us->unusual_dev->productName, 250 memcpy(data+8, us->unusual_dev->vendorName, min(8, n));
251 strlen(us->unusual_dev->productName) > 16 ? 16 : 251 n = strlen(us->unusual_dev->productName);
252 strlen(us->unusual_dev->productName)); 252 memcpy(data+16, us->unusual_dev->productName, min(16, n));
253
253 data[32] = 0x30 + ((bcdDevice>>12) & 0x0F); 254 data[32] = 0x30 + ((bcdDevice>>12) & 0x0F);
254 data[33] = 0x30 + ((bcdDevice>>8) & 0x0F); 255 data[33] = 0x30 + ((bcdDevice>>8) & 0x0F);
255 data[34] = 0x30 + ((bcdDevice>>4) & 0x0F); 256 data[34] = 0x30 + ((bcdDevice>>4) & 0x0F);