rt-thread-official/bsp/gd32vf103v-eval/libraries/n22/env_Eclipse/GD32VF103xB.lds

200 lines
4.4 KiB
Plaintext
Raw Normal View History

2019-07-24 17:03:26 +08:00
OUTPUT_ARCH( "riscv" )
ENTRY( _start )
MEMORY
2023-01-09 10:16:47 +08:00
{
/* Run in FLASH */
2019-07-24 19:25:39 +08:00
flash (rxai!w) : ORIGIN = 0x08000000, LENGTH = 128k
2023-01-09 10:16:47 +08:00
ram (wxa!ri) : ORIGIN = 0x20000000, LENGTH = 32K
2019-07-24 19:25:39 +08:00
2023-01-09 10:16:47 +08:00
/* Run in RAM */
2019-07-24 19:25:39 +08:00
/* flash (rxai!w) : ORIGIN = 0x20000000, LENGTH = 24k
ram (wxa!ri) : ORIGIN = 0x20006000, LENGTH = 8K
*/
2019-07-24 17:03:26 +08:00
}
SECTIONS
{
__stack_size = DEFINED(__stack_size) ? __stack_size : 2K;
.init :
{
KEEP (*(SORT_NONE(.init)))
2023-01-09 10:16:47 +08:00
} >flash AT>flash
2019-07-24 17:03:26 +08:00
.ilalign :
{
. = ALIGN(4);
PROVIDE( _ilm_lma = . );
2023-01-09 10:16:47 +08:00
} >flash AT>flash
2019-07-24 17:03:26 +08:00
.ialign :
{
PROVIDE( _ilm = . );
2023-01-09 10:16:47 +08:00
} >flash AT>flash
2019-07-24 17:03:26 +08:00
.text :
{
2023-01-09 10:16:47 +08:00
*(.rodata .rodata.*)
2019-07-24 17:03:26 +08:00
*(.text.unlikely .text.unlikely.*)
*(.text.startup .text.startup.*)
*(.text .text.*)
*(.gnu.linkonce.t.*)
2023-01-09 10:16:47 +08:00
2019-07-24 17:03:26 +08:00
/* section information for finsh shell */
. = ALIGN(4);
__fsymtab_start = .;
KEEP(*(FSymTab))
__fsymtab_end = .;
. = ALIGN(4);
__vsymtab_start = .;
KEEP(*(VSymTab))
__vsymtab_end = .;
. = ALIGN(4);
2023-01-09 10:16:47 +08:00
2019-07-24 17:03:26 +08:00
/* section information for initial. */
. = ALIGN(4);
__rt_init_start = .;
KEEP(*(SORT(.rti_fn*)))
__rt_init_end = .;
. = ALIGN(4);
/* section information for modules */
. = ALIGN(4);
__rtmsymtab_start = .;
KEEP(*(RTMSymTab))
__rtmsymtab_end = .;
2023-01-09 10:16:47 +08:00
} >flash AT>flash
2019-07-24 17:03:26 +08:00
.fini :
{
KEEP (*(SORT_NONE(.fini)))
2023-01-09 10:16:47 +08:00
} >flash AT>flash
2019-07-24 17:03:26 +08:00
. = ALIGN(4);
PROVIDE (__etext = .);
PROVIDE (_etext = .);/*0x80022c8*/
PROVIDE (etext = .);/*0x80022c8*/
PROVIDE( _eilm = . );
.preinit_array :
{
PROVIDE_HIDDEN (__preinit_array_start = .);
KEEP (*(.preinit_array))
PROVIDE_HIDDEN (__preinit_array_end = .);
2023-01-09 10:16:47 +08:00
} >flash AT>flash
2019-07-24 17:03:26 +08:00
.init_array :
{
PROVIDE_HIDDEN (__init_array_start = .);
KEEP (*(SORT_BY_INIT_PRIORITY(.init_array.*) SORT_BY_INIT_PRIORITY(.ctors.*)))
KEEP (*(.init_array EXCLUDE_FILE (*crtbegin.o *crtbegin?.o *crtend.o *crtend?.o ) .ctors))
PROVIDE_HIDDEN (__init_array_end = .);
2023-01-09 10:16:47 +08:00
} >flash AT>flash
2019-07-24 17:03:26 +08:00
.fini_array :
{
PROVIDE_HIDDEN (__fini_array_start = .);
KEEP (*(SORT_BY_INIT_PRIORITY(.fini_array.*) SORT_BY_INIT_PRIORITY(.dtors.*)))
KEEP (*(.fini_array EXCLUDE_FILE (*crtbegin.o *crtbegin?.o *crtend.o *crtend?.o ) .dtors))
PROVIDE_HIDDEN (__fini_array_end = .);
2023-01-09 10:16:47 +08:00
} >flash AT>flash
2019-07-24 17:03:26 +08:00
.ctors :
{
/* gcc uses crtbegin.o to find the start of
the constructors, so we make sure it is
first. Because this is a wildcard, it
doesn't matter if the user does not
actually link against crtbegin.o; the
linker won't look for a file to match a
wildcard. The wildcard also means that it
doesn't matter which directory crtbegin.o
is in. */
KEEP (*crtbegin.o(.ctors))
KEEP (*crtbegin?.o(.ctors))
/* We don't want to include the .ctor section from
the crtend.o file until after the sorted ctors.
The .ctor section from the crtend file contains the
end of ctors marker and it must be last */
KEEP (*(EXCLUDE_FILE (*crtend.o *crtend?.o ) .ctors))
KEEP (*(SORT(.ctors.*)))
KEEP (*(.ctors))
2023-01-09 10:16:47 +08:00
} >flash AT>flash
2019-07-24 17:03:26 +08:00
.dtors :
{
KEEP (*crtbegin.o(.dtors))
KEEP (*crtbegin?.o(.dtors))
KEEP (*(EXCLUDE_FILE (*crtend.o *crtend?.o ) .dtors))
KEEP (*(SORT(.dtors.*)))
KEEP (*(.dtors))
2023-01-09 10:16:47 +08:00
} >flash AT>flash
2019-07-24 17:03:26 +08:00
. = ALIGN(4);
PROVIDE( _eilm = . );
.lalign :
{
. = ALIGN(4);
PROVIDE( _data_lma = . );
2023-01-09 10:16:47 +08:00
} >flash AT>flash
2019-07-24 17:03:26 +08:00
.dalign :
{
. = ALIGN(4);
PROVIDE( _data = . );
2023-01-09 10:16:47 +08:00
} >ram AT>flash
2019-07-24 17:03:26 +08:00
.data :
{
2023-01-09 10:16:47 +08:00
*(.rdata)
2019-07-24 17:03:26 +08:00
*(.gnu.linkonce.r.*)
*(.data .data.*)
*(.gnu.linkonce.d.*)
. = ALIGN(8);
2023-01-09 10:16:47 +08:00
PROVIDE( __global_pointer$ = . + 0x800);
2019-07-24 17:03:26 +08:00
*(.sdata .sdata.*)
*(.gnu.linkonce.s.*)
. = ALIGN(8);
*(.srodata.cst16)
*(.srodata.cst8)
*(.srodata.cst4)
*(.srodata.cst2)
*(.srodata .srodata.*)
2023-01-09 10:16:47 +08:00
} >ram AT>flash
2019-07-24 17:03:26 +08:00
. = ALIGN(4);
PROVIDE( _edata = . );
PROVIDE( edata = . );
PROVIDE( _fbss = . ); /*0X200052A0 0X200002A0*/
PROVIDE( __bss_start = . );
.bss :
{
*(.sbss*)
*(.gnu.linkonce.sb.*)
*(.bss .bss.*)
*(.gnu.linkonce.b.*)
*(COMMON)
. = ALIGN(4);
2023-01-09 10:16:47 +08:00
} >ram AT>ram
2019-07-24 17:03:26 +08:00
. = ALIGN(8);
PROVIDE( _end = . ); /*0X2000,0340*/
PROVIDE( end = . );
.stack ORIGIN(ram) + LENGTH(ram) - __stack_size :
{
2023-01-09 10:16:47 +08:00
PROVIDE( _heap_end = . );
. = __stack_size;
PROVIDE( _sp = . );
} >ram AT>ram
2019-07-24 17:03:26 +08:00
}