Skip to content

Commit

Permalink
io_uring/kbuf: prune deferred locked cache when tearing down
Browse files Browse the repository at this point in the history
We used to just use our page list for final teardown, which would ensure
that we got all the buffers, even the ones that were not on the normal
cached list. But while moving to slab for the io_buffers, we know only
prune this list, not the deferred locked list that we have. This can
cause a leak of memory, if the workload ends up using the intermediate
locked list.

Fix this by always pruning both lists when tearing down.

Fixes: b3a4dbc ("io_uring/kbuf: Use slab for struct io_buffer objects")
Signed-off-by: Jens Axboe <[email protected]>
  • Loading branch information
axboe committed Nov 28, 2023
1 parent b10b73c commit 07d6063
Showing 1 changed file with 8 additions and 0 deletions.
8 changes: 8 additions & 0 deletions io_uring/kbuf.c
Original file line number Diff line number Diff line change
Expand Up @@ -306,6 +306,14 @@ void io_destroy_buffers(struct io_ring_ctx *ctx)
kfree(bl);
}

/*
* Move deferred locked entries to cache before pruning
*/
spin_lock(&ctx->completion_lock);
if (!list_empty(&ctx->io_buffers_comp))
list_splice_init(&ctx->io_buffers_comp, &ctx->io_buffers_cache);
spin_unlock(&ctx->completion_lock);

list_for_each_safe(item, tmp, &ctx->io_buffers_cache) {
buf = list_entry(item, struct io_buffer, list);
kmem_cache_free(io_buf_cachep, buf);
Expand Down

0 comments on commit 07d6063

Please sign in to comment.