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
|
2015-11-27 10:33:50 +01:00
|
|
|
b Init
|
|
|
|
|
2016-11-01 16:29:13 +01:00
|
|
|
.include "asm/rom_header.inc"
|
2015-10-05 15:03:59 +02:00
|
|
|
|
2016-09-03 04:51:16 +02:00
|
|
|
@ 80000C0
|
2016-09-03 08:11:29 +02:00
|
|
|
.word 0
|
2015-10-05 15:03:59 +02:00
|
|
|
|
2016-09-03 08:11:29 +02:00
|
|
|
.global GPIOPortData
|
2016-09-03 04:51:16 +02:00
|
|
|
GPIOPortData: @ 80000C4
|
2017-09-18 03:32:32 +02:00
|
|
|
.2byte 0
|
2015-10-05 15:03:59 +02:00
|
|
|
|
2016-09-03 08:11:29 +02:00
|
|
|
.global GPIOPortDirection
|
2016-09-03 04:51:16 +02:00
|
|
|
GPIOPortDirection: @ 80000C6
|
2017-09-18 03:32:32 +02:00
|
|
|
.2byte 0
|
2015-10-05 15:03:59 +02:00
|
|
|
|
2016-09-03 08:11:29 +02:00
|
|
|
.global GPIOPortReadEnable
|
|
|
|
GPIOPortReadEnable: @ 80000C8
|
2017-09-18 03:32:32 +02:00
|
|
|
.2byte 0
|
2015-10-05 15:03:59 +02:00
|
|
|
|
2017-09-18 03:32:32 +02:00
|
|
|
@ 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
|
2017-09-18 03:32:32 +02:00
|
|
|
|
|
|
|
.4byte 0x000000a8, 0x00000864, 0x0000089b
|
|
|
|
|
|
|
|
.byte 0x1e, 0x1e, 0x10, 0x40
|
|
|
|
|
|
|
|
.4byte 0x0000322e, 0x00000498, 0x000031a8, 0x000031f8
|
|
|
|
.4byte 0x00000034, 0x00000000, 0x00000000
|
2015-10-05 15:03:59 +02:00
|
|
|
|
2016-09-03 08:11:29 +02:00
|
|
|
.arm
|
|
|
|
.align 2, 0
|
|
|
|
.global Init
|
2016-09-03 04:51:16 +02:00
|
|
|
Init: @ 8000204
|
2020-07-17 00:15:49 +02:00
|
|
|
mov r0, #PSR_IRQ_MODE
|
2015-10-05 15:03:59 +02:00
|
|
|
msr cpsr_cf, r0
|
|
|
|
ldr sp, sp_irq
|
2020-07-17 00:15:49 +02:00
|
|
|
mov r0, #PSR_SYS_MODE
|
2015-10-05 15:03:59 +02:00
|
|
|
msr cpsr_cf, r0
|
|
|
|
ldr sp, sp_sys
|
|
|
|
ldr r1, =INTR_VECTOR
|
2017-02-04 01:44:06 +01:00
|
|
|
adr r0, IntrMain
|
2015-10-05 15:03:59 +02:00
|
|
|
str r0, [r1]
|
2020-11-06 18:29:40 +01:00
|
|
|
.if MODERN
|
|
|
|
mov r0, #255 @ RESET_ALL
|
|
|
|
swi #1 << 16
|
|
|
|
.endif @ MODERN
|
2017-02-04 01:44:06 +01:00
|
|
|
ldr r1, =AgbMain + 1
|
2015-10-05 15:03:59 +02:00
|
|
|
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
|
2015-10-05 15:03:59 +02:00
|
|
|
|
|
|
|
.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
|
2020-07-17 00:15:49 +02:00
|
|
|
mov r3, #REG_BASE
|
|
|
|
add r3, r3, #OFFSET_REG_IE
|
|
|
|
ldr r2, [r3]
|
|
|
|
ldrh r1, [r3, #OFFSET_REG_IME - 0x200]
|
2015-10-05 15:03:59 +02:00
|
|
|
mrs r0, spsr
|
2020-07-17 00:15:49 +02:00
|
|
|
stmfd sp!, {r0-r3,lr}
|
|
|
|
mov r0, #0
|
|
|
|
strh r0, [r3, #OFFSET_REG_IME - 0x200]
|
|
|
|
and r1, r2, r2, lsr #16
|
|
|
|
mov r12, #0
|
|
|
|
ands r0, r1, #INTR_FLAG_VCOUNT
|
2017-02-04 01:44:06 +01:00
|
|
|
bne IntrMain_FoundIntr
|
2015-10-05 15:03:59 +02:00
|
|
|
add r12, r12, 0x4
|
|
|
|
mov r0, 0x1
|
2020-07-17 00:15:49 +02:00
|
|
|
strh r0, [r3, #OFFSET_REG_IME - 0x200]
|
|
|
|
ands r0, r1, #INTR_FLAG_SERIAL
|
2017-02-04 01:44:06 +01:00
|
|
|
bne IntrMain_FoundIntr
|
2015-10-05 15:03:59 +02:00
|
|
|
add r12, r12, 0x4
|
2020-07-17 00:15:49 +02:00
|
|
|
ands r0, r1, #INTR_FLAG_TIMER3
|
2017-02-04 01:44:06 +01:00
|
|
|
bne IntrMain_FoundIntr
|
2015-10-05 15:03:59 +02:00
|
|
|
add r12, r12, 0x4
|
2020-07-17 00:15:49 +02:00
|
|
|
ands r0, r1, #INTR_FLAG_HBLANK
|
2017-02-04 01:44:06 +01:00
|
|
|
bne IntrMain_FoundIntr
|
2015-10-05 15:03:59 +02:00
|
|
|
add r12, r12, 0x4
|
2020-07-17 00:15:49 +02:00
|
|
|
ands r0, r1, #INTR_FLAG_VBLANK
|
2017-02-04 01:44:06 +01:00
|
|
|
bne IntrMain_FoundIntr
|
2015-10-05 15:03:59 +02:00
|
|
|
add r12, r12, 0x4
|
2020-07-17 00:15:49 +02:00
|
|
|
ands r0, r1, #INTR_FLAG_TIMER0
|
2017-02-04 01:44:06 +01:00
|
|
|
bne IntrMain_FoundIntr
|
2015-10-05 15:03:59 +02:00
|
|
|
add r12, r12, 0x4
|
2020-07-17 00:15:49 +02:00
|
|
|
ands r0, r1, #INTR_FLAG_TIMER1
|
2017-02-04 01:44:06 +01:00
|
|
|
bne IntrMain_FoundIntr
|
2015-10-05 15:03:59 +02:00
|
|
|
add r12, r12, 0x4
|
2020-07-17 00:15:49 +02:00
|
|
|
ands r0, r1, #INTR_FLAG_TIMER2
|
2017-02-04 01:44:06 +01:00
|
|
|
bne IntrMain_FoundIntr
|
2015-10-05 15:03:59 +02:00
|
|
|
add r12, r12, 0x4
|
2020-07-17 00:15:49 +02:00
|
|
|
ands r0, r1, #INTR_FLAG_DMA0
|
2017-02-04 01:44:06 +01:00
|
|
|
bne IntrMain_FoundIntr
|
2015-10-05 15:03:59 +02:00
|
|
|
add r12, r12, 0x4
|
2020-07-17 00:15:49 +02:00
|
|
|
ands r0, r1, #INTR_FLAG_DMA1
|
2017-02-04 01:44:06 +01:00
|
|
|
bne IntrMain_FoundIntr
|
2015-10-05 15:03:59 +02:00
|
|
|
add r12, r12, 0x4
|
2020-07-17 00:15:49 +02:00
|
|
|
ands r0, r1, #INTR_FLAG_DMA2
|
2017-02-04 01:44:06 +01:00
|
|
|
bne IntrMain_FoundIntr
|
2015-10-05 15:03:59 +02:00
|
|
|
add r12, r12, 0x4
|
2020-07-17 00:15:49 +02:00
|
|
|
ands r0, r1, #INTR_FLAG_DMA3
|
2017-02-04 01:44:06 +01:00
|
|
|
bne IntrMain_FoundIntr
|
2015-10-05 15:03:59 +02:00
|
|
|
add r12, r12, 0x4
|
2020-07-17 00:15:49 +02:00
|
|
|
ands r0, r1, #INTR_FLAG_KEYPAD
|
2017-02-04 01:44:06 +01:00
|
|
|
bne IntrMain_FoundIntr
|
2015-10-05 15:03:59 +02:00
|
|
|
add r12, r12, 0x4
|
2020-07-17 00:15:49 +02:00
|
|
|
ands r0, r1, #INTR_FLAG_GAMEPAK
|
|
|
|
strbne r0, [r3, #REG_SOUNDCNT_X - REG_IE]
|
2017-02-04 01:44:06 +01:00
|
|
|
bne . @ spin
|
|
|
|
IntrMain_FoundIntr:
|
2020-07-17 00:15:49 +02:00
|
|
|
strh r0, [r3, #OFFSET_REG_IF - 0x200]
|
2015-10-05 15:03:59 +02:00
|
|
|
bic r2, r2, r0
|
2020-01-15 21:46:17 +01:00
|
|
|
ldr r0, =gSTWIStatus
|
2015-10-05 15:03:59 +02:00
|
|
|
ldr r0, [r0]
|
|
|
|
ldrb r0, [r0, 0xA]
|
|
|
|
mov r1, 0x8
|
2020-07-17 00:15:49 +02:00
|
|
|
lsl r0, r1, r0
|
|
|
|
orr r0, r0, #INTR_FLAG_GAMEPAK
|
|
|
|
orr r1, r0, #INTR_FLAG_SERIAL | INTR_FLAG_TIMER3 | INTR_FLAG_VCOUNT | INTR_FLAG_HBLANK
|
2015-10-05 15:03:59 +02:00
|
|
|
and r1, r1, r2
|
2020-07-17 00:15:49 +02:00
|
|
|
strh r1, [r3, #OFFSET_REG_IE - 0x200]
|
2015-10-05 15:03:59 +02:00
|
|
|
mrs r3, cpsr
|
2020-07-17 00:15:49 +02:00
|
|
|
bic r3, r3, #PSR_I_BIT | PSR_F_BIT | PSR_MODE_MASK
|
|
|
|
orr r3, r3, #PSR_SYS_MODE
|
2015-10-05 15:03:59 +02:00
|
|
|
msr cpsr_cf, r3
|
2017-02-15 22:25:21 +01:00
|
|
|
ldr r1, =gIntrTable
|
2015-10-05 15:03:59 +02:00
|
|
|
add r1, r1, r12
|
|
|
|
ldr r0, [r1]
|
2020-07-17 00:15:49 +02:00
|
|
|
stmfd sp!, {lr}
|
2017-02-04 01:44:06 +01:00
|
|
|
adr lr, IntrMain_RetAddr
|
2015-10-05 15:03:59 +02:00
|
|
|
bx r0
|
2017-02-04 01:44:06 +01:00
|
|
|
IntrMain_RetAddr:
|
2020-07-17 00:15:49 +02:00
|
|
|
ldmfd sp!, {lr}
|
2015-10-05 15:03:59 +02:00
|
|
|
mrs r3, cpsr
|
2020-07-17 00:15:49 +02: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 15:03:59 +02:00
|
|
|
msr cpsr_cf, r3
|
|
|
|
ldmia sp!, {r0-r3,lr}
|
2020-07-17 00:15:49 +02:00
|
|
|
strh r2, [r3, #OFFSET_REG_IE - 0x200]
|
|
|
|
strh r1, [r3, #OFFSET_REG_IME - 0x200]
|
2015-10-05 15:03:59 +02:00
|
|
|
msr spsr_cf, r0
|
|
|
|
bx lr
|
|
|
|
|
|
|
|
.pool
|
|
|
|
|
2016-09-03 08:11:29 +02:00
|
|
|
.align 2, 0 @ Don't pad with nop.
|