2022-01-02 09:37:39 +11:00
|
|
|
OUTPUT_FORMAT("elf32-littlearm", "elf32-bigarm", "elf32-littlearm")
|
|
|
|
OUTPUT_ARCH(arm)
|
|
|
|
|
|
|
|
ENTRY(__start)
|
|
|
|
EXTERN(__RUST_INTERRUPT_HANDLER)
|
|
|
|
|
2022-06-17 09:43:51 +10:00
|
|
|
EXTERN(__agbabi_memset)
|
|
|
|
EXTERN(__agbabi_memcpy)
|
|
|
|
|
2023-10-18 06:29:12 +11:00
|
|
|
/* The bios reserves the final 256 bytes of iwram for its exclusive use, so we
|
|
|
|
* need to avoid writing there */
|
|
|
|
__bios_reserved_iwram = 256;
|
|
|
|
|
2022-01-02 09:37:39 +11:00
|
|
|
MEMORY {
|
|
|
|
ewram (w!x) : ORIGIN = 0x02000000, LENGTH = 256K
|
2023-10-18 06:29:12 +11:00
|
|
|
iwram (w!x) : ORIGIN = 0x03000000, LENGTH = 32K - __bios_reserved_iwram
|
2022-01-02 09:37:39 +11:00
|
|
|
rom (rx) : ORIGIN = 0x08000000, LENGTH = 32M
|
|
|
|
}
|
|
|
|
|
|
|
|
SECTIONS {
|
2023-10-18 09:52:04 +11:00
|
|
|
. = ORIGIN(rom);
|
|
|
|
|
|
|
|
.entrypoint : {
|
|
|
|
*(.entrypoint.regular .entrypoint.common);
|
|
|
|
. = ALIGN(4);
|
|
|
|
} > rom
|
2022-01-02 09:37:39 +11:00
|
|
|
|
|
|
|
.text : {
|
|
|
|
*(.text .text*);
|
|
|
|
. = ALIGN(4);
|
|
|
|
} > rom
|
|
|
|
|
|
|
|
.rodata : {
|
|
|
|
*(.rodata .rodata.*);
|
|
|
|
. = ALIGN(4);
|
|
|
|
} > rom
|
|
|
|
|
|
|
|
.iwram : {
|
|
|
|
*(.iwram .iwram.*);
|
|
|
|
. = ALIGN(4);
|
|
|
|
|
|
|
|
*(.text_iwram .text_iwram.*);
|
|
|
|
. = ALIGN(4);
|
|
|
|
} > iwram AT>rom
|
2023-10-18 06:29:12 +11:00
|
|
|
__iwram_data_start = ADDR(.iwram);
|
|
|
|
__iwram_rom_start = LOADADDR(.iwram);
|
|
|
|
__iwram_rom_length_halfwords = (SIZEOF(.iwram) + 1) / 2;
|
2023-10-18 07:53:50 +11:00
|
|
|
__iwram_end = __iwram_data_start + SIZEOF(.iwram);
|
2022-01-02 09:37:39 +11:00
|
|
|
|
|
|
|
.ewram : {
|
|
|
|
*(.ewram .ewram.*);
|
|
|
|
. = ALIGN(4);
|
|
|
|
|
|
|
|
*(.data .data.*);
|
|
|
|
. = ALIGN(4);
|
2023-10-18 07:53:50 +11:00
|
|
|
|
2022-01-02 09:37:39 +11:00
|
|
|
} > ewram AT>rom
|
2023-10-18 06:29:12 +11:00
|
|
|
__ewram_data_start = ADDR(.ewram);
|
|
|
|
__ewram_rom_start = LOADADDR(.ewram);
|
|
|
|
__ewram_rom_length_halfwords = (SIZEOF(.ewram) + 1) / 2;
|
2022-01-02 09:37:39 +11:00
|
|
|
|
|
|
|
.bss : {
|
|
|
|
*(.bss .bss.*);
|
|
|
|
. = ALIGN(4);
|
2023-10-18 07:53:50 +11:00
|
|
|
= ABSOLUTE(.);
|
|
|
|
} > ewram
|
|
|
|
|
|
|
|
__ewram_data_end = __ewram_data_start + SIZEOF(.ewram) + SIZEOF(.bss);
|
|
|
|
|
2022-01-02 09:37:39 +11:00
|
|
|
|
2023-04-03 05:37:37 +10:00
|
|
|
.shstrtab : {
|
|
|
|
*(.shstrtab)
|
|
|
|
}
|
|
|
|
|
2022-01-02 09:37:39 +11:00
|
|
|
/* debugging sections */
|
|
|
|
/* Stabs */
|
|
|
|
.stab 0 : { *(.stab) }
|
|
|
|
.stabstr 0 : { *(.stabstr) }
|
|
|
|
.stab.excl 0 : { *(.stab.excl) }
|
|
|
|
.stab.exclstr 0 : { *(.stab.exclstr) }
|
|
|
|
.stab.index 0 : { *(.stab.index) }
|
|
|
|
.stab.indexstr 0 : { *(.stab.indexstr) }
|
|
|
|
.comment 0 : { *(.comment) }
|
|
|
|
/* DWARF 1 */
|
|
|
|
.debug 0 : { *(.debug) }
|
|
|
|
.line 0 : { *(.line) }
|
|
|
|
/* GNU DWARF 1 extensions */
|
|
|
|
.debug_srcinfo 0 : { *(.debug_srcinfo) }
|
|
|
|
.debug_sfnames 0 : { *(.debug_sfnames) }
|
|
|
|
/* DWARF 1.1 and DWARF 2 */
|
|
|
|
.debug_aranges 0 : { *(.debug_aranges) }
|
|
|
|
.debug_pubnames 0 : { *(.debug_pubnames) }
|
|
|
|
/* DWARF 2 */
|
|
|
|
.debug_info 0 : { *(.debug_info) }
|
|
|
|
.debug_abbrev 0 : { *(.debug_abbrev) }
|
|
|
|
.debug_line 0 : { *(.debug_line) }
|
|
|
|
.debug_frame 0 : { *(.debug_frame) }
|
|
|
|
.debug_str 0 : { *(.debug_str) }
|
|
|
|
.debug_loc 0 : { *(.debug_loc) }
|
|
|
|
.debug_macinfo 0 : { *(.debug_macinfo) }
|
|
|
|
/* SGI/MIPS DWARF 2 extensions */
|
|
|
|
.debug_weaknames 0 : { *(.debug_weaknames) }
|
|
|
|
.debug_funcnames 0 : { *(.debug_funcnames) }
|
|
|
|
.debug_typenames 0 : { *(.debug_typenames) }
|
|
|
|
.debug_varnames 0 : { *(.debug_varnames) }
|
|
|
|
|
|
|
|
.debug_ranges 0 : { *(.debug_ranges) }
|
|
|
|
|
|
|
|
/* discard anything not already mentioned */
|
|
|
|
/DISCARD/ : { *(*) }
|
|
|
|
}
|