diff options
author | Jens Axboe <axboe@kernel.dk> | 2024-10-26 18:41:51 +0200 |
---|---|---|
committer | Jens Axboe <axboe@kernel.dk> | 2024-11-02 22:44:30 +0100 |
commit | 0701db7439208951c8a7d8600668e5cfdd5f63d2 (patch) | |
tree | da619885e5375a534c829a3ca613e8e0b9320060 /io_uring/splice.c | |
parent | io_uring/rsrc: get rid of io_rsrc_node allocation cache (diff) | |
download | linux-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.c | 2 |
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; } |