mirror of
https://github.com/pret/pokeplatinum.git
synced 2026-04-25 15:49:02 -05:00
403 lines
6.9 KiB
ArmAsm
403 lines
6.9 KiB
ArmAsm
.include "macros/function.inc"
|
|
.include "include/connect.inc"
|
|
|
|
|
|
|
|
.text
|
|
|
|
|
|
arm_func_start ov4_021E6B90
|
|
ov4_021E6B90: ; 0x021E6B90
|
|
stmfd sp!, {r4, lr}
|
|
bl ov4_021E63A4
|
|
mov r4, r0
|
|
mov r0, #0x10
|
|
bl ov4_021E62EC
|
|
cmp r4, #7
|
|
beq _021E6BB8
|
|
cmp r4, #8
|
|
beq _021E6BC4
|
|
b _021E6BCC
|
|
_021E6BB8:
|
|
bl ov4_021E6BD4
|
|
mov r4, r0
|
|
b _021E6BCC
|
|
_021E6BC4:
|
|
bl ov4_021E6CCC
|
|
mov r4, r0
|
|
_021E6BCC:
|
|
mov r0, r4
|
|
ldmia sp!, {r4, pc}
|
|
arm_func_end ov4_021E6B90
|
|
|
|
arm_func_start ov4_021E6BD4
|
|
ov4_021E6BD4: ; 0x021E6BD4
|
|
stmfd sp!, {r3, r4, r5, lr}
|
|
mov r5, r0
|
|
ldrb r2, [r5, #0xd13]
|
|
add r3, r5, #0x470
|
|
mov r1, #0xc0
|
|
mla r4, r2, r1, r3
|
|
bl ov4_021E6E08
|
|
add r1, r5, #0xb8
|
|
strb r0, [r5, #0xd0d]
|
|
add r0, r1, #0xc00
|
|
mov r1, #0
|
|
mov r2, #0x52
|
|
bl MI_CpuFill8
|
|
add r2, r5, #0xb8
|
|
ldrb r1, [r5, #0xd0d]
|
|
mov r0, r5
|
|
add r2, r2, #0xc00
|
|
bl ov4_021E6FDC
|
|
cmp r0, #0
|
|
ldrb r0, [r5, #0xd0b]
|
|
bic r0, r0, #0xc
|
|
beq _021E6C88
|
|
orr r0, r0, #4
|
|
strb r0, [r5, #0xd0b]
|
|
ldrh r0, [r4, #0x2c]
|
|
mov r0, r0, asr #4
|
|
tst r0, #1
|
|
bne _021E6C5C
|
|
ldrb r1, [r5, #0xd13]
|
|
mov r2, #3
|
|
mov r0, #9
|
|
add r1, r5, r1, lsl #2
|
|
strb r2, [r1, #0x444]
|
|
ldmia sp!, {r3, r4, r5, pc}
|
|
_021E6C5C:
|
|
ldrb r0, [r5, #0xd0d]
|
|
cmp r0, #6
|
|
ldreqb r0, [r4, #0x15]
|
|
cmpeq r0, #0
|
|
bne _021E6CB8
|
|
ldrb r1, [r5, #0xd13]
|
|
mov r2, #3
|
|
mov r0, #9
|
|
add r1, r5, r1, lsl #2
|
|
strb r2, [r1, #0x444]
|
|
ldmia sp!, {r3, r4, r5, pc}
|
|
_021E6C88:
|
|
strb r0, [r5, #0xd0b]
|
|
ldrh r0, [r4, #0x2c]
|
|
mov r0, r0, asr #4
|
|
and r0, r0, #1
|
|
cmp r0, #1
|
|
bne _021E6CB8
|
|
ldrb r1, [r5, #0xd13]
|
|
mov r2, #3
|
|
mov r0, #9
|
|
add r1, r5, r1, lsl #2
|
|
strb r2, [r1, #0x444]
|
|
ldmia sp!, {r3, r4, r5, pc}
|
|
_021E6CB8:
|
|
mov r0, #0
|
|
strb r0, [r5, #0xd15]
|
|
strb r0, [r5, #0xd14]
|
|
mov r0, #8
|
|
ldmia sp!, {r3, r4, r5, pc}
|
|
arm_func_end ov4_021E6BD4
|
|
|
|
arm_func_start ov4_021E6CCC
|
|
ov4_021E6CCC: ; 0x021E6CCC
|
|
stmfd sp!, {r3, r4, r5, r6, r7, lr}
|
|
mov r7, r0
|
|
bl WCM_GetPhase
|
|
ldrb r2, [r7, #0xd13]
|
|
mov r1, #0xc0
|
|
cmp r0, #3
|
|
add r5, r7, #0x470
|
|
smulbb r4, r2, r1
|
|
bne _021E6DDC
|
|
mov r0, r7
|
|
bl ov4_021E6FA4
|
|
ldrb r1, [r7, #0xd15]
|
|
mov r6, r0
|
|
add r0, r1, #1
|
|
and r1, r0, #0xff
|
|
strb r0, [r7, #0xd15]
|
|
cmp r1, #3
|
|
bls _021E6D34
|
|
mov r0, #0
|
|
strb r0, [r7, #0xd15]
|
|
ldrb r1, [r7, #0xd13]
|
|
mov r2, #1
|
|
mov r0, #9
|
|
add r1, r7, r1, lsl #2
|
|
strb r2, [r1, #0x444]
|
|
ldmia sp!, {r3, r4, r5, r6, r7, pc}
|
|
_021E6D34:
|
|
cmp r1, #1
|
|
beq _021E6DB8
|
|
ldrb r0, [r7, #0xd14]
|
|
cmp r0, #1
|
|
bne _021E6D58
|
|
ldrb r0, [r7, #0xd0b]
|
|
bic r0, r0, #0xc
|
|
strb r0, [r7, #0xd0b]
|
|
b _021E6DB8
|
|
_021E6D58:
|
|
cmp r0, #2
|
|
bne _021E6D80
|
|
mov r0, #0
|
|
strb r0, [r7, #0xd15]
|
|
ldrb r1, [r7, #0xd13]
|
|
mov r2, #3
|
|
mov r0, #9
|
|
add r1, r7, r1, lsl #2
|
|
strb r2, [r1, #0x444]
|
|
ldmia sp!, {r3, r4, r5, r6, r7, pc}
|
|
_021E6D80:
|
|
cmp r0, #3
|
|
bne _021E6DA8
|
|
mov r0, #0
|
|
strb r0, [r7, #0xd15]
|
|
ldrb r1, [r7, #0xd13]
|
|
mov r2, #4
|
|
mov r0, #9
|
|
add r1, r7, r1, lsl #2
|
|
strb r2, [r1, #0x444]
|
|
ldmia sp!, {r3, r4, r5, r6, r7, pc}
|
|
_021E6DA8:
|
|
cmp r1, #3
|
|
ldreqb r0, [r7, #0xd0b]
|
|
biceq r0, r0, #0xc
|
|
streqb r0, [r7, #0xd0b]
|
|
_021E6DB8:
|
|
mov r0, r7
|
|
bl ov4_021E6FC0
|
|
mov r2, r0
|
|
add r1, r7, #0xb8
|
|
add r0, r5, r4
|
|
add r1, r1, #0xc00
|
|
orr r2, r6, r2
|
|
bl ov4_02213368
|
|
b _021E6E00
|
|
_021E6DDC:
|
|
cmp r0, #9
|
|
bne _021E6E00
|
|
mov r0, #0
|
|
strb r0, [r7, #0xd15]
|
|
bl OS_GetTick
|
|
str r0, [r7, #0xcb0]
|
|
str r1, [r7, #0xcb4]
|
|
mov r0, #0xa
|
|
ldmia sp!, {r3, r4, r5, r6, r7, pc}
|
|
_021E6E00:
|
|
mov r0, #8
|
|
ldmia sp!, {r3, r4, r5, r6, r7, pc}
|
|
arm_func_end ov4_021E6CCC
|
|
|
|
arm_func_start ov4_021E6E08
|
|
ov4_021E6E08: ; 0x021E6E08
|
|
stmfd sp!, {r3, r4, r5, r6, r7, r8, sb, sl, fp, lr}
|
|
mov sl, r0
|
|
ldrb r2, [sl, #0xd13]
|
|
ldrb r1, [sl, #0xd0c]
|
|
add r3, sl, #0x470
|
|
mov r0, #0xc0
|
|
mla r4, r2, r0, r3
|
|
mov r0, r1, lsl #0x18
|
|
movs r0, r0, lsr #0x1e
|
|
mov r0, #0
|
|
str r0, [sp]
|
|
bne _021E6F24
|
|
ldrh r0, [r4, #0xa]
|
|
ldr r6, [sp]
|
|
cmp r0, #0x20
|
|
bne _021E6E68
|
|
mov r0, r4
|
|
bl ov4_021E66F4
|
|
cmp r0, #0
|
|
str r0, [sp]
|
|
movle r0, #0
|
|
addgt r6, r6, #1
|
|
strle r0, [sp]
|
|
b _021E6E8C
|
|
_021E6E68:
|
|
cmp r0, #8
|
|
bne _021E6E8C
|
|
mov r0, r4
|
|
bl ov4_021E7490
|
|
cmp r0, #0
|
|
str r0, [sp]
|
|
moveq r0, #0
|
|
addne r6, r6, #1
|
|
streq r0, [sp]
|
|
_021E6E8C:
|
|
ldrb r0, [sl, #0xd10]
|
|
mov r5, #0
|
|
cmp r0, #0
|
|
ble _021E6F98
|
|
mov r7, sl
|
|
add r8, sl, #0x304
|
|
add sb, sl, #0x300
|
|
add fp, sl, #0x10c
|
|
_021E6EAC:
|
|
ldrh r2, [r4, #0xa]
|
|
ldrb r0, [r7, #0x303]
|
|
cmp r2, r0
|
|
bne _021E6F04
|
|
mov r1, r8
|
|
add r0, r4, #0xc
|
|
bl strncmp
|
|
cmp r0, #0
|
|
bne _021E6F04
|
|
cmp r6, #0
|
|
ldreqb r0, [r7, #0x301]
|
|
streq r0, [sp]
|
|
beq _021E6F00
|
|
ldrb r0, [sb]
|
|
bic r0, r0, #0xf0
|
|
orr r0, r0, #0x10
|
|
strb r0, [sb]
|
|
ldrb r0, [fp, #0xc00]
|
|
bic r0, r0, #0xc0
|
|
orr r0, r0, #0x40
|
|
strb r0, [fp, #0xc00]
|
|
_021E6F00:
|
|
add r6, r6, #1
|
|
_021E6F04:
|
|
ldrb r0, [sl, #0xd10]
|
|
add r5, r5, #1
|
|
add r7, r7, #0x24
|
|
cmp r5, r0
|
|
add r8, r8, #0x24
|
|
add sb, sb, #0x24
|
|
blt _021E6EAC
|
|
b _021E6F98
|
|
_021E6F24:
|
|
ldrb r0, [sl, #0xd10]
|
|
ldr r5, [sp]
|
|
mov r4, r5
|
|
cmp r0, #0
|
|
ble _021E6F88
|
|
mov r3, sl
|
|
add r2, sl, #0x300
|
|
_021E6F40:
|
|
ldrb r0, [r2]
|
|
mov r1, r0, lsl #0x18
|
|
mov r1, r1, lsr #0x1c
|
|
cmp r1, #1
|
|
bne _021E6F70
|
|
cmp r4, #0
|
|
bne _021E6F6C
|
|
bic r0, r0, #0xf0
|
|
strb r0, [r2]
|
|
ldrb r0, [r3, #0x301]
|
|
str r0, [sp]
|
|
_021E6F6C:
|
|
add r4, r4, #1
|
|
_021E6F70:
|
|
ldrb r0, [sl, #0xd10]
|
|
add r5, r5, #1
|
|
add r2, r2, #0x24
|
|
cmp r5, r0
|
|
add r3, r3, #0x24
|
|
blt _021E6F40
|
|
_021E6F88:
|
|
cmp r4, #1
|
|
ldreqb r0, [sl, #0xd0c]
|
|
biceq r0, r0, #0xc0
|
|
streqb r0, [sl, #0xd0c]
|
|
_021E6F98:
|
|
ldr r0, [sp]
|
|
and r0, r0, #0xff
|
|
ldmia sp!, {r3, r4, r5, r6, r7, r8, sb, sl, fp, pc}
|
|
arm_func_end ov4_021E6E08
|
|
|
|
arm_func_start ov4_021E6FA4
|
|
ov4_021E6FA4: ; 0x021E6FA4
|
|
ldrb r0, [r0, #0xd0b]
|
|
mov r0, r0, lsl #0x1e
|
|
mov r0, r0, lsr #0x1e
|
|
cmp r0, #1
|
|
moveq r0, #0x30000
|
|
movne r0, #0x20000
|
|
bx lr
|
|
arm_func_end ov4_021E6FA4
|
|
|
|
arm_func_start ov4_021E6FC0
|
|
ov4_021E6FC0: ; 0x021E6FC0
|
|
ldrb r0, [r0, #0xd0b]
|
|
mov r0, r0, lsl #0x1c
|
|
mov r0, r0, lsr #0x1e
|
|
cmp r0, #1
|
|
moveq r0, #0xc0000
|
|
movne r0, #0x80000
|
|
bx lr
|
|
arm_func_end ov4_021E6FC0
|
|
|
|
arm_func_start ov4_021E6FDC
|
|
ov4_021E6FDC: ; 0x021E6FDC
|
|
stmfd sp!, {r4, lr}
|
|
mov r4, r2
|
|
cmp r1, #9
|
|
addls pc, pc, r1, lsl #2
|
|
b _021E70B4
|
|
_021E6FF0: ; jump table
|
|
b _021E7020 ; case 0
|
|
b _021E701C ; case 1
|
|
b _021E7018 ; case 2
|
|
b _021E704C ; case 3
|
|
b _021E7048 ; case 4
|
|
b _021E7044 ; case 5
|
|
b _021E7068 ; case 6
|
|
b _021E7090 ; case 7
|
|
b _021E70B4 ; case 8
|
|
b _021E70B4 ; case 9
|
|
_021E7018:
|
|
add r0, r0, #0x100
|
|
_021E701C:
|
|
add r0, r0, #0x100
|
|
_021E7020:
|
|
ldrb r2, [r0, #0xe6]
|
|
add r0, r0, #0x80
|
|
add r1, r4, #2
|
|
mov r2, r2, lsl #0x1e
|
|
mov r3, r2, lsr #0x1e
|
|
mov r2, #0x10
|
|
strb r3, [r4]
|
|
bl MI_CpuCopy8
|
|
b _021E70B4
|
|
_021E7044:
|
|
add r0, r0, #0x100
|
|
_021E7048:
|
|
add r0, r0, #0x100
|
|
_021E704C:
|
|
mov r3, #1
|
|
add r0, r0, #0xd1
|
|
add r1, r4, #2
|
|
mov r2, #5
|
|
strb r3, [r4]
|
|
bl MI_CpuCopy8
|
|
b _021E70B4
|
|
_021E7068:
|
|
mov r1, #2
|
|
strb r1, [r4]
|
|
ldrb r1, [r0, #0xd13]
|
|
add r0, r0, #0x7c
|
|
add r2, r0, #0x400
|
|
mov r0, #0xc0
|
|
mla r0, r1, r0, r2
|
|
add r1, r4, #2
|
|
bl ov4_021E86C4
|
|
b _021E70B4
|
|
_021E7090:
|
|
mov r1, #2
|
|
strb r1, [r4]
|
|
ldrb r1, [r0, #0xd13]
|
|
add r0, r0, #0x7c
|
|
add r2, r0, #0x400
|
|
mov r0, #0xc0
|
|
mla r0, r1, r0, r2
|
|
add r1, r4, #2
|
|
bl ov4_021E862C
|
|
_021E70B4:
|
|
ldrb r0, [r4]
|
|
cmp r0, #0
|
|
movne r0, #1
|
|
moveq r0, #0
|
|
ldmia sp!, {r4, pc}
|
|
arm_func_end ov4_021E6FDC |