mirror of
https://github.com/espressif/ESP8266_RTOS_SDK.git
synced 2025-05-22 09:37:00 +08:00
Merge branch 'feature/refactor_link_section' into 'master'
Refactor link section See merge request sdk/ESP8266_RTOS_SDK!832
This commit is contained in:
@ -26,10 +26,10 @@
|
|||||||
#define ICACHE_RODATA_ATTR
|
#define ICACHE_RODATA_ATTR
|
||||||
|
|
||||||
// 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(".dram0")))
|
#define DRAM_ATTR _SECTION_ATTR_IMPL(".dram0", __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)))
|
||||||
@ -41,12 +41,23 @@
|
|||||||
// Forces data into RTC memory.
|
// Forces data into RTC memory.
|
||||||
// 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.
|
// Forces read-only data into RTC memory.
|
||||||
#define RTC_RODATA_ATTR __attribute__((section(".rtc.rodata")))
|
#define RTC_RODATA_ATTR _SECTION_ATTR_IMPL(".rtc.rodata", __COUNTER__)
|
||||||
|
|
||||||
// Forces to put some user defined data in the binary file header, the offset is 0x10.
|
// Forces to put some user defined data in the binary file header, the offset is 0x10.
|
||||||
#define USER_DATA_ATTR __attribute__((section(".user.data")))
|
#define USER_DATA_ATTR _SECTION_ATTR_IMPL(".user.data", __COUNTER__)
|
||||||
|
|
||||||
|
// 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__ */
|
||||||
|
@ -106,6 +106,8 @@ SECTIONS
|
|||||||
*(.init)
|
*(.init)
|
||||||
*(.iram1 .iram1.*)
|
*(.iram1 .iram1.*)
|
||||||
*libspi_flash.a:spi_flash_raw.o(.literal .text .literal.* .text.*)
|
*libspi_flash.a:spi_flash_raw.o(.literal .text .literal.* .text.*)
|
||||||
|
*libpp.a:(.literal .text .literal.* .text.*)
|
||||||
|
*libphy.a:(.literal .text .literal.* .text.*)
|
||||||
*(.literal .text .stub .gnu.warning .gnu.linkonce.literal.* .gnu.linkonce.t.*.literal .gnu.linkonce.t.*)
|
*(.literal .text .stub .gnu.warning .gnu.linkonce.literal.* .gnu.linkonce.t.*.literal .gnu.linkonce.t.*)
|
||||||
*(.fini.literal)
|
*(.fini.literal)
|
||||||
*(.fini)
|
*(.fini)
|
||||||
@ -233,7 +235,8 @@ SECTIONS
|
|||||||
*(.user.data)
|
*(.user.data)
|
||||||
*(.rodata.* .rodata .irom0.literal .irom.literal .irom.text.literal .irom0.text .irom.text)
|
*(.rodata.* .rodata .irom0.literal .irom.literal .irom.text.literal .irom0.text .irom.text)
|
||||||
*(.literal.* .text.*)
|
*(.literal.* .text.*)
|
||||||
|
*(.rodata2.* .rodata2 .literal2.* .literal2 .text2.* .text2)
|
||||||
|
|
||||||
_irom0_text_end = ABSOLUTE(.);
|
_irom0_text_end = ABSOLUTE(.);
|
||||||
} >irom0_0_seg :irom0_0_phdr
|
} >irom0_0_seg :irom0_0_phdr
|
||||||
|
|
||||||
|
@ -1,10 +1,10 @@
|
|||||||
gwen:
|
gwen:
|
||||||
core: 021ebb5
|
core: 38f8c34
|
||||||
net80211: 021ebb5
|
net80211: 38f8c34
|
||||||
pp: 021ebb5
|
pp: 38f8c34
|
||||||
wpa: 021ebb5
|
wpa: 38f8c34
|
||||||
espnow: 021ebb5
|
espnow: 38f8c34
|
||||||
wps: 021ebb5
|
wps: 38f8c34
|
||||||
|
|
||||||
smartconfig: 2.8.1
|
smartconfig: 2.8.1
|
||||||
phy: 1055_8
|
phy: 1055_8
|
||||||
|
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Binary file not shown.
Reference in New Issue
Block a user