io_uring: truncate lengths larger than MAX_RW_COUNT on provide buffers
authorThadeu Lima de Souza Cascardo <cascardo@canonical.com>
Wed, 5 May 2021 12:47:06 +0000 (09:47 -0300)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 14 May 2021 07:49:55 +0000 (09:49 +0200)
commit7e916d0124e5f40d7912f93a633f5dee2c3ad735
tree54aba516856d71e616e5afe759f1287f9ca3dfc5
parent6b7021ed36dabf29e56842e3408781cd3b82ef6e
io_uring: truncate lengths larger than MAX_RW_COUNT on provide buffers

commit d1f82808877bb10d3deee7cf3374a4eb3fb582db upstream.

Read and write operations are capped to MAX_RW_COUNT. Some read ops rely on
that limit, and that is not guaranteed by the IORING_OP_PROVIDE_BUFFERS.

Truncate those lengths when doing io_add_buffers, so buffer addresses still
use the uncapped length.

Also, take the chance and change struct io_buffer len member to __u32, so
it matches struct io_provide_buffer len member.

This fixes CVE-2021-3491, also reported as ZDI-CAN-13546.

Fixes: ddf0322db79c ("io_uring: add IORING_OP_PROVIDE_BUFFERS")
Reported-by: Billy Jheng Bing-Jhong (@st424204)
Signed-off-by: Thadeu Lima de Souza Cascardo <cascardo@canonical.com>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
fs/io_uring.c