mirror of
https://github.com/Ninjdai1/pokeemerald.git
synced 2025-01-13 23:23:43 +01:00
finish link rfu and fix rom 8011dc0
This commit is contained in:
parent
b082f000af
commit
e17140536a
520
asm/link_rfu.s
520
asm/link_rfu.s
@ -1,520 +0,0 @@
|
|||||||
.include "asm/macros.inc"
|
|
||||||
.include "constants/constants.inc"
|
|
||||||
|
|
||||||
.syntax unified
|
|
||||||
|
|
||||||
.text
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
thumb_func_start sub_801209C
|
|
||||||
sub_801209C: @ 801209C
|
|
||||||
push {r4-r7,lr}
|
|
||||||
mov r7, r8
|
|
||||||
push {r7}
|
|
||||||
lsls r0, 24
|
|
||||||
lsrs r5, r0, 24
|
|
||||||
mov r8, r5
|
|
||||||
ldr r6, =gUnknown_03005000
|
|
||||||
adds r0, r6, 0
|
|
||||||
adds r0, 0xF1
|
|
||||||
ldrb r0, [r0]
|
|
||||||
cmp r0, 0x4
|
|
||||||
bne _080120BA
|
|
||||||
adds r0, r5, 0
|
|
||||||
bl DestroyTask
|
|
||||||
_080120BA:
|
|
||||||
ldr r1, =gTasks
|
|
||||||
lsls r0, r5, 2
|
|
||||||
adds r0, r5
|
|
||||||
lsls r0, 3
|
|
||||||
adds r4, r0, r1
|
|
||||||
ldrh r0, [r4, 0x8]
|
|
||||||
adds r0, 0x1
|
|
||||||
strh r0, [r4, 0x8]
|
|
||||||
lsls r0, 16
|
|
||||||
movs r1, 0x96
|
|
||||||
lsls r1, 17
|
|
||||||
cmp r0, r1
|
|
||||||
ble _080120E4
|
|
||||||
movs r1, 0xE0
|
|
||||||
lsls r1, 7
|
|
||||||
movs r0, 0x2
|
|
||||||
bl sub_8011A64
|
|
||||||
adds r0, r5, 0
|
|
||||||
bl DestroyTask
|
|
||||||
_080120E4:
|
|
||||||
ldr r1, =0x00000ccd
|
|
||||||
adds r0, r6, r1
|
|
||||||
ldrb r0, [r0]
|
|
||||||
cmp r0, 0
|
|
||||||
beq _0801217C
|
|
||||||
ldr r0, =gUnknown_03004140
|
|
||||||
ldrb r0, [r0, 0x6]
|
|
||||||
cmp r0, 0
|
|
||||||
bne _0801217C
|
|
||||||
movs r2, 0x86
|
|
||||||
lsls r2, 1
|
|
||||||
adds r0, r6, r2
|
|
||||||
bl ReadU16
|
|
||||||
adds r1, r0, 0
|
|
||||||
lsls r1, 16
|
|
||||||
lsrs r1, 16
|
|
||||||
ldr r2, =0x00000119
|
|
||||||
adds r0, r6, r2
|
|
||||||
bl sub_8011CE4
|
|
||||||
lsls r0, 24
|
|
||||||
lsrs r2, r0, 24
|
|
||||||
cmp r2, 0xFF
|
|
||||||
beq _0801217C
|
|
||||||
movs r1, 0xA
|
|
||||||
ldrsh r0, [r4, r1]
|
|
||||||
ldr r7, =gUnknown_03007890
|
|
||||||
lsls r4, r2, 5
|
|
||||||
adds r2, r4, 0
|
|
||||||
adds r2, 0x14
|
|
||||||
ldr r1, [r7]
|
|
||||||
adds r1, r2
|
|
||||||
adds r1, 0x6
|
|
||||||
bl sub_801200C
|
|
||||||
cmp r0, 0
|
|
||||||
bne _0801216C
|
|
||||||
ldr r0, [r7]
|
|
||||||
adds r1, r0, r4
|
|
||||||
ldrb r0, [r1, 0x16]
|
|
||||||
cmp r0, 0xFF
|
|
||||||
beq _0801217C
|
|
||||||
ldrh r0, [r1, 0x14]
|
|
||||||
movs r1, 0x5A
|
|
||||||
bl sub_800C12C
|
|
||||||
lsls r0, 24
|
|
||||||
cmp r0, 0
|
|
||||||
bne _0801217C
|
|
||||||
movs r0, 0xA
|
|
||||||
strh r0, [r6, 0x4]
|
|
||||||
adds r0, r5, 0
|
|
||||||
bl DestroyTask
|
|
||||||
b _0801217C
|
|
||||||
.pool
|
|
||||||
_0801216C:
|
|
||||||
movs r1, 0xE0
|
|
||||||
lsls r1, 7
|
|
||||||
movs r0, 0x2
|
|
||||||
bl sub_8011A64
|
|
||||||
mov r0, r8
|
|
||||||
bl DestroyTask
|
|
||||||
_0801217C:
|
|
||||||
pop {r3}
|
|
||||||
mov r8, r3
|
|
||||||
pop {r4-r7}
|
|
||||||
pop {r0}
|
|
||||||
bx r0
|
|
||||||
thumb_func_end sub_801209C
|
|
||||||
|
|
||||||
thumb_func_start sub_8012188
|
|
||||||
sub_8012188: @ 8012188
|
|
||||||
push {r4-r7,lr}
|
|
||||||
adds r3, r0, 0
|
|
||||||
adds r5, r1, 0
|
|
||||||
lsls r4, r2, 24
|
|
||||||
lsrs r4, 24
|
|
||||||
ldr r6, =gUnknown_03005000
|
|
||||||
ldr r1, =0x00000ccf
|
|
||||||
adds r0, r6, r1
|
|
||||||
movs r7, 0
|
|
||||||
strb r7, [r0]
|
|
||||||
adds r0, r6, 0
|
|
||||||
adds r0, 0xF1
|
|
||||||
strb r7, [r0]
|
|
||||||
ldr r1, =0x00000119
|
|
||||||
adds r0, r6, r1
|
|
||||||
adds r1, r3, 0
|
|
||||||
bl StringCopy
|
|
||||||
movs r1, 0x85
|
|
||||||
lsls r1, 1
|
|
||||||
adds r0, r6, r1
|
|
||||||
adds r1, r5, 0
|
|
||||||
movs r2, 0xD
|
|
||||||
bl memcpy
|
|
||||||
bl sub_800D658
|
|
||||||
ldr r0, =sub_801209C
|
|
||||||
movs r1, 0x2
|
|
||||||
bl CreateTask
|
|
||||||
lsls r0, 24
|
|
||||||
lsrs r0, 24
|
|
||||||
ldr r5, =gTasks
|
|
||||||
lsls r1, r0, 2
|
|
||||||
adds r1, r0
|
|
||||||
lsls r1, 3
|
|
||||||
adds r1, r5
|
|
||||||
strh r4, [r1, 0xA]
|
|
||||||
ldr r0, =sub_800EB44
|
|
||||||
bl FindTaskIdByFunc
|
|
||||||
lsls r0, 24
|
|
||||||
lsrs r1, r0, 24
|
|
||||||
adds r2, r1, 0
|
|
||||||
cmp r4, 0x45
|
|
||||||
bne _08012210
|
|
||||||
cmp r1, 0xFF
|
|
||||||
beq _0801221E
|
|
||||||
lsls r0, r1, 2
|
|
||||||
adds r0, r1
|
|
||||||
lsls r0, 3
|
|
||||||
adds r0, r5
|
|
||||||
movs r1, 0x1
|
|
||||||
strh r1, [r0, 0x16]
|
|
||||||
b _0801221E
|
|
||||||
.pool
|
|
||||||
_08012210:
|
|
||||||
cmp r2, 0xFF
|
|
||||||
beq _0801221E
|
|
||||||
lsls r0, r2, 2
|
|
||||||
adds r0, r2
|
|
||||||
lsls r0, 3
|
|
||||||
adds r0, r5
|
|
||||||
strh r7, [r0, 0x16]
|
|
||||||
_0801221E:
|
|
||||||
pop {r4-r7}
|
|
||||||
pop {r0}
|
|
||||||
bx r0
|
|
||||||
thumb_func_end sub_8012188
|
|
||||||
|
|
||||||
thumb_func_start sub_8012224
|
|
||||||
sub_8012224: @ 8012224
|
|
||||||
push {lr}
|
|
||||||
ldr r0, =gUnknown_03005000
|
|
||||||
adds r0, 0xF0
|
|
||||||
ldrb r0, [r0]
|
|
||||||
cmp r0, 0x1
|
|
||||||
beq _08012238
|
|
||||||
movs r0, 0
|
|
||||||
b _0801223A
|
|
||||||
.pool
|
|
||||||
_08012238:
|
|
||||||
movs r0, 0x1
|
|
||||||
_0801223A:
|
|
||||||
pop {r1}
|
|
||||||
bx r1
|
|
||||||
thumb_func_end sub_8012224
|
|
||||||
|
|
||||||
thumb_func_start sub_8012240
|
|
||||||
sub_8012240: @ 8012240
|
|
||||||
push {r4,lr}
|
|
||||||
movs r1, 0
|
|
||||||
ldr r0, =gUnknown_03004140
|
|
||||||
ldrb r2, [r0]
|
|
||||||
ldr r4, =gUnknown_03005000+0xCD1
|
|
||||||
movs r3, 0x1
|
|
||||||
_0801224C:
|
|
||||||
adds r0, r2, 0
|
|
||||||
asrs r0, r1
|
|
||||||
ands r0, r3
|
|
||||||
cmp r0, 0
|
|
||||||
beq _0801226C
|
|
||||||
adds r0, r1, r4
|
|
||||||
ldrb r0, [r0]
|
|
||||||
cmp r0, 0
|
|
||||||
bne _0801226C
|
|
||||||
movs r0, 0
|
|
||||||
b _08012274
|
|
||||||
.pool
|
|
||||||
_0801226C:
|
|
||||||
adds r1, 0x1
|
|
||||||
cmp r1, 0x3
|
|
||||||
ble _0801224C
|
|
||||||
movs r0, 0x1
|
|
||||||
_08012274:
|
|
||||||
pop {r4}
|
|
||||||
pop {r1}
|
|
||||||
bx r1
|
|
||||||
thumb_func_end sub_8012240
|
|
||||||
|
|
||||||
thumb_func_start sub_801227C
|
|
||||||
sub_801227C: @ 801227C
|
|
||||||
push {r4,lr}
|
|
||||||
movs r4, 0
|
|
||||||
_08012280:
|
|
||||||
lsls r2, r4, 24
|
|
||||||
lsrs r2, 24
|
|
||||||
ldr r0, =gUnknown_082ED82C
|
|
||||||
movs r1, 0
|
|
||||||
bl nullsub_5
|
|
||||||
adds r4, 0x1
|
|
||||||
cmp r4, 0x13
|
|
||||||
ble _08012280
|
|
||||||
pop {r4}
|
|
||||||
pop {r0}
|
|
||||||
bx r0
|
|
||||||
.pool
|
|
||||||
thumb_func_end sub_801227C
|
|
||||||
|
|
||||||
thumb_func_start sub_801229C
|
|
||||||
sub_801229C: @ 801229C
|
|
||||||
push {r4-r7,lr}
|
|
||||||
mov r7, r8
|
|
||||||
push {r7}
|
|
||||||
bl GetBlockReceivedStatus
|
|
||||||
lsls r0, 24
|
|
||||||
lsrs r0, 24
|
|
||||||
movs r1, 0x1C
|
|
||||||
movs r2, 0x13
|
|
||||||
movs r3, 0x2
|
|
||||||
bl nullsub_13
|
|
||||||
ldr r4, =gUnknown_03007890
|
|
||||||
ldr r0, [r4]
|
|
||||||
ldrb r0, [r0, 0x2]
|
|
||||||
movs r1, 0x14
|
|
||||||
movs r2, 0x1
|
|
||||||
movs r3, 0x1
|
|
||||||
bl nullsub_13
|
|
||||||
ldr r0, [r4]
|
|
||||||
ldrb r0, [r0, 0x3]
|
|
||||||
movs r1, 0x17
|
|
||||||
movs r2, 0x1
|
|
||||||
movs r3, 0x1
|
|
||||||
bl nullsub_13
|
|
||||||
ldr r0, =gUnknown_03005000
|
|
||||||
ldrb r0, [r0, 0xC]
|
|
||||||
cmp r0, 0x1
|
|
||||||
bne _08012378
|
|
||||||
movs r6, 0
|
|
||||||
adds r7, r4, 0
|
|
||||||
movs r5, 0x14
|
|
||||||
_080122E0:
|
|
||||||
ldr r2, [r7]
|
|
||||||
ldrb r0, [r2, 0x7]
|
|
||||||
asrs r0, r6
|
|
||||||
movs r1, 0x1
|
|
||||||
ands r0, r1
|
|
||||||
cmp r0, 0
|
|
||||||
beq _0801231E
|
|
||||||
lsls r0, r6, 5
|
|
||||||
adds r0, r2, r0
|
|
||||||
ldrh r0, [r0, 0x18]
|
|
||||||
adds r4, r6, 0x3
|
|
||||||
lsls r4, 24
|
|
||||||
lsrs r4, 24
|
|
||||||
adds r2, r4, 0
|
|
||||||
movs r3, 0x4
|
|
||||||
bl nullsub_13
|
|
||||||
ldr r0, [r7]
|
|
||||||
adds r0, r5
|
|
||||||
adds r0, 0x6
|
|
||||||
movs r1, 0x6
|
|
||||||
adds r2, r4, 0
|
|
||||||
bl nullsub_5
|
|
||||||
ldr r0, [r7]
|
|
||||||
adds r0, r5
|
|
||||||
adds r0, 0x15
|
|
||||||
movs r1, 0x16
|
|
||||||
adds r2, r4, 0
|
|
||||||
bl nullsub_5
|
|
||||||
_0801231E:
|
|
||||||
adds r5, 0x20
|
|
||||||
adds r6, 0x1
|
|
||||||
cmp r6, 0x3
|
|
||||||
ble _080122E0
|
|
||||||
movs r6, 0
|
|
||||||
ldr r0, =gUnknown_03005000
|
|
||||||
mov r8, r0
|
|
||||||
_0801232C:
|
|
||||||
movs r5, 0
|
|
||||||
adds r7, r6, 0x1
|
|
||||||
lsls r0, r6, 3
|
|
||||||
adds r2, r6, 0
|
|
||||||
adds r2, 0xB
|
|
||||||
subs r0, r6
|
|
||||||
lsls r0, 1
|
|
||||||
mov r1, r8
|
|
||||||
adds r1, 0x14
|
|
||||||
adds r4, r0, r1
|
|
||||||
lsls r6, r2, 24
|
|
||||||
_08012342:
|
|
||||||
ldrb r0, [r4]
|
|
||||||
lsls r1, r5, 25
|
|
||||||
lsrs r1, 24
|
|
||||||
lsrs r2, r6, 24
|
|
||||||
movs r3, 0x2
|
|
||||||
bl nullsub_13
|
|
||||||
adds r4, 0x1
|
|
||||||
adds r5, 0x1
|
|
||||||
cmp r5, 0xD
|
|
||||||
ble _08012342
|
|
||||||
adds r6, r7, 0
|
|
||||||
cmp r6, 0x3
|
|
||||||
ble _0801232C
|
|
||||||
ldr r0, =gUnknown_082ED868
|
|
||||||
movs r1, 0x1
|
|
||||||
movs r2, 0xF
|
|
||||||
bl nullsub_5
|
|
||||||
b _080124AA
|
|
||||||
.pool
|
|
||||||
_08012378:
|
|
||||||
ldr r1, [r4]
|
|
||||||
ldrb r0, [r1, 0x2]
|
|
||||||
cmp r0, 0
|
|
||||||
beq _08012414
|
|
||||||
ldrb r0, [r1, 0x7]
|
|
||||||
cmp r0, 0
|
|
||||||
beq _08012414
|
|
||||||
movs r6, 0
|
|
||||||
movs r5, 0xC0
|
|
||||||
lsls r5, 18
|
|
||||||
_0801238C:
|
|
||||||
lsrs r4, r5, 24
|
|
||||||
movs r0, 0
|
|
||||||
movs r1, 0x1
|
|
||||||
adds r2, r4, 0
|
|
||||||
movs r3, 0x4
|
|
||||||
bl nullsub_13
|
|
||||||
ldr r0, =gUnknown_082ED84B
|
|
||||||
movs r1, 0x6
|
|
||||||
adds r2, r4, 0
|
|
||||||
bl nullsub_5
|
|
||||||
ldr r0, =gUnknown_082ED85B
|
|
||||||
movs r1, 0x16
|
|
||||||
adds r2, r4, 0
|
|
||||||
bl nullsub_5
|
|
||||||
movs r1, 0x80
|
|
||||||
lsls r1, 17
|
|
||||||
adds r5, r1
|
|
||||||
adds r6, 0x1
|
|
||||||
cmp r6, 0x3
|
|
||||||
ble _0801238C
|
|
||||||
ldr r5, =gUnknown_03007890
|
|
||||||
ldr r1, [r5]
|
|
||||||
ldr r4, =gUnknown_03005000
|
|
||||||
ldr r0, =0x00000c3e
|
|
||||||
adds r4, r0
|
|
||||||
ldrb r0, [r4]
|
|
||||||
lsls r0, 5
|
|
||||||
adds r1, r0
|
|
||||||
ldrh r0, [r1, 0x18]
|
|
||||||
movs r1, 0x1
|
|
||||||
movs r2, 0x3
|
|
||||||
movs r3, 0x4
|
|
||||||
bl nullsub_13
|
|
||||||
ldrb r1, [r4]
|
|
||||||
lsls r1, 5
|
|
||||||
adds r1, 0x14
|
|
||||||
ldr r0, [r5]
|
|
||||||
adds r0, r1
|
|
||||||
adds r0, 0x6
|
|
||||||
movs r1, 0x6
|
|
||||||
movs r2, 0x3
|
|
||||||
bl nullsub_5
|
|
||||||
ldrb r1, [r4]
|
|
||||||
lsls r1, 5
|
|
||||||
adds r1, 0x14
|
|
||||||
ldr r0, [r5]
|
|
||||||
adds r0, r1
|
|
||||||
adds r0, 0x15
|
|
||||||
movs r1, 0x16
|
|
||||||
movs r2, 0x3
|
|
||||||
bl nullsub_5
|
|
||||||
b _080124AA
|
|
||||||
.pool
|
|
||||||
_08012414:
|
|
||||||
movs r6, 0
|
|
||||||
ldr r1, =gUnknown_03007890
|
|
||||||
ldr r0, [r1]
|
|
||||||
ldrb r0, [r0, 0x8]
|
|
||||||
cmp r6, r0
|
|
||||||
bge _08012470
|
|
||||||
adds r7, r1, 0
|
|
||||||
movs r1, 0x14
|
|
||||||
mov r8, r1
|
|
||||||
_08012426:
|
|
||||||
ldr r0, [r7]
|
|
||||||
lsls r5, r6, 5
|
|
||||||
adds r1, r0, r5
|
|
||||||
ldrb r0, [r1, 0x16]
|
|
||||||
cmp r0, 0xFF
|
|
||||||
beq _08012462
|
|
||||||
ldrh r0, [r1, 0x18]
|
|
||||||
adds r4, r6, 0x3
|
|
||||||
lsls r4, 24
|
|
||||||
lsrs r4, 24
|
|
||||||
movs r1, 0x1
|
|
||||||
adds r2, r4, 0
|
|
||||||
movs r3, 0x4
|
|
||||||
bl nullsub_13
|
|
||||||
ldr r0, [r7]
|
|
||||||
adds r0, r5
|
|
||||||
ldrh r0, [r0, 0x14]
|
|
||||||
movs r1, 0x6
|
|
||||||
adds r2, r4, 0
|
|
||||||
movs r3, 0x4
|
|
||||||
bl nullsub_13
|
|
||||||
ldr r0, [r7]
|
|
||||||
add r0, r8
|
|
||||||
adds r0, 0x15
|
|
||||||
movs r1, 0x16
|
|
||||||
adds r2, r4, 0
|
|
||||||
bl nullsub_5
|
|
||||||
_08012462:
|
|
||||||
movs r0, 0x20
|
|
||||||
add r8, r0
|
|
||||||
adds r6, 0x1
|
|
||||||
ldr r0, [r7]
|
|
||||||
ldrb r0, [r0, 0x8]
|
|
||||||
cmp r6, r0
|
|
||||||
blt _08012426
|
|
||||||
_08012470:
|
|
||||||
cmp r6, 0x3
|
|
||||||
bgt _080124AA
|
|
||||||
lsls r0, r6, 24
|
|
||||||
movs r1, 0xC0
|
|
||||||
lsls r1, 18
|
|
||||||
adds r5, r0, r1
|
|
||||||
_0801247C:
|
|
||||||
lsrs r4, r5, 24
|
|
||||||
movs r0, 0
|
|
||||||
movs r1, 0x1
|
|
||||||
adds r2, r4, 0
|
|
||||||
movs r3, 0x4
|
|
||||||
bl nullsub_13
|
|
||||||
ldr r0, =gUnknown_082ED84B
|
|
||||||
movs r1, 0x6
|
|
||||||
adds r2, r4, 0
|
|
||||||
bl nullsub_5
|
|
||||||
ldr r0, =gUnknown_082ED85B
|
|
||||||
movs r1, 0x16
|
|
||||||
adds r2, r4, 0
|
|
||||||
bl nullsub_5
|
|
||||||
movs r0, 0x80
|
|
||||||
lsls r0, 17
|
|
||||||
adds r5, r0
|
|
||||||
adds r6, 0x1
|
|
||||||
cmp r6, 0x3
|
|
||||||
ble _0801247C
|
|
||||||
_080124AA:
|
|
||||||
pop {r3}
|
|
||||||
mov r8, r3
|
|
||||||
pop {r4-r7}
|
|
||||||
pop {r0}
|
|
||||||
bx r0
|
|
||||||
.pool
|
|
||||||
thumb_func_end sub_801229C
|
|
||||||
|
|
||||||
thumb_func_start sub_80124C0
|
|
||||||
sub_80124C0: @ 80124C0
|
|
||||||
ldr r0, =gUnknown_03005000
|
|
||||||
ldr r1, =0x00000c1a
|
|
||||||
adds r0, r1
|
|
||||||
ldrb r0, [r0]
|
|
||||||
bx lr
|
|
||||||
.pool
|
|
||||||
thumb_func_end sub_80124C0
|
|
||||||
|
|
||||||
thumb_func_start sub_80124D4
|
|
||||||
sub_80124D4: @ 80124D4
|
|
||||||
ldr r0, =gUnknown_03005000
|
|
||||||
ldr r1, =0x000009e6
|
|
||||||
adds r0, r1
|
|
||||||
ldrb r0, [r0]
|
|
||||||
bx lr
|
|
||||||
.pool
|
|
||||||
thumb_func_end sub_80124D4
|
|
||||||
|
|
||||||
.align 2, 0 @ don't pad with nop
|
|
1851
asm/rom_8011DC0.s
1851
asm/rom_8011DC0.s
File diff suppressed because it is too large
Load Diff
@ -1,3 +1,6 @@
|
|||||||
|
#ifndef GUARD_LIBRFU_H
|
||||||
|
#define GUARD_LIBRFU_H
|
||||||
|
|
||||||
#include "main.h"
|
#include "main.h"
|
||||||
|
|
||||||
enum
|
enum
|
||||||
@ -253,3 +256,5 @@ void rfu_UNI_readySendData(u8 a0);
|
|||||||
void rfu_UNI_clearRecvNewDataFlag(u8 a0);
|
void rfu_UNI_clearRecvNewDataFlag(u8 a0);
|
||||||
void rfu_REQ_PARENT_resumeRetransmitAndChange(void);
|
void rfu_REQ_PARENT_resumeRetransmitAndChange(void);
|
||||||
void rfu_NI_setSendData(u8, u8, u8 *, u8);
|
void rfu_NI_setSendData(u8, u8, u8 *, u8);
|
||||||
|
|
||||||
|
#endif // GUARD_LIBRFU_H
|
||||||
|
@ -1,6 +1,8 @@
|
|||||||
#ifndef GUARD_LINK_RFU_H
|
#ifndef GUARD_LINK_RFU_H
|
||||||
#define GUARD_LINK_RFU_H
|
#define GUARD_LINK_RFU_H
|
||||||
|
|
||||||
|
#include "librfu.h"
|
||||||
|
|
||||||
// Exported type declarations
|
// Exported type declarations
|
||||||
|
|
||||||
struct UnkLinkRfuStruct_02022B2C
|
struct UnkLinkRfuStruct_02022B2C
|
||||||
@ -158,7 +160,8 @@ struct UnkRfuStruct_2
|
|||||||
/* 0x102 */ u8 unk_102;
|
/* 0x102 */ u8 unk_102;
|
||||||
/* 0x103 */ u8 filler_103[0x10A - 0x103];
|
/* 0x103 */ u8 filler_103[0x10A - 0x103];
|
||||||
/* 0x10A */ struct UnkLinkRfuStruct_02022B14 unk_10A;
|
/* 0x10A */ struct UnkLinkRfuStruct_02022B14 unk_10A;
|
||||||
u8 filler_120[12];
|
u8 filler_;
|
||||||
|
u8 playerName[PLAYER_NAME_LENGTH + 1];
|
||||||
/* 0x124 */ struct UnkRfuStruct_2_Sub_124 unk_124;
|
/* 0x124 */ struct UnkRfuStruct_2_Sub_124 unk_124;
|
||||||
/* 0x9e8 */ struct UnkRfuStruct_2_Sub_9e8 unk_9e8;
|
/* 0x9e8 */ struct UnkRfuStruct_2_Sub_9e8 unk_9e8;
|
||||||
/* 0xc1c */ struct UnkRfuStruct_2_Sub_c1c unk_c1c;
|
/* 0xc1c */ struct UnkRfuStruct_2_Sub_c1c unk_c1c;
|
||||||
@ -193,7 +196,8 @@ struct UnkRfuStruct_2
|
|||||||
/* 0xcee */ u8 unk_cee[4];
|
/* 0xcee */ u8 unk_cee[4];
|
||||||
}; // size = 0xcf4
|
}; // size = 0xcf4
|
||||||
|
|
||||||
struct UnkRfuStruct_8010A14 {
|
struct UnkRfuStruct_8010A14
|
||||||
|
{
|
||||||
char unk_00[15];
|
char unk_00[15];
|
||||||
u8 unk_0f;
|
u8 unk_0f;
|
||||||
u8 unk_10[4];
|
u8 unk_10[4];
|
||||||
@ -266,7 +270,7 @@ void sub_8010FA0(bool32 a0, bool32 a1);
|
|||||||
void sub_8010F60(void);
|
void sub_8010F60(void);
|
||||||
void sub_8010FCC(u32 a0, u32 a1, u32 a2);
|
void sub_8010FCC(u32 a0, u32 a1, u32 a2);
|
||||||
void sub_8011C84(void);
|
void sub_8011C84(void);
|
||||||
void sub_8012188(const u8 *a0, struct UnkLinkRfuStruct_02022B14 *arg1, u8 arg2);
|
void sub_8012188(const u8 *name, struct UnkLinkRfuStruct_02022B14 *structPtr, u8 a2);
|
||||||
bool32 sub_8011B90(void);
|
bool32 sub_8011B90(void);
|
||||||
void sub_800FE50(u16 *a0);
|
void sub_800FE50(u16 *a0);
|
||||||
bool32 sub_800E540(u16 id, u8 *name);
|
bool32 sub_800E540(u16 id, u8 *name);
|
||||||
|
@ -54,7 +54,6 @@ SECTIONS {
|
|||||||
src/string_util.o(.text);
|
src/string_util.o(.text);
|
||||||
src/link.o(.text);
|
src/link.o(.text);
|
||||||
src/link_rfu.o(.text);
|
src/link_rfu.o(.text);
|
||||||
asm/link_rfu.o(.text);
|
|
||||||
src/rom_8011DC0.o(.text);
|
src/rom_8011DC0.o(.text);
|
||||||
asm/rom_8011DC0.o(.text);
|
asm/rom_8011DC0.o(.text);
|
||||||
src/rtc.o(.text);
|
src/rtc.o(.text);
|
||||||
|
311
src/link_rfu.c
311
src/link_rfu.c
@ -1,20 +1,20 @@
|
|||||||
#include "global.h"
|
#include "global.h"
|
||||||
#include "malloc.h"
|
|
||||||
#include "battle.h"
|
#include "battle.h"
|
||||||
#include "berry_blender.h"
|
#include "berry_blender.h"
|
||||||
#include "task.h"
|
|
||||||
#include "random.h"
|
|
||||||
#include "decompress.h"
|
#include "decompress.h"
|
||||||
#include "text.h"
|
|
||||||
#include "string_util.h"
|
|
||||||
#include "event_data.h"
|
#include "event_data.h"
|
||||||
#include "overworld.h"
|
|
||||||
#include "link.h"
|
|
||||||
#include "librfu.h"
|
|
||||||
#include "rom_8011DC0.h"
|
|
||||||
#include "link_rfu.h"
|
|
||||||
#include "palette.h"
|
|
||||||
#include "gpu_regs.h"
|
#include "gpu_regs.h"
|
||||||
|
#include "librfu.h"
|
||||||
|
#include "link.h"
|
||||||
|
#include "link_rfu.h"
|
||||||
|
#include "malloc.h"
|
||||||
|
#include "overworld.h"
|
||||||
|
#include "random.h"
|
||||||
|
#include "palette.h"
|
||||||
|
#include "rom_8011DC0.h"
|
||||||
|
#include "string_util.h"
|
||||||
|
#include "task.h"
|
||||||
|
#include "text.h"
|
||||||
#include "constants/species.h"
|
#include "constants/species.h"
|
||||||
|
|
||||||
extern u16 gUnknown_03005DA8;
|
extern u16 gUnknown_03005DA8;
|
||||||
@ -65,7 +65,7 @@ static void rfufunc_80FA020(void);
|
|||||||
bool32 sub_8010454(u32 a0);
|
bool32 sub_8010454(u32 a0);
|
||||||
static void sub_8010528(void);
|
static void sub_8010528(void);
|
||||||
void sub_8010750(void);
|
void sub_8010750(void);
|
||||||
int sub_80107A0(void);
|
s32 sub_80107A0(void);
|
||||||
void sub_801084C(u8 taskId);
|
void sub_801084C(u8 taskId);
|
||||||
void sub_80109E8(u16 a0);
|
void sub_80109E8(u16 a0);
|
||||||
void sub_8010A70(void *a0);
|
void sub_8010A70(void *a0);
|
||||||
@ -75,7 +75,7 @@ void sub_80115EC(s32 a0);
|
|||||||
u8 sub_8011CE4(const u8 *a0, u16 a1);
|
u8 sub_8011CE4(const u8 *a0, u16 a1);
|
||||||
void sub_8011D6C(u32 a0);
|
void sub_8011D6C(u32 a0);
|
||||||
void sub_8011E94(u32 a0, u32 a1);
|
void sub_8011E94(u32 a0, u32 a1);
|
||||||
u8 sub_8012224(void);
|
bool8 sub_8012224(void);
|
||||||
void sub_801227C(void);
|
void sub_801227C(void);
|
||||||
void sub_801209C(u8 taskId);
|
void sub_801209C(u8 taskId);
|
||||||
void sub_8011BF8(void);
|
void sub_8011BF8(void);
|
||||||
@ -308,6 +308,11 @@ const char gUnknown_082ED7EC[] = "PokemonSioInfo";
|
|||||||
const char gUnknown_082ED7FC[] = "LINK LOSS DISCONNECT!";
|
const char gUnknown_082ED7FC[] = "LINK LOSS DISCONNECT!";
|
||||||
const char gUnknown_082ED814[] = "LINK LOSS RECOVERY NOW";
|
const char gUnknown_082ED814[] = "LINK LOSS RECOVERY NOW";
|
||||||
|
|
||||||
|
extern const char gUnknown_082ED82C[];
|
||||||
|
extern const char gUnknown_082ED84B[];
|
||||||
|
extern const char gUnknown_082ED85B[];
|
||||||
|
extern const char gUnknown_082ED868[];
|
||||||
|
|
||||||
// .text
|
// .text
|
||||||
|
|
||||||
u32 sub_800BEC0(void)
|
u32 sub_800BEC0(void)
|
||||||
@ -352,7 +357,7 @@ void rfu_REQ_sendData_wrapper(u8 r2)
|
|||||||
rfu_REQ_sendData(r2);
|
rfu_REQ_sendData(r2);
|
||||||
}
|
}
|
||||||
|
|
||||||
int sub_800BF4C(void (*func1)(u8, u8), void (*func2)(u16))
|
s32 sub_800BF4C(void (*func1)(u8, u8), void (*func2)(u16))
|
||||||
{
|
{
|
||||||
if (func1 == NULL)
|
if (func1 == NULL)
|
||||||
{
|
{
|
||||||
@ -1684,8 +1689,8 @@ void sub_800D658(void)
|
|||||||
|
|
||||||
void sub_800D6C8(struct UnkRfuStruct_2_Sub_124 *ptr)
|
void sub_800D6C8(struct UnkRfuStruct_2_Sub_124 *ptr)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
int j;
|
s32 j;
|
||||||
|
|
||||||
for (i = 0; i < 32; i++)
|
for (i = 0; i < 32; i++)
|
||||||
{
|
{
|
||||||
@ -1702,8 +1707,8 @@ void sub_800D6C8(struct UnkRfuStruct_2_Sub_124 *ptr)
|
|||||||
|
|
||||||
void sub_800D724(struct UnkRfuStruct_2_Sub_9e8 *ptr)
|
void sub_800D724(struct UnkRfuStruct_2_Sub_9e8 *ptr)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
int j;
|
s32 j;
|
||||||
|
|
||||||
for (i = 0; i < 40; i++)
|
for (i = 0; i < 40; i++)
|
||||||
{
|
{
|
||||||
@ -1720,8 +1725,8 @@ void sub_800D724(struct UnkRfuStruct_2_Sub_9e8 *ptr)
|
|||||||
|
|
||||||
void sub_800D780(struct UnkRfuStruct_Sub_Unused *ptr)
|
void sub_800D780(struct UnkRfuStruct_Sub_Unused *ptr)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
int j;
|
s32 j;
|
||||||
|
|
||||||
for (i = 0; i < 2; i++)
|
for (i = 0; i < 2; i++)
|
||||||
{
|
{
|
||||||
@ -1738,7 +1743,7 @@ void sub_800D780(struct UnkRfuStruct_Sub_Unused *ptr)
|
|||||||
|
|
||||||
void sub_800D7D8(struct UnkRfuStruct_2_Sub_124 *q1, u8 *q2)
|
void sub_800D7D8(struct UnkRfuStruct_2_Sub_124 *q1, u8 *q2)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
u16 imeBak;
|
u16 imeBak;
|
||||||
u8 count;
|
u8 count;
|
||||||
|
|
||||||
@ -1778,7 +1783,7 @@ void sub_800D7D8(struct UnkRfuStruct_2_Sub_124 *q1, u8 *q2)
|
|||||||
|
|
||||||
void sub_800D888(struct UnkRfuStruct_2_Sub_9e8 *q1, u8 *q2)
|
void sub_800D888(struct UnkRfuStruct_2_Sub_9e8 *q1, u8 *q2)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
u16 imeBak;
|
u16 imeBak;
|
||||||
|
|
||||||
if (q1->unk_232 < 40)
|
if (q1->unk_232 < 40)
|
||||||
@ -1817,7 +1822,7 @@ void sub_800D888(struct UnkRfuStruct_2_Sub_9e8 *q1, u8 *q2)
|
|||||||
bool8 sub_800D934(struct UnkRfuStruct_2_Sub_124 *q1, u8 *q2)
|
bool8 sub_800D934(struct UnkRfuStruct_2_Sub_124 *q1, u8 *q2)
|
||||||
{
|
{
|
||||||
u16 imeBak;
|
u16 imeBak;
|
||||||
int i;
|
s32 i;
|
||||||
|
|
||||||
imeBak = REG_IME;
|
imeBak = REG_IME;
|
||||||
REG_IME = 0;
|
REG_IME = 0;
|
||||||
@ -1843,7 +1848,7 @@ bool8 sub_800D934(struct UnkRfuStruct_2_Sub_124 *q1, u8 *q2)
|
|||||||
|
|
||||||
bool8 sub_800D9DC(struct UnkRfuStruct_2_Sub_9e8 *q1, u8 *q2)
|
bool8 sub_800D9DC(struct UnkRfuStruct_2_Sub_9e8 *q1, u8 *q2)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
u16 imeBak;
|
u16 imeBak;
|
||||||
|
|
||||||
if (q1->unk_230 == q1->unk_231 || q1->unk_233 != 0)
|
if (q1->unk_230 == q1->unk_231 || q1->unk_233 != 0)
|
||||||
@ -1865,7 +1870,7 @@ bool8 sub_800D9DC(struct UnkRfuStruct_2_Sub_9e8 *q1, u8 *q2)
|
|||||||
|
|
||||||
void sub_800DA68(struct UnkRfuStruct_2_Sub_c1c *q1, const u8 *q2)
|
void sub_800DA68(struct UnkRfuStruct_2_Sub_c1c *q1, const u8 *q2)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
|
|
||||||
if (q2[1] == 0)
|
if (q2[1] == 0)
|
||||||
{
|
{
|
||||||
@ -1892,7 +1897,7 @@ void sub_800DA68(struct UnkRfuStruct_2_Sub_c1c *q1, const u8 *q2)
|
|||||||
|
|
||||||
static bool8 sub_800DAC8(struct UnkRfuStruct_2_Sub_c1c *q1, u8 *q2)
|
static bool8 sub_800DAC8(struct UnkRfuStruct_2_Sub_c1c *q1, u8 *q2)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
|
|
||||||
if (q1->unk_1e == 0)
|
if (q1->unk_1e == 0)
|
||||||
{
|
{
|
||||||
@ -1913,7 +1918,7 @@ static bool8 sub_800DAC8(struct UnkRfuStruct_2_Sub_c1c *q1, u8 *q2)
|
|||||||
|
|
||||||
void sub_800DB18(struct UnkRfuStruct_Sub_Unused *q1, u8 *q2)
|
void sub_800DB18(struct UnkRfuStruct_Sub_Unused *q1, u8 *q2)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
|
|
||||||
if (q1->unk_202 < 2)
|
if (q1->unk_202 < 2)
|
||||||
{
|
{
|
||||||
@ -1933,7 +1938,7 @@ void sub_800DB18(struct UnkRfuStruct_Sub_Unused *q1, u8 *q2)
|
|||||||
|
|
||||||
bool8 sub_800DB84(struct UnkRfuStruct_Sub_Unused *q1, u8 *q2)
|
bool8 sub_800DB84(struct UnkRfuStruct_Sub_Unused *q1, u8 *q2)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
|
|
||||||
if (q1->unk_200 == q1->unk_201 || q1->unk_203)
|
if (q1->unk_200 == q1->unk_201 || q1->unk_203)
|
||||||
{
|
{
|
||||||
@ -1951,7 +1956,7 @@ bool8 sub_800DB84(struct UnkRfuStruct_Sub_Unused *q1, u8 *q2)
|
|||||||
|
|
||||||
void sub_800DBF8(u8 *q1, u8 mode)
|
void sub_800DBF8(u8 *q1, u8 mode)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
u8 rval;
|
u8 rval;
|
||||||
u16 r5 = 0;
|
u16 r5 = 0;
|
||||||
switch (mode)
|
switch (mode)
|
||||||
@ -1995,7 +2000,7 @@ void sub_800DBF8(u8 *q1, u8 mode)
|
|||||||
|
|
||||||
void PkmnStrToASCII(u8 *q1, const u8 *q2)
|
void PkmnStrToASCII(u8 *q1, const u8 *q2)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
|
|
||||||
for (i = 0; q2[i] != EOS; i++)
|
for (i = 0; q2[i] != EOS; i++)
|
||||||
{
|
{
|
||||||
@ -2006,7 +2011,7 @@ void PkmnStrToASCII(u8 *q1, const u8 *q2)
|
|||||||
|
|
||||||
void ASCIIToPkmnStr(u8 *q1, const u8 *q2)
|
void ASCIIToPkmnStr(u8 *q1, const u8 *q2)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
|
|
||||||
for (i = 0; q2[i] != 0; i++)
|
for (i = 0; q2[i] != 0; i++)
|
||||||
{
|
{
|
||||||
@ -2114,9 +2119,9 @@ NAKED u8 sub_800DD1C(u8 maxFlags)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
void sub_800DD94(struct UnkLinkRfuStruct_02022B14 *data, u8 r9, bool32 r2, int r3)
|
void sub_800DD94(struct UnkLinkRfuStruct_02022B14 *data, u8 r9, bool32 r2, s32 r3)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
|
|
||||||
for (i = 0; i < 2; i++)
|
for (i = 0; i < 2; i++)
|
||||||
{
|
{
|
||||||
@ -2260,7 +2265,7 @@ u8 sub_800E124(void)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void sub_800E15C(struct Sprite *sprite, int signalStrengthAnimNum)
|
void sub_800E15C(struct Sprite *sprite, s32 signalStrengthAnimNum)
|
||||||
{
|
{
|
||||||
if (sprite->data[2] != signalStrengthAnimNum)
|
if (sprite->data[2] != signalStrengthAnimNum)
|
||||||
{
|
{
|
||||||
@ -2350,7 +2355,7 @@ void sub_800E378(struct UnkSaveSubstruct_3b98 *dest, u32 trainerId, const u8 *na
|
|||||||
|
|
||||||
bool32 sub_800E388(const u8 *name)
|
bool32 sub_800E388(const u8 *name)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
|
|
||||||
for (i = 0; i < 8; i++)
|
for (i = 0; i < 8; i++)
|
||||||
{
|
{
|
||||||
@ -2366,10 +2371,10 @@ void sub_800E3A8(void)
|
|||||||
{
|
{
|
||||||
if (gWirelessCommType != 0)
|
if (gWirelessCommType != 0)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
int j;
|
s32 j;
|
||||||
int cnt;
|
s32 cnt;
|
||||||
int sp0[5];
|
s32 sp0[5];
|
||||||
struct UnkSaveSubstruct_3b98 *sp14 = calloc(20, sizeof(struct UnkSaveSubstruct_3b98));
|
struct UnkSaveSubstruct_3b98 *sp14 = calloc(20, sizeof(struct UnkSaveSubstruct_3b98));
|
||||||
for (i = 0; i < GetLinkPlayerCount(); i++)
|
for (i = 0; i < GetLinkPlayerCount(); i++)
|
||||||
{
|
{
|
||||||
@ -2413,7 +2418,7 @@ void sub_800E3A8(void)
|
|||||||
|
|
||||||
bool32 sub_800E540(u16 id, u8 *name)
|
bool32 sub_800E540(u16 id, u8 *name)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
|
|
||||||
for (i = 0; i < 20; i++)
|
for (i = 0; i < 20; i++)
|
||||||
{
|
{
|
||||||
@ -2431,7 +2436,7 @@ bool32 sub_800E540(u16 id, u8 *name)
|
|||||||
|
|
||||||
void sub_800E5AC(void)
|
void sub_800E5AC(void)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
|
|
||||||
for (i = 0; i < 20; i++)
|
for (i = 0; i < 20; i++)
|
||||||
{
|
{
|
||||||
@ -2445,14 +2450,14 @@ void nullsub_5(const char *unused_0, u8 unused_1, u8 unused_2)
|
|||||||
// debug?
|
// debug?
|
||||||
}
|
}
|
||||||
|
|
||||||
void nullsub_13(u8 unused_0, u8 unused_1, u8 unused_2, u8 unused_3)
|
void nullsub_13(u16 unused_0, u8 unused_1, u8 unused_2, u8 unused_3)
|
||||||
{
|
{
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void sub_800E604(void)
|
void sub_800E604(void)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
u8 unk_ee_bak = gUnknown_03005000.unk_ee;
|
u8 unk_ee_bak = gUnknown_03005000.unk_ee;
|
||||||
CpuFill16(0, &gUnknown_03005000, sizeof gUnknown_03005000);
|
CpuFill16(0, &gUnknown_03005000, sizeof gUnknown_03005000);
|
||||||
gUnknown_03005000.unk_ee = unk_ee_bak;
|
gUnknown_03005000.unk_ee = unk_ee_bak;
|
||||||
@ -2541,12 +2546,12 @@ s32 sub_800E87C(u8 idx)
|
|||||||
return gUnknown_082ED6A5[idx];
|
return gUnknown_082ED6A5[idx];
|
||||||
}
|
}
|
||||||
|
|
||||||
void sub_800E88C(int r2, int r5)
|
void sub_800E88C(s32 r2, s32 r5)
|
||||||
{
|
{
|
||||||
u8 i;
|
u8 i;
|
||||||
u8 r4 = 1;
|
u8 r4 = 1;
|
||||||
int r1 = r2;
|
s32 r1 = r2;
|
||||||
int r6 = 0;
|
s32 r6 = 0;
|
||||||
if (r5 == -1)
|
if (r5 == -1)
|
||||||
{
|
{
|
||||||
for (i = 0; i < 4; r2 >>= 1, i++)
|
for (i = 0; i < 4; r2 >>= 1, i++)
|
||||||
@ -2737,7 +2742,7 @@ void sub_800ED28(void)
|
|||||||
|
|
||||||
void sub_800ED34(u16 unused)
|
void sub_800ED34(u16 unused)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
|
|
||||||
for (i = 0; i < 14; i++)
|
for (i = 0; i < 14; i++)
|
||||||
{
|
{
|
||||||
@ -2879,7 +2884,7 @@ void sub_800EF88(u8 a0)
|
|||||||
// FIXME: gRecvCmds should be in r6 and r7
|
// FIXME: gRecvCmds should be in r6 and r7
|
||||||
void sub_800EFB0(void)
|
void sub_800EFB0(void)
|
||||||
{
|
{
|
||||||
int i, j;
|
s32 i, j;
|
||||||
for (i = 0; i < 5; i++)
|
for (i = 0; i < 5; i++)
|
||||||
{
|
{
|
||||||
for (j = 0; j < 7; j++)
|
for (j = 0; j < 7; j++)
|
||||||
@ -2941,7 +2946,7 @@ NAKED void sub_800EFB0(void)
|
|||||||
|
|
||||||
void sub_800F014(void)
|
void sub_800F014(void)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
for (i = 0; i < 7; i++)
|
for (i = 0; i < 7; i++)
|
||||||
{
|
{
|
||||||
gRecvCmds[0][i] = gSendCmd[i];
|
gRecvCmds[0][i] = gSendCmd[i];
|
||||||
@ -2975,8 +2980,8 @@ static void sub_800F048(void)
|
|||||||
|
|
||||||
bool32 sub_800F0B8(void)
|
bool32 sub_800F0B8(void)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
int j;
|
s32 j;
|
||||||
|
|
||||||
if (gUnknown_03007890->unk_06 == 0)
|
if (gUnknown_03007890->unk_06 == 0)
|
||||||
{
|
{
|
||||||
@ -3131,7 +3136,7 @@ bool32 sub_800F1E0(void)
|
|||||||
|
|
||||||
void sub_800F498(u16 *a0, u8 *a1)
|
void sub_800F498(u16 *a0, u8 *a1)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
|
|
||||||
if (a0[0])
|
if (a0[0])
|
||||||
{
|
{
|
||||||
@ -3199,7 +3204,7 @@ bool32 sub_800F4F0(void)
|
|||||||
|
|
||||||
void sub_800F638(u8 unused, u32 flags)
|
void sub_800F638(u8 unused, u32 flags)
|
||||||
{
|
{
|
||||||
int i, j;
|
s32 i, j;
|
||||||
|
|
||||||
const u8 *r10 = gUnknown_03005000.unk_6c.unk_04;
|
const u8 *r10 = gUnknown_03005000.unk_6c.unk_04;
|
||||||
for (i = 0; i < gUnknown_03005000.unk_6c.unk_02; i++)
|
for (i = 0; i < gUnknown_03005000.unk_6c.unk_02; i++)
|
||||||
@ -3404,7 +3409,7 @@ static void sub_800F86C(u8 unused)
|
|||||||
|
|
||||||
bool8 sub_800FC60(void)
|
bool8 sub_800FC60(void)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
|
|
||||||
for (i = 0; i < 5; i++)
|
for (i = 0; i < 5; i++)
|
||||||
{
|
{
|
||||||
@ -3416,7 +3421,7 @@ bool8 sub_800FC60(void)
|
|||||||
|
|
||||||
bool8 sub_800FC88(void)
|
bool8 sub_800FC88(void)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
|
|
||||||
for (i = 0; i < gUnknown_03005000.playerCount; i++)
|
for (i = 0; i < gUnknown_03005000.playerCount; i++)
|
||||||
{
|
{
|
||||||
@ -3440,7 +3445,7 @@ static void sub_800FCC4(struct UnkRfuStruct_2_Sub_6c *data)
|
|||||||
u8 sub_800FCD8(void)
|
u8 sub_800FCD8(void)
|
||||||
{
|
{
|
||||||
u8 flags = 0;
|
u8 flags = 0;
|
||||||
int i;
|
s32 i;
|
||||||
|
|
||||||
for (i = 0; i < 5; i++)
|
for (i = 0; i < 5; i++)
|
||||||
{
|
{
|
||||||
@ -3560,7 +3565,7 @@ static void rfufunc_80F9F44(void)
|
|||||||
|
|
||||||
static void sub_800FFB0(void)
|
static void sub_800FFB0(void)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
const u8 *src = gUnknown_03005000.unk_6c.unk_04;
|
const u8 *src = gUnknown_03005000.unk_6c.unk_04;
|
||||||
gSendCmd[0] = 0x8900 | gUnknown_03005000.unk_6c.unk_00;
|
gSendCmd[0] = 0x8900 | gUnknown_03005000.unk_6c.unk_00;
|
||||||
for (i = 0; i < 7; i++)
|
for (i = 0; i < 7; i++)
|
||||||
@ -3577,7 +3582,7 @@ static void rfufunc_80FA020(void)
|
|||||||
{
|
{
|
||||||
const u8 *src = gUnknown_03005000.unk_6c.unk_04;
|
const u8 *src = gUnknown_03005000.unk_6c.unk_04;
|
||||||
u8 mpId = GetMultiplayerId();
|
u8 mpId = GetMultiplayerId();
|
||||||
int i;
|
s32 i;
|
||||||
if (gUnknown_03005000.unk_0c == 0)
|
if (gUnknown_03005000.unk_0c == 0)
|
||||||
{
|
{
|
||||||
gSendCmd[0] = (~0x76ff) | (gUnknown_03005000.unk_6c.unk_02 - 1);
|
gSendCmd[0] = (~0x76ff) | (gUnknown_03005000.unk_6c.unk_02 - 1);
|
||||||
@ -3641,9 +3646,9 @@ void sub_8010198(void)
|
|||||||
|
|
||||||
void sub_80101CC(void)
|
void sub_80101CC(void)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
u8 playerCount = gUnknown_03005000.playerCount;
|
u8 playerCount = gUnknown_03005000.playerCount;
|
||||||
int count = 0;
|
s32 count = 0;
|
||||||
|
|
||||||
for (i = 0; i < MAX_RFU_PLAYERS; i++)
|
for (i = 0; i < MAX_RFU_PLAYERS; i++)
|
||||||
{
|
{
|
||||||
@ -3770,7 +3775,7 @@ void sub_8010434(void)
|
|||||||
|
|
||||||
bool32 sub_8010454(u32 a0)
|
bool32 sub_8010454(u32 a0)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
for (i = 0; gUnknown_082ED6E0[i] != a0; i++)
|
for (i = 0; gUnknown_082ED6E0[i] != a0; i++)
|
||||||
{
|
{
|
||||||
if (gUnknown_082ED6E0[i] == 0xffff)
|
if (gUnknown_082ED6E0[i] == 0xffff)
|
||||||
@ -3820,7 +3825,7 @@ static void sub_8010528(void)
|
|||||||
|
|
||||||
bool8 sub_8010540(void)
|
bool8 sub_8010540(void)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
bool8 retval = FALSE;
|
bool8 retval = FALSE;
|
||||||
for (i = 0; i < 4; i++)
|
for (i = 0; i < 4; i++)
|
||||||
{
|
{
|
||||||
@ -3851,7 +3856,7 @@ bool8 sub_8010540(void)
|
|||||||
bool32 sub_80105EC(void)
|
bool32 sub_80105EC(void)
|
||||||
{
|
{
|
||||||
u8 flags = 0;
|
u8 flags = 0;
|
||||||
int i;
|
s32 i;
|
||||||
for (i = 0; i < 4; i++)
|
for (i = 0; i < 4; i++)
|
||||||
{
|
{
|
||||||
if (gUnknown_03005000.unk_cd5[i] == 11)
|
if (gUnknown_03005000.unk_cd5[i] == 11)
|
||||||
@ -3910,7 +3915,7 @@ u32 sub_8010714(u16 a0, const u8 *a1)
|
|||||||
|
|
||||||
void sub_8010750(void)
|
void sub_8010750(void)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
|
|
||||||
sub_8010540();
|
sub_8010540();
|
||||||
for (i = 0; i < 4; i++)
|
for (i = 0; i < 4; i++)
|
||||||
@ -3924,9 +3929,9 @@ void sub_8010750(void)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int sub_80107A0(void)
|
s32 sub_80107A0(void)
|
||||||
{
|
{
|
||||||
int retval = 0;
|
s32 retval = 0;
|
||||||
if (gUnknown_03005000.unk_c85 == 8)
|
if (gUnknown_03005000.unk_c85 == 8)
|
||||||
{
|
{
|
||||||
if (gUnknown_03007880[gUnknown_03005000.unk_c3e]->unk_0 == 0x26 || gUnknown_03007880[gUnknown_03005000.unk_c3e]->unk_0 == 0x27)
|
if (gUnknown_03007880[gUnknown_03005000.unk_c3e]->unk_0 == 0x26 || gUnknown_03007880[gUnknown_03005000.unk_c3e]->unk_0 == 0x27)
|
||||||
@ -3948,7 +3953,7 @@ int sub_80107A0(void)
|
|||||||
|
|
||||||
void sub_801084C(u8 taskId)
|
void sub_801084C(u8 taskId)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
|
|
||||||
if (gUnknown_03005000.unk_f1 == 1 || gUnknown_03005000.unk_f1 == 2)
|
if (gUnknown_03005000.unk_f1 == 1 || gUnknown_03005000.unk_f1 == 2)
|
||||||
{
|
{
|
||||||
@ -4032,7 +4037,7 @@ void sub_801084C(u8 taskId)
|
|||||||
|
|
||||||
void sub_80109E8(u16 a0)
|
void sub_80109E8(u16 a0)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
|
|
||||||
for (i = 0; i < 4; i++)
|
for (i = 0; i < 4; i++)
|
||||||
{
|
{
|
||||||
@ -4043,7 +4048,7 @@ void sub_80109E8(u16 a0)
|
|||||||
|
|
||||||
void sub_8010A14(const struct UnkRfuStruct_8010A14 *a0)
|
void sub_8010A14(const struct UnkRfuStruct_8010A14 *a0)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
gUnknown_03005000.playerCount = a0->unk_0f;
|
gUnknown_03005000.playerCount = a0->unk_0f;
|
||||||
for (i = 0; i < 4; i++)
|
for (i = 0; i < 4; i++)
|
||||||
gUnknown_03005000.unk_cde[i] = a0->unk_10[i];
|
gUnknown_03005000.unk_cde[i] = a0->unk_10[i];
|
||||||
@ -4066,7 +4071,7 @@ void sub_8010A70(void *a0)
|
|||||||
|
|
||||||
void sub_8010AAC(u8 taskId)
|
void sub_8010AAC(u8 taskId)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
struct LinkPlayerBlock *r2;
|
struct LinkPlayerBlock *r2;
|
||||||
struct UnkRfuStruct_8010A14 *r5;
|
struct UnkRfuStruct_8010A14 *r5;
|
||||||
u8 r4 = gUnknown_03005000.unk_cde[gUnknown_082ED68C[gUnknown_03005000.unk_ce9]];
|
u8 r4 = gUnknown_03005000.unk_cde[gUnknown_082ED68C[gUnknown_03005000.unk_ce9]];
|
||||||
@ -4267,7 +4272,7 @@ void sub_8010FCC(u32 a0, u32 a1, u32 a2)
|
|||||||
gUnknown_02022B14.unk_0b_1 = a2;
|
gUnknown_02022B14.unk_0b_1 = a2;
|
||||||
}
|
}
|
||||||
|
|
||||||
u8 sub_801100C(int a0)
|
u8 sub_801100C(s32 a0)
|
||||||
{
|
{
|
||||||
u8 retval = 0x80;
|
u8 retval = 0x80;
|
||||||
retval |= (gLinkPlayers[a0].gender << 3);
|
retval |= (gLinkPlayers[a0].gender << 3);
|
||||||
@ -4278,7 +4283,7 @@ u8 sub_801100C(int a0)
|
|||||||
void sub_801103C(void)
|
void sub_801103C(void)
|
||||||
{
|
{
|
||||||
struct UnkLinkRfuStruct_02022B14 *r5 = &gUnknown_02022B14;
|
struct UnkLinkRfuStruct_02022B14 *r5 = &gUnknown_02022B14;
|
||||||
int i;
|
s32 i;
|
||||||
|
|
||||||
for (i = 1; i < GetLinkPlayerCount(); i++)
|
for (i = 1; i < GetLinkPlayerCount(); i++)
|
||||||
r5->unk_04[i - 1] = sub_801100C(i);
|
r5->unk_04[i - 1] = sub_801100C(i);
|
||||||
@ -4299,10 +4304,10 @@ void sub_8011090(u8 a0, u32 a1, u32 a2)
|
|||||||
|
|
||||||
void sub_80110B8(u32 a0)
|
void sub_80110B8(u32 a0)
|
||||||
{
|
{
|
||||||
int i;
|
s32 i;
|
||||||
u32 r5;
|
u32 r5;
|
||||||
u32 r7;
|
u32 r7;
|
||||||
int r8;
|
s32 r8;
|
||||||
|
|
||||||
if (sub_800F7DC()->unk_0a_0 == 0x45)
|
if (sub_800F7DC()->unk_0a_0 == 0x45)
|
||||||
{
|
{
|
||||||
@ -4962,7 +4967,7 @@ void sub_8011FC8(const u8 *src, u16 trainerId)
|
|||||||
data[8] = trainerId;
|
data[8] = trainerId;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool32 sub_801200C(u16 a1, struct UnkLinkRfuStruct_02022B14 *structPtr)
|
bool32 sub_801200C(s16 a1, struct UnkLinkRfuStruct_02022B14 *structPtr)
|
||||||
{
|
{
|
||||||
if (sub_800F7DC()->unk_0a_0 == 0x45)
|
if (sub_800F7DC()->unk_0a_0 == 0x45)
|
||||||
{
|
{
|
||||||
@ -4993,3 +4998,159 @@ bool32 sub_801200C(u16 a1, struct UnkLinkRfuStruct_02022B14 *structPtr)
|
|||||||
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void sub_801209C(u8 taskId)
|
||||||
|
{
|
||||||
|
if (gUnknown_03005000.unk_f1 == 4)
|
||||||
|
DestroyTask(taskId);
|
||||||
|
|
||||||
|
if (++gTasks[taskId].data[0] > 300)
|
||||||
|
{
|
||||||
|
sub_8011A64(2, 0x7000);
|
||||||
|
DestroyTask(taskId);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (gUnknown_03005000.unk_ccd != 0 && gUnknown_03004140.unk_06 == 0)
|
||||||
|
{
|
||||||
|
u16 trainerId = ReadU16(gUnknown_03005000.unk_10A.unk_00.playerTrainerId);
|
||||||
|
u8 id = sub_8011CE4(gUnknown_03005000.playerName, trainerId);
|
||||||
|
if (id != 0xFF)
|
||||||
|
{
|
||||||
|
if (!sub_801200C(gTasks[taskId].data[1], &gUnknown_03007890->unk_14[id].unk_06))
|
||||||
|
{
|
||||||
|
if (gUnknown_03007890->unk_14[id].unk_02 != 0xFF && !sub_800C12C(gUnknown_03007890->unk_14[id].unk_00, 0x5A))
|
||||||
|
{
|
||||||
|
gUnknown_03005000.unk_04 = 0xA;
|
||||||
|
DestroyTask(taskId);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
sub_8011A64(2, 0x7000);
|
||||||
|
DestroyTask(taskId);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void sub_8012188(const u8 *name, struct UnkLinkRfuStruct_02022B14 *structPtr, u8 a2)
|
||||||
|
{
|
||||||
|
u8 taskId, taskId2;
|
||||||
|
|
||||||
|
gUnknown_03005000.unk_ccf = 0;
|
||||||
|
gUnknown_03005000.unk_f1 = 0;
|
||||||
|
StringCopy(gUnknown_03005000.playerName, name);
|
||||||
|
memcpy(&gUnknown_03005000.unk_10A, structPtr, 0xD);
|
||||||
|
sub_800D658();
|
||||||
|
taskId = CreateTask(sub_801209C, 2);
|
||||||
|
gTasks[taskId].data[1] = a2;
|
||||||
|
taskId2 = FindTaskIdByFunc(sub_800EB44);
|
||||||
|
if (a2 == 0x45)
|
||||||
|
{
|
||||||
|
if (taskId2 != 0xFF)
|
||||||
|
gTasks[taskId2].data[7] = 1;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (taskId2 != 0xFF)
|
||||||
|
gTasks[taskId2].data[7] = 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
bool8 sub_8012224(void)
|
||||||
|
{
|
||||||
|
if (gUnknown_03005000.unk_f0 == 1)
|
||||||
|
return TRUE;
|
||||||
|
else
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool32 sub_8012240(void)
|
||||||
|
{
|
||||||
|
s32 i;
|
||||||
|
|
||||||
|
for (i = 0; i < 4; i++)
|
||||||
|
{
|
||||||
|
if ((gUnknown_03004140.unk_00 >> i) & 1 && gUnknown_03005000.unk_cd1[i] == 0)
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
void sub_801227C(void)
|
||||||
|
{
|
||||||
|
s32 i;
|
||||||
|
|
||||||
|
for (i = 0; i < 20; i++)
|
||||||
|
nullsub_5(gUnknown_082ED82C, 0, i);
|
||||||
|
}
|
||||||
|
|
||||||
|
void sub_801229C(void)
|
||||||
|
{
|
||||||
|
s32 i, j;
|
||||||
|
|
||||||
|
nullsub_13(GetBlockReceivedStatus(), 0x1C, 0x13, 2);
|
||||||
|
nullsub_13(gUnknown_03007890->unk_02, 0x14, 1, 1);
|
||||||
|
nullsub_13(gUnknown_03007890->unk_03, 0x17, 1, 1);
|
||||||
|
if (gUnknown_03005000.unk_0c == 1)
|
||||||
|
{
|
||||||
|
for (i = 0; i < 4; i++)
|
||||||
|
{
|
||||||
|
if ((gUnknown_03007890->unk_07 >> i) & 1)
|
||||||
|
{
|
||||||
|
nullsub_13(gUnknown_03007890->unk_14[i].unk_04, 1, i + 3, 4);
|
||||||
|
nullsub_5((void*) &gUnknown_03007890->unk_14[i].unk_06, 6, i + 3);
|
||||||
|
nullsub_5(gUnknown_03007890->unk_14[i].playerName, 0x16, i + 3);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (i = 0; i < 4; i++)
|
||||||
|
{
|
||||||
|
for (j = 0; j < 14; j++)
|
||||||
|
{
|
||||||
|
nullsub_13(gUnknown_03005000.unk_14[i][j], j * 2, i + 11, 2);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
nullsub_5(gUnknown_082ED868, 1, 0xF);
|
||||||
|
}
|
||||||
|
else if (gUnknown_03007890->unk_02 != 0 && gUnknown_03007890->unk_07 != 0)
|
||||||
|
{
|
||||||
|
for (i = 0; i < 4; i++)
|
||||||
|
{
|
||||||
|
nullsub_13(0, 1, i + 3, 4);
|
||||||
|
nullsub_5(gUnknown_082ED84B, 6, i + 3);
|
||||||
|
nullsub_5(gUnknown_082ED85B, 0x16, i + 3);
|
||||||
|
}
|
||||||
|
nullsub_13(gUnknown_03007890->unk_14[gUnknown_03005000.unk_c3e].unk_04, 1, 3, 4);
|
||||||
|
nullsub_5((void*) &gUnknown_03007890->unk_14[gUnknown_03005000.unk_c3e].unk_06, 6, 3);
|
||||||
|
nullsub_5(gUnknown_03007890->unk_14[gUnknown_03005000.unk_c3e].playerName, 0x16, 3);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
for (i = 0; i < gUnknown_03007890->unk_08; i++)
|
||||||
|
{
|
||||||
|
if (gUnknown_03007890->unk_14[i].unk_02 != 0xFF)
|
||||||
|
{
|
||||||
|
nullsub_13(gUnknown_03007890->unk_14[i].unk_04, 1, i + 3, 4);
|
||||||
|
nullsub_13(gUnknown_03007890->unk_14[i].unk_00, 6, i + 3, 4);
|
||||||
|
nullsub_5(gUnknown_03007890->unk_14[i].playerName, 0x16, i + 3);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
for (; i < 4; i++)
|
||||||
|
{
|
||||||
|
nullsub_13(0, 1, i + 3, 4);
|
||||||
|
nullsub_5(gUnknown_082ED84B, 6, i + 3);
|
||||||
|
nullsub_5(gUnknown_082ED85B, 0x16, i + 3);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
u32 sub_80124C0(void)
|
||||||
|
{
|
||||||
|
return gUnknown_03005000.unk_9e8.unk_232;
|
||||||
|
}
|
||||||
|
|
||||||
|
u32 sub_80124D4(void)
|
||||||
|
{
|
||||||
|
return gUnknown_03005000.unk_124.unk_8c2;
|
||||||
|
}
|
||||||
|
@ -39,7 +39,7 @@ extern void HealPlayerParty(void);
|
|||||||
struct UnkStruct_Shared
|
struct UnkStruct_Shared
|
||||||
{
|
{
|
||||||
struct UnkLinkRfuStruct_02022B14 field_0;
|
struct UnkLinkRfuStruct_02022B14 field_0;
|
||||||
u8 needingPadding[3];
|
u8 needingPadding[2];
|
||||||
u8 playerName[PLAYER_NAME_LENGTH + 1];
|
u8 playerName[PLAYER_NAME_LENGTH + 1];
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -265,7 +265,7 @@ void sub_801689C(struct UnkStruct_URoom *arg0);
|
|||||||
u8 sub_80181DC(struct UnkStruct_URoom *arg0);
|
u8 sub_80181DC(struct UnkStruct_URoom *arg0);
|
||||||
bool32 sub_80168DC(struct UnkStruct_URoom *arg0);
|
bool32 sub_80168DC(struct UnkStruct_URoom *arg0);
|
||||||
bool32 sub_801704C(void);
|
bool32 sub_801704C(void);
|
||||||
u32 sub_8017CF8(u32 arg1, struct UnkStruct_Main0 *arg0);
|
s32 sub_8017CF8(s32 arg1, struct UnkStruct_Main0 *arg0);
|
||||||
s32 sub_80179D4(struct UnkStruct_Main0 *arg0, u8 arg1, u8 arg2, u32 playerGender);
|
s32 sub_80179D4(struct UnkStruct_Main0 *arg0, u8 arg1, u8 arg2, u32 playerGender);
|
||||||
void sub_801818C(bool32 arg0);
|
void sub_801818C(bool32 arg0);
|
||||||
void sub_801A3D0(u32 arg0, u32 arg1, struct UnkStruct_Main0 *arg2);
|
void sub_801A3D0(u32 arg0, u32 arg1, struct UnkStruct_Main0 *arg2);
|
||||||
@ -2510,13 +2510,11 @@ void sub_80156C8(struct UnkStruct_URoom *data)
|
|||||||
memcpy(data->field_0, &gDecompressionBuffer[0x3F00], 0x100);
|
memcpy(data->field_0, &gDecompressionBuffer[0x3F00], 0x100);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Cannot match, please fix later.
|
|
||||||
/*
|
|
||||||
void sub_80156E0(u8 taskId)
|
void sub_80156E0(u8 taskId)
|
||||||
{
|
{
|
||||||
u32 id = 0;
|
u32 id = 0;
|
||||||
s32 var5 = 0;
|
s32 var5 = 0;
|
||||||
u32 playerGender = 0;
|
s32 playerGender = 0;
|
||||||
struct UnkStruct_URoom *data = gUnknown_02022C30.uRoom;
|
struct UnkStruct_URoom *data = gUnknown_02022C30.uRoom;
|
||||||
s16 *taskData = gTasks[taskId].data;
|
s16 *taskData = gTasks[taskId].data;
|
||||||
|
|
||||||
@ -2679,7 +2677,7 @@ void sub_80156E0(u8 taskId)
|
|||||||
break;
|
break;
|
||||||
case 1:
|
case 1:
|
||||||
sub_8012188(data->field_0->arr[taskData[1]].unk.playerName, &data->field_0->arr[taskData[1]].unk.field_0, gUnknown_02022C2C);
|
sub_8012188(data->field_0->arr[taskData[1]].unk.playerName, &data->field_0->arr[taskData[1]].unk.field_0, gUnknown_02022C2C);
|
||||||
data->field_12 = id;
|
data->field_12 = id; // Should be just 0, but won't match any other way.
|
||||||
data->state = 25;
|
data->state = 25;
|
||||||
break;
|
break;
|
||||||
case 2:
|
case 2:
|
||||||
@ -2730,6 +2728,11 @@ void sub_80156E0(u8 taskId)
|
|||||||
data->state = 2;
|
data->state = 2;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case 5:
|
||||||
|
id = sub_80179AC(&data->field_0->arr[taskData[1]]);
|
||||||
|
playerGender = sub_8017CF8(taskData[1], data->field_0);
|
||||||
|
sub_8015664(6, gUnknown_082EE24C[id][playerGender]);
|
||||||
|
break;
|
||||||
case 6:
|
case 6:
|
||||||
var5 = sub_8017178(&data->textState, &data->field_1B, &data->field_1C, &gUnknown_082F021C, &gUnknown_082F0244);
|
var5 = sub_8017178(&data->textState, &data->field_1B, &data->field_1C, &gUnknown_082F021C, &gUnknown_082F0244);
|
||||||
if (var5 != -1)
|
if (var5 != -1)
|
||||||
@ -2742,16 +2745,15 @@ void sub_80156E0(u8 taskId)
|
|||||||
{
|
{
|
||||||
data->field_98 = 0;
|
data->field_98 = 0;
|
||||||
playerGender = sub_8017CF8(taskData[1], data->field_0);
|
playerGender = sub_8017CF8(taskData[1], data->field_0);
|
||||||
switch (var5)
|
if (var5 == -2 || var5 == 0x40)
|
||||||
{
|
{
|
||||||
case -2:
|
|
||||||
case 0x40:
|
|
||||||
data->field_4C[0] = 0x40;
|
data->field_4C[0] = 0x40;
|
||||||
sub_800FE50(data->field_4C);
|
sub_800FE50(data->field_4C);
|
||||||
StringCopy(gStringVar4, gUnknown_082EEB80[gLinkPlayers[0].gender]);
|
StringCopy(gStringVar4, gUnknown_082EEB80[gLinkPlayers[0].gender]);
|
||||||
data->state = 32;
|
data->state = 32;
|
||||||
break;
|
}
|
||||||
default:
|
else
|
||||||
|
{
|
||||||
gUnknown_02022C2C = var5;
|
gUnknown_02022C2C = var5;
|
||||||
gUnknown_02022C2D = (u32)(var5) >> 8;
|
gUnknown_02022C2D = (u32)(var5) >> 8;
|
||||||
if (gUnknown_02022C2C == 0x41 && !sub_8018024())
|
if (gUnknown_02022C2C == 0x41 && !sub_8018024())
|
||||||
@ -2764,7 +2766,6 @@ void sub_80156E0(u8 taskId)
|
|||||||
sub_800FE50(data->field_4C);
|
sub_800FE50(data->field_4C);
|
||||||
data->state = 27;
|
data->state = 27;
|
||||||
}
|
}
|
||||||
break;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -2823,7 +2824,7 @@ void sub_80156E0(u8 taskId)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 5:
|
|
||||||
case 7:
|
case 7:
|
||||||
id = sub_80179AC(&data->field_0->arr[taskData[1]]);
|
id = sub_80179AC(&data->field_0->arr[taskData[1]]);
|
||||||
playerGender = sub_8017CF8(taskData[1], data->field_0);
|
playerGender = sub_8017CF8(taskData[1], data->field_0);
|
||||||
@ -3261,5 +3262,3 @@ void var_800D_set_xB(void)
|
|||||||
if (InUnionRoom() == TRUE)
|
if (InUnionRoom() == TRUE)
|
||||||
gSpecialVar_Result = 11;
|
gSpecialVar_Result = 11;
|
||||||
}
|
}
|
||||||
|
|
||||||
*/
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user