]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
io_uring/rw: split io_read() into a helper
authorJens Axboe <axboe@kernel.dk>
Mon, 11 Sep 2023 19:31:56 +0000 (13:31 -0600)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 27 Dec 2024 12:53:02 +0000 (13:53 +0100)
Commit a08d195b586a217d76b42062f88f375a3eedda4d upstream.

Add __io_read() which does the grunt of the work, leaving the completion
side to the new io_read(). No functional changes in this patch.

Reviewed-by: Gabriel Krisman Bertazi <krisman@suse.de>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
(cherry picked from commit a08d195b586a217d76b42062f88f375a3eedda4d)
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
io_uring/rw.c

index 9d6e17a244ae7947738c3145bb65eaf5ee24640d..d54f26db013585f216ef7c3dd62d4b88390b3761 100644 (file)
@@ -691,7 +691,7 @@ static int io_rw_init_file(struct io_kiocb *req, fmode_t mode)
        return 0;
 }
 
-int io_read(struct io_kiocb *req, unsigned int issue_flags)
+static int __io_read(struct io_kiocb *req, unsigned int issue_flags)
 {
        struct io_rw *rw = io_kiocb_to_cmd(req, struct io_rw);
        struct io_rw_state __s, *s = &__s;
@@ -836,7 +836,18 @@ done:
        /* it's faster to check here then delegate to kfree */
        if (iovec)
                kfree(iovec);
-       return kiocb_done(req, ret, issue_flags);
+       return ret;
+}
+
+int io_read(struct io_kiocb *req, unsigned int issue_flags)
+{
+       int ret;
+
+       ret = __io_read(req, issue_flags);
+       if (ret >= 0)
+               return kiocb_done(req, ret, issue_flags);
+
+       return ret;
 }
 
 static bool io_kiocb_start_write(struct io_kiocb *req, struct kiocb *kiocb)