moves linker script file into moonlight
This commit is contained in:
@@ -1,12 +0,0 @@
|
||||
OUTPUT_ARCH( "riscv" )
|
||||
|
||||
ENTRY( _start )
|
||||
|
||||
INCLUDE memory_map.ld
|
||||
|
||||
REGION_ALIAS("LOCATION_TEXT", flash);
|
||||
REGION_ALIAS("LOCATION_RODATA", flash);
|
||||
REGION_ALIAS("LOCATION_DATA", ram);
|
||||
REGION_ALIAS("LOCATION_STACK", ram);
|
||||
|
||||
INCLUDE sections.ld
|
||||
@@ -1,7 +0,0 @@
|
||||
MEMORY
|
||||
{
|
||||
rom (rxai!w) : ORIGIN = 0x10080000, LENGTH = 8k
|
||||
flash (rxai!w) : ORIGIN = 0x20000000, LENGTH = 16M
|
||||
ram (wxa!ri) : ORIGIN = 0x30000000, LENGTH = 128K
|
||||
dram (wxa!ri) : ORIGIN = 0x40000000, LENGTH = 1024M
|
||||
}
|
||||
12
src/ram.lds
12
src/ram.lds
@@ -1,12 +0,0 @@
|
||||
OUTPUT_ARCH(riscv)
|
||||
|
||||
ENTRY(_start)
|
||||
|
||||
INCLUDE memory_map.ld
|
||||
|
||||
REGION_ALIAS("LOCATION_TEXT", ram);
|
||||
REGION_ALIAS("LOCATION_RODATA", ram);
|
||||
REGION_ALIAS("LOCATION_DATA", ram);
|
||||
REGION_ALIAS("LOCATION_STACK", ram);
|
||||
|
||||
INCLUDE sections.ld
|
||||
@@ -1,12 +0,0 @@
|
||||
OUTPUT_ARCH( "riscv" )
|
||||
|
||||
ENTRY( _start )
|
||||
|
||||
INCLUDE memory_map.ld
|
||||
|
||||
REGION_ALIAS("LOCATION_TEXT", ram);
|
||||
REGION_ALIAS("LOCATION_RODATA", ram);
|
||||
REGION_ALIAS("LOCATION_DATA", dram);
|
||||
REGION_ALIAS("LOCATION_STACK", dram);
|
||||
|
||||
INCLUDE sections.ld
|
||||
12
src/rom.lds
12
src/rom.lds
@@ -1,12 +0,0 @@
|
||||
OUTPUT_ARCH( "riscv" )
|
||||
|
||||
ENTRY( _start )
|
||||
|
||||
INCLUDE memory_map.ld
|
||||
|
||||
REGION_ALIAS("LOCATION_TEXT", rom);
|
||||
REGION_ALIAS("LOCATION_RODATA", rom);
|
||||
REGION_ALIAS("LOCATION_DATA", ram);
|
||||
REGION_ALIAS("LOCATION_STACK", ram);
|
||||
|
||||
INCLUDE sections.ld
|
||||
109
src/sections.ld
109
src/sections.ld
@@ -1,109 +0,0 @@
|
||||
SECTIONS
|
||||
{
|
||||
__stack_size = DEFINED(__stack_size) ? __stack_size : 2K;
|
||||
__stack_segment_size = DEFINED(__stack_segment_size) ? __stack_segment_size : __stack_size;
|
||||
|
||||
/* Code/Const in LOCATION_TEXT */
|
||||
. = ORIGIN(LOCATION_TEXT);
|
||||
.text : ALIGN(4)
|
||||
{
|
||||
KEEP(*(.text.boot))
|
||||
*(.text .text.*)
|
||||
*(.rodata .rodata.*)
|
||||
*(.srodata .srodata.*)
|
||||
KEEP(*(.init))
|
||||
KEEP(*(.fini))
|
||||
} > LOCATION_TEXT
|
||||
|
||||
/* trap/interrupt vectors */
|
||||
.vectors : ALIGN(256)
|
||||
{
|
||||
KEEP(*(.vectors .vectors.*))
|
||||
} > LOCATION_TEXT
|
||||
|
||||
/* C++ ctors/dtors */
|
||||
.init_array : ALIGN(4)
|
||||
{
|
||||
PROVIDE_HIDDEN(__init_array_start = .);
|
||||
KEEP(*(SORT_BY_INIT_PRIORITY(.init_array.*)))
|
||||
KEEP(*(.init_array))
|
||||
PROVIDE_HIDDEN(__init_array_end = .);
|
||||
} > LOCATION_TEXT
|
||||
|
||||
.fini_array : ALIGN(4)
|
||||
{
|
||||
PROVIDE_HIDDEN(__fini_array_start = .);
|
||||
KEEP(*(SORT_BY_INIT_PRIORITY(.fini_array.*)))
|
||||
KEEP(*(.fini_array))
|
||||
PROVIDE_HIDDEN(__fini_array_end = .);
|
||||
} > LOCATION_TEXT
|
||||
|
||||
.data_mark (NOLOAD) : ALIGN(4)
|
||||
{
|
||||
} > LOCATION_DATA
|
||||
__data_offs = ((ADDR(.data_mark) == 0) ? 0x10 : 0);
|
||||
.data_pad (NOLOAD) : ALIGN(4)
|
||||
{
|
||||
. += __data_offs;
|
||||
} > LOCATION_DATA
|
||||
|
||||
/* .data in LOCATION_DATA, Load-Image in LOCATION_TEXT, PHDR is data */
|
||||
.data : ALIGN(4)
|
||||
{
|
||||
__data_start = .;
|
||||
*(.data .data.*)
|
||||
*(.sdata .sdata.*)
|
||||
__data_end = .;
|
||||
} > LOCATION_DATA AT> LOCATION_TEXT
|
||||
__data_source = LOADADDR(.data);
|
||||
|
||||
/* TLS: in LOCATION_DATA, initial values are in LOCATION_TEXT, PHDR is tls */
|
||||
.tls : ALIGN(16)
|
||||
{
|
||||
/* TLS init data (.tdata) */
|
||||
__tls_base = .;
|
||||
*(.tdata .tdata.* .gnu.linkonce.td.*)
|
||||
__tdata_end = .;
|
||||
__tdata_size = __tdata_end - __tls_base;
|
||||
|
||||
/* TLS bss (.tbss) */
|
||||
__tbss_start = .;
|
||||
*(.tbss .tbss.* .gnu.linkonce.tb.*)
|
||||
__tbss_end = .;
|
||||
__tbss_size = __tbss_end - __tbss_start;
|
||||
|
||||
__tls_size = __tbss_end - __tls_base;
|
||||
} > LOCATION_DATA AT> LOCATION_TEXT
|
||||
__tdata_source = LOADADDR(.tls);
|
||||
|
||||
/* normales BSS (inkl. sbss), PHDR is data */
|
||||
.bss (NOLOAD) : ALIGN(16)
|
||||
{
|
||||
__bss_start = .;
|
||||
*(.bss .bss.*)
|
||||
*(.sbss .sbss.*)
|
||||
*(COMMON)
|
||||
__bss_end = .;
|
||||
} > LOCATION_DATA
|
||||
|
||||
__global_pointer$ = .;
|
||||
|
||||
/* Heap/Stack Grenzen */
|
||||
. = ALIGN(16);
|
||||
__heap_start = .;
|
||||
|
||||
/* __stack_top = ORIGIN(LOCATION_BSS) + LENGTH(LOCATION_BSS); */
|
||||
/* PROVIDE(_sp = __stack_top); */
|
||||
/* stack segement, PHDR is stack */
|
||||
.stack ORIGIN(LOCATION_STACK) + LENGTH(LOCATION_STACK) - __stack_segment_size :
|
||||
{
|
||||
PROVIDE( __heap_end = . );
|
||||
. = __stack_segment_size;
|
||||
PROVIDE( _sp = . );
|
||||
} >LOCATION_STACK AT>LOCATION_STACK
|
||||
|
||||
PROVIDE( tohost = . );
|
||||
PROVIDE( fromhost = . + 8 );
|
||||
|
||||
/DISCARD/ : { *(.eh_frame*) *(.comment) *(.note .note.*) }
|
||||
}
|
||||
Reference in New Issue
Block a user