Select one of the symbols to view example projects that use it.
 
Outline
#include <stdlib.h>
#include <stdint.h>
#include <soc/soc_memory_layout.h>
#include "multi_heap.h"
#include "multi_heap_platform.h"
#include "sys/queue.h"
#include "esp_attr.h"
#define HEAP_SIZE_MAX
heap_t_
registered_heaps;
heap_caps_match(const heap_t *, uint32_t);
get_all_caps(const heap_t *)
find_containing_heap(void *)
heap_caps_realloc_default(void *, size_t);
heap_caps_malloc_default(size_t);
heap_caps_aligned_alloc_default(size_t, size_t);
heap_caps_realloc_base(void *, size_t, uint32_t);
heap_caps_calloc_base(size_t, size_t, uint32_t);
heap_caps_malloc_base(size_t, uint32_t);
heap_caps_aligned_alloc_base(size_t, size_t, uint32_t);
Files
ESP-IDF
components
app_trace
app_update
bootloader_support
bt
cmock
console
cxx
driver
efuse
esp_adc
esp_app_format
esp_bootloader_format
esp_coex
esp_common
esp_driver_ana_cmpr
esp_driver_cam
esp_driver_dac
esp_driver_gpio
esp_driver_gptimer
esp_driver_i2c
esp_driver_i2s
esp_driver_jpeg
esp_driver_ledc
esp_driver_mcpwm
esp_driver_parlio
esp_driver_pcnt
esp_driver_rmt
esp_driver_sdio
esp_driver_sdm
esp_driver_sdmmc
esp_driver_sdspi
esp_driver_spi
esp_driver_tsens
esp_driver_uart
esp_driver_usb_serial_jtag
esp_eth
esp_event
esp_gdbstub
esp_hid
esp_http_client
esp_http_server
esp_https_ota
esp_https_server
esp_hw_support
esp_lcd
esp_local_ctrl
esp_mm
esp_netif
esp_partition
esp_phy
esp_pm
esp_psram
esp_ringbuf
esp_rom
esp_security
esp_system
esp_timer
esp_vfs_console
esp_wifi
esp-tls
espcoredump
hal
heap
include
port
tlsf
http_parser
ieee802154
log
mqtt
newlib
nvs_flash
nvs_sec_provider
openthread
perfmon
protobuf-c
protocomm
pthread
rt
sdmmc
soc
spi_flash
spiffs
tcp_transport
ulp
unity
vfs
wear_levelling
wifi_provisioning
wpa_supplicant
xtensa
examples
lwIP
FreeRTOS
cJSON
mbedTLS
SourceVuESP-IDF Framework and ExamplesESP-IDFcomponents/heap/heap_private.h
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
/* * SPDX-FileCopyrightText: 2015-2024 Espressif Systems (Shanghai) CO LTD * * SPDX-License-Identifier: Apache-2.0 *//* ... */ #pragma once #include <stdlib.h> #include <stdint.h> #include <soc/soc_memory_layout.h> #include "multi_heap.h" #include "multi_heap_platform.h" #include "sys/queue.h" #include "esp_attr.h"7 includes #ifdef __cplusplus extern "C" { #endif /* Some common heap registration data structures used for heap_caps_init.c to share heap information with heap_caps.c *//* ... */ #define HEAP_SIZE_MAX (SOC_MAX_CONTIGUOUS_RAM_SIZE) /* Type for describing each registered heap */ typedef struct heap_t_ { uint32_t caps[SOC_MEMORY_TYPE_NO_PRIOS]; ///< Capabilities for the type of memory in this heap (as a prioritised set). Copied from soc_memory_types so it's in RAM not flash. intptr_t start; intptr_t end; multi_heap_lock_t heap_mux; multi_heap_handle_t heap; SLIST_ENTRY(heap_t_) next; }{ ... } heap_t; /* All registered heaps. Forms a single linked list, even though most entries are contiguous. This means at the expense of 4 bytes per heap, new heaps can be added at runtime in a fast & thread-safe way. *//* ... */ extern SLIST_HEAD(registered_heap_ll, heap_t_) registered_heaps; bool heap_caps_match(const heap_t *heap, uint32_t caps); /* return all possible capabilities (across all priorities) for a given heap */ FORCE_INLINE_ATTR uint32_t get_all_caps(const heap_t *heap) { if (heap->heap == NULL) { return 0; }{...} uint32_t all_caps = 0; for (int prio = 0; prio < SOC_MEMORY_TYPE_NO_PRIOS; prio++) { all_caps |= heap->caps[prio]; }{...} return all_caps; }{ ... } /* Find the heap which belongs to ptr, or return NULL if it's not in any heap. (This confirms if ptr is inside the heap's region, doesn't confirm if 'ptr' is an allocated block or is some other random address inside the heap.) *//* ... */ FORCE_INLINE_ATTR heap_t *find_containing_heap(void *ptr ) { intptr_t p = (intptr_t)ptr; heap_t *heap; SLIST_FOREACH(heap, &registered_heaps, next) { if (heap->heap != NULL && p >= heap->start && p < heap->end) { return heap; }{...} }{...} return NULL; }{ ... } /* Because we don't want to add _another_ known allocation method to the stack of functions to trace wrt memory tracing, these are declared private. The newlib malloc()/realloc() implementation also calls these, so they are declared separately in newlib/syscalls.c. *//* ... */ void *heap_caps_realloc_default(void *p, size_t size); void *heap_caps_malloc_default(size_t size); void *heap_caps_aligned_alloc_default(size_t alignment, size_t size); void *heap_caps_realloc_base(void *ptr, size_t size, uint32_t caps); void *heap_caps_calloc_base(size_t n, size_t size, uint32_t caps); void *heap_caps_malloc_base(size_t size, uint32_t caps); void *heap_caps_aligned_alloc_base(size_t alignment, size_t size, uint32_t caps); #ifdef __cplusplus }{...} #endif
Details