mirror of
https://github.com/Ninjdai1/pokeemerald.git
synced 2025-01-16 00:22:10 +01:00
commit
1cf2470aac
@ -75,21 +75,21 @@ _send: @ 14c
|
|||||||
_150:
|
_150:
|
||||||
bl _recv
|
bl _recv
|
||||||
bne _150
|
bne _150
|
||||||
mov r2, 0
|
mov r2, #0
|
||||||
strh r2, [r0, 0xa] @ SIOMLT_SEND
|
strh r2, [r0, 0xa] @ SIOMLT_SEND
|
||||||
cmp r1, 0
|
cmp r1, #0
|
||||||
bne _150
|
bne _150
|
||||||
mov r2, 0x8000
|
mov r2, 0x8000
|
||||||
_16c:
|
_16c:
|
||||||
mov r1, 0
|
mov r1, #0
|
||||||
_170:
|
_170:
|
||||||
strh r1, [r0, 0xa] @ SIOMLT_SEND
|
strh r1, [r0, 0xa] @ SIOMLT_SEND
|
||||||
bl _recv
|
bl _recv
|
||||||
bne _150
|
bne _150
|
||||||
cmp r1, r2
|
cmp r1, r2
|
||||||
bne _16c
|
bne _16c
|
||||||
lsr r2, 5
|
lsr r2, #5
|
||||||
cmp r1, 0
|
cmp r1, #0
|
||||||
bne _170
|
bne _170
|
||||||
ldr r3, =BerryFixMBHeaderGameCode
|
ldr r3, =BerryFixMBHeaderGameCode
|
||||||
ldrh r2, [r3]
|
ldrh r2, [r3]
|
||||||
@ -105,7 +105,7 @@ _1a0:
|
|||||||
bne _1a0
|
bne _1a0
|
||||||
cmp r1, r2
|
cmp r1, r2
|
||||||
bne _1a0
|
bne _1a0
|
||||||
mov r1, 0
|
mov r1, #0
|
||||||
strh r1, [r0, 0xa] @ SIOMLT_SEND
|
strh r1, [r0, 0xa] @ SIOMLT_SEND
|
||||||
ldr r0, =_data_2f0
|
ldr r0, =_data_2f0
|
||||||
ldr r1, =gCode
|
ldr r1, =gCode
|
||||||
|
@ -9,10 +9,10 @@
|
|||||||
.align 2, 0
|
.align 2, 0
|
||||||
.global Init
|
.global Init
|
||||||
Init:
|
Init:
|
||||||
mov r0, PSR_IRQ_MODE
|
mov r0, #PSR_IRQ_MODE
|
||||||
msr cpsr_cf, r0
|
msr cpsr_cf, r0
|
||||||
ldr sp, sp_irq
|
ldr sp, sp_irq
|
||||||
mov r0, PSR_SYS_MODE
|
mov r0, #PSR_SYS_MODE
|
||||||
msr cpsr_cf, r0
|
msr cpsr_cf, r0
|
||||||
ldr sp, sp_sys
|
ldr sp, sp_sys
|
||||||
ldr r1, =INTR_VECTOR
|
ldr r1, =INTR_VECTOR
|
||||||
@ -34,8 +34,8 @@ sp_irq: .word IWRAM_END - 0x60
|
|||||||
.align 2, 0
|
.align 2, 0
|
||||||
.global IntrMain
|
.global IntrMain
|
||||||
IntrMain: @ 0x2010048
|
IntrMain: @ 0x2010048
|
||||||
mov ip, REG_BASE
|
mov ip, #REG_BASE
|
||||||
add r3, ip, OFFSET_REG_IE
|
add r3, ip, #OFFSET_REG_IE
|
||||||
ldr r2, [r3]
|
ldr r2, [r3]
|
||||||
and r1, r2, r2, lsr #16
|
and r1, r2, r2, lsr #16
|
||||||
mov r2, #0
|
mov r2, #0
|
||||||
|
@ -7,39 +7,39 @@
|
|||||||
|
|
||||||
thumb_func_start CpuSet
|
thumb_func_start CpuSet
|
||||||
CpuSet: @ 81E3B64
|
CpuSet: @ 81E3B64
|
||||||
swi 0xB
|
svc 0xB
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end CpuSet
|
thumb_func_end CpuSet
|
||||||
|
|
||||||
thumb_func_start Div
|
thumb_func_start Div
|
||||||
Div: @ 81E3B68
|
Div: @ 81E3B68
|
||||||
swi 0x6
|
svc 0x6
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end Div
|
thumb_func_end Div
|
||||||
|
|
||||||
thumb_func_start Mod
|
thumb_func_start Mod
|
||||||
Mod:
|
Mod:
|
||||||
swi 0x6
|
svc 0x6
|
||||||
adds r0, r1, 0
|
adds r0, r1, 0
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end Mod
|
thumb_func_end Mod
|
||||||
|
|
||||||
thumb_func_start LZ77UnCompVram
|
thumb_func_start LZ77UnCompVram
|
||||||
LZ77UnCompVram: @ 81E3B6C
|
LZ77UnCompVram: @ 81E3B6C
|
||||||
swi 0x12
|
svc 0x12
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end LZ77UnCompVram
|
thumb_func_end LZ77UnCompVram
|
||||||
|
|
||||||
thumb_func_start RegisterRamReset
|
thumb_func_start RegisterRamReset
|
||||||
RegisterRamReset: @ 81E3B80
|
RegisterRamReset: @ 81E3B80
|
||||||
swi 0x1
|
svc 0x1
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end RegisterRamReset
|
thumb_func_end RegisterRamReset
|
||||||
|
|
||||||
thumb_func_start VBlankIntrWait
|
thumb_func_start VBlankIntrWait
|
||||||
VBlankIntrWait: @ 81E3BA0
|
VBlankIntrWait: @ 81E3BA0
|
||||||
movs r2, 0
|
movs r2, 0
|
||||||
swi 0x5
|
svc 0x5
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end VBlankIntrWait
|
thumb_func_end VBlankIntrWait
|
||||||
|
|
||||||
|
@ -55,8 +55,8 @@
|
|||||||
.ifdef L_IntrWait
|
.ifdef L_IntrWait
|
||||||
thumb_func_start IntrWait
|
thumb_func_start IntrWait
|
||||||
IntrWait:
|
IntrWait:
|
||||||
mov r2, #0
|
movs r2, #0
|
||||||
swi 4
|
svc #4
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end IntrWait
|
thumb_func_end IntrWait
|
||||||
.endif
|
.endif
|
||||||
@ -64,7 +64,7 @@ IntrWait:
|
|||||||
.ifdef L_RegisterRamReset
|
.ifdef L_RegisterRamReset
|
||||||
thumb_func_start RegisterRamReset
|
thumb_func_start RegisterRamReset
|
||||||
RegisterRamReset:
|
RegisterRamReset:
|
||||||
swi 1
|
svc #1
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end RegisterRamReset
|
thumb_func_end RegisterRamReset
|
||||||
.endif
|
.endif
|
||||||
@ -72,7 +72,7 @@ RegisterRamReset:
|
|||||||
.ifdef L_Sqrt
|
.ifdef L_Sqrt
|
||||||
thumb_func_start Sqrt
|
thumb_func_start Sqrt
|
||||||
Sqrt:
|
Sqrt:
|
||||||
swi 8
|
svc #8
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end Sqrt
|
thumb_func_end Sqrt
|
||||||
.endif
|
.endif
|
||||||
@ -80,7 +80,7 @@ Sqrt:
|
|||||||
.ifdef L_MusicPlayerOpen
|
.ifdef L_MusicPlayerOpen
|
||||||
thumb_func_start MusicPlayerOpen
|
thumb_func_start MusicPlayerOpen
|
||||||
MusicPlayerOpen:
|
MusicPlayerOpen:
|
||||||
swi 32
|
svc #32
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end MusicPlayerOpen
|
thumb_func_end MusicPlayerOpen
|
||||||
.endif
|
.endif
|
||||||
@ -88,8 +88,8 @@ MusicPlayerOpen:
|
|||||||
.ifdef L_SoundBiasReset
|
.ifdef L_SoundBiasReset
|
||||||
thumb_func_start SoundBiasReset
|
thumb_func_start SoundBiasReset
|
||||||
SoundBiasReset:
|
SoundBiasReset:
|
||||||
mov r0, #0
|
movs r0, #0
|
||||||
swi 25
|
svc #25
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end SoundBiasReset
|
thumb_func_end SoundBiasReset
|
||||||
.endif
|
.endif
|
||||||
@ -97,7 +97,7 @@ SoundBiasReset:
|
|||||||
.ifdef L_SoundDriverVSyncOn
|
.ifdef L_SoundDriverVSyncOn
|
||||||
thumb_func_start SoundDriverVSyncOn
|
thumb_func_start SoundDriverVSyncOn
|
||||||
SoundDriverVSyncOn:
|
SoundDriverVSyncOn:
|
||||||
swi 41
|
svc #41
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end SoundDriverVSyncOn
|
thumb_func_end SoundDriverVSyncOn
|
||||||
.endif
|
.endif
|
||||||
@ -105,7 +105,7 @@ SoundDriverVSyncOn:
|
|||||||
.ifdef L_Mod
|
.ifdef L_Mod
|
||||||
thumb_func_start Mod
|
thumb_func_start Mod
|
||||||
Mod:
|
Mod:
|
||||||
swi 6
|
svc #6
|
||||||
mov r0, r1
|
mov r0, r1
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end Mod
|
thumb_func_end Mod
|
||||||
@ -114,8 +114,8 @@ Mod:
|
|||||||
.ifdef L_VBlankIntrWait
|
.ifdef L_VBlankIntrWait
|
||||||
thumb_func_start VBlankIntrWait
|
thumb_func_start VBlankIntrWait
|
||||||
VBlankIntrWait:
|
VBlankIntrWait:
|
||||||
mov r2, #0
|
movs r2, #0
|
||||||
swi 5
|
svc #5
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end VBlankIntrWait
|
thumb_func_end VBlankIntrWait
|
||||||
.endif
|
.endif
|
||||||
@ -123,7 +123,7 @@ VBlankIntrWait:
|
|||||||
.ifdef L_MusicPlayerStart
|
.ifdef L_MusicPlayerStart
|
||||||
thumb_func_start MusicPlayerStart
|
thumb_func_start MusicPlayerStart
|
||||||
MusicPlayerStart:
|
MusicPlayerStart:
|
||||||
swi 33
|
svc #33
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end MusicPlayerStart
|
thumb_func_end MusicPlayerStart
|
||||||
.endif
|
.endif
|
||||||
@ -131,7 +131,7 @@ MusicPlayerStart:
|
|||||||
.ifdef L_SoundDriverVSyncOff
|
.ifdef L_SoundDriverVSyncOff
|
||||||
thumb_func_start SoundDriverVSyncOff
|
thumb_func_start SoundDriverVSyncOff
|
||||||
SoundDriverVSyncOff:
|
SoundDriverVSyncOff:
|
||||||
swi 40
|
svc #40
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end SoundDriverVSyncOff
|
thumb_func_end SoundDriverVSyncOff
|
||||||
.endif
|
.endif
|
||||||
@ -139,34 +139,34 @@ SoundDriverVSyncOff:
|
|||||||
.ifdef L_HuffUnComp
|
.ifdef L_HuffUnComp
|
||||||
thumb_func_start HuffUnComp
|
thumb_func_start HuffUnComp
|
||||||
HuffUnComp:
|
HuffUnComp:
|
||||||
swi 19
|
svc #19
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end HuffUnComp
|
thumb_func_end HuffUnComp
|
||||||
.endif
|
.endif
|
||||||
|
|
||||||
.ifdef L_SoftResetExram
|
.ifdef L_SoftResetExram
|
||||||
thumb_func_start SoftResetExram
|
arm_func_start SoftResetExram
|
||||||
SoftResetExram:
|
SoftResetExram:
|
||||||
ldr r3, =REG_IME
|
ldr r3, =REG_IME
|
||||||
mov r2, #0
|
movs r2, #0
|
||||||
strb r2, [r3, #0]
|
strb r2, [r3, #0]
|
||||||
ldr r3, =SOFT_RESET_DIRECT_BUF
|
ldr r3, =SOFT_RESET_DIRECT_BUF
|
||||||
mov r2, #1
|
movs r2, #1
|
||||||
strb r2, [r3, #0]
|
strb r2, [r3, #0]
|
||||||
sub r3, #SOFT_RESET_DIRECT_BUF - 0x3007f00
|
subs r3, #SOFT_RESET_DIRECT_BUF - 0x3007f00
|
||||||
mov sp, r3
|
mov sp, r3
|
||||||
mov r2, #RESET_EX_WRAM_FLAG
|
movs r2, #RESET_EX_WRAM_FLAG
|
||||||
bic r0, r2
|
bics r0, r2
|
||||||
swi 1
|
svc #1
|
||||||
swi 0
|
svc #0
|
||||||
.pool
|
.pool
|
||||||
thumb_func_end SoftResetExram
|
arm_func_end SoftResetExram
|
||||||
.endif
|
.endif
|
||||||
|
|
||||||
.ifdef L_MusicPlayerFadeOut
|
.ifdef L_MusicPlayerFadeOut
|
||||||
thumb_func_start MusicPlayerFadeOut
|
thumb_func_start MusicPlayerFadeOut
|
||||||
MusicPlayerFadeOut:
|
MusicPlayerFadeOut:
|
||||||
swi 36
|
svc #36
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end MusicPlayerFadeOut
|
thumb_func_end MusicPlayerFadeOut
|
||||||
.endif
|
.endif
|
||||||
@ -174,7 +174,7 @@ MusicPlayerFadeOut:
|
|||||||
.ifdef L_LZ77UnCompWram
|
.ifdef L_LZ77UnCompWram
|
||||||
thumb_func_start LZ77UnCompWram
|
thumb_func_start LZ77UnCompWram
|
||||||
LZ77UnCompWram:
|
LZ77UnCompWram:
|
||||||
swi 17
|
svc #17
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end LZ77UnCompWram
|
thumb_func_end LZ77UnCompWram
|
||||||
.endif
|
.endif
|
||||||
@ -182,7 +182,7 @@ LZ77UnCompWram:
|
|||||||
.ifdef L_SoundDriverMain
|
.ifdef L_SoundDriverMain
|
||||||
thumb_func_start SoundDriverMain
|
thumb_func_start SoundDriverMain
|
||||||
SoundDriverMain:
|
SoundDriverMain:
|
||||||
swi 28
|
svc #28
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end SoundDriverMain
|
thumb_func_end SoundDriverMain
|
||||||
.endif
|
.endif
|
||||||
@ -190,7 +190,7 @@ SoundDriverMain:
|
|||||||
.ifdef L_SoundBiasChange
|
.ifdef L_SoundBiasChange
|
||||||
thumb_func_start SoundBiasChange
|
thumb_func_start SoundBiasChange
|
||||||
SoundBiasChange:
|
SoundBiasChange:
|
||||||
swi 25
|
svc #25
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end SoundBiasChange
|
thumb_func_end SoundBiasChange
|
||||||
.endif
|
.endif
|
||||||
@ -198,7 +198,7 @@ SoundBiasChange:
|
|||||||
.ifdef L_LZ77UnCompVram
|
.ifdef L_LZ77UnCompVram
|
||||||
thumb_func_start LZ77UnCompVram
|
thumb_func_start LZ77UnCompVram
|
||||||
LZ77UnCompVram:
|
LZ77UnCompVram:
|
||||||
swi 18
|
svc #18
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end LZ77UnCompVram
|
thumb_func_end LZ77UnCompVram
|
||||||
.endif
|
.endif
|
||||||
@ -206,7 +206,7 @@ LZ77UnCompVram:
|
|||||||
.ifdef L_ArcTan2
|
.ifdef L_ArcTan2
|
||||||
thumb_func_start ArcTan2
|
thumb_func_start ArcTan2
|
||||||
ArcTan2:
|
ArcTan2:
|
||||||
swi 10
|
svc #10
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end ArcTan2
|
thumb_func_end ArcTan2
|
||||||
.endif
|
.endif
|
||||||
@ -214,7 +214,7 @@ ArcTan2:
|
|||||||
.ifdef L_MusicPlayerStop
|
.ifdef L_MusicPlayerStop
|
||||||
thumb_func_start MusicPlayerStop
|
thumb_func_start MusicPlayerStop
|
||||||
MusicPlayerStop:
|
MusicPlayerStop:
|
||||||
swi 34
|
svc #34
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end MusicPlayerStop
|
thumb_func_end MusicPlayerStop
|
||||||
.endif
|
.endif
|
||||||
@ -222,7 +222,7 @@ MusicPlayerStop:
|
|||||||
.ifdef L_DivArm
|
.ifdef L_DivArm
|
||||||
thumb_func_start DivArm
|
thumb_func_start DivArm
|
||||||
DivArm:
|
DivArm:
|
||||||
swi 7
|
svc #7
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end DivArm
|
thumb_func_end DivArm
|
||||||
.endif
|
.endif
|
||||||
@ -230,7 +230,7 @@ DivArm:
|
|||||||
.ifdef L_ModArm
|
.ifdef L_ModArm
|
||||||
thumb_func_start ModArm
|
thumb_func_start ModArm
|
||||||
ModArm:
|
ModArm:
|
||||||
swi 7
|
svc #7
|
||||||
mov r0, r1
|
mov r0, r1
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end ModArm
|
thumb_func_end ModArm
|
||||||
@ -239,7 +239,7 @@ ModArm:
|
|||||||
.ifdef L_SoundDriverVSync
|
.ifdef L_SoundDriverVSync
|
||||||
thumb_func_start SoundDriverVSync
|
thumb_func_start SoundDriverVSync
|
||||||
SoundDriverVSync:
|
SoundDriverVSync:
|
||||||
swi 29
|
svc #29
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end SoundDriverVSync
|
thumb_func_end SoundDriverVSync
|
||||||
.endif
|
.endif
|
||||||
@ -247,7 +247,7 @@ SoundDriverVSync:
|
|||||||
.ifdef L_SoundDriverInit
|
.ifdef L_SoundDriverInit
|
||||||
thumb_func_start SoundDriverInit
|
thumb_func_start SoundDriverInit
|
||||||
SoundDriverInit:
|
SoundDriverInit:
|
||||||
swi 26
|
svc #26
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end SoundDriverInit
|
thumb_func_end SoundDriverInit
|
||||||
.endif
|
.endif
|
||||||
@ -255,7 +255,7 @@ SoundDriverInit:
|
|||||||
.ifdef L_BgAffineSet
|
.ifdef L_BgAffineSet
|
||||||
thumb_func_start BgAffineSet
|
thumb_func_start BgAffineSet
|
||||||
BgAffineSet:
|
BgAffineSet:
|
||||||
swi 14
|
svc #14
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end BgAffineSet
|
thumb_func_end BgAffineSet
|
||||||
.endif
|
.endif
|
||||||
@ -263,7 +263,7 @@ BgAffineSet:
|
|||||||
.ifdef L_Diff8bitUnFilterWram
|
.ifdef L_Diff8bitUnFilterWram
|
||||||
thumb_func_start Diff8bitUnFilterWram
|
thumb_func_start Diff8bitUnFilterWram
|
||||||
Diff8bitUnFilterWram:
|
Diff8bitUnFilterWram:
|
||||||
swi 22
|
svc #22
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end Diff8bitUnFilterWram
|
thumb_func_end Diff8bitUnFilterWram
|
||||||
.endif
|
.endif
|
||||||
@ -272,7 +272,7 @@ Diff8bitUnFilterWram:
|
|||||||
thumb_func_start MultiBoot
|
thumb_func_start MultiBoot
|
||||||
MultiBoot:
|
MultiBoot:
|
||||||
mov r1, #1
|
mov r1, #1
|
||||||
swi 37
|
svc #37
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end MultiBoot
|
thumb_func_end MultiBoot
|
||||||
.endif
|
.endif
|
||||||
@ -280,7 +280,7 @@ MultiBoot:
|
|||||||
.ifdef L_MidiKey2Freq
|
.ifdef L_MidiKey2Freq
|
||||||
thumb_func_start MidiKey2Freq
|
thumb_func_start MidiKey2Freq
|
||||||
MidiKey2Freq:
|
MidiKey2Freq:
|
||||||
swi 31
|
svc #31
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end MidiKey2Freq
|
thumb_func_end MidiKey2Freq
|
||||||
.endif
|
.endif
|
||||||
@ -288,7 +288,7 @@ MidiKey2Freq:
|
|||||||
.ifdef L_Div
|
.ifdef L_Div
|
||||||
thumb_func_start Div
|
thumb_func_start Div
|
||||||
Div:
|
Div:
|
||||||
swi 6
|
svc #6
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end Div
|
thumb_func_end Div
|
||||||
.endif
|
.endif
|
||||||
@ -296,7 +296,7 @@ Div:
|
|||||||
.ifdef L_Diff8bitUnFilterVram
|
.ifdef L_Diff8bitUnFilterVram
|
||||||
thumb_func_start Diff8bitUnFilterVram
|
thumb_func_start Diff8bitUnFilterVram
|
||||||
Diff8bitUnFilterVram:
|
Diff8bitUnFilterVram:
|
||||||
swi 23
|
svc #23
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end Diff8bitUnFilterVram
|
thumb_func_end Diff8bitUnFilterVram
|
||||||
.endif
|
.endif
|
||||||
@ -304,7 +304,7 @@ Diff8bitUnFilterVram:
|
|||||||
.ifdef L_ArcTan
|
.ifdef L_ArcTan
|
||||||
thumb_func_start ArcTan
|
thumb_func_start ArcTan
|
||||||
ArcTan:
|
ArcTan:
|
||||||
swi 9
|
svc #9
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end ArcTan
|
thumb_func_end ArcTan
|
||||||
.endif
|
.endif
|
||||||
@ -312,7 +312,7 @@ ArcTan:
|
|||||||
.ifdef L_ObjAffineSet
|
.ifdef L_ObjAffineSet
|
||||||
thumb_func_start ObjAffineSet
|
thumb_func_start ObjAffineSet
|
||||||
ObjAffineSet:
|
ObjAffineSet:
|
||||||
swi 15
|
svc #15
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end ObjAffineSet
|
thumb_func_end ObjAffineSet
|
||||||
.endif
|
.endif
|
||||||
@ -321,15 +321,15 @@ ObjAffineSet:
|
|||||||
thumb_func_start SoftResetRom
|
thumb_func_start SoftResetRom
|
||||||
SoftResetRom:
|
SoftResetRom:
|
||||||
ldr r3, =REG_IME
|
ldr r3, =REG_IME
|
||||||
mov r2, #0
|
movs r2, #0
|
||||||
strb r2, [r3, #0]
|
strb r2, [r3, #0]
|
||||||
ldr r3, =SOFT_RESET_DIRECT_BUF
|
ldr r3, =SOFT_RESET_DIRECT_BUF
|
||||||
mov r2, #0
|
movs r2, #0
|
||||||
strb r2, [r3, #0]
|
strb r2, [r3, #0]
|
||||||
sub r3, #SOFT_RESET_DIRECT_BUF - 0x3007f00
|
sub r3, #SOFT_RESET_DIRECT_BUF - 0x3007f00
|
||||||
mov sp, r3
|
mov sp, r3
|
||||||
swi 1
|
svc #1
|
||||||
swi 0
|
svc #0
|
||||||
.pool
|
.pool
|
||||||
thumb_func_end SoftResetRom
|
thumb_func_end SoftResetRom
|
||||||
.endif
|
.endif
|
||||||
@ -337,7 +337,7 @@ SoftResetRom:
|
|||||||
.ifdef L_SoundDriverMode
|
.ifdef L_SoundDriverMode
|
||||||
thumb_func_start SoundDriverMode
|
thumb_func_start SoundDriverMode
|
||||||
SoundDriverMode:
|
SoundDriverMode:
|
||||||
swi 27
|
svc #27
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end SoundDriverMode
|
thumb_func_end SoundDriverMode
|
||||||
.endif
|
.endif
|
||||||
@ -345,7 +345,7 @@ SoundDriverMode:
|
|||||||
.ifdef L_RLUnCompWram
|
.ifdef L_RLUnCompWram
|
||||||
thumb_func_start RLUnCompWram
|
thumb_func_start RLUnCompWram
|
||||||
RLUnCompWram:
|
RLUnCompWram:
|
||||||
swi 20
|
svc #20
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end RLUnCompWram
|
thumb_func_end RLUnCompWram
|
||||||
.endif
|
.endif
|
||||||
@ -353,7 +353,7 @@ RLUnCompWram:
|
|||||||
.ifdef L_BitUnPack
|
.ifdef L_BitUnPack
|
||||||
thumb_func_start BitUnPack
|
thumb_func_start BitUnPack
|
||||||
BitUnPack:
|
BitUnPack:
|
||||||
swi 16
|
svc #16
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end BitUnPack
|
thumb_func_end BitUnPack
|
||||||
.endif
|
.endif
|
||||||
@ -361,7 +361,7 @@ BitUnPack:
|
|||||||
.ifdef L_SoundChannelClear
|
.ifdef L_SoundChannelClear
|
||||||
thumb_func_start SoundChannelClear
|
thumb_func_start SoundChannelClear
|
||||||
SoundChannelClear:
|
SoundChannelClear:
|
||||||
swi 30
|
svc #30
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end SoundChannelClear
|
thumb_func_end SoundChannelClear
|
||||||
.endif
|
.endif
|
||||||
@ -369,7 +369,7 @@ SoundChannelClear:
|
|||||||
.ifdef L_CpuFastSet
|
.ifdef L_CpuFastSet
|
||||||
thumb_func_start CpuFastSet
|
thumb_func_start CpuFastSet
|
||||||
CpuFastSet:
|
CpuFastSet:
|
||||||
swi 12
|
svc #12
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end CpuFastSet
|
thumb_func_end CpuFastSet
|
||||||
.endif
|
.endif
|
||||||
@ -377,7 +377,7 @@ CpuFastSet:
|
|||||||
.ifdef L_CpuSet
|
.ifdef L_CpuSet
|
||||||
thumb_func_start CpuSet
|
thumb_func_start CpuSet
|
||||||
CpuSet:
|
CpuSet:
|
||||||
swi 11
|
svc #11
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end CpuSet
|
thumb_func_end CpuSet
|
||||||
.endif
|
.endif
|
||||||
@ -385,7 +385,7 @@ CpuSet:
|
|||||||
.ifdef L_Diff16bitUnFilter
|
.ifdef L_Diff16bitUnFilter
|
||||||
thumb_func_start Diff16bitUnFilter
|
thumb_func_start Diff16bitUnFilter
|
||||||
Diff16bitUnFilter:
|
Diff16bitUnFilter:
|
||||||
swi 24
|
svc #24
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end Diff16bitUnFilter
|
thumb_func_end Diff16bitUnFilter
|
||||||
.endif
|
.endif
|
||||||
@ -393,8 +393,8 @@ Diff16bitUnFilter:
|
|||||||
.ifdef L_SoundBiasSet
|
.ifdef L_SoundBiasSet
|
||||||
thumb_func_start SoundBiasSet
|
thumb_func_start SoundBiasSet
|
||||||
SoundBiasSet:
|
SoundBiasSet:
|
||||||
mov r0, #1
|
movs r0, #1
|
||||||
swi 25
|
svc #25
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end SoundBiasSet
|
thumb_func_end SoundBiasSet
|
||||||
.endif
|
.endif
|
||||||
@ -402,7 +402,7 @@ SoundBiasSet:
|
|||||||
.ifdef L_MusicPlayerContinue
|
.ifdef L_MusicPlayerContinue
|
||||||
thumb_func_start MusicPlayerContinue
|
thumb_func_start MusicPlayerContinue
|
||||||
MusicPlayerContinue:
|
MusicPlayerContinue:
|
||||||
swi 35
|
svc #35
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end MusicPlayerContinue
|
thumb_func_end MusicPlayerContinue
|
||||||
.endif
|
.endif
|
||||||
@ -411,12 +411,12 @@ MusicPlayerContinue:
|
|||||||
thumb_func_start SoftReset
|
thumb_func_start SoftReset
|
||||||
SoftReset:
|
SoftReset:
|
||||||
ldr r3, =REG_IME
|
ldr r3, =REG_IME
|
||||||
mov r2, #0
|
movs r2, #0
|
||||||
strb r2, [r3, #0]
|
strb r2, [r3, #0]
|
||||||
ldr r1, =0x3007f00
|
ldr r1, =0x3007f00
|
||||||
mov sp, r1
|
mov sp, r1
|
||||||
swi 1
|
svc #1
|
||||||
swi 0
|
svc #0
|
||||||
.pool
|
.pool
|
||||||
thumb_func_end SoftReset
|
thumb_func_end SoftReset
|
||||||
.endif
|
.endif
|
||||||
@ -424,7 +424,7 @@ SoftReset:
|
|||||||
.ifdef L_RLUnCompVram
|
.ifdef L_RLUnCompVram
|
||||||
thumb_func_start RLUnCompVram
|
thumb_func_start RLUnCompVram
|
||||||
RLUnCompVram:
|
RLUnCompVram:
|
||||||
swi 21
|
svc #21
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end RLUnCompVram
|
thumb_func_end RLUnCompVram
|
||||||
.endif
|
.endif
|
||||||
|
80
src/crt0.s
80
src/crt0.s
@ -82,10 +82,10 @@ GPIOPortReadEnable: @ 80000C8
|
|||||||
.align 2, 0
|
.align 2, 0
|
||||||
.global Init
|
.global Init
|
||||||
Init: @ 8000204
|
Init: @ 8000204
|
||||||
mov r0, PSR_IRQ_MODE
|
mov r0, #PSR_IRQ_MODE
|
||||||
msr cpsr_cf, r0
|
msr cpsr_cf, r0
|
||||||
ldr sp, sp_irq
|
ldr sp, sp_irq
|
||||||
mov r0, PSR_SYS_MODE
|
mov r0, #PSR_SYS_MODE
|
||||||
msr cpsr_cf, r0
|
msr cpsr_cf, r0
|
||||||
ldr sp, sp_sys
|
ldr sp, sp_sys
|
||||||
ldr r1, =INTR_VECTOR
|
ldr r1, =INTR_VECTOR
|
||||||
@ -106,91 +106,91 @@ sp_irq: .word IWRAM_END - 0x60
|
|||||||
.align 2, 0
|
.align 2, 0
|
||||||
.global IntrMain
|
.global IntrMain
|
||||||
IntrMain: @ 8000248
|
IntrMain: @ 8000248
|
||||||
mov r3, REG_BASE
|
mov r3, #REG_BASE
|
||||||
add r3, r3, 0x200
|
add r3, r3, #OFFSET_REG_IE
|
||||||
ldr r2, [r3, OFFSET_REG_IE - 0x200]
|
ldr r2, [r3]
|
||||||
ldrh r1, [r3, OFFSET_REG_IME - 0x200]
|
ldrh r1, [r3, #OFFSET_REG_IME - 0x200]
|
||||||
mrs r0, spsr
|
mrs r0, spsr
|
||||||
stmdb sp!, {r0-r3,lr}
|
stmfd sp!, {r0-r3,lr}
|
||||||
mov r0, 0
|
mov r0, #0
|
||||||
strh r0, [r3, OFFSET_REG_IME - 0x200]
|
strh r0, [r3, #OFFSET_REG_IME - 0x200]
|
||||||
and r1, r2, r2, lsr 16
|
and r1, r2, r2, lsr #16
|
||||||
mov r12, 0
|
mov r12, #0
|
||||||
ands r0, r1, INTR_FLAG_VCOUNT
|
ands r0, r1, #INTR_FLAG_VCOUNT
|
||||||
bne IntrMain_FoundIntr
|
bne IntrMain_FoundIntr
|
||||||
add r12, r12, 0x4
|
add r12, r12, 0x4
|
||||||
mov r0, 0x1
|
mov r0, 0x1
|
||||||
strh r0, [r3, OFFSET_REG_IME - 0x200]
|
strh r0, [r3, #OFFSET_REG_IME - 0x200]
|
||||||
ands r0, r1, INTR_FLAG_SERIAL
|
ands r0, r1, #INTR_FLAG_SERIAL
|
||||||
bne IntrMain_FoundIntr
|
bne IntrMain_FoundIntr
|
||||||
add r12, r12, 0x4
|
add r12, r12, 0x4
|
||||||
ands r0, r1, INTR_FLAG_TIMER3
|
ands r0, r1, #INTR_FLAG_TIMER3
|
||||||
bne IntrMain_FoundIntr
|
bne IntrMain_FoundIntr
|
||||||
add r12, r12, 0x4
|
add r12, r12, 0x4
|
||||||
ands r0, r1, INTR_FLAG_HBLANK
|
ands r0, r1, #INTR_FLAG_HBLANK
|
||||||
bne IntrMain_FoundIntr
|
bne IntrMain_FoundIntr
|
||||||
add r12, r12, 0x4
|
add r12, r12, 0x4
|
||||||
ands r0, r1, INTR_FLAG_VBLANK
|
ands r0, r1, #INTR_FLAG_VBLANK
|
||||||
bne IntrMain_FoundIntr
|
bne IntrMain_FoundIntr
|
||||||
add r12, r12, 0x4
|
add r12, r12, 0x4
|
||||||
ands r0, r1, INTR_FLAG_TIMER0
|
ands r0, r1, #INTR_FLAG_TIMER0
|
||||||
bne IntrMain_FoundIntr
|
bne IntrMain_FoundIntr
|
||||||
add r12, r12, 0x4
|
add r12, r12, 0x4
|
||||||
ands r0, r1, INTR_FLAG_TIMER1
|
ands r0, r1, #INTR_FLAG_TIMER1
|
||||||
bne IntrMain_FoundIntr
|
bne IntrMain_FoundIntr
|
||||||
add r12, r12, 0x4
|
add r12, r12, 0x4
|
||||||
ands r0, r1, INTR_FLAG_TIMER2
|
ands r0, r1, #INTR_FLAG_TIMER2
|
||||||
bne IntrMain_FoundIntr
|
bne IntrMain_FoundIntr
|
||||||
add r12, r12, 0x4
|
add r12, r12, 0x4
|
||||||
ands r0, r1, INTR_FLAG_DMA0
|
ands r0, r1, #INTR_FLAG_DMA0
|
||||||
bne IntrMain_FoundIntr
|
bne IntrMain_FoundIntr
|
||||||
add r12, r12, 0x4
|
add r12, r12, 0x4
|
||||||
ands r0, r1, INTR_FLAG_DMA1
|
ands r0, r1, #INTR_FLAG_DMA1
|
||||||
bne IntrMain_FoundIntr
|
bne IntrMain_FoundIntr
|
||||||
add r12, r12, 0x4
|
add r12, r12, 0x4
|
||||||
ands r0, r1, INTR_FLAG_DMA2
|
ands r0, r1, #INTR_FLAG_DMA2
|
||||||
bne IntrMain_FoundIntr
|
bne IntrMain_FoundIntr
|
||||||
add r12, r12, 0x4
|
add r12, r12, 0x4
|
||||||
ands r0, r1, INTR_FLAG_DMA3
|
ands r0, r1, #INTR_FLAG_DMA3
|
||||||
bne IntrMain_FoundIntr
|
bne IntrMain_FoundIntr
|
||||||
add r12, r12, 0x4
|
add r12, r12, 0x4
|
||||||
ands r0, r1, INTR_FLAG_KEYPAD
|
ands r0, r1, #INTR_FLAG_KEYPAD
|
||||||
bne IntrMain_FoundIntr
|
bne IntrMain_FoundIntr
|
||||||
add r12, r12, 0x4
|
add r12, r12, 0x4
|
||||||
ands r0, r1, INTR_FLAG_GAMEPAK
|
ands r0, r1, #INTR_FLAG_GAMEPAK
|
||||||
strbne r0, [r3, OFFSET_REG_SOUNDCNT_X - 0x200]
|
strbne r0, [r3, #REG_SOUNDCNT_X - REG_IE]
|
||||||
bne . @ spin
|
bne . @ spin
|
||||||
IntrMain_FoundIntr:
|
IntrMain_FoundIntr:
|
||||||
strh r0, [r3, OFFSET_REG_IF - 0x200]
|
strh r0, [r3, #OFFSET_REG_IF - 0x200]
|
||||||
bic r2, r2, r0
|
bic r2, r2, r0
|
||||||
ldr r0, =gSTWIStatus
|
ldr r0, =gSTWIStatus
|
||||||
ldr r0, [r0]
|
ldr r0, [r0]
|
||||||
ldrb r0, [r0, 0xA]
|
ldrb r0, [r0, 0xA]
|
||||||
mov r1, 0x8
|
mov r1, 0x8
|
||||||
mov r0, r1, lsl r0
|
lsl r0, r1, r0
|
||||||
orr r0, r0, INTR_FLAG_GAMEPAK
|
orr r0, r0, #INTR_FLAG_GAMEPAK
|
||||||
orr r1, r0, INTR_FLAG_SERIAL | INTR_FLAG_TIMER3 | INTR_FLAG_VCOUNT | INTR_FLAG_HBLANK
|
orr r1, r0, #INTR_FLAG_SERIAL | INTR_FLAG_TIMER3 | INTR_FLAG_VCOUNT | INTR_FLAG_HBLANK
|
||||||
and r1, r1, r2
|
and r1, r1, r2
|
||||||
strh r1, [r3, OFFSET_REG_IE - 0x200]
|
strh r1, [r3, #OFFSET_REG_IE - 0x200]
|
||||||
mrs r3, cpsr
|
mrs r3, cpsr
|
||||||
bic r3, r3, PSR_I_BIT | PSR_F_BIT | PSR_MODE_MASK
|
bic r3, r3, #PSR_I_BIT | PSR_F_BIT | PSR_MODE_MASK
|
||||||
orr r3, r3, PSR_SYS_MODE
|
orr r3, r3, #PSR_SYS_MODE
|
||||||
msr cpsr_cf, r3
|
msr cpsr_cf, r3
|
||||||
ldr r1, =gIntrTable
|
ldr r1, =gIntrTable
|
||||||
add r1, r1, r12
|
add r1, r1, r12
|
||||||
ldr r0, [r1]
|
ldr r0, [r1]
|
||||||
stmdb sp!, {lr}
|
stmfd sp!, {lr}
|
||||||
adr lr, IntrMain_RetAddr
|
adr lr, IntrMain_RetAddr
|
||||||
bx r0
|
bx r0
|
||||||
IntrMain_RetAddr:
|
IntrMain_RetAddr:
|
||||||
ldmia sp!, {lr}
|
ldmfd sp!, {lr}
|
||||||
mrs r3, cpsr
|
mrs r3, cpsr
|
||||||
bic r3, r3, PSR_I_BIT | PSR_F_BIT | PSR_MODE_MASK
|
bic r3, r3, #PSR_I_BIT | PSR_F_BIT | PSR_MODE_MASK
|
||||||
orr r3, r3, PSR_I_BIT | PSR_IRQ_MODE
|
orr r3, r3, #PSR_I_BIT | PSR_IRQ_MODE
|
||||||
msr cpsr_cf, r3
|
msr cpsr_cf, r3
|
||||||
ldmia sp!, {r0-r3,lr}
|
ldmia sp!, {r0-r3,lr}
|
||||||
strh r2, [r3, OFFSET_REG_IE - 0x200]
|
strh r2, [r3, #OFFSET_REG_IE - 0x200]
|
||||||
strh r1, [r3, OFFSET_REG_IME - 0x200]
|
strh r1, [r3, #OFFSET_REG_IME - 0x200]
|
||||||
msr spsr_cf, r0
|
msr spsr_cf, r0
|
||||||
bx lr
|
bx lr
|
||||||
|
|
||||||
|
@ -22,7 +22,7 @@ GameCubeMultiBoot_Hash: @ 82DED70
|
|||||||
movs r2, 0x20
|
movs r2, 0x20
|
||||||
|
|
||||||
GameCubeMultiBoot_Hash_Loop:
|
GameCubeMultiBoot_Hash_Loop:
|
||||||
lsrs r3, 1
|
lsrs r3, #1
|
||||||
bcc GameCubeMultiBoot_Hash_SkipEor
|
bcc GameCubeMultiBoot_Hash_SkipEor
|
||||||
|
|
||||||
eors r3, r4
|
eors r3, r4
|
||||||
@ -37,8 +37,8 @@ GameCubeMultiBoot_Hash_SkipEor:
|
|||||||
thumb_func_start GameCubeMultiBoot_Main
|
thumb_func_start GameCubeMultiBoot_Main
|
||||||
@ void GameCubeMultiBoot_Main(struct GameCubeMultiBoot *mb);
|
@ void GameCubeMultiBoot_Main(struct GameCubeMultiBoot *mb);
|
||||||
GameCubeMultiBoot_Main: @ 82DED84
|
GameCubeMultiBoot_Main: @ 82DED84
|
||||||
ldr r1, [r0, GCMB_STRUCT_SERIAL_INTR_HANDLER]
|
ldr r1, [r0, #GCMB_STRUCT_SERIAL_INTR_HANDLER]
|
||||||
cmp r1, 0
|
cmp r1, #0
|
||||||
beq _082DEDAA
|
beq _082DEDAA
|
||||||
ldrb r1, [r0, 0x1]
|
ldrb r1, [r0, 0x1]
|
||||||
adds r1, 0x1
|
adds r1, 0x1
|
||||||
@ -47,30 +47,30 @@ GameCubeMultiBoot_Main: @ 82DED84
|
|||||||
cmp r1, 0x2
|
cmp r1, 0x2
|
||||||
beq _082DEDF4
|
beq _082DEDF4
|
||||||
ldr r3, pool_InterruptRegs
|
ldr r3, pool_InterruptRegs
|
||||||
ldrh r2, [r3, OFFSET_REG_IME - 0x200]
|
ldrh r2, [r3, #OFFSET_REG_IME - 0x200]
|
||||||
movs r1, 0
|
movs r1, 0
|
||||||
strh r1, [r3, OFFSET_REG_IME - 0x200]
|
strh r1, [r3, #OFFSET_REG_IME - 0x200]
|
||||||
ldrb r1, [r0]
|
ldrb r1, [r0]
|
||||||
cmp r1, 0xA
|
cmp r1, 0xA
|
||||||
bgt _082DEDA8
|
bgt _082DEDA8
|
||||||
adds r1, 0x1
|
adds r1, 0x1
|
||||||
strb r1, [r0]
|
strb r1, [r0]
|
||||||
_082DEDA8:
|
_082DEDA8:
|
||||||
strh r2, [r3, OFFSET_REG_IME - 0x200]
|
strh r2, [r3, #OFFSET_REG_IME - 0x200]
|
||||||
_082DEDAA:
|
_082DEDAA:
|
||||||
bcs GameCubeMultiBoot_Init
|
bcs GameCubeMultiBoot_Init
|
||||||
ldrb r1, [r0, 0x2]
|
ldrb r1, [r0, 0x2]
|
||||||
cmp r1, 0
|
cmp r1, 0
|
||||||
bne _082DEDF6
|
bne _082DEDF6
|
||||||
ldr r1, [r0, GCMB_STRUCT_CUR_DEST_PTR]
|
ldr r1, [r0, #GCMB_STRUCT_CUR_DEST_PTR]
|
||||||
ldr r2, [r0, GCMB_STRUCT_BASE_DEST_PTR]
|
ldr r2, [r0, #GCMB_STRUCT_BASE_DEST_PTR]
|
||||||
subs r1, r2
|
subs r1, r2
|
||||||
beq _082DEE76
|
beq _082DEE76
|
||||||
cmp r1, 0xA0
|
cmp r1, 0xA0
|
||||||
bcc _082DEE76
|
bcc _082DEE76
|
||||||
push {r4-r6}
|
push {r4-r6}
|
||||||
movs r1, 0x98
|
movs r1, 0x98
|
||||||
adds r2, ROM_HEADER_NINTENDO_LOGO_OFFSET
|
adds r2, #ROM_HEADER_NINTENDO_LOGO_OFFSET
|
||||||
ldr r4, pool_NintendoLogo
|
ldr r4, pool_NintendoLogo
|
||||||
_082DEDC6:
|
_082DEDC6:
|
||||||
ldm r2!, {r5}
|
ldm r2!, {r5}
|
||||||
@ -82,8 +82,8 @@ _082DEDC6:
|
|||||||
ldm r2!, {r5}
|
ldm r2!, {r5}
|
||||||
ldm r4!, {r6}
|
ldm r4!, {r6}
|
||||||
eors r5, r6
|
eors r5, r6
|
||||||
lsrs r5, 8
|
lsrs r5, #8
|
||||||
str r2, [r0, GCMB_STRUCT_BASE_DEST_PTR]
|
str r2, [r0, #GCMB_STRUCT_BASE_DEST_PTR]
|
||||||
_082DEDDC:
|
_082DEDDC:
|
||||||
pop {r4-r6}
|
pop {r4-r6}
|
||||||
bne GameCubeMultiBoot_Init
|
bne GameCubeMultiBoot_Init
|
||||||
@ -100,11 +100,11 @@ _082DEDDC:
|
|||||||
_082DEDF4:
|
_082DEDF4:
|
||||||
bx lr
|
bx lr
|
||||||
_082DEDF6:
|
_082DEDF6:
|
||||||
ldr r1, [r0, GCMB_STRUCT_CUR_DEST_PTR]
|
ldr r1, [r0, #GCMB_STRUCT_CUR_DEST_PTR]
|
||||||
mov r12, r1
|
mov r12, r1
|
||||||
ldr r3, [r0, 0x18]
|
ldr r3, [r0, 0x18]
|
||||||
push {r4-r7}
|
push {r4-r7}
|
||||||
ldr r4, [r0, GCMB_STRUCT_BASE_DEST_PTR]
|
ldr r4, [r0, #GCMB_STRUCT_BASE_DEST_PTR]
|
||||||
ldr r5, pool_Kawa
|
ldr r5, pool_Kawa
|
||||||
ldr r6, [r0, 0x14]
|
ldr r6, [r0, 0x14]
|
||||||
ldr r7, pool_HashVal
|
ldr r7, pool_HashVal
|
||||||
@ -118,7 +118,7 @@ _082DEE06:
|
|||||||
eors r3, r1
|
eors r3, r1
|
||||||
movs r2, 0x20
|
movs r2, 0x20
|
||||||
_082DEE16:
|
_082DEE16:
|
||||||
lsrs r3, 1
|
lsrs r3, #1
|
||||||
bcc _082DEE1C
|
bcc _082DEE1C
|
||||||
eors r3, r7
|
eors r3, r7
|
||||||
_082DEE1C:
|
_082DEE1C:
|
||||||
@ -128,22 +128,22 @@ _082DEE1C:
|
|||||||
adds r6, 0x1
|
adds r6, 0x1
|
||||||
b _082DEE06
|
b _082DEE06
|
||||||
_082DEE26:
|
_082DEE26:
|
||||||
str r4, [r0, GCMB_STRUCT_BASE_DEST_PTR]
|
str r4, [r0, #GCMB_STRUCT_BASE_DEST_PTR]
|
||||||
str r6, [r0, 0x14]
|
str r6, [r0, 0x14]
|
||||||
pop {r4-r7}
|
pop {r4-r7}
|
||||||
str r3, [r0, 0x18]
|
str r3, [r0, 0x18]
|
||||||
ldrh r1, [r0, 0x12]
|
ldrh r1, [r0, 0x12]
|
||||||
cmp r1, 0
|
cmp r1, #0
|
||||||
bne _082DEE76
|
bne _082DEE76
|
||||||
ldr r1, [r0, GCMB_STRUCT_CUR_DEST_PTR]
|
ldr r1, [r0, #GCMB_STRUCT_CUR_DEST_PTR]
|
||||||
ldr r2, [r0, GCMB_STRUCT_BASE_DEST_PTR]
|
ldr r2, [r0, #GCMB_STRUCT_BASE_DEST_PTR]
|
||||||
cmp r1, r2
|
cmp r1, r2
|
||||||
bne _082DEE76
|
bne _082DEE76
|
||||||
ldr r1, [r0, 0xC]
|
ldr r1, [r0, 0xC]
|
||||||
cmp r1, 0
|
cmp r1, #0
|
||||||
beq _082DEE60
|
beq _082DEE60
|
||||||
ldrh r1, [r0, 0x10]
|
ldrh r1, [r0, 0x10]
|
||||||
cmp r1, 0
|
cmp r1, #0
|
||||||
beq _082DEDF4
|
beq _082DEDF4
|
||||||
mov r12, lr
|
mov r12, lr
|
||||||
movs r1, 0xBB
|
movs r1, 0xBB
|
||||||
@ -159,11 +159,11 @@ _082DEE26:
|
|||||||
_082DEE60:
|
_082DEE60:
|
||||||
mov r12, lr
|
mov r12, lr
|
||||||
ldrb r1, [r0, 0x3]
|
ldrb r1, [r0, 0x3]
|
||||||
lsls r1, 24
|
lsls r1, #24
|
||||||
subs r1, 0x1
|
subs r1, 0x1
|
||||||
str r1, [r0, 0xC]
|
str r1, [r0, 0xC]
|
||||||
bl GameCubeMultiBoot_Hash
|
bl GameCubeMultiBoot_Hash
|
||||||
lsls r3, 8
|
lsls r3, #8
|
||||||
adds r3, 0xFF
|
adds r3, 0xFF
|
||||||
str r3, [r0, 0x1C]
|
str r3, [r0, 0x1C]
|
||||||
bx r12
|
bx r12
|
||||||
@ -186,8 +186,8 @@ GameCubeMultiBoot_ExecuteProgram: @ 82DEE84
|
|||||||
cmp r1, 0x2
|
cmp r1, 0x2
|
||||||
bne GameCubeMultiBoot_ExecuteProgram_Fail
|
bne GameCubeMultiBoot_ExecuteProgram_Fail
|
||||||
ldr r3, pool_InterruptRegs
|
ldr r3, pool_InterruptRegs
|
||||||
movs r1, 0
|
movs r1, #0
|
||||||
strh r1, [r3, OFFSET_REG_IME - 0x200]
|
strh r1, [r3, #OFFSET_REG_IME - 0x200]
|
||||||
ldr r1, pool_MultiBootLoadAddr
|
ldr r1, pool_MultiBootLoadAddr
|
||||||
adds r1, 0xC0
|
adds r1, 0xC0
|
||||||
bx r1
|
bx r1
|
||||||
@ -201,25 +201,25 @@ GameCubeMultiBoot_Init: @ 82DEE98
|
|||||||
ldr r3, pool_InterruptRegs
|
ldr r3, pool_InterruptRegs
|
||||||
|
|
||||||
@ Save IME register.
|
@ Save IME register.
|
||||||
ldrh r2, [r3, OFFSET_REG_IME - 0x200]
|
ldrh r2, [r3, #OFFSET_REG_IME - 0x200]
|
||||||
|
|
||||||
@ Disable interrupts.
|
@ Disable interrupts.
|
||||||
movs r1, 0
|
movs r1, 0
|
||||||
strh r1, [r3, OFFSET_REG_IME - 0x200]
|
strh r1, [r3, #OFFSET_REG_IME - 0x200]
|
||||||
|
|
||||||
@ Set the handler to the "Stop" routine.
|
@ Set the handler to the "Stop" routine.
|
||||||
@ Unless the first command that is received is a device reset command, the
|
@ Unless the first command that is received is a device reset command, the
|
||||||
@ "Stop" routine will be executed and no further commands will be processed.
|
@ "Stop" routine will be executed and no further commands will be processed.
|
||||||
adr r3, GcMbIntrHandler_Stop
|
adr r3, GcMbIntrHandler_Stop
|
||||||
str r3, [r0, GCMB_STRUCT_SERIAL_INTR_HANDLER]
|
str r3, [r0, #GCMB_STRUCT_SERIAL_INTR_HANDLER]
|
||||||
|
|
||||||
ldrb r3, [r0, 0x3]
|
ldrb r3, [r0, 0x3]
|
||||||
push {r3}
|
push {r3}
|
||||||
ldrb r3, [r0, 0x1]
|
ldrb r3, [r0, 0x1]
|
||||||
push {r0,r3}
|
push {r0,r3}
|
||||||
|
|
||||||
adds r3, r0, 0
|
adds r3, r0, #0
|
||||||
adds r3, GCMB_STRUCT_BASE_DEST_PTR
|
adds r3, #GCMB_STRUCT_BASE_DEST_PTR
|
||||||
|
|
||||||
@ clear all but the last 3 fields of the struct
|
@ clear all but the last 3 fields of the struct
|
||||||
GameCubeMultiBoot_Init_ClearStructLoop:
|
GameCubeMultiBoot_Init_ClearStructLoop:
|
||||||
@ -261,7 +261,7 @@ GameCubeMultiBoot_Init_ClearStructLoop:
|
|||||||
strh r1, [r3, OFFSET_REG_IE - 0x200]
|
strh r1, [r3, OFFSET_REG_IE - 0x200]
|
||||||
|
|
||||||
@ Restore IME register.
|
@ Restore IME register.
|
||||||
strh r2, [r3, OFFSET_REG_IME - 0x200]
|
strh r2, [r3, #OFFSET_REG_IME - 0x200]
|
||||||
|
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end GameCubeMultiBoot_Init
|
thumb_func_end GameCubeMultiBoot_Init
|
||||||
@ -275,11 +275,11 @@ GameCubeMultiBoot_HandleSerialInterrupt: @ 82DEEE2
|
|||||||
ldrh r1, [r3, OFFSET_REG_JOYCNT - 0x120]
|
ldrh r1, [r3, OFFSET_REG_JOYCNT - 0x120]
|
||||||
strh r1, [r3, OFFSET_REG_JOYCNT - 0x120]
|
strh r1, [r3, OFFSET_REG_JOYCNT - 0x120]
|
||||||
|
|
||||||
movs r2, 0
|
movs r2, #0
|
||||||
strb r2, [r0]
|
strb r2, [r0]
|
||||||
|
|
||||||
ldr r2, [r0, GCMB_STRUCT_SERIAL_INTR_HANDLER]
|
ldr r2, [r0, #GCMB_STRUCT_SERIAL_INTR_HANDLER]
|
||||||
cmp r2, 0
|
cmp r2, #0
|
||||||
beq GameCubeMultiBoot_HandleSerialInterruptDone
|
beq GameCubeMultiBoot_HandleSerialInterruptDone
|
||||||
|
|
||||||
lsrs r1, 1 @ was a device reset command received?
|
lsrs r1, 1 @ was a device reset command received?
|
||||||
@ -297,7 +297,7 @@ GcMbIntrHandler_Stop:
|
|||||||
strh r2, [r3, OFFSET_REG_JOYSTAT - 0x120]
|
strh r2, [r3, OFFSET_REG_JOYSTAT - 0x120]
|
||||||
|
|
||||||
GameCubeMultiBoot_SetInterruptHandler:
|
GameCubeMultiBoot_SetInterruptHandler:
|
||||||
str r2, [r0, GCMB_STRUCT_SERIAL_INTR_HANDLER]
|
str r2, [r0, #GCMB_STRUCT_SERIAL_INTR_HANDLER]
|
||||||
|
|
||||||
GameCubeMultiBoot_ReadVCount:
|
GameCubeMultiBoot_ReadVCount:
|
||||||
ldr r3, pool_RegDispstat
|
ldr r3, pool_RegDispstat
|
||||||
@ -319,8 +319,8 @@ GameCubeMultiBoot_BeginHandshake:
|
|||||||
cmp r1, 0
|
cmp r1, 0
|
||||||
bne GcMbIntrHandler_Stop
|
bne GcMbIntrHandler_Stop
|
||||||
ldr r1, pool_MultiBootLoadAddr
|
ldr r1, pool_MultiBootLoadAddr
|
||||||
str r1, [r0, GCMB_STRUCT_BASE_DEST_PTR]
|
str r1, [r0, #GCMB_STRUCT_BASE_DEST_PTR]
|
||||||
str r1, [r0, GCMB_STRUCT_CUR_DEST_PTR]
|
str r1, [r0, #GCMB_STRUCT_CUR_DEST_PTR]
|
||||||
adr r2, GcMbIntrHandler_CheckGameCodeSent
|
adr r2, GcMbIntrHandler_CheckGameCodeSent
|
||||||
b GameCubeMultiBoot_SetInterruptHandler
|
b GameCubeMultiBoot_SetInterruptHandler
|
||||||
|
|
||||||
@ -417,8 +417,8 @@ _082DEF94:
|
|||||||
_082DEFA6:
|
_082DEFA6:
|
||||||
bne GcMbIntrHandler_Stop
|
bne GcMbIntrHandler_Stop
|
||||||
ldr r1, pool_MultiBootLoadAddr
|
ldr r1, pool_MultiBootLoadAddr
|
||||||
str r1, [r0, GCMB_STRUCT_BASE_DEST_PTR]
|
str r1, [r0, #GCMB_STRUCT_BASE_DEST_PTR]
|
||||||
str r1, [r0, GCMB_STRUCT_CUR_DEST_PTR]
|
str r1, [r0, #GCMB_STRUCT_CUR_DEST_PTR]
|
||||||
adr r2, GcMbIntrHandler_82DEFB4
|
adr r2, GcMbIntrHandler_82DEFB4
|
||||||
b GameCubeMultiBoot_SetInterruptHandler
|
b GameCubeMultiBoot_SetInterruptHandler
|
||||||
|
|
||||||
@ -427,7 +427,7 @@ _082DEFA6:
|
|||||||
GcMbIntrHandler_82DEFB4: @ 82DEFB4
|
GcMbIntrHandler_82DEFB4: @ 82DEFB4
|
||||||
lsrs r1, 1 @ is receive complete?
|
lsrs r1, 1 @ is receive complete?
|
||||||
bcc GcMbIntrHandler_Stop @ branch if not
|
bcc GcMbIntrHandler_Stop @ branch if not
|
||||||
ldr r2, [r0, GCMB_STRUCT_CUR_DEST_PTR]
|
ldr r2, [r0, #GCMB_STRUCT_CUR_DEST_PTR]
|
||||||
movs r1, 0x4
|
movs r1, 0x4
|
||||||
ands r1, r2
|
ands r1, r2
|
||||||
adds r1, 0x8
|
adds r1, 0x8
|
||||||
@ -435,7 +435,7 @@ GcMbIntrHandler_82DEFB4: @ 82DEFB4
|
|||||||
strh r1, [r3, OFFSET_REG_JOYSTAT - 0x120]
|
strh r1, [r3, OFFSET_REG_JOYSTAT - 0x120]
|
||||||
ldr r1, [r3, OFFSET_REG_JOY_RECV - 0x120]
|
ldr r1, [r3, OFFSET_REG_JOY_RECV - 0x120]
|
||||||
stm r2!, {r1}
|
stm r2!, {r1}
|
||||||
str r2, [r0, GCMB_STRUCT_CUR_DEST_PTR]
|
str r2, [r0, #GCMB_STRUCT_CUR_DEST_PTR]
|
||||||
ldrh r1, [r0, 0x12]
|
ldrh r1, [r0, 0x12]
|
||||||
subs r1, 0x1
|
subs r1, 0x1
|
||||||
strh r1, [r0, 0x12]
|
strh r1, [r0, 0x12]
|
||||||
@ -500,11 +500,11 @@ GameCubeMultiBoot_Quit: @ 82DF012
|
|||||||
ldr r3, pool_InterruptRegs
|
ldr r3, pool_InterruptRegs
|
||||||
|
|
||||||
@ Save IME register.
|
@ Save IME register.
|
||||||
ldrh r2, [r3, OFFSET_REG_IME - 0x200]
|
ldrh r2, [r3, #OFFSET_REG_IME - 0x200]
|
||||||
|
|
||||||
@ Disable interrupts.
|
@ Disable interrupts.
|
||||||
movs r1, 0
|
movs r1, 0
|
||||||
strh r1, [r3, OFFSET_REG_IME - 0x200]
|
strh r1, [r3, #OFFSET_REG_IME - 0x200]
|
||||||
|
|
||||||
ldr r3, pool_SerialRegs
|
ldr r3, pool_SerialRegs
|
||||||
|
|
||||||
@ -528,7 +528,7 @@ GameCubeMultiBoot_Quit: @ 82DF012
|
|||||||
strh r1, [r3, OFFSET_REG_IE - 0x200]
|
strh r1, [r3, OFFSET_REG_IE - 0x200]
|
||||||
|
|
||||||
@ Restore IME register.
|
@ Restore IME register.
|
||||||
strh r2, [r3, OFFSET_REG_IME - 0x200]
|
strh r2, [r3, #OFFSET_REG_IME - 0x200]
|
||||||
|
|
||||||
bx lr
|
bx lr
|
||||||
thumb_func_end GameCubeMultiBoot_Quit
|
thumb_func_end GameCubeMultiBoot_Quit
|
||||||
|
Loading…
x
Reference in New Issue
Block a user