pokeemerald/src/crt0.s

200 lines
4.0 KiB
ArmAsm
Raw Normal View History

2016-11-01 16:29:13 +01:00
.include "constants/gba_constants.inc"
2016-09-03 08:11:29 +02:00
.syntax unified
.global Start
.text
.arm
Start: @ 8000000
b Init
2016-11-01 16:29:13 +01:00
.include "asm/rom_header.inc"
2016-09-03 04:51:16 +02:00
@ 80000C0
2016-09-03 08:11:29 +02:00
.word 0
2016-09-03 08:11:29 +02:00
.global GPIOPortData
2016-09-03 04:51:16 +02:00
GPIOPortData: @ 80000C4
.2byte 0
2016-09-03 08:11:29 +02:00
.global GPIOPortDirection
2016-09-03 04:51:16 +02:00
GPIOPortDirection: @ 80000C6
.2byte 0
2016-09-03 08:11:29 +02:00
.global GPIOPortReadEnable
GPIOPortReadEnable: @ 80000C8
.2byte 0
@ 80000CA
.2byte 0
@ 80000CC
.space 0x34
.4byte 3
.4byte 2
.ascii "pokemon emerald version"
.space 9
.4byte gMonFrontPicTable
.4byte gMonBackPicTable
.4byte gMonPaletteTable
.4byte gMonShinyPaletteTable
.4byte gMonIconTable
.4byte gMonIconPaletteIndices
.4byte gMonIconPaletteTable
.4byte gSpeciesNames
.4byte gMoveNames
.4byte gDecorations
.4byte 0x00001270, 0x0000139c, 0x00000018, 0x00000988
.4byte 0x00003b24, 0x00000046, 0x000008e4, 0x000008ac
.4byte 0x00000182
.byte 0x07, 0x0a, 0x0a, 0x0a, 0x0c, 0x0c, 0x06, 0x0c
.byte 0x06, 0x10, 0x12, 0x0c, 0x0f, 0x0b, 0x01, 0x08
.4byte 0x0000000c, 0x00000f2c, 0x00003d88, 0x00000234
.4byte 0x00000238, 0x00000009, 0x0000000a, 0x00000000
.4byte 0x00000008, 0x00000ca8, 0x00000ca8, 0x000031c7
.4byte 0x000031b3, 0x00000000
.4byte gBaseStats
.4byte gAbilityNames
.4byte gAbilityDescriptionPointers
.4byte gItems
.4byte gBattleMoves
2017-12-02 21:27:00 +01:00
.4byte gBallSpriteSheets
.4byte gBallSpritePalettes
.4byte 0x000000a8, 0x00000864, 0x0000089b
.byte 0x1e, 0x1e, 0x10, 0x40
.4byte 0x0000322e, 0x00000498, 0x000031a8, 0x000031f8
.4byte 0x00000034, 0x00000000, 0x00000000
2016-09-03 08:11:29 +02:00
.arm
.align 2, 0
.global Init
2016-09-03 04:51:16 +02: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 01:44:06 +01:00
adr r0, IntrMain
str r0, [r1]
2017-02-04 01:44:06 +01:00
ldr r1, =AgbMain + 1
mov lr, pc
bx r1
b Init
.align 2, 0
2016-09-03 08:11:29 +02:00
sp_sys: .word IWRAM_END - 0x1c0
sp_irq: .word IWRAM_END - 0x60
.pool
2016-09-03 08:11:29 +02:00
.arm
.align 2, 0
2017-02-04 01:44:06 +01:00
.global IntrMain
IntrMain: @ 8000248
2015-10-10 19:06:17 +02:00
mov r3, REG_BASE
add r3, r3, 0x200
2015-10-10 19:06:17 +02: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 19:06:17 +02:00
strh r0, [r3, OFFSET_REG_IME - 0x200]
and r1, r2, r2, lsr 16
mov r12, 0
2015-10-05 15:53:39 +02:00
ands r0, r1, INTR_FLAG_VCOUNT
2017-02-04 01:44:06 +01:00
bne IntrMain_FoundIntr
add r12, r12, 0x4
mov r0, 0x1
2015-10-10 19:06:17 +02:00
strh r0, [r3, OFFSET_REG_IME - 0x200]
2015-10-05 15:53:39 +02:00
ands r0, r1, INTR_FLAG_SERIAL
2017-02-04 01:44:06 +01:00
bne IntrMain_FoundIntr
add r12, r12, 0x4
2015-10-05 15:53:39 +02:00
ands r0, r1, INTR_FLAG_TIMER3
2017-02-04 01:44:06 +01:00
bne IntrMain_FoundIntr
add r12, r12, 0x4
2015-10-05 15:53:39 +02:00
ands r0, r1, INTR_FLAG_HBLANK
2017-02-04 01:44:06 +01:00
bne IntrMain_FoundIntr
add r12, r12, 0x4
2015-10-05 15:53:39 +02:00
ands r0, r1, INTR_FLAG_VBLANK
2017-02-04 01:44:06 +01:00
bne IntrMain_FoundIntr
add r12, r12, 0x4
2015-10-05 15:53:39 +02:00
ands r0, r1, INTR_FLAG_TIMER0
2017-02-04 01:44:06 +01:00
bne IntrMain_FoundIntr
add r12, r12, 0x4
2015-10-05 15:53:39 +02:00
ands r0, r1, INTR_FLAG_TIMER1
2017-02-04 01:44:06 +01:00
bne IntrMain_FoundIntr
add r12, r12, 0x4
2015-10-05 15:53:39 +02:00
ands r0, r1, INTR_FLAG_TIMER2
2017-02-04 01:44:06 +01:00
bne IntrMain_FoundIntr
add r12, r12, 0x4
2015-10-05 15:53:39 +02:00
ands r0, r1, INTR_FLAG_DMA0
2017-02-04 01:44:06 +01:00
bne IntrMain_FoundIntr
add r12, r12, 0x4
2015-10-05 15:53:39 +02:00
ands r0, r1, INTR_FLAG_DMA1
2017-02-04 01:44:06 +01:00
bne IntrMain_FoundIntr
add r12, r12, 0x4
2015-10-05 15:53:39 +02:00
ands r0, r1, INTR_FLAG_DMA2
2017-02-04 01:44:06 +01:00
bne IntrMain_FoundIntr
add r12, r12, 0x4
2015-10-05 15:53:39 +02:00
ands r0, r1, INTR_FLAG_DMA3
2017-02-04 01:44:06 +01:00
bne IntrMain_FoundIntr
add r12, r12, 0x4
2015-10-05 15:53:39 +02:00
ands r0, r1, INTR_FLAG_KEYPAD
2017-02-04 01:44:06 +01:00
bne IntrMain_FoundIntr
add r12, r12, 0x4
2015-10-05 15:53:39 +02:00
ands r0, r1, INTR_FLAG_GAMEPAK
2015-10-10 19:06:17 +02:00
strbne r0, [r3, OFFSET_REG_SOUNDCNT_X - 0x200]
2017-02-04 01:44:06 +01:00
bne . @ spin
IntrMain_FoundIntr:
2015-10-10 19:06:17 +02:00
strh r0, [r3, OFFSET_REG_IF - 0x200]
bic r2, r2, r0
2020-01-15 21:46:17 +01:00
ldr r0, =gSTWIStatus
ldr r0, [r0]
ldrb r0, [r0, 0xA]
mov r1, 0x8
mov r0, r1, lsl r0
2015-10-05 15:53:39 +02: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 19:06:17 +02:00
strh r1, [r3, OFFSET_REG_IE - 0x200]
mrs r3, cpsr
2015-10-05 15:53:39 +02: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 01:44:06 +01:00
adr lr, IntrMain_RetAddr
bx r0
2017-02-04 01:44:06 +01:00
IntrMain_RetAddr:
ldmia sp!, {lr}
mrs r3, cpsr
2015-10-05 15:53:39 +02: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 19:06:17 +02: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 08:11:29 +02:00
.align 2, 0 @ Don't pad with nop.