mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-01-22 20:57:25 +08:00
fe24ae7ca4
* the initial support of synopsys designware ARC processor using embARC_BSP, all synopsys ARC-based boards are supported: -ARC Software Development Platform -ARC EM Starter Kit -ARC EM Software Development Platform -ARC HS Development Kit -ARC IoT Development Kit * The embARC BSP is a new generation embARC software development package. It is designed to be the inter-layer between hardware and operating system. BSP could hide the difference of hardware/boards, provide a unified interface to upper-layer. * the initial support of synopsys MWDT toolchain. The DesignWare® ARC® MetaWare Development Toolkit builds upon a 25-year legacy of industry-leading compiler and debugger products. It is a complete solution that contains all the components needed to support the development, debugging and tuning of embedded applications for the DesignWare ARC processors. * for detailed board information, pls go embarc.org. Signed-off-by: Watson Zeng <zhiwei@synopsys.com>
155 lines
2.7 KiB
Plaintext
155 lines
2.7 KiB
Plaintext
#define __ASSEMBLY__
|
|
#include <target_mem_config.h>
|
|
|
|
MEMORY {
|
|
#if (REGION_ICCM_SIZE != 0)
|
|
REGION_ICCM : ORIGIN = REGION_ICCM_START, LENGTH = REGION_ICCM_SIZE
|
|
#endif
|
|
#if (REGION_DCCM_SIZE !=0)
|
|
REGION_DCCM : ORIGIN = REGION_DCCM_START, LENGTH = REGION_DCCM_SIZE
|
|
#endif
|
|
#if (REGION_XCCM_SIZE != 0)
|
|
REGION_XCCM : ORIGIN = REGION_XCCM_START, LENGTH = REGION_XCCM_SIZE
|
|
#endif
|
|
#if (REGION_YCCM_SIZE != 0)
|
|
REGION_YCCM : ORIGIN = REGION_YCCM_START, LENGTH = REGION_YCCM_SIZE
|
|
#endif
|
|
#if (REGION_EXT_ROM_SIZE != 0)
|
|
REGION_EXT_ROM : ORIGIN = REGION_EXT_ROM_START, LENGTH = REGION_EXT_ROM_SIZE
|
|
#endif
|
|
#if (REGION_EXT_RAM_SIZE != 0)
|
|
REGION_EXT_RAM : ORIGIN = REGION_EXT_RAM_START, LENGTH = REGION_EXT_RAM_SIZE
|
|
#endif
|
|
}
|
|
|
|
ENTRY(_start)
|
|
|
|
SECTIONS {
|
|
|
|
GROUP : {
|
|
.image_head: {
|
|
. = . + IMAGE_HEAD_SIZE;
|
|
}
|
|
.init_bootstrap:{
|
|
_f_init = .;
|
|
*(.init_vector .init_vector.*)
|
|
*(.init_bootstrap .init_bootstrap.*)
|
|
_e_init = .;
|
|
}
|
|
.vector ALIGN(1024): {
|
|
_f_vector = .;
|
|
*(.vector .vector.*)
|
|
_e_vector = .;
|
|
}
|
|
} > REGION_ROM
|
|
|
|
#if (REGION_XCCM_SIZE != 0)
|
|
GROUP (NOLOAD): {
|
|
.x_ccm ALIGN(8): {
|
|
_f_x_ccm = .;
|
|
*(.x_ccm)
|
|
*(.x_ccm.*)
|
|
_e_x_ccm = .;
|
|
}
|
|
} > REGION_XCCM
|
|
#endif
|
|
|
|
#if (REGION_YCCM_SIZE != 0)
|
|
GROUP (NOLOAD): {
|
|
.y_ccm ALIGN(8): {
|
|
_f_y_ccm = .;
|
|
*(.y_ccm)
|
|
*(.y_ccm.*)
|
|
_e_y_ccm = .;
|
|
}
|
|
} > REGION_YCCM
|
|
#endif
|
|
|
|
GROUP : {
|
|
|
|
.text ALIGN(4): {
|
|
_f_text = .;
|
|
*(TYPE text)
|
|
*(.text*)
|
|
_e_text = .;
|
|
}
|
|
|
|
.rodata ALIGN(4): {
|
|
_f_rodata = .;
|
|
|
|
_fctors = .;
|
|
*(.ctors*)
|
|
_ectors = .;
|
|
_fdtors = .;
|
|
*(.dtors*)
|
|
_edtors = .;
|
|
_feh_frame = .;
|
|
*(.eh_frame*)
|
|
_eeh_frame = .;
|
|
|
|
*(TYPE lit)
|
|
|
|
/* section information for finsh shell */
|
|
. = ALIGN(4);
|
|
__fsymtab_start = .;
|
|
*(FSymTab*)
|
|
__fsymtab_end = .;
|
|
. = ALIGN(4);
|
|
__vsymtab_start = .;
|
|
*(VSymTab*)
|
|
__vsymtab_end = .;
|
|
|
|
. = ALIGN(4);
|
|
__rt_init_start = .;
|
|
*(.rti_fn*)
|
|
__rt_init_end = .;
|
|
. = ALIGN(4);
|
|
|
|
_e_rodata = .;
|
|
}
|
|
|
|
} > REGION_ROM
|
|
|
|
|
|
GROUP : {
|
|
.data ALIGN(8): {
|
|
_f_data = .;
|
|
_f_sdata = .;
|
|
*(.sdata)
|
|
*(.sbss)
|
|
_e_sdata = .;
|
|
*(TYPE data)
|
|
}
|
|
#if defined(EMBARC_UNIT_TEST)
|
|
.unit_test ALIGN(8): {
|
|
_f_embarc_unittest = .;
|
|
KEEP(*(".embarc_unittest"))
|
|
_e_embarc_unittest = .;
|
|
}
|
|
#endif
|
|
.tls ALIGN(8): {
|
|
*(.tls*)
|
|
_e_data = .;
|
|
}
|
|
} > REGION_RAM AT > REGION_ROM
|
|
|
|
GROUP (NOLOAD) : {
|
|
.bss ALIGN(8): {
|
|
_f_bss = .;
|
|
*(TYPE bss)
|
|
_e_bss = .;
|
|
}
|
|
.stack ALIGN(4) SIZE(_STACKSIZE): {}
|
|
.heap? ALIGN(4) SIZE(_HEAPSIZE): {}
|
|
} > REGION_RAM
|
|
|
|
_f_stack = ADDR(.stack);
|
|
_e_stack = ADDR(.stack) + SIZEOF(.stack);
|
|
_f_heap = ADDR(.heap);
|
|
_e_heap = ADDR(.heap) + SIZEOF(.heap);
|
|
|
|
_load_addr_text = LOADADDR(.text);
|
|
_load_addr_rodata = LOADADDR(.rodata);
|
|
_load_addr_data = LOADADDR(.data);
|
|
}
|