io_uring/kbuf: reject zero sized provided buffers
commit cf960726eb65e8d0bfecbcce6cf95f47b1ffa6cc upstream. This isn't fixing a real issue, but there's also zero point in going through group and buffer setup, when the buffers are going to be rejected once attempted to get used. Cc: stable@vger.kernel.org Reported-by: syzbot+58928048fd1416f1457c@syzkaller.appspotmail.com Signed-off-by: Jens Axboe <axboe@kernel.dk> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
This commit is contained in:
committed by
Greg Kroah-Hartman
parent
21b0c54546
commit
35c4a652d8
@@ -321,6 +321,8 @@ int io_provide_buffers_prep(struct io_kiocb *req, const struct io_uring_sqe *sqe
|
|||||||
p->nbufs = tmp;
|
p->nbufs = tmp;
|
||||||
p->addr = READ_ONCE(sqe->addr);
|
p->addr = READ_ONCE(sqe->addr);
|
||||||
p->len = READ_ONCE(sqe->len);
|
p->len = READ_ONCE(sqe->len);
|
||||||
|
if (!p->len)
|
||||||
|
return -EINVAL;
|
||||||
|
|
||||||
if (check_mul_overflow((unsigned long)p->len, (unsigned long)p->nbufs,
|
if (check_mul_overflow((unsigned long)p->len, (unsigned long)p->nbufs,
|
||||||
&size))
|
&size))
|
||||||
|
Reference in New Issue
Block a user