Skip to content

Commit

Permalink
sanitize do_i2c_smbus_ioctl()
Browse files Browse the repository at this point in the history
no need to mess with __copy_in_user()

Signed-off-by: Al Viro <[email protected]>
  • Loading branch information
Al Viro committed May 25, 2017
1 parent 2ea659a commit 8d1a81a
Showing 1 changed file with 9 additions and 10 deletions.
19 changes: 9 additions & 10 deletions fs/compat_ioctl.c
Original file line number Diff line number Diff line change
Expand Up @@ -739,23 +739,22 @@ static int do_i2c_smbus_ioctl(struct file *file,
unsigned int cmd, struct i2c_smbus_ioctl_data32 __user *udata)
{
struct i2c_smbus_ioctl_data __user *tdata;
compat_caddr_t datap;
union {
/* beginnings of those have identical layouts */
struct i2c_smbus_ioctl_data32 data32;
struct i2c_smbus_ioctl_data data;
} v;

tdata = compat_alloc_user_space(sizeof(*tdata));
if (tdata == NULL)
return -ENOMEM;
if (!access_ok(VERIFY_WRITE, tdata, sizeof(*tdata)))
return -EFAULT;

if (!access_ok(VERIFY_READ, udata, sizeof(*udata)))
memset(&v, 0, sizeof(v));
if (copy_from_user(&v.data32, udata, sizeof(v.data32)))
return -EFAULT;
v.data.data = compat_ptr(v.data32.data);

if (__copy_in_user(&tdata->read_write, &udata->read_write, 2 * sizeof(u8)))
return -EFAULT;
if (__copy_in_user(&tdata->size, &udata->size, 2 * sizeof(u32)))
return -EFAULT;
if (__get_user(datap, &udata->data) ||
__put_user(compat_ptr(datap), &tdata->data))
if (copy_to_user(tdata, &v.data, sizeof(v.data)))
return -EFAULT;

return do_ioctl(file, cmd, (unsigned long)tdata);
Expand Down

0 comments on commit 8d1a81a

Please sign in to comment.