Commit 86ff25ed authored by Greg Kroah-Hartman's avatar Greg Kroah-Hartman Committed by Wolfram Sang

i2c: dev: zero out array used for i2c reads from userspace

If an i2c driver happens to not provide the full amount of data that a
user asks for, it is possible that some uninitialized data could be sent
to userspace.  While all in-kernel drivers look to be safe, just be sure
by initializing the buffer to zero before it is passed to the i2c driver
so that any future drivers will not have this issue.

Also properly copy the amount of data recvieved to the userspace buffer,
as pointed out by Dan Carpenter.
Reported-by: default avatarEric Dumazet <edumazet@google.com>
Cc: stable@vger.kernel.org
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Signed-off-by: default avatarWolfram Sang <wsa@kernel.org>
parent bba676cc
...@@ -141,7 +141,7 @@ static ssize_t i2cdev_read(struct file *file, char __user *buf, size_t count, ...@@ -141,7 +141,7 @@ static ssize_t i2cdev_read(struct file *file, char __user *buf, size_t count,
if (count > 8192) if (count > 8192)
count = 8192; count = 8192;
tmp = kmalloc(count, GFP_KERNEL); tmp = kzalloc(count, GFP_KERNEL);
if (tmp == NULL) if (tmp == NULL)
return -ENOMEM; return -ENOMEM;
...@@ -150,7 +150,8 @@ static ssize_t i2cdev_read(struct file *file, char __user *buf, size_t count, ...@@ -150,7 +150,8 @@ static ssize_t i2cdev_read(struct file *file, char __user *buf, size_t count,
ret = i2c_master_recv(client, tmp, count); ret = i2c_master_recv(client, tmp, count);
if (ret >= 0) if (ret >= 0)
ret = copy_to_user(buf, tmp, count) ? -EFAULT : ret; if (copy_to_user(buf, tmp, ret))
ret = -EFAULT;
kfree(tmp); kfree(tmp);
return ret; return ret;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment