| 
									
										
										
										
											2021-10-30 00:48:19 +08:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2022-01-17 17:44:25 +08:00
										 |  |  |  * SPDX-FileCopyrightText: 2015-2022 Espressif Systems (Shanghai) CO LTD | 
					
						
							| 
									
										
										
										
											2021-10-30 00:48:19 +08:00
										 |  |  |  * | 
					
						
							|  |  |  |  * SPDX-License-Identifier: Apache-2.0 | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2017-04-28 14:08:58 +10:00
										 |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-18 17:04:49 +01:00
										 |  |  | #ifdef MULTI_HEAP_FREERTOS
 | 
					
						
							| 
									
										
										
										
											2017-04-28 14:08:58 +10:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-06 15:00:07 +11:00
										 |  |  | #include "freertos/FreeRTOS.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-06 10:57:29 +08:00
										 |  |  | #include "sdkconfig.h"
 | 
					
						
							| 
									
										
										
										
											2020-07-21 13:07:34 +08:00
										 |  |  | #include "esp_rom_sys.h"
 | 
					
						
							| 
									
										
										
										
											2017-09-18 14:51:51 +10:00
										 |  |  | #include <assert.h>
 | 
					
						
							| 
									
										
										
										
											2017-04-28 14:08:58 +10:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-18 17:04:49 +01:00
										 |  |  | typedef portMUX_TYPE multi_heap_lock_t; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-28 14:08:58 +10:00
										 |  |  | /* Because malloc/free can happen inside an ISR context,
 | 
					
						
							|  |  |  |    we need to use portmux spinlocks here not RTOS mutexes */ | 
					
						
							| 
									
										
										
										
											2019-12-18 17:04:49 +01:00
										 |  |  | #define MULTI_HEAP_LOCK(PLOCK) do {                         \
 | 
					
						
							| 
									
										
										
										
											2017-04-28 14:08:58 +10:00
										 |  |  |         if((PLOCK) != NULL) {                               \ | 
					
						
							| 
									
										
										
										
											2019-12-18 17:04:49 +01:00
										 |  |  |             portENTER_CRITICAL((PLOCK));                    \ | 
					
						
							| 
									
										
										
										
											2017-04-28 14:08:58 +10:00
										 |  |  |         }                                                   \ | 
					
						
							|  |  |  |     } while(0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-18 17:04:49 +01:00
										 |  |  | #define MULTI_HEAP_UNLOCK(PLOCK) do {                       \
 | 
					
						
							| 
									
										
										
										
											2017-04-28 14:08:58 +10:00
										 |  |  |         if ((PLOCK) != NULL) {                              \ | 
					
						
							| 
									
										
										
										
											2019-12-18 17:04:49 +01:00
										 |  |  |             portEXIT_CRITICAL((PLOCK));                     \ | 
					
						
							| 
									
										
										
										
											2017-04-28 14:08:58 +10:00
										 |  |  |         }                                                   \ | 
					
						
							|  |  |  |     } while(0) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-18 17:04:49 +01:00
										 |  |  | #define MULTI_HEAP_LOCK_INIT(PLOCK) do {                    \
 | 
					
						
							| 
									
										
										
										
											2021-10-30 00:48:19 +08:00
										 |  |  |         portMUX_INITIALIZE((PLOCK));                        \ | 
					
						
							| 
									
										
										
										
											2019-12-18 17:04:49 +01:00
										 |  |  |     } while(0) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define MULTI_HEAP_LOCK_STATIC_INITIALIZER     portMUX_INITIALIZER_UNLOCKED
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-04-28 14:08:58 +10:00
										 |  |  | /* Not safe to use std i/o while in a portmux critical section,
 | 
					
						
							|  |  |  |    can deadlock, so we use the ROM equivalent functions. */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-21 13:07:34 +08:00
										 |  |  | #define MULTI_HEAP_PRINTF esp_rom_printf
 | 
					
						
							|  |  |  | #define MULTI_HEAP_STDERR_PRINTF(MSG, ...) esp_rom_printf(MSG, __VA_ARGS__)
 | 
					
						
							| 
									
										
										
										
											2017-04-28 14:08:58 +10:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-18 14:51:51 +10:00
										 |  |  | inline static void multi_heap_assert(bool condition, const char *format, int line, intptr_t address) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |     /* Can't use libc assert() here as it calls printf() which can cause another malloc() for a newlib lock.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |        Also, it's useful to be able to print the memory address where corruption was detected. | 
					
						
							|  |  |  |     */ | 
					
						
							|  |  |  | #ifndef NDEBUG
 | 
					
						
							|  |  |  |     if(!condition) { | 
					
						
							| 
									
										
										
										
											2019-04-24 15:02:25 +02:00
										 |  |  | #ifndef CONFIG_COMPILER_OPTIMIZATION_ASSERTIONS_SILENT
 | 
					
						
							| 
									
										
										
										
											2020-07-21 13:07:34 +08:00
										 |  |  |         esp_rom_printf(format, line, address); | 
					
						
							| 
									
										
										
										
											2019-04-24 15:02:25 +02:00
										 |  |  | #endif  // CONFIG_COMPILER_OPTIMIZATION_ASSERTIONS_SILENT
 | 
					
						
							| 
									
										
										
										
											2017-09-18 14:51:51 +10:00
										 |  |  |         abort(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | #else // NDEBUG
 | 
					
						
							|  |  |  |     (void) condition; | 
					
						
							|  |  |  | #endif // NDEBUG
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #define MULTI_HEAP_ASSERT(CONDITION, ADDRESS) \
 | 
					
						
							|  |  |  |     multi_heap_assert((CONDITION), "CORRUPT HEAP: multi_heap.c:%d detected at 0x%08x\n", \ | 
					
						
							|  |  |  |                       __LINE__, (intptr_t)(ADDRESS)) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-10 01:14:47 -08:00
										 |  |  | #ifdef CONFIG_HEAP_TASK_TRACKING
 | 
					
						
							| 
									
										
										
										
											2018-04-26 11:03:43 +05:30
										 |  |  | #include <freertos/task.h>
 | 
					
						
							| 
									
										
										
										
											2018-01-10 01:14:47 -08:00
										 |  |  | #define MULTI_HEAP_BLOCK_OWNER TaskHandle_t task;
 | 
					
						
							|  |  |  | #define MULTI_HEAP_SET_BLOCK_OWNER(HEAD) (HEAD)->task = xTaskGetCurrentTaskHandle()
 | 
					
						
							|  |  |  | #define MULTI_HEAP_GET_BLOCK_OWNER(HEAD) ((HEAD)->task)
 | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | #define MULTI_HEAP_BLOCK_OWNER
 | 
					
						
							|  |  |  | #define MULTI_HEAP_SET_BLOCK_OWNER(HEAD)
 | 
					
						
							|  |  |  | #define MULTI_HEAP_GET_BLOCK_OWNER(HEAD) (NULL)
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-18 17:04:49 +01:00
										 |  |  | #else // MULTI_HEAP_FREERTOS
 | 
					
						
							| 
									
										
										
										
											2017-09-18 14:51:51 +10:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include <assert.h>
 | 
					
						
							| 
									
										
										
										
											2017-04-28 14:08:58 +10:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define MULTI_HEAP_PRINTF printf
 | 
					
						
							|  |  |  | #define MULTI_HEAP_STDERR_PRINTF(MSG, ...) fprintf(stderr, MSG, __VA_ARGS__)
 | 
					
						
							| 
									
										
										
										
											2019-12-18 17:04:49 +01:00
										 |  |  | #define MULTI_HEAP_LOCK(PLOCK)  (void) (PLOCK)
 | 
					
						
							|  |  |  | #define MULTI_HEAP_UNLOCK(PLOCK)  (void) (PLOCK)
 | 
					
						
							|  |  |  | #define MULTI_HEAP_LOCK_INIT(PLOCK)  (void) (PLOCK)
 | 
					
						
							|  |  |  | #define MULTI_HEAP_LOCK_STATIC_INITIALIZER  0
 | 
					
						
							| 
									
										
										
										
											2017-04-28 14:08:58 +10:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-09-18 14:51:51 +10:00
										 |  |  | #define MULTI_HEAP_ASSERT(CONDITION, ADDRESS) assert((CONDITION) && "Heap corrupt")
 | 
					
						
							| 
									
										
										
										
											2018-01-10 01:14:47 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define MULTI_HEAP_BLOCK_OWNER
 | 
					
						
							|  |  |  | #define MULTI_HEAP_SET_BLOCK_OWNER(HEAD)
 | 
					
						
							|  |  |  | #define MULTI_HEAP_GET_BLOCK_OWNER(HEAD) (NULL)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-18 17:04:49 +01:00
										 |  |  | #endif // MULTI_HEAP_FREERTOS
 |