io_uring: simplify io_rw_prep_async()
authorPavel Begunkov <asml.silence@gmail.com>
Sat, 5 Sep 2020 21:45:45 +0000 (00:45 +0300)
committerJens Axboe <axboe@kernel.dk>
Thu, 1 Oct 2020 02:32:33 +0000 (20:32 -0600)
Don't touch iter->iov and iov in between __io_import_iovec() and
io_req_map_rw(), the former function aleady sets it correctly, because it
creates one more case with NULL'ed iov to consider in io_req_map_rw().

Signed-off-by: Pavel Begunkov <asml.silence@gmail.com>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
fs/io_uring.c

index 3ee6ee1..6d8c2dc 100644 (file)
@@ -3065,16 +3065,14 @@ static inline int io_rw_prep_async(struct io_kiocb *req, int rw,
                                   bool force_nonblock)
 {
        struct io_async_rw *iorw = &req->io->rw;
-       struct iovec *iov;
+       struct iovec *iov = iorw->fast_iov;
        ssize_t ret;
 
-       iorw->iter.iov = iov = iorw->fast_iov;
        ret = __io_import_iovec(rw, req, &iov, &iorw->iter, !force_nonblock);
        if (unlikely(ret < 0))
                return ret;
 
-       iorw->iter.iov = iov;
-       io_req_map_rw(req, iorw->iter.iov, iorw->fast_iov, &iorw->iter);
+       io_req_map_rw(req, iov, iorw->fast_iov, &iorw->iter);
        return 0;
 }