]> www.infradead.org Git - users/dwmw2/linux.git/commitdiff
io_uring: align iowq and task request error handling
authorPavel Begunkov <asml.silence@gmail.com>
Wed, 24 Jul 2024 11:16:21 +0000 (12:16 +0100)
committerJens Axboe <axboe@kernel.dk>
Wed, 24 Jul 2024 14:01:49 +0000 (08:01 -0600)
There is a difference in how io_queue_sqe and io_wq_submit_work treat
error codes they get from io_issue_sqe. The first one fails anything
unknown but latter only fails when the code is negative.

It doesn't make sense to have this discrepancy, align them to the
io_queue_sqe behaviour.

Signed-off-by: Pavel Begunkov <asml.silence@gmail.com>
Link: https://lore.kernel.org/r/c550e152bf4a290187f91a4322ddcb5d6d1f2c73.1721819383.git.asml.silence@gmail.com
Signed-off-by: Jens Axboe <axboe@kernel.dk>
io_uring/io_uring.c

index 10c409e56241e7009d0ac3b22b35357189ad2a30..2626424f5d73d05c9ca1d8c3eb6c53d5b305b345 100644 (file)
@@ -1849,7 +1849,7 @@ fail:
        } while (1);
 
        /* avoid locking problems by failing it from a clean context */
-       if (ret < 0)
+       if (ret)
                io_req_task_queue_fail(req, ret);
 }