diff --git a/vlib/vlib/threads.h b/vlib/vlib/threads.h index 98f19c442e3..6c16878a5b5 100644 --- a/vlib/vlib/threads.h +++ b/vlib/vlib/threads.h @@ -50,6 +50,10 @@ typedef struct vlib_thread_registration_ { #define VLIB_MAX_CPUS 256 +#if VLIB_MAX_CPUS > CLIB_MAX_MHEAPS +#error Please increase number of per-cpu mheaps +#endif + #define VLIB_CPU_MASK (VLIB_MAX_CPUS - 1) /* 0x3f, max */ #define VLIB_OFFSET_MASK (~VLIB_CPU_MASK) diff --git a/vppinfra/vppinfra/mem.h b/vppinfra/vppinfra/mem.h index 938f2d23502..301bcdd0d32 100644 --- a/vppinfra/vppinfra/mem.h +++ b/vppinfra/vppinfra/mem.h @@ -46,8 +46,10 @@ #include /* memcpy, memset */ #include +#define CLIB_MAX_MHEAPS 256 + /* Per CPU heaps. */ -extern void * clib_per_cpu_mheaps[32]; +extern void * clib_per_cpu_mheaps[CLIB_MAX_MHEAPS]; always_inline void * clib_mem_get_per_cpu_heap (void) { diff --git a/vppinfra/vppinfra/mem_mheap.c b/vppinfra/vppinfra/mem_mheap.c index e25ae35b77a..5718c8ce618 100644 --- a/vppinfra/vppinfra/mem_mheap.c +++ b/vppinfra/vppinfra/mem_mheap.c @@ -50,7 +50,7 @@ clib_smp_main_t clib_smp_main = { .n_tls_4k_pages = 1, }; -void * clib_per_cpu_mheaps[32]; +void * clib_per_cpu_mheaps[CLIB_MAX_MHEAPS]; void clib_mem_exit (void) {