mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/next/linux-next.git
synced 2025-01-15 21:23:23 +00:00
usbip: tools: Fix read_usb_vudc_device() error path handling
This isn't really accurate right. fread() doesn't always return 0 in error. It could return < number of elements and set errno. Signed-off-by: GwanYeong Kim <gy741.kim@gmail.com> Acked-by: Shuah Khan <skhan@linuxfoundation.org> Link: https://lore.kernel.org/r/20191018032223.4644-1-gy741.kim@gmail.com Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
parent
d5501d5c29
commit
28df0642ab
@ -69,7 +69,7 @@ int read_usb_vudc_device(struct udev_device *sdev, struct usbip_usb_device *dev)
|
|||||||
FILE *fd = NULL;
|
FILE *fd = NULL;
|
||||||
struct udev_device *plat;
|
struct udev_device *plat;
|
||||||
const char *speed;
|
const char *speed;
|
||||||
int ret = 0;
|
size_t ret;
|
||||||
|
|
||||||
plat = udev_device_get_parent(sdev);
|
plat = udev_device_get_parent(sdev);
|
||||||
path = udev_device_get_syspath(plat);
|
path = udev_device_get_syspath(plat);
|
||||||
@ -79,8 +79,10 @@ int read_usb_vudc_device(struct udev_device *sdev, struct usbip_usb_device *dev)
|
|||||||
if (!fd)
|
if (!fd)
|
||||||
return -1;
|
return -1;
|
||||||
ret = fread((char *) &descr, sizeof(descr), 1, fd);
|
ret = fread((char *) &descr, sizeof(descr), 1, fd);
|
||||||
if (ret < 0)
|
if (ret != 1) {
|
||||||
|
err("Cannot read vudc device descr file: %s", strerror(errno));
|
||||||
goto err;
|
goto err;
|
||||||
|
}
|
||||||
fclose(fd);
|
fclose(fd);
|
||||||
|
|
||||||
copy_descr_attr(dev, &descr, bDeviceClass);
|
copy_descr_attr(dev, &descr, bDeviceClass);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user