|
@@ -1604,10 +1604,14 @@ static int processcompl_compat(struct async *as, void __user * __user *arg)
|
|
|
void __user *addr = as->userurb;
|
|
|
unsigned int i;
|
|
|
|
|
|
- if (as->userbuffer && urb->actual_length)
|
|
|
- if (copy_to_user(as->userbuffer, urb->transfer_buffer,
|
|
|
- urb->actual_length))
|
|
|
+ if (as->userbuffer && urb->actual_length) {
|
|
|
+ if (urb->number_of_packets > 0) /* Isochronous */
|
|
|
+ i = urb->transfer_buffer_length;
|
|
|
+ else /* Non-Isoc */
|
|
|
+ i = urb->actual_length;
|
|
|
+ if (copy_to_user(as->userbuffer, urb->transfer_buffer, i))
|
|
|
return -EFAULT;
|
|
|
+ }
|
|
|
if (put_user(as->status, &userurb->status))
|
|
|
return -EFAULT;
|
|
|
if (put_user(urb->actual_length, &userurb->actual_length))
|