mirror of
				https://github.com/espressif/ESP8266_RTOS_SDK.git
				synced 2025-10-25 05:25:06 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			257 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			257 lines
		
	
	
		
			6.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| /* This linker script generated from xt-genldscripts.tpp for LSP . */
 | |
| /* Linker Script for ld -N */
 | |
| 
 | |
| #include "sdkconfig.h"
 | |
| 
 | |
| PHDRS
 | |
| {
 | |
|   dport0_0_phdr PT_LOAD;
 | |
|   dram0_0_phdr PT_LOAD;
 | |
|   dram0_0_bss_phdr PT_LOAD;
 | |
|   iram1_0_phdr PT_LOAD;
 | |
|   irom0_0_phdr PT_LOAD;
 | |
| }
 | |
| 
 | |
| /*  Default entry point:  */
 | |
| ENTRY(call_user_start)
 | |
| EXTERN(_DebugExceptionVector)
 | |
| EXTERN(_DoubleExceptionVector)
 | |
| EXTERN(_KernelExceptionVector)
 | |
| EXTERN(_NMIExceptionVector)
 | |
| EXTERN(_UserExceptionVector)
 | |
| PROVIDE(_memmap_vecbase_reset = 0x40000000);
 | |
| /* Various memory-map dependent cache attribute settings: */
 | |
| _memmap_cacheattr_wb_base = 0x00000110;
 | |
| _memmap_cacheattr_wt_base = 0x00000110;
 | |
| _memmap_cacheattr_bp_base = 0x00000220;
 | |
| _memmap_cacheattr_unused_mask = 0xFFFFF00F;
 | |
| _memmap_cacheattr_wb_trapnull = 0x2222211F;
 | |
| _memmap_cacheattr_wba_trapnull = 0x2222211F;
 | |
| _memmap_cacheattr_wbna_trapnull = 0x2222211F;
 | |
| _memmap_cacheattr_wt_trapnull = 0x2222211F;
 | |
| _memmap_cacheattr_bp_trapnull = 0x2222222F;
 | |
| _memmap_cacheattr_wb_strict = 0xFFFFF11F;
 | |
| _memmap_cacheattr_wt_strict = 0xFFFFF11F;
 | |
| _memmap_cacheattr_bp_strict = 0xFFFFF22F;
 | |
| _memmap_cacheattr_wb_allvalid = 0x22222112;
 | |
| _memmap_cacheattr_wt_allvalid = 0x22222112;
 | |
| _memmap_cacheattr_bp_allvalid = 0x22222222;
 | |
| PROVIDE(_memmap_cacheattr_reset = _memmap_cacheattr_wb_trapnull);
 | |
| 
 | |
| SECTIONS
 | |
| {
 | |
|   .dport0.rodata : ALIGN(4)
 | |
|   {
 | |
|     _dport0_rodata_start = ABSOLUTE(.);
 | |
|     *(.dport0.rodata)
 | |
|     *(.dport.rodata)
 | |
|     _dport0_rodata_end = ABSOLUTE(.);
 | |
|   } >dport0_0_seg :dport0_0_phdr
 | |
| 
 | |
|   .dport0.literal : ALIGN(4)
 | |
|   {
 | |
|     _dport0_literal_start = ABSOLUTE(.);
 | |
|     *(.dport0.literal)
 | |
|     *(.dport.literal)
 | |
|     _dport0_literal_end = ABSOLUTE(.);
 | |
|   } >dport0_0_seg :dport0_0_phdr
 | |
| 
 | |
|   .dport0.data : ALIGN(4)
 | |
|   {
 | |
|     _dport0_data_start = ABSOLUTE(.);
 | |
|     *(.dport0.data)
 | |
|     *(.dport.data)
 | |
|     _dport0_data_end = ABSOLUTE(.);
 | |
|   } >dport0_0_seg :dport0_0_phdr
 | |
| 
 | |
|   /* RTC memory holds user's data/rodata */
 | |
|   .rtc.data :
 | |
|   {
 | |
|     _rtc_data_start = ABSOLUTE(.);
 | |
|     *(.rtc.data)
 | |
|     *(.rtc.rodata)
 | |
|     _rtc_data_end = ABSOLUTE(.);
 | |
|   } > rtc_seg
 | |
| 
 | |
|   .text : ALIGN(4)
 | |
|   {
 | |
|     _stext = .;
 | |
|     _text_start = ABSOLUTE(.);
 | |
|     LONG(_text_start)
 | |
|     . = ALIGN(16);
 | |
|     *(.DebugExceptionVector.text)
 | |
|     . = ALIGN(16);
 | |
|     *(.NMIExceptionVector.text)
 | |
|     . = ALIGN(16);
 | |
|     *(.KernelExceptionVector.text)
 | |
|     LONG(0)
 | |
|     LONG(0)
 | |
|     LONG(0)
 | |
|     LONG(0)
 | |
|     . = ALIGN(16);
 | |
|     *(.UserExceptionVector.text)
 | |
|     LONG(0)
 | |
|     LONG(0)
 | |
|     LONG(0)
 | |
|     LONG(0)
 | |
|     . = ALIGN(16);
 | |
|     *(.DoubleExceptionVector.text)
 | |
|     LONG(0)
 | |
|     LONG(0)
 | |
|     LONG(0)
 | |
|     LONG(0)
 | |
|     . = ALIGN (16);
 | |
|     *(.entry.text)
 | |
|     *(.init.literal)
 | |
|     *(.init)
 | |
|     *(.iram1 .iram1.*)
 | |
|     *libspi_flash.a:spi_flash_raw.o(.literal .text .literal.* .text.*)
 | |
|     *libpp.a:lmac.o(.literal .text .literal.* .text.*) 
 | |
|     *(.literal .text .stub .gnu.warning .gnu.linkonce.literal.* .gnu.linkonce.t.*.literal .gnu.linkonce.t.*)
 | |
|     *(.fini.literal)
 | |
|     *(.fini)
 | |
|     *(.gnu.version)
 | |
| 
 | |
| #ifdef CONFIG_LWIP_GLOBAL_DATA_LINK_IRAM
 | |
|     *liblwip.a:(.bss .data .bss.* .data.* COMMON)
 | |
| #endif
 | |
| 
 | |
| #ifdef CONFIG_TCPIP_ADAPTER_GLOBAL_DATA_LINK_IRAM
 | |
|     *libtcpip_adapter.a:(.bss .data .bss.* .data.* COMMON)
 | |
| #endif
 | |
| 
 | |
| #ifdef CONFIG_ESP8266_CORE_GLOBAL_DATA_LINK_IRAM
 | |
|     *libcore.a:(.bss .data .bss.* .data.* COMMON)
 | |
| #endif
 | |
| 
 | |
| #ifdef CONFIG_FREERTOS_GLOBAL_DATA_LINK_IRAM
 | |
|     *libfreertos.a:tasks.o(.bss .data .bss.* .data.* COMMON)
 | |
|     *libfreertos.a:timers.o(.bss .data .bss.* .data.* COMMON)
 | |
|     *libfreertos.a:freertos_hooks.o(.bss .data .bss.* .data.* COMMON)
 | |
| #endif
 | |
| 
 | |
| #ifdef CONFIG_LINK_ETS_PRINTF_TO_IRAM
 | |
|     *libesp8266.a:ets_printf.o(.literal .text .literal.* .text.* .rodata.* .rodata)
 | |
| #endif
 | |
| 
 | |
|     *libheap.a:(.literal .text .literal.* .text.*)
 | |
| 
 | |
|     _text_end = ABSOLUTE(.);
 | |
|     _etext = .;
 | |
|   } >iram1_0_seg :iram1_0_phdr
 | |
| 
 | |
|   .data : ALIGN(4)
 | |
|   {
 | |
|     _data_start = ABSOLUTE(.);
 | |
|     *(.data)
 | |
|     *(.data.*)
 | |
|     *(.dram0)
 | |
|     *(.gnu.linkonce.d.*)
 | |
|     *(.data1)
 | |
|     *(.sdata)
 | |
|     *(.sdata.*)
 | |
|     *(.gnu.linkonce.s.*)
 | |
|     *(.sdata2)
 | |
|     *(.sdata2.*)
 | |
|     *(.gnu.linkonce.s2.*)
 | |
|     *(.jcr)
 | |
|     _data_end = ABSOLUTE(.);
 | |
|   } >dram0_0_seg :dram0_0_phdr
 | |
| 
 | |
|   .rodata : ALIGN(4)
 | |
|   {
 | |
|     _rodata_start = ABSOLUTE(.);
 | |
|     *libpp.a:(.rodata.* .rodata)
 | |
|     *liblog.a:(.rodata.* .rodata)
 | |
|     *(.gnu.linkonce.r.*)
 | |
|     *(.rodata1)
 | |
|     __XT_EXCEPTION_TABLE__ = ABSOLUTE(.);
 | |
|     *(.xt_except_table)
 | |
|     *(.gcc_except_table)
 | |
|     *(.gnu.linkonce.e.*)
 | |
|     *(.gnu.version_r)
 | |
|     *(.eh_frame)
 | |
|     . = (. + 3) & ~ 3;
 | |
|     /*  C++ constructor and destructor tables, properly ordered:  */
 | |
|     __init_array_start = ABSOLUTE(.);
 | |
|     KEEP (*crtbegin.o(.ctors))
 | |
|     KEEP (*(EXCLUDE_FILE (*crtend.o) .ctors))
 | |
|     KEEP (*(SORT(.ctors.*)))
 | |
|     KEEP (*(.ctors))
 | |
|     __init_array_end = ABSOLUTE(.);
 | |
|     KEEP (*crtbegin.o(.dtors))
 | |
|     KEEP (*(EXCLUDE_FILE (*crtend.o) .dtors))
 | |
|     KEEP (*(SORT(.dtors.*)))
 | |
|     KEEP (*(.dtors))
 | |
|     /*  C++ exception handlers table:  */
 | |
|     __XT_EXCEPTION_DESCS__ = ABSOLUTE(.);
 | |
|     *(.xt_except_desc)
 | |
|     *(.gnu.linkonce.h.*)
 | |
|     __XT_EXCEPTION_DESCS_END__ = ABSOLUTE(.);
 | |
|     *(.xt_except_desc_end)
 | |
|     *(.dynamic)
 | |
|     *(.gnu.version_d)
 | |
|     . = ALIGN(4);       /* this table MUST be 4-byte aligned */
 | |
|     _bss_table_start = ABSOLUTE(.);
 | |
|     LONG(_bss_start)
 | |
|     LONG(_bss_end)
 | |
|     _bss_table_end = ABSOLUTE(.);
 | |
|     _rodata_end = ABSOLUTE(.);
 | |
|   } >dram0_0_seg :dram0_0_phdr
 | |
| 
 | |
|   .UserExceptionVector.literal : AT(LOADADDR(.rodata) + (ADDR(.UserExceptionVector.literal) - ADDR(.rodata))) ALIGN(4)
 | |
|   {
 | |
|     _UserExceptionVector_literal_start = ABSOLUTE(.);
 | |
|     *(.UserExceptionVector.literal)
 | |
|     _UserExceptionVector_literal_end = ABSOLUTE(.);
 | |
|   } >dram0_0_seg :dram0_0_phdr
 | |
| 
 | |
|   .bss ALIGN(8) (NOLOAD) : ALIGN(4)
 | |
|   {
 | |
|     . = ALIGN (8);
 | |
|     _bss_start = ABSOLUTE(.);
 | |
|     *(.dynsbss)
 | |
|     *(.sbss)
 | |
|     *(.sbss.*)
 | |
|     *(.gnu.linkonce.sb.*)
 | |
|     *(.scommon)
 | |
|     *(.sbss2)
 | |
|     *(.sbss2.*)
 | |
|     *(.gnu.linkonce.sb2.*)
 | |
|     *(.dynbss)
 | |
|     *(.bss)
 | |
|     *(.bss.*)
 | |
|     *(.gnu.linkonce.b.*)
 | |
|     *(COMMON)
 | |
|     . = ALIGN (8);
 | |
|     _bss_end = ABSOLUTE(.);
 | |
|     _heap_start = ABSOLUTE(.);
 | |
| /*    _stack_sentry = ALIGN(0x8); */
 | |
|   } >dram0_0_seg :dram0_0_bss_phdr
 | |
| /* __stack = 0x3ffc8000; */
 | |
| 
 | |
|   .irom0.text : ALIGN(4)
 | |
|   {
 | |
|     _irom0_text_start = ABSOLUTE(.);
 | |
|     *(.rodata.* .rodata .irom0.literal .irom.literal .irom.text.literal .irom0.text .irom.text)
 | |
|     *(.literal.* .text.*)
 | |
| 
 | |
|     . = ALIGN(16);
 | |
|     __start_ksymatabesp_socket = .;
 | |
|     *(ksymatabesp_socket)
 | |
|     __stop_ksymatabesp_socket = .;
 | |
| 
 | |
|     _irom0_text_end = ABSOLUTE(.);
 | |
|   } >irom0_0_seg :irom0_0_phdr
 | |
| 
 | |
|   .lit4 : ALIGN(4)
 | |
|   {
 | |
|     _lit4_start = ABSOLUTE(.);
 | |
|     *(*.lit4)
 | |
|     *(.lit4.*)
 | |
|     *(.gnu.linkonce.lit4.*)
 | |
|     _lit4_end = ABSOLUTE(.);
 | |
|   } >iram1_0_seg :iram1_0_phdr
 | |
| 
 | |
| }
 | 
