virtio: console: Prevent userspace from submitting NULL buffers
A userspace could submit a buffer with 0 length to be written to the host. Prevent such a situation. This was not needed previously, but recent changes in the way write() works exposed this condition to trigger a virtqueue event to the host, causing a NULL buffer to be sent across. Signed-off-by: Amit Shah <amit.shah@redhat.com> Signed-off-by: Rusty Russell <rusty@rustcorp.com.au> CC: stable@kernel.org
This commit is contained in:
parent
6df7aadcd9
commit
65745422a8
|
@ -596,6 +596,10 @@ static ssize_t port_fops_write(struct file *filp, const char __user *ubuf,
|
|||
ssize_t ret;
|
||||
bool nonblock;
|
||||
|
||||
/* Userspace could be out to fool us */
|
||||
if (!count)
|
||||
return 0;
|
||||
|
||||
port = filp->private_data;
|
||||
|
||||
nonblock = filp->f_flags & O_NONBLOCK;
|
||||
|
|
Loading…
Reference in New Issue