diff options
author | Philippe Retornaz <couriousous@mandriva.org> | 2006-06-01 23:48:46 -0400 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@suse.de> | 2006-06-21 18:04:15 -0400 |
commit | 786dc1d3d7333f269e17d742886eac2188a2d9cc (patch) | |
tree | c2c3f14b485fd2fd9bf41ba2a7dada7486ee4c49 | |
parent | 6ad07129a8ed2e13dcd7e6313c201c32bcf7cc32 (diff) |
[PATCH] usb: drivers/usb/core/devio.c dereferences a userspace pointer
See http://bugzilla.kernel.org/show_bug.cgi?id=6617.
This function dereference a __user pointer.
Signed-off-by: Philippe Retornaz <couriousous@mandriva.org>
Signed-off-by: Andrew Morton <akpm@osdl.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
-rw-r--r-- | drivers/usb/core/devio.c | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/drivers/usb/core/devio.c b/drivers/usb/core/devio.c index df3fb57d71e6..2eda52fc1ebc 100644 --- a/drivers/usb/core/devio.c +++ b/drivers/usb/core/devio.c | |||
@@ -1078,7 +1078,9 @@ static int proc_submiturb(struct dev_state *ps, void __user *arg) | |||
1078 | if (copy_from_user(&uurb, arg, sizeof(uurb))) | 1078 | if (copy_from_user(&uurb, arg, sizeof(uurb))) |
1079 | return -EFAULT; | 1079 | return -EFAULT; |
1080 | 1080 | ||
1081 | return proc_do_submiturb(ps, &uurb, (((struct usbdevfs_urb __user *)arg)->iso_frame_desc), arg); | 1081 | return proc_do_submiturb(ps, &uurb, |
1082 | (struct usbdevfs_iso_packet_desc __user *)uurb.iso_frame_desc, | ||
1083 | arg); | ||
1082 | } | 1084 | } |
1083 | 1085 | ||
1084 | static int proc_unlinkurb(struct dev_state *ps, void __user *arg) | 1086 | static int proc_unlinkurb(struct dev_state *ps, void __user *arg) |
@@ -1203,7 +1205,9 @@ static int proc_submiturb_compat(struct dev_state *ps, void __user *arg) | |||
1203 | if (get_urb32(&uurb,(struct usbdevfs_urb32 *)arg)) | 1205 | if (get_urb32(&uurb,(struct usbdevfs_urb32 *)arg)) |
1204 | return -EFAULT; | 1206 | return -EFAULT; |
1205 | 1207 | ||
1206 | return proc_do_submiturb(ps, &uurb, ((struct usbdevfs_urb32 __user *)arg)->iso_frame_desc, arg); | 1208 | return proc_do_submiturb(ps, &uurb, |
1209 | (struct usbdevfs_iso_packet_desc __user *)uurb.iso_frame_desc, | ||
1210 | arg); | ||
1207 | } | 1211 | } |
1208 | 1212 | ||
1209 | static int processcompl_compat(struct async *as, void __user * __user *arg) | 1213 | static int processcompl_compat(struct async *as, void __user * __user *arg) |