183 lines
4.0 KiB
Plaintext
Raw Normal View History

2019-07-24 17:03:26 +08:00
OUTPUT_ARCH( "riscv" )
ENTRY( _start )
MEMORY
2023-01-08 21:16:47 -05:00
{
/* Run in FLASH */
flash (rxai!w) : ORIGIN = 0x08000000, LENGTH = 128k
ram (wxa!ri) : ORIGIN = 0x20000000, LENGTH = 32K
/* Run in RAM */
/* 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-08 21:16:47 -05:00
} >flash AT>flash
2019-07-24 17:03:26 +08:00
.ilalign :
{
. = ALIGN(4);
PROVIDE( _ilm_lma = . );
2023-01-08 21:16:47 -05:00
} >flash AT>flash
2019-07-24 17:03:26 +08:00
.ialign :
{
PROVIDE( _ilm = . );
2023-01-08 21:16:47 -05:00
} >flash AT>flash
2019-07-24 17:03:26 +08:00
.PrgData ALIGN(0x08004000,4) : AT(ALIGN(0x08004000,4))
{
2023-01-08 21:16:47 -05:00
KEEP(*(.PrgData))
2019-07-24 17:03:26 +08:00
}
2023-01-08 21:16:47 -05:00
2019-07-24 17:03:26 +08:00
.text :
{
2023-01-08 21:16:47 -05:00
*(.rodata .rodata.*)
2019-07-24 17:03:26 +08:00
*(.text.unlikely .text.unlikely.*)
*(.text.startup .text.startup.*)
*(.text .text.*)
*(.gnu.linkonce.t.*)
*(.sdata2 .sdata2. *)
2023-01-08 21:16:47 -05:00
} >flash AT>flash
2019-07-24 17:03:26 +08:00
.fini :
{
KEEP (*(SORT_NONE(.fini)))
2023-01-08 21:16:47 -05: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-08 21:16:47 -05: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-08 21:16:47 -05: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-08 21:16:47 -05: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-08 21:16:47 -05: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-08 21:16:47 -05:00
} >flash AT>flash
2019-07-24 17:03:26 +08:00
. = ALIGN(4);
PROVIDE( _eilm = . );
.lalign :
{
. = ALIGN(4);
PROVIDE( _data_lma = . );
2023-01-08 21:16:47 -05:00
} >flash AT>flash
2019-07-24 17:03:26 +08:00
.dalign :
{
. = ALIGN(4);
PROVIDE( _data = . );
2023-01-08 21:16:47 -05:00
} >ram AT>flash
2019-07-24 17:03:26 +08:00
.data :
{
2023-01-08 21:16:47 -05:00
*(.rdata)
2019-07-24 17:03:26 +08:00
*(.gnu.linkonce.r.*)
*(.data .data.*)
*(.gnu.linkonce.d.*)
. = ALIGN(8);
2023-01-08 21:16:47 -05: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-08 21:16:47 -05: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-08 21:16:47 -05: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-08 21:16:47 -05:00
PROVIDE( _heap_end = . );
. = __stack_size;
PROVIDE( _sp = . );
} >ram AT>ram
2019-07-24 17:03:26 +08:00
}