2015-11-27 01:33:50 -08:00
|
|
|
RomBase: ; 8000000
|
|
|
|
b Init
|
|
|
|
|
2015-10-08 02:03:14 -07:00
|
|
|
.include "asm/rom_header.s"
|
2015-10-05 06:03:59 -07:00
|
|
|
|
2015-11-27 15:46:51 -08:00
|
|
|
; 80000C0
|
2015-10-10 08:37:51 -07:00
|
|
|
.4byte 0
|
2015-10-05 06:03:59 -07:00
|
|
|
|
2015-11-27 15:46:51 -08:00
|
|
|
GPIOPortData: ; 80000C4
|
2015-10-10 08:37:51 -07:00
|
|
|
.2byte 0
|
2015-10-05 06:03:59 -07:00
|
|
|
|
2015-11-27 15:46:51 -08:00
|
|
|
GPIOPortDirection: ; 80000C6
|
2015-10-10 08:37:51 -07:00
|
|
|
.2byte 0
|
2015-10-05 06:03:59 -07:00
|
|
|
|
2015-11-27 15:46:51 -08:00
|
|
|
GPIOPortReadWrite: ; 80000C8
|
|
|
|
.2byte 0
|
2015-10-05 06:03:59 -07:00
|
|
|
|
2015-11-27 15:46:51 -08:00
|
|
|
.incbin "base_emerald.gba", 0xCA, 0x204 - 0xCA
|
2015-10-05 06:03:59 -07:00
|
|
|
|
|
|
|
arm_func_start Init
|
2015-11-27 15:46:51 -08:00
|
|
|
Init: ; 8000204
|
2015-10-05 06:03:59 -07:00
|
|
|
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
|
|
|
|
adr r0, InterruptMain
|
|
|
|
str r0, [r1]
|
|
|
|
ldr r1, =Main + 1
|
|
|
|
mov lr, pc
|
|
|
|
bx r1
|
|
|
|
b Init
|
|
|
|
|
|
|
|
.align 2, 0
|
|
|
|
sp_sys: .4byte IWRAM_END - 0x1c0
|
|
|
|
sp_irq: .4byte IWRAM_END - 0x60
|
|
|
|
|
|
|
|
.pool
|
|
|
|
|
|
|
|
arm_func_end Init
|
|
|
|
|
|
|
|
arm_func_start InterruptMain
|
2015-11-27 15:46:51 -08:00
|
|
|
InterruptMain: ; 8000248
|
2015-10-10 10:06:17 -07:00
|
|
|
mov r3, REG_BASE
|
2015-10-05 06:03:59 -07:00
|
|
|
add r3, r3, 0x200
|
2015-10-10 10:06:17 -07:00
|
|
|
ldr r2, [r3, OFFSET_REG_IE - 0x200]
|
|
|
|
ldrh r1, [r3, OFFSET_REG_IME - 0x200]
|
2015-10-05 06:03:59 -07:00
|
|
|
mrs r0, spsr
|
|
|
|
stmdb sp!, {r0-r3,lr}
|
|
|
|
mov r0, 0
|
2015-10-10 10:06:17 -07:00
|
|
|
strh r0, [r3, OFFSET_REG_IME - 0x200]
|
2015-10-05 06:03:59 -07:00
|
|
|
and r1, r2, r2, lsr 16
|
|
|
|
mov r12, 0
|
2015-10-05 06:53:39 -07:00
|
|
|
ands r0, r1, INTR_FLAG_VCOUNT
|
2016-01-06 20:44:58 -08:00
|
|
|
bne $foundInterrupt
|
2015-10-05 06:03:59 -07:00
|
|
|
add r12, r12, 0x4
|
|
|
|
mov r0, 0x1
|
2015-10-10 10:06:17 -07:00
|
|
|
strh r0, [r3, OFFSET_REG_IME - 0x200]
|
2015-10-05 06:53:39 -07:00
|
|
|
ands r0, r1, INTR_FLAG_SERIAL
|
2016-01-06 20:44:58 -08:00
|
|
|
bne $foundInterrupt
|
2015-10-05 06:03:59 -07:00
|
|
|
add r12, r12, 0x4
|
2015-10-05 06:53:39 -07:00
|
|
|
ands r0, r1, INTR_FLAG_TIMER3
|
2016-01-06 20:44:58 -08:00
|
|
|
bne $foundInterrupt
|
2015-10-05 06:03:59 -07:00
|
|
|
add r12, r12, 0x4
|
2015-10-05 06:53:39 -07:00
|
|
|
ands r0, r1, INTR_FLAG_HBLANK
|
2016-01-06 20:44:58 -08:00
|
|
|
bne $foundInterrupt
|
2015-10-05 06:03:59 -07:00
|
|
|
add r12, r12, 0x4
|
2015-10-05 06:53:39 -07:00
|
|
|
ands r0, r1, INTR_FLAG_VBLANK
|
2016-01-06 20:44:58 -08:00
|
|
|
bne $foundInterrupt
|
2015-10-05 06:03:59 -07:00
|
|
|
add r12, r12, 0x4
|
2015-10-05 06:53:39 -07:00
|
|
|
ands r0, r1, INTR_FLAG_TIMER0
|
2016-01-06 20:44:58 -08:00
|
|
|
bne $foundInterrupt
|
2015-10-05 06:03:59 -07:00
|
|
|
add r12, r12, 0x4
|
2015-10-05 06:53:39 -07:00
|
|
|
ands r0, r1, INTR_FLAG_TIMER1
|
2016-01-06 20:44:58 -08:00
|
|
|
bne $foundInterrupt
|
2015-10-05 06:03:59 -07:00
|
|
|
add r12, r12, 0x4
|
2015-10-05 06:53:39 -07:00
|
|
|
ands r0, r1, INTR_FLAG_TIMER2
|
2016-01-06 20:44:58 -08:00
|
|
|
bne $foundInterrupt
|
2015-10-05 06:03:59 -07:00
|
|
|
add r12, r12, 0x4
|
2015-10-05 06:53:39 -07:00
|
|
|
ands r0, r1, INTR_FLAG_DMA0
|
2016-01-06 20:44:58 -08:00
|
|
|
bne $foundInterrupt
|
2015-10-05 06:03:59 -07:00
|
|
|
add r12, r12, 0x4
|
2015-10-05 06:53:39 -07:00
|
|
|
ands r0, r1, INTR_FLAG_DMA1
|
2016-01-06 20:44:58 -08:00
|
|
|
bne $foundInterrupt
|
2015-10-05 06:03:59 -07:00
|
|
|
add r12, r12, 0x4
|
2015-10-05 06:53:39 -07:00
|
|
|
ands r0, r1, INTR_FLAG_DMA2
|
2016-01-06 20:44:58 -08:00
|
|
|
bne $foundInterrupt
|
2015-10-05 06:03:59 -07:00
|
|
|
add r12, r12, 0x4
|
2015-10-05 06:53:39 -07:00
|
|
|
ands r0, r1, INTR_FLAG_DMA3
|
2016-01-06 20:44:58 -08:00
|
|
|
bne $foundInterrupt
|
2015-10-05 06:03:59 -07:00
|
|
|
add r12, r12, 0x4
|
2015-10-05 06:53:39 -07:00
|
|
|
ands r0, r1, INTR_FLAG_KEYPAD
|
2016-01-06 20:44:58 -08:00
|
|
|
bne $foundInterrupt
|
2015-10-05 06:03:59 -07:00
|
|
|
add r12, r12, 0x4
|
2015-10-05 06:53:39 -07:00
|
|
|
ands r0, r1, INTR_FLAG_GAMEPAK
|
2015-10-10 10:06:17 -07:00
|
|
|
strbne r0, [r3, OFFSET_REG_SOUNDCNT_X - 0x200]
|
2016-01-06 21:24:27 -08:00
|
|
|
$loop:
|
|
|
|
bne $loop
|
2016-01-06 20:44:58 -08:00
|
|
|
$foundInterrupt:
|
2015-10-10 10:06:17 -07:00
|
|
|
strh r0, [r3, OFFSET_REG_IF - 0x200]
|
2015-10-05 06:03:59 -07:00
|
|
|
bic r2, r2, r0
|
|
|
|
ldr r0, =0x03007868
|
|
|
|
ldr r0, [r0]
|
|
|
|
ldrb r0, [r0, 0xA]
|
|
|
|
mov r1, 0x8
|
|
|
|
mov r0, r1, lsl r0
|
2015-10-05 06:53:39 -07:00
|
|
|
orr r0, r0, INTR_FLAG_GAMEPAK
|
|
|
|
orr r1, r0, INTR_FLAG_SERIAL | INTR_FLAG_TIMER3 | INTR_FLAG_VCOUNT | INTR_FLAG_HBLANK
|
2015-10-05 06:03:59 -07:00
|
|
|
and r1, r1, r2
|
2015-10-10 10:06:17 -07:00
|
|
|
strh r1, [r3, OFFSET_REG_IE - 0x200]
|
2015-10-05 06:03:59 -07:00
|
|
|
mrs r3, cpsr
|
2015-10-05 06:53:39 -07:00
|
|
|
bic r3, r3, PSR_I_BIT | PSR_F_BIT | PSR_MODE_MASK
|
|
|
|
orr r3, r3, PSR_SYS_MODE
|
2015-10-05 06:03:59 -07:00
|
|
|
msr cpsr_cf, r3
|
|
|
|
ldr r1, =0x03002710
|
|
|
|
add r1, r1, r12
|
|
|
|
ldr r0, [r1]
|
|
|
|
stmdb sp!, {lr}
|
|
|
|
add lr, pc, 0
|
|
|
|
bx r0
|
|
|
|
ldmia sp!, {lr}
|
|
|
|
mrs r3, cpsr
|
2015-10-05 06:53:39 -07:00
|
|
|
bic r3, r3, PSR_I_BIT | PSR_F_BIT | PSR_MODE_MASK
|
|
|
|
orr r3, r3, PSR_I_BIT | PSR_IRQ_MODE
|
2015-10-05 06:03:59 -07:00
|
|
|
msr cpsr_cf, r3
|
|
|
|
ldmia sp!, {r0-r3,lr}
|
2015-10-10 10:06:17 -07:00
|
|
|
strh r2, [r3, OFFSET_REG_IE - 0x200]
|
|
|
|
strh r1, [r3, OFFSET_REG_IME - 0x200]
|
2015-10-05 06:03:59 -07:00
|
|
|
msr spsr_cf, r0
|
|
|
|
bx lr
|
|
|
|
|
|
|
|
.pool
|
|
|
|
|
|
|
|
arm_func_end InterruptMain
|