SummerCart64/sw/bootloader/N64.ld

52 lines
1.1 KiB
Plaintext
Raw Normal View History

MEMORY {
2022-05-15 15:47:12 +02:00
rdram (rwx) : org = 0x80300000, len = 1M
flash (r) : org = 0xB0000000, len = 1028k
}
ENTRY(entry_handler)
2022-01-07 15:01:43 +01:00
__exception_stack_size = 8k;
2022-01-18 19:21:49 +01:00
__stack_size = 16k;
SECTIONS {
.flash : {
KEEP(*(.text.rom_header));
KEEP(*(.text.ipl3));
} > flash
2022-05-15 15:47:12 +02:00
.text : SUBALIGN(4) {
*(.text.entry_handler)
*(.text .text.* .gnu.linkonce.t.*)
*(.rodata .rodata.* .gnu.linkonce.r.*)
*(.data .data.* .gnu.linkonce.d.*)
_gp = . + 0x8000;
*(.sdata .sdata.* .gnu.linkonce.s.*)
*(.lit8 .lit4)
2022-01-07 15:01:43 +01:00
. = ALIGN(8);
} > rdram AT > flash
.bss : {
2022-05-15 15:47:12 +02:00
_sbss = .;
*(.sbss .sbss.* .gnu.linkonce.sb.*)
*(.scommon .scommon.*)
*(.bss .bss.* .gnu.linkonce.b.*)
*(COMMON)
2022-01-07 15:01:43 +01:00
. = ALIGN(8);
2022-05-15 15:47:12 +02:00
_ebss = .;
} > rdram
_sheap = .;
2022-01-07 15:01:43 +01:00
. = ORIGIN(rdram) + LENGTH(rdram) - __exception_stack_size - __stack_size;
_eheap = .;
2022-01-07 15:01:43 +01:00
. += __exception_stack_size;
_esp = .;
. += __stack_size;
_sp = .;
/DISCARD/ : {
*(.MIPS.*)
}
}