Zephyr Project API  3.2.0
A Scalable Open Source RTOS
mem_blocks.h
Go to the documentation of this file.
1/*
2 * Copyright (c) 2021 Intel Corporation
3 *
4 * SPDX-License-Identifier: Apache-2.0
5 */
6
13#ifndef ZEPHYR_INCLUDE_SYS_MEM_BLOCKS_H_
14#define ZEPHYR_INCLUDE_SYS_MEM_BLOCKS_H_
15
16#ifdef __cplusplus
17extern "C" {
18#endif
19
20#include <stddef.h>
21#include <stdint.h>
22
23#include <zephyr/kernel.h>
24#include <zephyr/math/ilog2.h>
25#include <zephyr/sys/bitarray.h>
27
28#define MAX_MULTI_ALLOCATORS 8
29
39struct sys_mem_blocks;
40
44struct sys_multi_mem_blocks;
45
51typedef struct sys_mem_blocks sys_mem_blocks_t;
52
58typedef struct sys_multi_mem_blocks sys_multi_mem_blocks_t;
59
78typedef sys_mem_blocks_t *(*sys_multi_mem_blocks_choice_fn_t)
79 (struct sys_multi_mem_blocks *group, void *cfg);
80
85struct sys_mem_blocks {
86 /* Number of blocks */
87 uint32_t num_blocks;
88
89 /* Bit shift for block size */
90 uint8_t blk_sz_shift;
91
92 /* Memory block buffer */
94
95 /* Bitmap of allocated blocks */
96 sys_bitarray_t *bitmap;
97
98#ifdef CONFIG_SYS_MEM_BLOCKS_RUNTIME_STATS
99 /* Spinlock guarding access to memory block internals */
100 struct k_spinlock lock;
101
102 uint32_t used_blocks;
103 uint32_t max_used_blocks;
104#endif
105
106};
107
108struct sys_multi_mem_blocks {
109 /* Number of allocators in this group */
110 int num_allocators;
113};
114
124#define _SYS_MEM_BLOCKS_DEFINE_WITH_EXT_BUF(name, blk_sz, num_blks, buf, mbmod) \
125 _SYS_BITARRAY_DEFINE(_sys_mem_blocks_bitmap_##name, \
126 num_blks, mbmod); \
127 mbmod sys_mem_blocks_t name = { \
128 .num_blocks = num_blks, \
129 .blk_sz_shift = ilog2(blk_sz), \
130 .buffer = buf, \
131 .bitmap = &_sys_mem_blocks_bitmap_##name, \
132 }
133
143#define _SYS_MEM_BLOCKS_DEFINE(name, blk_sz, num_blks, balign, mbmod) \
144 mbmod uint8_t __noinit_named(sys_mem_blocks_buf_##name) \
145 __aligned(WB_UP(balign)) \
146 _sys_mem_blocks_buf_##name[num_blks * WB_UP(blk_sz)]; \
147 _SYS_MEM_BLOCKS_DEFINE_WITH_EXT_BUF(name, blk_sz, num_blks, \
148 _sys_mem_blocks_buf_##name, \
149 mbmod);
150
163#define SYS_MEM_BLOCKS_DEFINE(name, blk_sz, num_blks, buf_align) \
164 _SYS_MEM_BLOCKS_DEFINE(name, blk_sz, num_blks, buf_align,)
165
174#define SYS_MEM_BLOCKS_DEFINE_STATIC(name, blk_sz, num_blks, buf_align) \
175 _SYS_MEM_BLOCKS_DEFINE(name, blk_sz, num_blks, buf_align, static)
176
177
186#define SYS_MEM_BLOCKS_DEFINE_WITH_EXT_BUF(name, blk_sz, num_blks, buf) \
187 _SYS_MEM_BLOCKS_DEFINE_WITH_EXT_BUF(name, blk_sz, num_blks, buf,)
188
197#define SYS_MEM_BLOCKS_DEFINE_STATIC_WITH_EXT_BUF(name, blk_sz, num_blks, buf) \
198 _SYS_MEM_BLOCKS_DEFINE_WITH_EXT_BUF(name, blk_sz, num_blks, buf, static)
199
217 void **out_blocks);
218
234 void **out_block);
235
253
265
281 void **in_blocks);
282
297
298#ifdef CONFIG_SYS_MEM_BLOCKS_RUNTIME_STATS
310int sys_mem_blocks_runtime_stats_get(sys_mem_blocks_t *mem_block,
311 struct sys_memory_stats *stats);
312
323int sys_mem_blocks_runtime_stats_reset_max(sys_mem_blocks_t *mem_block);
324#endif
325
339
350 sys_mem_blocks_t *alloc);
351
374 void *cfg, size_t count,
375 void **out_blocks,
376 size_t *blk_size);
377
394 size_t count, void **in_blocks);
395
398#ifdef __cplusplus
399}
400#endif
401
402#endif /* ZEPHYR_INCLUDE_SYS_MEM_BLOCKS_H_ */
ZTEST_BMEM int count
Definition: main.c:33
void sys_multi_mem_blocks_add_allocator(sys_multi_mem_blocks_t *group, sys_mem_blocks_t *alloc)
Add an allocator to an allocator group.
int sys_mem_blocks_get(sys_mem_blocks_t *mem_block, void *in_block, size_t count)
Force allocation of a specified blocks in a memory block object.
sys_mem_blocks_t *(* sys_multi_mem_blocks_choice_fn_t)(struct sys_multi_mem_blocks *group, void *cfg)
Multi memory blocks allocator choice function.
Definition: mem_blocks.h:79
int sys_mem_blocks_free_contiguous(sys_mem_blocks_t *mem_block, void *block, size_t count)
Free contiguous multiple memory blocks.
int sys_mem_blocks_alloc(sys_mem_blocks_t *mem_block, size_t count, void **out_blocks)
Allocate multiple memory blocks.
int sys_mem_blocks_alloc_contiguous(sys_mem_blocks_t *mem_block, size_t count, void **out_block)
Allocate a contiguous set of memory blocks.
int sys_mem_blocks_is_region_free(sys_mem_blocks_t *mem_block, void *in_block, size_t count)
check if the region is free
int sys_multi_mem_blocks_free(sys_multi_mem_blocks_t *group, size_t count, void **in_blocks)
Free memory allocated from multi memory blocks allocator group.
struct sys_mem_blocks sys_mem_blocks_t
Memory Blocks Allocator.
Definition: mem_blocks.h:51
struct sys_multi_mem_blocks sys_multi_mem_blocks_t
Multi Memory Blocks Allocator.
Definition: mem_blocks.h:58
void sys_multi_mem_blocks_init(sys_multi_mem_blocks_t *group, sys_multi_mem_blocks_choice_fn_t choice_fn)
Initialize multi memory blocks allocator group.
int sys_mem_blocks_free(sys_mem_blocks_t *mem_block, size_t count, void **in_blocks)
Free multiple memory blocks.
int sys_multi_mem_blocks_alloc(sys_multi_mem_blocks_t *group, void *cfg, size_t count, void **out_blocks, size_t *blk_size)
Allocate memory from multi memory blocks allocator group.
Provide ilog2() function.
Public kernel APIs.
#define MAX_MULTI_ALLOCATORS
Definition: mem_blocks.h:28
Memory Statistics.
static struct k_spinlock lock
Definition: spinlock_error_case.c:12
__UINT32_TYPE__ uint32_t
Definition: stdint.h:90
__UINT8_TYPE__ uint8_t
Definition: stdint.h:88
Kernel Spin Lock.
Definition: spinlock.h:42
Definition: test_pipe_contexts.c:43
Definition: bitarray.h:19
Definition: mem_stats.h:24
static ZTEST_BMEM char buffer[8]
Definition: test_mbox_api.c:551
void * block
Definition: test_threads_cancel_abort.c:108