]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
io_uring/rsrc: fix lost entries after cloned range
authorJoanne Koong <joannelkoong@gmail.com>
Thu, 4 Dec 2025 21:51:16 +0000 (13:51 -0800)
committerJens Axboe <axboe@kernel.dk>
Thu, 4 Dec 2025 22:46:13 +0000 (15:46 -0700)
When cloning with node replacements (IORING_REGISTER_DST_REPLACE),
destination entries after the cloned range are not copied over.

Add logic to copy them over to the new destination table.

Fixes: c1329532d5aa ("io_uring/rsrc: allow cloning with node replacements")
Cc: stable@vger.kernel.org
Signed-off-by: Joanne Koong <joannelkoong@gmail.com>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
io_uring/rsrc.c

index 04f56212398a57ed6d0bdc53307e154adda71a7f..a63474b331bf89c36ab279454189d3e5a9ae6938 100644 (file)
@@ -1205,7 +1205,7 @@ static int io_clone_buffers(struct io_ring_ctx *ctx, struct io_ring_ctx *src_ctx
        if (ret)
                return ret;
 
-       /* Fill entries in data from dst that won't overlap with src */
+       /* Copy original dst nodes from before the cloned range */
        for (i = 0; i < min(arg->dst_off, ctx->buf_table.nr); i++) {
                struct io_rsrc_node *node = ctx->buf_table.nodes[i];
 
@@ -1238,6 +1238,16 @@ static int io_clone_buffers(struct io_ring_ctx *ctx, struct io_ring_ctx *src_ctx
                i++;
        }
 
+       /* Copy original dst nodes from after the cloned range */
+       for (i = nbufs; i < ctx->buf_table.nr; i++) {
+               struct io_rsrc_node *node = ctx->buf_table.nodes[i];
+
+               if (node) {
+                       data.nodes[i] = node;
+                       node->refs++;
+               }
+       }
+
        /*
         * If asked for replace, put the old table. data->nodes[] holds both
         * old and new nodes at this point.