summaryrefslogtreecommitdiffstats
path: root/io_uring/splice.c
diff options
context:
space:
mode:
authorJens Axboe <axboe@kernel.dk>2024-10-26 18:41:51 +0200
committerJens Axboe <axboe@kernel.dk>2024-11-02 22:44:30 +0100
commit0701db7439208951c8a7d8600668e5cfdd5f63d2 (patch)
treeda619885e5375a534c829a3ca613e8e0b9320060 /io_uring/splice.c
parentio_uring/rsrc: get rid of io_rsrc_node allocation cache (diff)
downloadlinux-0701db7439208951c8a7d8600668e5cfdd5f63d2.tar.xz
linux-0701db7439208951c8a7d8600668e5cfdd5f63d2.zip
io_uring/rsrc: add an empty io_rsrc_node for sparse buffer entries
Rather than allocate an io_rsrc_node for an empty/sparse buffer entry, add a const entry that can be used for that. This just needs checking for writing the tag, and the put check needs to check for that sparse node rather than NULL for validity. This avoids allocating rsrc nodes for sparse buffer entries. Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to '')
-rw-r--r--io_uring/splice.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/io_uring/splice.c b/io_uring/splice.c
index a0b4e0435b8b..f78afb575ae6 100644
--- a/io_uring/splice.c
+++ b/io_uring/splice.c
@@ -35,7 +35,7 @@ static int __io_splice_prep(struct io_kiocb *req,
if (unlikely(sp->flags & ~valid_flags))
return -EINVAL;
sp->splice_fd_in = READ_ONCE(sqe->splice_fd_in);
- sp->rsrc_node = NULL;
+ sp->rsrc_node = rsrc_empty_node;
req->flags |= REQ_F_FORCE_ASYNC;
return 0;
}