agb/crt0.s

39 lines
1.2 KiB
ArmAsm
Raw Normal View History

2021-03-06 17:58:59 +00:00
.arm
.global __start
__start:
b .Initialise
@ Filled in by gbafix
.fill 188, 1, 0
.Initialise:
@ Set interrupt handler
ldr r0, =InterruptHandlerSimple
ldr r1, =0x03007FFC
str r0, [r1]
2021-04-13 01:32:40 +01:00
@ copies iwram section in rom to iwram in ram
ldr r0, =__iwram_rom_start @ load memory address storing start of data for iwram in rom
ldr r1, =__iwram_data_start @ load memory address storing location of iwram in ram
ldr r2, =__iwram_rom_length_halfwords @ load number of 16 bit values to copy
swi 0x000B0000 @ call interrupt CpuSet.
@ r0: source
@ r1: destination
@ r2: length + size information
@
@ see: https://mgba-emu.github.io/gbatek/#swi-0bh-gbands7nds9dsi7dsi9---cpuset
2021-04-16 05:23:38 +01:00
@ copies ewram section in rom to ewram in ram
ldr r0, =__ewram_rom_start
ldr r1, =__ewram_data_start
ldr r2, =__ewram_rom_length_halfwords
swi 0x000B0000
2021-03-06 17:58:59 +00:00
@ load main and branch
ldr r0, =main
bx r0
2021-04-13 01:33:05 +01:00
.pool
2021-03-06 17:58:59 +00:00
.include "interrupt_simple.s"