]> git.ipfire.org Git - thirdparty/kernel/stable.git/commit
io_uring: fix return value when removing provided buffers
authorWojciech Lukowicz <wlukowicz01@gmail.com>
Sat, 1 Apr 2023 19:50:38 +0000 (20:50 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 13 Apr 2023 15:02:53 +0000 (17:02 +0200)
commitaf882684962e493f0a809f7f43d15eda58098905
treea93446facaf812e3630d9cd0a5f9e88ee16756c7
parent48d8bbb6b6cf8415bfa095ea94a2d78565d64a72
io_uring: fix return value when removing provided buffers

[ Upstream commit c0921e51dab767ef5adf6175c4a0ba3c6e1074a3 ]

When a request to remove buffers is submitted, and the given number to be
removed is larger than available in the specified buffer group, the
resulting CQE result will be the number of removed buffers + 1, which is
1 more than it should be.

Previously, the head was part of the list and it got removed after the
loop, so the increment was needed. Now, the head is not an element of
the list, so the increment shouldn't be there anymore.

Fixes: dbc7d452e7cf ("io_uring: manage provided buffers strictly ordered")
Signed-off-by: Wojciech Lukowicz <wlukowicz01@gmail.com>
Link: https://lore.kernel.org/r/20230401195039.404909-2-wlukowicz01@gmail.com
Signed-off-by: Jens Axboe <axboe@kernel.dk>
Signed-off-by: Sasha Levin <sashal@kernel.org>
io_uring/kbuf.c