sovereignx/asm/crt0.s

152 lines
2.9 KiB
ArmAsm
Raw Normal View History

2016-11-01 15:29:13 +00:00
.include "constants/gba_constants.inc"
2016-09-03 07:11:29 +01:00
.syntax unified
.global Start
.text
.arm
Start: @ 8000000
b Init
2016-11-01 15:29:13 +00:00
.include "asm/rom_header.inc"
2016-09-03 03:51:16 +01:00
@ 80000C0
2016-09-03 07:11:29 +01:00
.word 0
2016-09-03 07:11:29 +01:00
.global GPIOPortData
2016-09-03 03:51:16 +01:00
GPIOPortData: @ 80000C4
2016-09-03 07:11:29 +01:00
.hword 0
2016-09-03 07:11:29 +01:00
.global GPIOPortDirection
2016-09-03 03:51:16 +01:00
GPIOPortDirection: @ 80000C6
2016-09-03 07:11:29 +01:00
.hword 0
2016-09-03 07:11:29 +01:00
.global GPIOPortReadEnable
GPIOPortReadEnable: @ 80000C8
.hword 0
2016-09-03 23:07:51 +01:00
.incbin "baserom.gba", 0xCA, 0x204 - 0xCA
2016-09-03 07:11:29 +01:00
.arm
.align 2, 0
.global Init
2016-09-03 03:51:16 +01:00
Init: @ 8000204
mov r0, PSR_IRQ_MODE
msr cpsr_cf, r0
ldr sp, sp_irq
mov r0, PSR_SYS_MODE
msr cpsr_cf, r0
ldr sp, sp_sys
ldr r1, =INTR_VECTOR
2017-02-04 00:44:06 +00:00
adr r0, IntrMain
str r0, [r1]
2017-02-04 00:44:06 +00:00
ldr r1, =AgbMain + 1
mov lr, pc
bx r1
b Init
.align 2, 0
2016-09-03 07:11:29 +01:00
sp_sys: .word IWRAM_END - 0x1c0
sp_irq: .word IWRAM_END - 0x60
.pool
2016-09-03 07:11:29 +01:00
.arm
.align 2, 0
2017-02-04 00:44:06 +00:00
.global IntrMain
IntrMain: @ 8000248
2015-10-10 18:06:17 +01:00
mov r3, REG_BASE
add r3, r3, 0x200
2015-10-10 18:06:17 +01:00
ldr r2, [r3, OFFSET_REG_IE - 0x200]
ldrh r1, [r3, OFFSET_REG_IME - 0x200]
mrs r0, spsr
stmdb sp!, {r0-r3,lr}
mov r0, 0
2015-10-10 18:06:17 +01:00
strh r0, [r3, OFFSET_REG_IME - 0x200]
and r1, r2, r2, lsr 16
mov r12, 0
2015-10-05 14:53:39 +01:00
ands r0, r1, INTR_FLAG_VCOUNT
2017-02-04 00:44:06 +00:00
bne IntrMain_FoundIntr
add r12, r12, 0x4
mov r0, 0x1
2015-10-10 18:06:17 +01:00
strh r0, [r3, OFFSET_REG_IME - 0x200]
2015-10-05 14:53:39 +01:00
ands r0, r1, INTR_FLAG_SERIAL
2017-02-04 00:44:06 +00:00
bne IntrMain_FoundIntr
add r12, r12, 0x4
2015-10-05 14:53:39 +01:00
ands r0, r1, INTR_FLAG_TIMER3
2017-02-04 00:44:06 +00:00
bne IntrMain_FoundIntr
add r12, r12, 0x4
2015-10-05 14:53:39 +01:00
ands r0, r1, INTR_FLAG_HBLANK
2017-02-04 00:44:06 +00:00
bne IntrMain_FoundIntr
add r12, r12, 0x4
2015-10-05 14:53:39 +01:00
ands r0, r1, INTR_FLAG_VBLANK
2017-02-04 00:44:06 +00:00
bne IntrMain_FoundIntr
add r12, r12, 0x4
2015-10-05 14:53:39 +01:00
ands r0, r1, INTR_FLAG_TIMER0
2017-02-04 00:44:06 +00:00
bne IntrMain_FoundIntr
add r12, r12, 0x4
2015-10-05 14:53:39 +01:00
ands r0, r1, INTR_FLAG_TIMER1
2017-02-04 00:44:06 +00:00
bne IntrMain_FoundIntr
add r12, r12, 0x4
2015-10-05 14:53:39 +01:00
ands r0, r1, INTR_FLAG_TIMER2
2017-02-04 00:44:06 +00:00
bne IntrMain_FoundIntr
add r12, r12, 0x4
2015-10-05 14:53:39 +01:00
ands r0, r1, INTR_FLAG_DMA0
2017-02-04 00:44:06 +00:00
bne IntrMain_FoundIntr
add r12, r12, 0x4
2015-10-05 14:53:39 +01:00
ands r0, r1, INTR_FLAG_DMA1
2017-02-04 00:44:06 +00:00
bne IntrMain_FoundIntr
add r12, r12, 0x4
2015-10-05 14:53:39 +01:00
ands r0, r1, INTR_FLAG_DMA2
2017-02-04 00:44:06 +00:00
bne IntrMain_FoundIntr
add r12, r12, 0x4
2015-10-05 14:53:39 +01:00
ands r0, r1, INTR_FLAG_DMA3
2017-02-04 00:44:06 +00:00
bne IntrMain_FoundIntr
add r12, r12, 0x4
2015-10-05 14:53:39 +01:00
ands r0, r1, INTR_FLAG_KEYPAD
2017-02-04 00:44:06 +00:00
bne IntrMain_FoundIntr
add r12, r12, 0x4
2015-10-05 14:53:39 +01:00
ands r0, r1, INTR_FLAG_GAMEPAK
2015-10-10 18:06:17 +01:00
strbne r0, [r3, OFFSET_REG_SOUNDCNT_X - 0x200]
2017-02-04 00:44:06 +00:00
bne . @ spin
IntrMain_FoundIntr:
2015-10-10 18:06:17 +01:00
strh r0, [r3, OFFSET_REG_IF - 0x200]
bic r2, r2, r0
2016-11-01 18:35:16 +00:00
ldr r0, =gUnknown_03007868
ldr r0, [r0]
ldrb r0, [r0, 0xA]
mov r1, 0x8
mov r0, r1, lsl r0
2015-10-05 14:53:39 +01:00
orr r0, r0, INTR_FLAG_GAMEPAK
orr r1, r0, INTR_FLAG_SERIAL | INTR_FLAG_TIMER3 | INTR_FLAG_VCOUNT | INTR_FLAG_HBLANK
and r1, r1, r2
2015-10-10 18:06:17 +01:00
strh r1, [r3, OFFSET_REG_IE - 0x200]
mrs r3, cpsr
2015-10-05 14:53:39 +01:00
bic r3, r3, PSR_I_BIT | PSR_F_BIT | PSR_MODE_MASK
orr r3, r3, PSR_SYS_MODE
msr cpsr_cf, r3
ldr r1, =gIntrTable
add r1, r1, r12
ldr r0, [r1]
stmdb sp!, {lr}
2017-02-04 00:44:06 +00:00
adr lr, IntrMain_RetAddr
bx r0
2017-02-04 00:44:06 +00:00
IntrMain_RetAddr:
ldmia sp!, {lr}
mrs r3, cpsr
2015-10-05 14:53:39 +01:00
bic r3, r3, PSR_I_BIT | PSR_F_BIT | PSR_MODE_MASK
orr r3, r3, PSR_I_BIT | PSR_IRQ_MODE
msr cpsr_cf, r3
ldmia sp!, {r0-r3,lr}
2015-10-10 18:06:17 +01:00
strh r2, [r3, OFFSET_REG_IE - 0x200]
strh r1, [r3, OFFSET_REG_IME - 0x200]
msr spsr_cf, r0
bx lr
.pool
2016-09-03 07:11:29 +01:00
.align 2, 0 @ Don't pad with nop.