1.. _memory_slabs_v2: 2 3Memory Slabs 4############ 5 6A :dfn:`memory slab` is a kernel object that allows memory blocks 7to be dynamically allocated from a designated memory region. 8All memory blocks in a memory slab have a single fixed size, 9allowing them to be allocated and released efficiently 10and avoiding memory fragmentation concerns. 11 12.. contents:: 13 :local: 14 :depth: 2 15 16Concepts 17******** 18 19Any number of memory slabs can be defined (limited only by available RAM). Each 20memory slab is referenced by its memory address. 21 22A memory slab has the following key properties: 23 24* The **block size** of each block, measured in bytes. 25 It must be at least 4N bytes long, where N is greater than 0. 26 27* The **number of blocks** available for allocation. 28 It must be greater than zero. 29 30* A **buffer** that provides the memory for the memory slab's blocks. 31 It must be at least "block size" times "number of blocks" bytes long. 32 33The memory slab's buffer must be aligned to an N-byte boundary, where 34N is a power of 2 larger than 2 (i.e. 4, 8, 16, ...). To ensure that 35all memory blocks in the buffer are similarly aligned to this boundary, 36the block size must also be a multiple of N. 37 38A memory slab must be initialized before it can be used. This marks all of 39its blocks as unused. 40 41A thread that needs to use a memory block simply allocates it from a memory 42slab. When the thread finishes with a memory block, 43it must release the block back to the memory slab so the block can be reused. 44 45If all the blocks are currently in use, a thread can optionally wait 46for one to become available. 47Any number of threads may wait on an empty memory slab simultaneously; 48when a memory block becomes available, it is given to the highest-priority 49thread that has waited the longest. 50 51Unlike a heap, more than one memory slab can be defined, if needed. This 52allows for a memory slab with smaller blocks and others with larger-sized 53blocks. Alternatively, a memory pool object may be used. 54 55Internal Operation 56================== 57 58A memory slab's buffer is an array of fixed-size blocks, 59with no wasted space between the blocks. 60 61The memory slab keeps track of unallocated blocks using a linked list; 62the first 4 bytes of each unused block provide the necessary linkage. 63 64Implementation 65************** 66 67Defining a Memory Slab 68====================== 69 70A memory slab is defined using a variable of type :c:type:`k_mem_slab`. 71It must then be initialized by calling :c:func:`k_mem_slab_init`. 72 73The following code defines and initializes a memory slab that has 6 blocks 74that are 400 bytes long, each of which is aligned to a 4-byte boundary. 75 76.. code-block:: c 77 78 struct k_mem_slab my_slab; 79 char __aligned(4) my_slab_buffer[6 * 400]; 80 81 k_mem_slab_init(&my_slab, my_slab_buffer, 400, 6); 82 83Alternatively, a memory slab can be defined and initialized at compile time 84by calling :c:macro:`K_MEM_SLAB_DEFINE`. 85 86The following code has the same effect as the code segment above. Observe 87that the macro defines both the memory slab and its buffer. 88 89.. code-block:: c 90 91 K_MEM_SLAB_DEFINE(my_slab, 400, 6, 4); 92 93Similarly, you can define a memory slab in private scope: 94 95.. code-block:: c 96 97 K_MEM_SLAB_DEFINE_STATIC(my_slab, 400, 6, 4); 98 99Allocating a Memory Block 100========================= 101 102A memory block is allocated by calling :c:func:`k_mem_slab_alloc`. 103 104The following code builds on the example above, and waits up to 100 milliseconds 105for a memory block to become available, then fills it with zeroes. 106A warning is printed if a suitable block is not obtained. 107 108.. code-block:: c 109 110 char *block_ptr; 111 112 if (k_mem_slab_alloc(&my_slab, (void **)&block_ptr, K_MSEC(100)) == 0) { 113 memset(block_ptr, 0, 400); 114 ... 115 } else { 116 printf("Memory allocation time-out"); 117 } 118 119Releasing a Memory Block 120======================== 121 122A memory block is released by calling :c:func:`k_mem_slab_free`. 123 124The following code builds on the example above, and allocates a memory block, 125then releases it once it is no longer needed. 126 127.. code-block:: c 128 129 char *block_ptr; 130 131 k_mem_slab_alloc(&my_slab, (void **)&block_ptr, K_FOREVER); 132 ... /* use memory block pointed at by block_ptr */ 133 k_mem_slab_free(&my_slab, (void *)block_ptr); 134 135Suggested Uses 136************** 137 138Use a memory slab to allocate and free memory in fixed-size blocks. 139 140Use memory slab blocks when sending large amounts of data from one thread 141to another, to avoid unnecessary copying of the data. 142 143Configuration Options 144********************* 145 146Related configuration options: 147 148* :kconfig:option:`CONFIG_MEM_SLAB_TRACE_MAX_UTILIZATION` 149 150API Reference 151************* 152 153.. doxygengroup:: mem_slab_apis 154