mirror of
https://github.com/espressif/esp-idf.git
synced 2024-10-05 20:47:46 -04:00
Merge branch 'bugfix/individual_custom_sections' into 'master'
linker: When using section type attributes, create unique sections See merge request idf/esp-idf!3920
This commit is contained in:
commit
d453cce1b3
@ -20,11 +20,11 @@
|
|||||||
//and all variables in shared RAM. These macros can be used to redirect
|
//and all variables in shared RAM. These macros can be used to redirect
|
||||||
//particular functions/variables to other memory regions.
|
//particular functions/variables to other memory regions.
|
||||||
|
|
||||||
// Forces code into IRAM instead of flash.
|
// Forces code into IRAM instead of flash
|
||||||
#define IRAM_ATTR __attribute__((section(".iram1")))
|
#define IRAM_ATTR _SECTION_ATTR_IMPL(".iram1", __COUNTER__)
|
||||||
|
|
||||||
// Forces data into DRAM instead of flash
|
// Forces data into DRAM instead of flash
|
||||||
#define DRAM_ATTR __attribute__((section(".dram1")))
|
#define DRAM_ATTR _SECTION_ATTR_IMPL(".dram1", __COUNTER__)
|
||||||
|
|
||||||
// Forces data to be 4 bytes aligned
|
// Forces data to be 4 bytes aligned
|
||||||
#define WORD_ALIGNED_ATTR __attribute__((aligned(4)))
|
#define WORD_ALIGNED_ATTR __attribute__((aligned(4)))
|
||||||
@ -37,11 +37,11 @@
|
|||||||
#define DRAM_STR(str) (__extension__({static const DRAM_ATTR char __c[] = (str); (const char *)&__c;}))
|
#define DRAM_STR(str) (__extension__({static const DRAM_ATTR char __c[] = (str); (const char *)&__c;}))
|
||||||
|
|
||||||
// Forces code into RTC fast memory. See "docs/deep-sleep-stub.rst"
|
// Forces code into RTC fast memory. See "docs/deep-sleep-stub.rst"
|
||||||
#define RTC_IRAM_ATTR __attribute__((section(".rtc.text")))
|
#define RTC_IRAM_ATTR _SECTION_ATTR_IMPL(".rtc.text", __COUNTER__)
|
||||||
|
|
||||||
#if CONFIG_SPIRAM_ALLOW_BSS_SEG_EXTERNAL_MEMORY
|
#if CONFIG_SPIRAM_ALLOW_BSS_SEG_EXTERNAL_MEMORY
|
||||||
// Forces bss variable into external memory. "
|
// Forces bss variable into external memory. "
|
||||||
#define EXT_RAM_ATTR __attribute__((section(".ext_ram.bss")))
|
#define EXT_RAM_ATTR _SECTION_ATTR_IMPL(".ext_ram.bss", __COUNTER__)
|
||||||
#else
|
#else
|
||||||
#define EXT_RAM_ATTR
|
#define EXT_RAM_ATTR
|
||||||
#endif
|
#endif
|
||||||
@ -49,26 +49,37 @@
|
|||||||
// Forces data into RTC slow memory. See "docs/deep-sleep-stub.rst"
|
// Forces data into RTC slow memory. See "docs/deep-sleep-stub.rst"
|
||||||
// Any variable marked with this attribute will keep its value
|
// Any variable marked with this attribute will keep its value
|
||||||
// during a deep sleep / wake cycle.
|
// during a deep sleep / wake cycle.
|
||||||
#define RTC_DATA_ATTR __attribute__((section(".rtc.data")))
|
#define RTC_DATA_ATTR _SECTION_ATTR_IMPL(".rtc.data", __COUNTER__)
|
||||||
|
|
||||||
// Forces read-only data into RTC memory. See "docs/deep-sleep-stub.rst"
|
// Forces read-only data into RTC memory. See "docs/deep-sleep-stub.rst"
|
||||||
#define RTC_RODATA_ATTR __attribute__((section(".rtc.rodata")))
|
#define RTC_RODATA_ATTR _SECTION_ATTR_IMPL(".rtc.rodata", __COUNTER__)
|
||||||
|
|
||||||
// Allows to place data into RTC_SLOW memory.
|
// Allows to place data into RTC_SLOW memory.
|
||||||
#define RTC_SLOW_ATTR __attribute__((section(".rtc.force_slow")))
|
#define RTC_SLOW_ATTR _SECTION_ATTR_IMPL(".rtc.force_slow", __COUNTER__)
|
||||||
|
|
||||||
// Allows to place data into RTC_FAST memory.
|
// Allows to place data into RTC_FAST memory.
|
||||||
#define RTC_FAST_ATTR __attribute__((section(".rtc.force_fast")))
|
#define RTC_FAST_ATTR _SECTION_ATTR_IMPL(".rtc.force_fast", __COUNTER__)
|
||||||
|
|
||||||
// Forces data into noinit section to avoid initialization after restart.
|
// Forces data into noinit section to avoid initialization after restart.
|
||||||
#define __NOINIT_ATTR __attribute__((section(".noinit")))
|
#define __NOINIT_ATTR _SECTION_ATTR_IMPL(".noinit", __COUNTER__)
|
||||||
|
|
||||||
// Forces data into RTC slow memory of .noinit section.
|
// Forces data into RTC slow memory of .noinit section.
|
||||||
// Any variable marked with this attribute will keep its value
|
// Any variable marked with this attribute will keep its value
|
||||||
// after restart or during a deep sleep / wake cycle.
|
// after restart or during a deep sleep / wake cycle.
|
||||||
#define RTC_NOINIT_ATTR __attribute__((section(".rtc_noinit")))
|
#define RTC_NOINIT_ATTR _SECTION_ATTR_IMPL(".rtc_noinit", __COUNTER__)
|
||||||
|
|
||||||
// Forces to not inline function
|
// Forces to not inline function
|
||||||
#define NOINLINE_ATTR __attribute__((noinline))
|
#define NOINLINE_ATTR __attribute__((noinline))
|
||||||
|
|
||||||
|
// Implementation for a unique custom section
|
||||||
|
//
|
||||||
|
// This prevents gcc producing "x causes a section type conflict with y"
|
||||||
|
// errors if two variables in the same source file have different linkage (maybe const & non-const) but are placed in the same custom section
|
||||||
|
//
|
||||||
|
// Using unique sections also means --gc-sections can remove unused
|
||||||
|
// data with a custom section type set
|
||||||
|
#define _SECTION_ATTR_IMPL(SECTION, COUNTER) __attribute__((section(SECTION "." _COUNTER_STRINGIFY(COUNTER))))
|
||||||
|
|
||||||
|
#define _COUNTER_STRINGIFY(COUNTER) #COUNTER
|
||||||
|
|
||||||
#endif /* __ESP_ATTR_H__ */
|
#endif /* __ESP_ATTR_H__ */
|
||||||
|
@ -21,16 +21,16 @@ entries:
|
|||||||
|
|
||||||
[sections:rtc_text]
|
[sections:rtc_text]
|
||||||
entries:
|
entries:
|
||||||
.rtc.text
|
.rtc.text+
|
||||||
.rtc.literal
|
.rtc.literal
|
||||||
|
|
||||||
[sections:rtc_data]
|
[sections:rtc_data]
|
||||||
entries:
|
entries:
|
||||||
.rtc.data
|
.rtc.data+
|
||||||
|
|
||||||
[sections:rtc_rodata]
|
[sections:rtc_rodata]
|
||||||
entries:
|
entries:
|
||||||
.rtc.rodata
|
.rtc.rodata+
|
||||||
|
|
||||||
[sections:rtc_bss]
|
[sections:rtc_bss]
|
||||||
entries:
|
entries:
|
||||||
|
@ -421,7 +421,7 @@ IRAM_ATTR void *__wrap_heap_caps_malloc(size_t size, uint32_t caps)
|
|||||||
return trace_malloc(size, caps, TRACE_MALLOC_CAPS);
|
return trace_malloc(size, caps, TRACE_MALLOC_CAPS);
|
||||||
}
|
}
|
||||||
|
|
||||||
IRAM_ATTR void __wrap_heap_caps_free(void *p) __attribute__((alias("__wrap_free")));
|
void __wrap_heap_caps_free(void *p) __attribute__((alias("__wrap_free")));
|
||||||
|
|
||||||
IRAM_ATTR void *__wrap_heap_caps_realloc(void *p, size_t size, uint32_t caps)
|
IRAM_ATTR void *__wrap_heap_caps_realloc(void *p, size_t size, uint32_t caps)
|
||||||
{
|
{
|
||||||
|
@ -118,7 +118,7 @@ void IRAM_ATTR _lock_close(_lock_t *lock) {
|
|||||||
portEXIT_CRITICAL(&lock_init_spinlock);
|
portEXIT_CRITICAL(&lock_init_spinlock);
|
||||||
}
|
}
|
||||||
|
|
||||||
void IRAM_ATTR _lock_close_recursive(_lock_t *lock) __attribute__((alias("_lock_close")));
|
void _lock_close_recursive(_lock_t *lock) __attribute__((alias("_lock_close")));
|
||||||
|
|
||||||
/* Acquire the mutex semaphore for lock. wait up to delay ticks.
|
/* Acquire the mutex semaphore for lock. wait up to delay ticks.
|
||||||
mutex_type is queueQUEUE_TYPE_RECURSIVE_MUTEX or queueQUEUE_TYPE_MUTEX
|
mutex_type is queueQUEUE_TYPE_RECURSIVE_MUTEX or queueQUEUE_TYPE_MUTEX
|
||||||
|
@ -21,16 +21,16 @@ entries:
|
|||||||
|
|
||||||
[sections:rtc_text]
|
[sections:rtc_text]
|
||||||
entries:
|
entries:
|
||||||
.rtc.text
|
.rtc.text+
|
||||||
.rtc.literal
|
.rtc.literal
|
||||||
|
|
||||||
[sections:rtc_data]
|
[sections:rtc_data]
|
||||||
entries:
|
entries:
|
||||||
.rtc.data
|
.rtc.data+
|
||||||
|
|
||||||
[sections:rtc_rodata]
|
[sections:rtc_rodata]
|
||||||
entries:
|
entries:
|
||||||
.rtc.rodata
|
.rtc.rodata+
|
||||||
|
|
||||||
[sections:rtc_bss]
|
[sections:rtc_bss]
|
||||||
entries:
|
entries:
|
||||||
@ -38,7 +38,7 @@ entries:
|
|||||||
|
|
||||||
[sections:extram_bss]
|
[sections:extram_bss]
|
||||||
entries:
|
entries:
|
||||||
.exram.bss
|
.ext_ram.bss+
|
||||||
|
|
||||||
[sections:iram]
|
[sections:iram]
|
||||||
entries:
|
entries:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user