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:
Angus Gratton 2018-12-19 15:18:26 +08:00
commit d453cce1b3
5 changed files with 31 additions and 20 deletions

View File

@ -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__ */

View File

@ -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:

View File

@ -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)
{ {

View File

@ -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

View File

@ -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: