Skip to content

Commit a7b7783

Browse files
Dan Carpenterfelipebalbi
authored andcommitted
usb: raw-gadget: Fix copy_to/from_user() checks
The copy_to/from_user() functions return the number of bytes remaining but we want to return negative error codes. I changed a couple checks in raw_ioctl_ep_read() and raw_ioctl_ep0_read() to show that we still we returning zero on error. Fixes: f2c2e71 ("usb: gadget: add raw-gadget interface") Signed-off-by: Dan Carpenter <[email protected]> Reviewed-by: Andrey Konovalov <[email protected]> Tested-by: Andrey Konovalov <[email protected]> Signed-off-by: Felipe Balbi <[email protected]>
1 parent 0666aa5 commit a7b7783

File tree

1 file changed

+22
-24
lines changed

1 file changed

+22
-24
lines changed

drivers/usb/gadget/legacy/raw_gadget.c

Lines changed: 22 additions & 24 deletions
Original file line numberDiff line numberDiff line change
@@ -400,9 +400,8 @@ static int raw_ioctl_init(struct raw_dev *dev, unsigned long value)
400400
char *udc_device_name;
401401
unsigned long flags;
402402

403-
ret = copy_from_user(&arg, (void __user *)value, sizeof(arg));
404-
if (ret)
405-
return ret;
403+
if (copy_from_user(&arg, (void __user *)value, sizeof(arg)))
404+
return -EFAULT;
406405

407406
switch (arg.speed) {
408407
case USB_SPEED_UNKNOWN:
@@ -509,15 +508,13 @@ static int raw_ioctl_run(struct raw_dev *dev, unsigned long value)
509508

510509
static int raw_ioctl_event_fetch(struct raw_dev *dev, unsigned long value)
511510
{
512-
int ret = 0;
513511
struct usb_raw_event arg;
514512
unsigned long flags;
515513
struct usb_raw_event *event;
516514
uint32_t length;
517515

518-
ret = copy_from_user(&arg, (void __user *)value, sizeof(arg));
519-
if (ret)
520-
return ret;
516+
if (copy_from_user(&arg, (void __user *)value, sizeof(arg)))
517+
return -EFAULT;
521518

522519
spin_lock_irqsave(&dev->lock, flags);
523520
if (dev->state != STATE_DEV_RUNNING) {
@@ -545,20 +542,19 @@ static int raw_ioctl_event_fetch(struct raw_dev *dev, unsigned long value)
545542
return -ENODEV;
546543
}
547544
length = min(arg.length, event->length);
548-
ret = copy_to_user((void __user *)value, event,
549-
sizeof(*event) + length);
550-
return ret;
545+
if (copy_to_user((void __user *)value, event, sizeof(*event) + length))
546+
return -EFAULT;
547+
548+
return 0;
551549
}
552550

553551
static void *raw_alloc_io_data(struct usb_raw_ep_io *io, void __user *ptr,
554552
bool get_from_user)
555553
{
556-
int ret;
557554
void *data;
558555

559-
ret = copy_from_user(io, ptr, sizeof(*io));
560-
if (ret)
561-
return ERR_PTR(ret);
556+
if (copy_from_user(io, ptr, sizeof(*io)))
557+
return ERR_PTR(-EFAULT);
562558
if (io->ep >= USB_RAW_MAX_ENDPOINTS)
563559
return ERR_PTR(-EINVAL);
564560
if (!usb_raw_io_flags_valid(io->flags))
@@ -673,12 +669,13 @@ static int raw_ioctl_ep0_read(struct raw_dev *dev, unsigned long value)
673669
if (IS_ERR(data))
674670
return PTR_ERR(data);
675671
ret = raw_process_ep0_io(dev, &io, data, false);
676-
if (ret < 0) {
677-
kfree(data);
678-
return ret;
679-
}
672+
if (ret)
673+
goto free;
674+
680675
length = min(io.length, (unsigned int)ret);
681-
ret = copy_to_user((void __user *)(value + sizeof(io)), data, length);
676+
if (copy_to_user((void __user *)(value + sizeof(io)), data, length))
677+
ret = -EFAULT;
678+
free:
682679
kfree(data);
683680
return ret;
684681
}
@@ -967,12 +964,13 @@ static int raw_ioctl_ep_read(struct raw_dev *dev, unsigned long value)
967964
if (IS_ERR(data))
968965
return PTR_ERR(data);
969966
ret = raw_process_ep_io(dev, &io, data, false);
970-
if (ret < 0) {
971-
kfree(data);
972-
return ret;
973-
}
967+
if (ret)
968+
goto free;
969+
974970
length = min(io.length, (unsigned int)ret);
975-
ret = copy_to_user((void __user *)(value + sizeof(io)), data, length);
971+
if (copy_to_user((void __user *)(value + sizeof(io)), data, length))
972+
ret = -EFAULT;
973+
free:
976974
kfree(data);
977975
return ret;
978976
}

0 commit comments

Comments
 (0)