diff options
author | Pavel Begunkov <asml.silence@gmail.com> | 2025-01-28 20:56:11 +0000 |
---|---|---|
committer | Jens Axboe <axboe@kernel.dk> | 2025-01-28 15:10:40 -0700 |
commit | d19af0e9366298aa60afc0fb51ffcbd6205edcee (patch) | |
tree | 2fb3f95af2d1e1fc883de333ef05966b12fd9821 /io_uring/alloc_cache.c | |
parent | 16ac51a0a7aa051fd3b82fa077597488b5572d41 (diff) | |
download | linux-d19af0e9366298aa60afc0fb51ffcbd6205edcee.tar.gz linux-d19af0e9366298aa60afc0fb51ffcbd6205edcee.tar.bz2 linux-d19af0e9366298aa60afc0fb51ffcbd6205edcee.zip |
io_uring: add alloc_cache.c
Avoid inlining all and everything from alloc_cache.h and move cold bits
into a new file.
Signed-off-by: Pavel Begunkov <asml.silence@gmail.com>
Reviewed-by: Gabriel Krisman Bertazi <krisman@suse.de>
Link: https://lore.kernel.org/r/06984c6cd58e703f7cfae5ab3067912f9f635a06.1738087204.git.asml.silence@gmail.com
Signed-off-by: Jens Axboe <axboe@kernel.dk>
Diffstat (limited to 'io_uring/alloc_cache.c')
-rw-r--r-- | io_uring/alloc_cache.c | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/io_uring/alloc_cache.c b/io_uring/alloc_cache.c new file mode 100644 index 000000000000..58423888b736 --- /dev/null +++ b/io_uring/alloc_cache.c @@ -0,0 +1,44 @@ +// SPDX-License-Identifier: GPL-2.0 + +#include "alloc_cache.h" + +void io_alloc_cache_free(struct io_alloc_cache *cache, + void (*free)(const void *)) +{ + void *entry; + + if (!cache->entries) + return; + + while ((entry = io_alloc_cache_get(cache)) != NULL) + free(entry); + + kvfree(cache->entries); + cache->entries = NULL; +} + +/* returns false if the cache was initialized properly */ +bool io_alloc_cache_init(struct io_alloc_cache *cache, + unsigned max_nr, unsigned int size, + unsigned int init_bytes) +{ + cache->entries = kvmalloc_array(max_nr, sizeof(void *), GFP_KERNEL); + if (!cache->entries) + return true; + + cache->nr_cached = 0; + cache->max_cached = max_nr; + cache->elem_size = size; + cache->init_clear = init_bytes; + return false; +} + +void *io_cache_alloc_new(struct io_alloc_cache *cache, gfp_t gfp) +{ + void *obj; + + obj = kmalloc(cache->elem_size, gfp); + if (obj && cache->init_clear) + memset(obj, 0, cache->init_clear); + return obj; +} |