summaryrefslogtreecommitdiff
path: root/asm/start.s
diff options
context:
space:
mode:
Diffstat (limited to 'asm/start.s')
-rwxr-xr-xasm/start.s198
1 files changed, 99 insertions, 99 deletions
diff --git a/asm/start.s b/asm/start.s
index ec036b0..ab124f4 100755
--- a/asm/start.s
+++ b/asm/start.s
@@ -1,112 +1,112 @@
- .include "constants/gba_constants.inc"
+ .include "constants/gba_constants.inc"
- .syntax unified
- .arm
+ .syntax unified
+ .arm
Start: @ 8000000
- b Init
+ b Init
.incbin "baserom.gba", 0x4, 0xBC
- .arm
- .align 2
+ .arm
+ .align 2
Init: @ 80000C0
- mov r0, #0x12
- msr cpsr_cf, r0
- ldr sp, sp_irq
- mov r0, #0x1F
- msr cpsr_cf, r0
- ldr sp, sp_sys
- ldr r1, =INTR_VECTOR
- adr r0, IntrMain
- str r0, [r1]
- ldr r1, =0x800095C + 1
- mov lr, pc
- bx r1
- b Init
+ mov r0, #0x12
+ msr cpsr_cf, r0
+ ldr sp, sp_irq
+ mov r0, #0x1F
+ msr cpsr_cf, r0
+ ldr sp, sp_sys
+ ldr r1, =INTR_VECTOR
+ adr r0, IntrMain
+ str r0, [r1]
+ ldr r1, =0x800095C + 1
+ mov lr, pc
+ bx r1
+ b Init
sp_sys: .4byte IWRAM_END - 0x100
sp_irq: .4byte IWRAM_END - 0x60
- .pool
+ .pool
- .global IntrMain
+ .global IntrMain
IntrMain: @ 8000104
- mov r3, REG_BASE
- add r3, r3, OFFSET_REG_IE
- ldr r2, [r3]
- ldrh r1, [r3, OFFSET_REG_IME - OFFSET_REG_IE]
- mrs r0, spsr
- stmdb sp!, {r0-r3,lr}
- mov r0, 1
- strh r0, [r3, OFFSET_REG_IME - OFFSET_REG_IE]
- and r1, r2, r2, lsr 16
- mov r12, 0
- ands r0, r1, INTR_FLAG_SERIAL
- bne IntrMain_FoundIntr
- add r12, r12, 4
- ands r0, r1, INTR_FLAG_TIMER3
- bne IntrMain_FoundIntr
- add r12, r12, 4
- ands r0, r1, INTR_FLAG_VBLANK
- bne IntrMain_FoundIntr
- add r12, r12, 4
- ands r0, r1, INTR_FLAG_HBLANK
- bne IntrMain_FoundIntr
- add r12, r12, 4
- ands r0, r1, INTR_FLAG_VCOUNT
- bne IntrMain_FoundIntr
- add r12, r12, 4
- ands r0, r1, INTR_FLAG_TIMER0
- bne IntrMain_FoundIntr
- add r12, r12, 4
- ands r0, r1, INTR_FLAG_TIMER1
- bne IntrMain_FoundIntr
- add r12, r12, 4
- ands r0, r1, INTR_FLAG_TIMER2
- bne IntrMain_FoundIntr
- add r12, r12, 4
- ands r0, r1, INTR_FLAG_DMA0
- bne IntrMain_FoundIntr
- add r12, r12, 4
- ands r0, r1, INTR_FLAG_DMA1
- bne IntrMain_FoundIntr
- add r12, r12, 4
- ands r0, r1, INTR_FLAG_DMA2
- bne IntrMain_FoundIntr
- add r12, r12, 4
- ands r0, r1, INTR_FLAG_DMA3
- bne IntrMain_FoundIntr
- add r12, r12, 4
- ands r0, r1, INTR_FLAG_KEYPAD
- bne IntrMain_FoundIntr
- add r12, r12, 4
- ands r0, r1, INTR_FLAG_GAMEPAK
- strbne r0, [r3, OFFSET_REG_SOUNDCNT_X - OFFSET_REG_IE]
- bne . @ spin
+ mov r3, REG_BASE
+ add r3, r3, OFFSET_REG_IE
+ ldr r2, [r3]
+ ldrh r1, [r3, OFFSET_REG_IME - OFFSET_REG_IE]
+ mrs r0, spsr
+ stmdb sp!, {r0-r3,lr}
+ mov r0, 1
+ strh r0, [r3, OFFSET_REG_IME - OFFSET_REG_IE]
+ and r1, r2, r2, lsr 16
+ mov r12, 0
+ ands r0, r1, INTR_FLAG_SERIAL
+ bne IntrMain_FoundIntr
+ add r12, r12, 4
+ ands r0, r1, INTR_FLAG_TIMER3
+ bne IntrMain_FoundIntr
+ add r12, r12, 4
+ ands r0, r1, INTR_FLAG_VBLANK
+ bne IntrMain_FoundIntr
+ add r12, r12, 4
+ ands r0, r1, INTR_FLAG_HBLANK
+ bne IntrMain_FoundIntr
+ add r12, r12, 4
+ ands r0, r1, INTR_FLAG_VCOUNT
+ bne IntrMain_FoundIntr
+ add r12, r12, 4
+ ands r0, r1, INTR_FLAG_TIMER0
+ bne IntrMain_FoundIntr
+ add r12, r12, 4
+ ands r0, r1, INTR_FLAG_TIMER1
+ bne IntrMain_FoundIntr
+ add r12, r12, 4
+ ands r0, r1, INTR_FLAG_TIMER2
+ bne IntrMain_FoundIntr
+ add r12, r12, 4
+ ands r0, r1, INTR_FLAG_DMA0
+ bne IntrMain_FoundIntr
+ add r12, r12, 4
+ ands r0, r1, INTR_FLAG_DMA1
+ bne IntrMain_FoundIntr
+ add r12, r12, 4
+ ands r0, r1, INTR_FLAG_DMA2
+ bne IntrMain_FoundIntr
+ add r12, r12, 4
+ ands r0, r1, INTR_FLAG_DMA3
+ bne IntrMain_FoundIntr
+ add r12, r12, 4
+ ands r0, r1, INTR_FLAG_KEYPAD
+ bne IntrMain_FoundIntr
+ add r12, r12, 4
+ ands r0, r1, INTR_FLAG_GAMEPAK
+ strbne r0, [r3, OFFSET_REG_SOUNDCNT_X - OFFSET_REG_IE]
+ bne . @ spin
IntrMain_FoundIntr: @ 80001D4
- strh r0, [r3, OFFSET_REG_IF - OFFSET_REG_IE]
- mov r1, INTR_FLAG_GAMEPAK | INTR_FLAG_TIMER3 | INTR_FLAG_SERIAL
- bic r2, r2, r0
- and r1, r1, r2
- strh r1, [r3]
- mrs r3, cpsr
- 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}
- adr lr, IntrMain_RetAddr
- bx r0
+ strh r0, [r3, OFFSET_REG_IF - OFFSET_REG_IE]
+ mov r1, INTR_FLAG_GAMEPAK | INTR_FLAG_TIMER3 | INTR_FLAG_SERIAL
+ bic r2, r2, r0
+ and r1, r1, r2
+ strh r1, [r3]
+ mrs r3, cpsr
+ 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}
+ adr lr, IntrMain_RetAddr
+ bx r0
IntrMain_RetAddr: @ 8000210
- ldmfd sp!, {lr}
- mrs r3, cpsr
- 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
- ldmfd sp!, {r0-r3,lr}
- strh r2, [r3]
- strh r1, [r3, OFFSET_REG_IME - OFFSET_REG_IE]
- msr spsr_cf, r0
- bx lr
- .pool
+ ldmfd sp!, {lr}
+ mrs r3, cpsr
+ 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
+ ldmfd sp!, {r0-r3,lr}
+ strh r2, [r3]
+ strh r1, [r3, OFFSET_REG_IME - OFFSET_REG_IE]
+ msr spsr_cf, r0
+ bx lr
+ .pool