zynq-rs/link.x

65 lines
1.2 KiB
Plaintext
Raw Normal View History

2019-05-05 20:56:23 +08:00
ENTRY(_boot_cores);
STACK_SIZE = 0x10000 - 8;
2019-05-31 06:17:53 +08:00
/* Provide some defaults */
2019-05-31 02:30:19 +08:00
PROVIDE(Reset = _boot_cores);
PROVIDE(UndefinedInstruction = Reset);
PROVIDE(SoftwareInterrupt = Reset);
PROVIDE(PrefetchAbort = Reset);
PROVIDE(DataAbort = Reset);
PROVIDE(ReservedException = Reset);
PROVIDE(IRQ = Reset);
PROVIDE(FIQ = Reset);
2019-05-05 20:56:23 +08:00
2019-05-27 07:44:24 +08:00
MEMORY
{
/* 256 kB On-Chip Memory */
OCM : ORIGIN = 0, LENGTH = 0x40000
}
2019-05-05 20:56:23 +08:00
SECTIONS
{
2019-05-31 06:17:53 +08:00
.exceptions (0x0) :
2019-05-31 02:30:19 +08:00
{
KEEP(*(.text.exceptions));
} > OCM
2019-05-31 06:17:53 +08:00
.text (0x8000) :
2019-05-05 20:56:23 +08:00
{
KEEP(*(.text.boot))
2019-05-27 07:44:24 +08:00
*(.text .text.*)
} > OCM
2019-05-05 20:56:23 +08:00
2019-05-31 06:17:53 +08:00
.rodata ALIGN(0x1000) :
2019-05-05 20:56:23 +08:00
{
*(.rodata)
2019-05-27 07:44:24 +08:00
} > OCM
2019-05-05 20:56:23 +08:00
2019-05-31 06:17:53 +08:00
.data ALIGN(0x1000) :
2019-05-05 20:56:23 +08:00
{
*(.data)
2019-05-27 07:44:24 +08:00
} > OCM
2019-05-05 20:56:23 +08:00
2019-06-18 08:22:07 +08:00
.bss ALIGN(0x4000) (NOLOAD) :
2019-05-05 20:56:23 +08:00
{
2019-06-18 08:22:07 +08:00
/* Aligned to 16 kB */
KEEP(*(.bss.l1_table));
2019-05-05 20:56:23 +08:00
*(.bss)
2019-05-27 07:44:24 +08:00
} > OCM
__bss_start = ADDR(.bss);
__bss_end = ADDR(.bss) + SIZEOF(.bss);
2019-05-31 06:17:53 +08:00
.stack ALIGN(0x1000) (NOLOAD) : {
2019-05-27 07:44:24 +08:00
. += STACK_SIZE;
} > OCM
__stack_end = ADDR(.stack);
__stack_start = ADDR(.stack) + SIZEOF(.stack);
2019-05-05 20:56:23 +08:00
/DISCARD/ :
{
/* Unused exception related info that only wastes space */
*(.ARM.exidx.*);
*(.ARM.extab.*);
}
}