diff options
author | Dan Carpenter <error27@gmail.com> | 2010-01-25 06:53:33 -0500 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@suse.de> | 2010-03-02 17:54:47 -0500 |
commit | f10718f5b812a2c55e37396518d426f88d5e35fc (patch) | |
tree | 6b982a4adfefc8a220679e0bfdc347372e29031f /drivers/usb/serial | |
parent | 5b520259ab6d661b8d5eb39dd17cc5e4e4553c62 (diff) |
USB: io_edgeport: eliminate get_string()
Johan Hovold points out that get_string() is basically just a
re-implimentation of usb_string(). It is also buggy. It does DMA on
the stack and it doesn't handle negative returns from
usb_get_descriptor(). Plus unicode_to_ascii() is a rubbish function and
moving to usb_string() avoids using it.
Let's eliminate get_string() entirely.
Reported-by: Johan Hovold <jhovold@gmail.com>
Signed-off-by: Dan Carpenter <error27@gmail.com>
Acked-by: Johan Hovold <jhovold@gmail.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers/usb/serial')
-rw-r--r-- | drivers/usb/serial/io_edgeport.c | 43 |
1 files changed, 4 insertions, 39 deletions
diff --git a/drivers/usb/serial/io_edgeport.c b/drivers/usb/serial/io_edgeport.c index 09456002bac0..c055c8ba377d 100644 --- a/drivers/usb/serial/io_edgeport.c +++ b/drivers/usb/serial/io_edgeport.c | |||
@@ -364,43 +364,6 @@ static void update_edgeport_E2PROM(struct edgeport_serial *edge_serial) | |||
364 | release_firmware(fw); | 364 | release_firmware(fw); |
365 | } | 365 | } |
366 | 366 | ||
367 | |||
368 | /************************************************************************ | ||
369 | * * | ||
370 | * Get string descriptor from device * | ||
371 | * * | ||
372 | ************************************************************************/ | ||
373 | static int get_string(struct usb_device *dev, int Id, char *string, int buflen) | ||
374 | { | ||
375 | struct usb_string_descriptor *StringDesc = NULL; | ||
376 | struct usb_string_descriptor *pStringDesc = NULL; | ||
377 | int ret = 0; | ||
378 | |||
379 | dbg("%s - USB String ID = %d", __func__, Id); | ||
380 | |||
381 | StringDesc = kmalloc(sizeof(*StringDesc), GFP_KERNEL); | ||
382 | if (!StringDesc) | ||
383 | goto free; | ||
384 | if (usb_get_descriptor(dev, USB_DT_STRING, Id, StringDesc, sizeof(*StringDesc)) <= 0) | ||
385 | goto free; | ||
386 | |||
387 | pStringDesc = kmalloc(StringDesc->bLength, GFP_KERNEL); | ||
388 | if (!pStringDesc) | ||
389 | goto free; | ||
390 | |||
391 | if (usb_get_descriptor(dev, USB_DT_STRING, Id, pStringDesc, StringDesc->bLength) <= 0) | ||
392 | goto free; | ||
393 | |||
394 | unicode_to_ascii(string, buflen, pStringDesc->wData, pStringDesc->bLength/2); | ||
395 | ret = strlen(string); | ||
396 | dbg("%s - USB String %s", __func__, string); | ||
397 | free: | ||
398 | kfree(StringDesc); | ||
399 | kfree(pStringDesc); | ||
400 | return ret; | ||
401 | } | ||
402 | |||
403 | |||
404 | #if 0 | 367 | #if 0 |
405 | /************************************************************************ | 368 | /************************************************************************ |
406 | * | 369 | * |
@@ -2998,10 +2961,12 @@ static int edge_startup(struct usb_serial *serial) | |||
2998 | usb_set_serial_data(serial, edge_serial); | 2961 | usb_set_serial_data(serial, edge_serial); |
2999 | 2962 | ||
3000 | /* get the name for the device from the device */ | 2963 | /* get the name for the device from the device */ |
3001 | i = get_string(dev, dev->descriptor.iManufacturer, | 2964 | i = usb_string(dev, dev->descriptor.iManufacturer, |
3002 | &edge_serial->name[0], MAX_NAME_LEN+1); | 2965 | &edge_serial->name[0], MAX_NAME_LEN+1); |
2966 | if (i < 0) | ||
2967 | i = 0; | ||
3003 | edge_serial->name[i++] = ' '; | 2968 | edge_serial->name[i++] = ' '; |
3004 | get_string(dev, dev->descriptor.iProduct, | 2969 | usb_string(dev, dev->descriptor.iProduct, |
3005 | &edge_serial->name[i], MAX_NAME_LEN+2 - i); | 2970 | &edge_serial->name[i], MAX_NAME_LEN+2 - i); |
3006 | 2971 | ||
3007 | dev_info(&serial->dev->dev, "%s detected\n", edge_serial->name); | 2972 | dev_info(&serial->dev->dev, "%s detected\n", edge_serial->name); |