1*10465441SEvalZero /** 2*10465441SEvalZero * @file 3*10465441SEvalZero * Memory pool API 4*10465441SEvalZero */ 5*10465441SEvalZero 6*10465441SEvalZero /* 7*10465441SEvalZero * Copyright (c) 2001-2004 Swedish Institute of Computer Science. 8*10465441SEvalZero * All rights reserved. 9*10465441SEvalZero * 10*10465441SEvalZero * Redistribution and use in source and binary forms, with or without modification, 11*10465441SEvalZero * are permitted provided that the following conditions are met: 12*10465441SEvalZero * 13*10465441SEvalZero * 1. Redistributions of source code must retain the above copyright notice, 14*10465441SEvalZero * this list of conditions and the following disclaimer. 15*10465441SEvalZero * 2. Redistributions in binary form must reproduce the above copyright notice, 16*10465441SEvalZero * this list of conditions and the following disclaimer in the documentation 17*10465441SEvalZero * and/or other materials provided with the distribution. 18*10465441SEvalZero * 3. The name of the author may not be used to endorse or promote products 19*10465441SEvalZero * derived from this software without specific prior written permission. 20*10465441SEvalZero * 21*10465441SEvalZero * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED 22*10465441SEvalZero * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF 23*10465441SEvalZero * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT 24*10465441SEvalZero * SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, 25*10465441SEvalZero * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT 26*10465441SEvalZero * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS 27*10465441SEvalZero * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN 28*10465441SEvalZero * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING 29*10465441SEvalZero * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY 30*10465441SEvalZero * OF SUCH DAMAGE. 31*10465441SEvalZero * 32*10465441SEvalZero * This file is part of the lwIP TCP/IP stack. 33*10465441SEvalZero * 34*10465441SEvalZero * Author: Adam Dunkels <[email protected]> 35*10465441SEvalZero * 36*10465441SEvalZero */ 37*10465441SEvalZero 38*10465441SEvalZero #ifndef LWIP_HDR_MEMP_H 39*10465441SEvalZero #define LWIP_HDR_MEMP_H 40*10465441SEvalZero 41*10465441SEvalZero #include "lwip/opt.h" 42*10465441SEvalZero 43*10465441SEvalZero #ifdef __cplusplus 44*10465441SEvalZero extern "C" { 45*10465441SEvalZero #endif 46*10465441SEvalZero 47*10465441SEvalZero /* run once with empty definition to handle all custom includes in lwippools.h */ 48*10465441SEvalZero #define LWIP_MEMPOOL(name,num,size,desc) 49*10465441SEvalZero #include "lwip/priv/memp_std.h" 50*10465441SEvalZero 51*10465441SEvalZero /** Create the list of all memory pools managed by memp. MEMP_MAX represents a NULL pool at the end */ 52*10465441SEvalZero typedef enum { 53*10465441SEvalZero #define LWIP_MEMPOOL(name,num,size,desc) MEMP_##name, 54*10465441SEvalZero #include "lwip/priv/memp_std.h" 55*10465441SEvalZero MEMP_MAX 56*10465441SEvalZero } memp_t; 57*10465441SEvalZero 58*10465441SEvalZero #include "lwip/priv/memp_priv.h" 59*10465441SEvalZero #include "lwip/stats.h" 60*10465441SEvalZero 61*10465441SEvalZero extern const struct memp_desc* const memp_pools[MEMP_MAX]; 62*10465441SEvalZero 63*10465441SEvalZero /** 64*10465441SEvalZero * @ingroup mempool 65*10465441SEvalZero * Declare prototype for private memory pool if it is used in multiple files 66*10465441SEvalZero */ 67*10465441SEvalZero #define LWIP_MEMPOOL_PROTOTYPE(name) extern const struct memp_desc memp_ ## name 68*10465441SEvalZero 69*10465441SEvalZero #if MEMP_MEM_MALLOC 70*10465441SEvalZero 71*10465441SEvalZero #define LWIP_MEMPOOL_DECLARE(name,num,size,desc) \ 72*10465441SEvalZero LWIP_MEMPOOL_DECLARE_STATS_INSTANCE(memp_stats_ ## name) \ 73*10465441SEvalZero const struct memp_desc memp_ ## name = { \ 74*10465441SEvalZero DECLARE_LWIP_MEMPOOL_DESC(desc) \ 75*10465441SEvalZero LWIP_MEMPOOL_DECLARE_STATS_REFERENCE(memp_stats_ ## name) \ 76*10465441SEvalZero LWIP_MEM_ALIGN_SIZE(size) \ 77*10465441SEvalZero }; 78*10465441SEvalZero 79*10465441SEvalZero #else /* MEMP_MEM_MALLOC */ 80*10465441SEvalZero 81*10465441SEvalZero /** 82*10465441SEvalZero * @ingroup mempool 83*10465441SEvalZero * Declare a private memory pool 84*10465441SEvalZero * Private mempools example: 85*10465441SEvalZero * .h: only when pool is used in multiple .c files: LWIP_MEMPOOL_PROTOTYPE(my_private_pool); 86*10465441SEvalZero * .c: 87*10465441SEvalZero * - in global variables section: LWIP_MEMPOOL_DECLARE(my_private_pool, 10, sizeof(foo), "Some description") 88*10465441SEvalZero * - call ONCE before using pool (e.g. in some init() function): LWIP_MEMPOOL_INIT(my_private_pool); 89*10465441SEvalZero * - allocate: void* my_new_mem = LWIP_MEMPOOL_ALLOC(my_private_pool); 90*10465441SEvalZero * - free: LWIP_MEMPOOL_FREE(my_private_pool, my_new_mem); 91*10465441SEvalZero * 92*10465441SEvalZero * To relocate a pool, declare it as extern in cc.h. Example for GCC: 93*10465441SEvalZero * extern u8_t \_\_attribute\_\_((section(".onchip_mem"))) memp_memory_my_private_pool_base[]; 94*10465441SEvalZero */ 95*10465441SEvalZero #define LWIP_MEMPOOL_DECLARE(name,num,size,desc) \ 96*10465441SEvalZero LWIP_DECLARE_MEMORY_ALIGNED(memp_memory_ ## name ## _base, ((num) * (MEMP_SIZE + MEMP_ALIGN_SIZE(size)))); \ 97*10465441SEvalZero \ 98*10465441SEvalZero LWIP_MEMPOOL_DECLARE_STATS_INSTANCE(memp_stats_ ## name) \ 99*10465441SEvalZero \ 100*10465441SEvalZero static struct memp *memp_tab_ ## name; \ 101*10465441SEvalZero \ 102*10465441SEvalZero const struct memp_desc memp_ ## name = { \ 103*10465441SEvalZero DECLARE_LWIP_MEMPOOL_DESC(desc) \ 104*10465441SEvalZero LWIP_MEMPOOL_DECLARE_STATS_REFERENCE(memp_stats_ ## name) \ 105*10465441SEvalZero LWIP_MEM_ALIGN_SIZE(size), \ 106*10465441SEvalZero (num), \ 107*10465441SEvalZero memp_memory_ ## name ## _base, \ 108*10465441SEvalZero &memp_tab_ ## name \ 109*10465441SEvalZero }; 110*10465441SEvalZero 111*10465441SEvalZero #endif /* MEMP_MEM_MALLOC */ 112*10465441SEvalZero 113*10465441SEvalZero /** 114*10465441SEvalZero * @ingroup mempool 115*10465441SEvalZero * Initialize a private memory pool 116*10465441SEvalZero */ 117*10465441SEvalZero #define LWIP_MEMPOOL_INIT(name) memp_init_pool(&memp_ ## name) 118*10465441SEvalZero /** 119*10465441SEvalZero * @ingroup mempool 120*10465441SEvalZero * Allocate from a private memory pool 121*10465441SEvalZero */ 122*10465441SEvalZero #define LWIP_MEMPOOL_ALLOC(name) memp_malloc_pool(&memp_ ## name) 123*10465441SEvalZero /** 124*10465441SEvalZero * @ingroup mempool 125*10465441SEvalZero * Free element from a private memory pool 126*10465441SEvalZero */ 127*10465441SEvalZero #define LWIP_MEMPOOL_FREE(name, x) memp_free_pool(&memp_ ## name, (x)) 128*10465441SEvalZero 129*10465441SEvalZero #if MEM_USE_POOLS 130*10465441SEvalZero /** This structure is used to save the pool one element came from. 131*10465441SEvalZero * This has to be defined here as it is required for pool size calculation. */ 132*10465441SEvalZero struct memp_malloc_helper 133*10465441SEvalZero { 134*10465441SEvalZero memp_t poolnr; 135*10465441SEvalZero #if MEMP_OVERFLOW_CHECK || (LWIP_STATS && MEM_STATS) 136*10465441SEvalZero u16_t size; 137*10465441SEvalZero #endif /* MEMP_OVERFLOW_CHECK || (LWIP_STATS && MEM_STATS) */ 138*10465441SEvalZero }; 139*10465441SEvalZero #endif /* MEM_USE_POOLS */ 140*10465441SEvalZero 141*10465441SEvalZero void memp_init(void); 142*10465441SEvalZero 143*10465441SEvalZero #if MEMP_OVERFLOW_CHECK 144*10465441SEvalZero void *memp_malloc_fn(memp_t type, const char* file, const int line); 145*10465441SEvalZero #define memp_malloc(t) memp_malloc_fn((t), __FILE__, __LINE__) 146*10465441SEvalZero #else 147*10465441SEvalZero void *memp_malloc(memp_t type); 148*10465441SEvalZero #endif 149*10465441SEvalZero void memp_free(memp_t type, void *mem); 150*10465441SEvalZero 151*10465441SEvalZero #ifdef __cplusplus 152*10465441SEvalZero } 153*10465441SEvalZero #endif 154*10465441SEvalZero 155*10465441SEvalZero #endif /* LWIP_HDR_MEMP_H */ 156