123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243 |
- /*
- Linker File for Renesas RZ/N2L FSP
- */
- MEMORY
- {
- ATCM : ORIGIN = 0x00000000, LENGTH = 0x00020000
- BTCM : ORIGIN = 0x00100000, LENGTH = 0x00020000
- SYSTEM_RAM : ORIGIN = 0x10000000, LENGTH = 0x00180000
- SYSTEM_RAM_MIRROR : ORIGIN = 0x30000000, LENGTH = 0x00180000
- xSPI0_CS0_SPACE_MIRROR : ORIGIN = 0x40000000, LENGTH = 0x04000000
- xSPI0_CS1_SPACE_MIRROR : ORIGIN = 0x44000000, LENGTH = 0x04000000
- xSPI1_CS0_SPACE_MIRROR : ORIGIN = 0x48000000, LENGTH = 0x04000000
- xSPI1_CS1_SPACE_MIRROR : ORIGIN = 0x4C000000, LENGTH = 0x04000000
- CS0_SPACE_MIRROR : ORIGIN = 0x50000000, LENGTH = 0x04000000
- CS2_SPACE_MIRROR : ORIGIN = 0x54000000, LENGTH = 0x04000000
- CS3_SPACE_MIRROR : ORIGIN = 0x58000000, LENGTH = 0x04000000
- CS5_SPACE_MIRROR : ORIGIN = 0x5C000000, LENGTH = 0x04000000
- xSPI0_CS0_SPACE : ORIGIN = 0x60000000, LENGTH = 0x04000000
- xSPI0_CS1_SPACE : ORIGIN = 0x64000000, LENGTH = 0x04000000
- xSPI1_CS0_SPACE : ORIGIN = 0x68000000, LENGTH = 0x04000000
- xSPI1_CS1_SPACE : ORIGIN = 0x6C000000, LENGTH = 0x04000000
- CS0_SPACE : ORIGIN = 0x70000000, LENGTH = 0x04000000
- CS2_SPACE : ORIGIN = 0x74000000, LENGTH = 0x04000000
- CS3_SPACE : ORIGIN = 0x78000000, LENGTH = 0x04000000
- CS5_SPACE : ORIGIN = 0x7C000000, LENGTH = 0x04000000
- }
- SECTIONS
- {
- .loader_text 0x00102000 : AT (0x00102000)
- {
- *(.loader_text)
- */fsp/src/bsp/cmsis/Device/RENESAS/Source/*.o(.text*)
- */fsp/src/bsp/mcu/all/bsp_clocks.o(.text*)
- */fsp/src/bsp/mcu/all/bsp_irq.o(.text*)
- */fsp/src/bsp/mcu/all/bsp_register_protection.o(.text*)
- */fsp/src/r_ioport/r_ioport.o(.text*)
- KEEP(*(.warm_start))
- } > BTCM
- .loader_data :
- {
- */fsp/src/bsp/cmsis/Device/RENESAS/Source/*.o(.data*)
- */fsp/src/bsp/mcu/all/bsp_clocks.o(.data*)
- */fsp/src/bsp/mcu/all/bsp_irq.o(.data*)
- */fsp/src/bsp/mcu/all/bsp_register_protection.o(.data*)
- */fsp/src/r_ioport/r_ioport.o(.data*)
- __loader_bss_start = .;
- */fsp/src/bsp/cmsis/Device/RENESAS/Source/*.o(.bss*)
- */fsp/src/bsp/mcu/all/bsp_clocks.o(.bss*)
- */fsp/src/bsp/mcu/all/bsp_irq.o(.bss*)
- */fsp/src/bsp/mcu/all/bsp_register_protection.o(.bss*)
- */fsp/src/r_ioport/r_ioport.o(.bss*)
- */fsp/src/bsp/cmsis/Device/RENESAS/Source/*.o(COMMON)
- */fsp/src/bsp/mcu/all/bsp_clocks.o(COMMON)
- */fsp/src/bsp/mcu/all/bsp_irq.o(COMMON)
- */fsp/src/bsp/mcu/all/bsp_register_protection.o(.COMMON)
- */fsp/src/r_ioport/r_ioport.o(.COMMON)
- __loader_bss_end = . ;
- } > BTCM
- .intvec 0x00000000 : AT (0x00000000)
- {
- _fvector_start = .;
- KEEP(*(.intvec))
- _fvector_end = .;
- } > ATCM
- .text 0x30000000 : AT (0x30000000)
- {
- _text_start = .;
- *(.text*)
- KEEP(*(.init))
- KEEP(*(.fini))
- /* .ctors */
- *crtbegin.o(.ctors)
- *crtbegin?.o(.ctors)
- *(EXCLUDE_FILE(*crtend?.o *crtend.o) .ctors)
- *(SORT(.ctors.*))
- *(.ctors)
- _ctor_end = .;
- /* .dtors */
- *crtbegin.o(.dtors)
- *crtbegin?.o(.dtors)
- *(EXCLUDE_FILE(*crtend?.o *crtend.o) .dtors)
- *(SORT(.dtors.*))
- *(.dtors)
- _dtor_end = .;
- *(.rodata*)
- _erodata = .;
- KEEP(*(.eh_frame*))
- } > SYSTEM_RAM_MIRROR
- .rvectors :
- {
- _rvectors_start = .;
- KEEP(*(.rvectors))
- _rvectors_end = .;
- } > SYSTEM_RAM_MIRROR
- .ARM.extab :
- {
- *(.ARM.extab* .gnu.linkonce.armextab.*)
- } > SYSTEM_RAM_MIRROR
- __exidx_start = .;
- .ARM.exidx :
- {
- *(.ARM.exidx* .gnu.linkonce.armexidx.*)
- } > SYSTEM_RAM_MIRROR
- __exidx_end = .;
- .got :
- {
- *(.got)
- *(.got.plt)
- _text_end = .;
- } > SYSTEM_RAM_MIRROR
- .data :
- {
- _data_start = .;
- *(vtable)
- *(.data.*)
- *(.data)
- . = ALIGN(4);
- /* preinit data */
- PROVIDE_HIDDEN (__preinit_array_start = .);
- KEEP(*(.preinit_array))
- PROVIDE_HIDDEN (__preinit_array_end = .);
- . = ALIGN(4);
- /* init data */
- PROVIDE_HIDDEN (__init_array_start = .);
- KEEP(*(SORT(.init_array.*)))
- KEEP(*(.init_array))
- PROVIDE_HIDDEN (__init_array_end = .);
- . = ALIGN(4);
- /* finit data */
- PROVIDE_HIDDEN (__fini_array_start = .);
- KEEP(*(SORT(.fini_array.*)))
- KEEP(*(.fini_array))
- PROVIDE_HIDDEN (__fini_array_end = .);
- KEEP(*(.jcr*))
- . = ALIGN(4);
- /* All data end */
- _data_end = .;
- } > SYSTEM_RAM_MIRROR
- .bss :
- {
- . = ALIGN(4);
- __bss_start__ = .;
- _bss = .;
- *(.bss*)
- *(COMMON)
- . = ALIGN(4);
- __bss_end__ = .;
- _ebss = .;
- _end = .;
- } > SYSTEM_RAM_MIRROR
- .heap (NOLOAD) :
- {
- . = ALIGN(8);
- __HeapBase = .;
- /* Place the STD heap here. */
- KEEP(*(.heap))
- __HeapLimit = .;
- } > SYSTEM_RAM_MIRROR
- .thread_stack (NOLOAD):
- {
- . = ALIGN(8);
- __ThreadStackBase = .;
- /* Place the Thread stacks here. */
- KEEP(*(.stack*))
- __ThreadStackLimit = .;
- } > SYSTEM_RAM_MIRROR
- .sys_stack (NOLOAD) :
- {
- . = ALIGN(8);
- __SysStackBase = .;
- /* Place the sys_stack here. */
- KEEP(*(.sys_stack))
- __SysStackLimit = .;
- } > BTCM
- .svc_stack (NOLOAD) :
- {
- . = ALIGN(8);
- __SvcStackBase = .;
- /* Place the svc_stack here. */
- KEEP(*(.svc_stack))
- __SvcStackLimit = .;
- } > BTCM
- .irq_stack (NOLOAD) :
- {
- . = ALIGN(8);
- __IrqStackBase = .;
- /* Place the irq_stack here. */
- KEEP(*(.irq_stack))
- __IrqStackLimit = .;
- } > BTCM
- .fiq_stack (NOLOAD) :
- {
- . = ALIGN(8);
- __FiqStackBase = .;
- /* Place the fiq_stack here. */
- KEEP(*(.fiq_stack))
- __FiqStackLimit = .;
- } > BTCM
- .und_stack (NOLOAD) :
- {
- . = ALIGN(8);
- __UndStackBase = .;
- /* Place the und_stack here. */
- KEEP(*(.und_stack))
- __UndStackLimit = .;
- } > BTCM
- .abt_stack (NOLOAD) :
- {
- . = ALIGN(8);
- __AbtStackBase = .;
- /* Place the abt_stack here. */
- KEEP(*(.abt_stack))
- __AbtStackLimit = .;
- } > BTCM
- .shared_noncache_buffer 0x300C0000 : AT (0x300C0000)
- {
- . = ALIGN(32);
- _sncbuffer_start = .;
- KEEP(*(.shared_noncache_buffer*))
- _sncbuffer_end = .;
- } > SYSTEM_RAM_MIRROR
- .noncache_buffer 0x30100000 : AT (0x30100000)
- {
- . = ALIGN(32);
- _ncbuffer_start = .;
- KEEP(*(.noncache_buffer*))
- _ncbuffer_end = .;
- } > SYSTEM_RAM_MIRROR
- }
|