summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDiegoisawesome <Diegoisawesome@users.noreply.github.com>2018-09-16 01:06:33 -0500
committerGitHub <noreply@github.com>2018-09-16 01:06:33 -0500
commit6a8f27c1ac53c8b1d5d1010643781c90eef337c5 (patch)
tree0ccd125eeff7fe2d87b091e97dae4feb46546d28
parent2bba2f91d6abe9adc7732e8fe8118001c0c8b29f (diff)
parentff13cb63520d58951c6d7fcbb026b1f1beb21ae8 (diff)
Merge pull request #326 from DizzyEggg/cablecarutil
Decompile cable_car_util.c
-rw-r--r--asm/cable_car_util.s762
-rw-r--r--include/pokemon.h8
-rw-r--r--include/rom_8034C54.h2
-rw-r--r--include/rom_81520A8.h33
-rw-r--r--ld_script.txt2
-rw-r--r--src/hall_of_fame.c51
-rw-r--r--src/rom_8034C54.c4
-rw-r--r--src/rom_81520A8.c218
-rw-r--r--sym_ewram.txt4
9 files changed, 270 insertions, 814 deletions
diff --git a/asm/cable_car_util.s b/asm/cable_car_util.s
deleted file mode 100644
index db434eaf9..000000000
--- a/asm/cable_car_util.s
+++ /dev/null
@@ -1,762 +0,0 @@
- .include "asm/macros.inc"
- .include "constants/constants.inc"
-
- .syntax unified
-
- .text
-
- thumb_func_start sub_81520A8
-sub_81520A8: @ 81520A8
- push {r4-r7,lr}
- mov r7, r10
- mov r6, r9
- mov r5, r8
- push {r5-r7}
- sub sp, 0x4
- mov r10, r0
- ldr r0, [sp, 0x24]
- ldr r4, [sp, 0x28]
- lsls r1, 16
- lsrs r1, 16
- mov r9, r1
- lsls r2, 24
- lsrs r2, 24
- str r2, [sp]
- lsls r3, 24
- lsls r0, 24
- lsrs r7, r0, 24
- lsls r4, 24
- lsrs r4, 24
- mov r8, r4
- movs r0, 0
- lsrs r4, r3, 24
- cmp r0, r8
- bcs _08152122
-_081520DA:
- ldr r2, [sp]
- movs r3, 0
- adds r6, r4, 0x1
- adds r0, 0x1
- mov r12, r0
- cmp r3, r7
- bcs _0815210C
- lsls r5, r4, 6
-_081520EA:
- lsls r0, r2, 1
- adds r0, r5
- add r0, r10
- mov r1, r9
- strh r1, [r0]
- adds r1, r2, 0x1
- adds r0, r1, 0
- asrs r0, 5
- lsls r0, 5
- subs r0, r1, r0
- lsls r0, 24
- lsrs r2, r0, 24
- adds r0, r3, 0x1
- lsls r0, 24
- lsrs r3, r0, 24
- cmp r3, r7
- bcc _081520EA
-_0815210C:
- adds r0, r6, 0
- asrs r0, 5
- lsls r0, 5
- subs r0, r6, r0
- lsls r0, 24
- lsrs r4, r0, 24
- mov r1, r12
- lsls r0, r1, 24
- lsrs r0, 24
- cmp r0, r8
- bcc _081520DA
-_08152122:
- add sp, 0x4
- pop {r3-r5}
- mov r8, r3
- mov r9, r4
- mov r10, r5
- pop {r4-r7}
- pop {r0}
- bx r0
- thumb_func_end sub_81520A8
-
- thumb_func_start sub_8152134
-sub_8152134: @ 8152134
- push {r4-r7,lr}
- mov r7, r10
- mov r6, r9
- mov r5, r8
- push {r5-r7}
- sub sp, 0x4
- mov r10, r0
- ldr r0, [sp, 0x24]
- ldr r4, [sp, 0x28]
- lsls r2, 24
- lsrs r2, 24
- str r2, [sp]
- lsls r3, 24
- lsls r0, 24
- lsrs r0, 24
- mov r12, r0
- lsls r4, 24
- lsrs r4, 24
- mov r9, r4
- movs r0, 0
- adds r5, r1, 0
- lsrs r4, r3, 24
- cmp r0, r9
- bcs _081521AE
-_08152164:
- ldr r2, [sp]
- movs r3, 0
- adds r7, r4, 0x1
- adds r0, 0x1
- mov r8, r0
- cmp r3, r12
- bcs _08152198
- lsls r6, r4, 6
-_08152174:
- lsls r0, r2, 1
- adds r0, r6
- add r0, r10
- ldrh r1, [r5]
- strh r1, [r0]
- adds r5, 0x2
- adds r1, r2, 0x1
- adds r0, r1, 0
- asrs r0, 5
- lsls r0, 5
- subs r0, r1, r0
- lsls r0, 24
- lsrs r2, r0, 24
- adds r0, r3, 0x1
- lsls r0, 24
- lsrs r3, r0, 24
- cmp r3, r12
- bcc _08152174
-_08152198:
- adds r0, r7, 0
- asrs r0, 5
- lsls r0, 5
- subs r0, r7, r0
- lsls r0, 24
- lsrs r4, r0, 24
- mov r1, r8
- lsls r0, r1, 24
- lsrs r0, 24
- cmp r0, r9
- bcc _08152164
-_081521AE:
- add sp, 0x4
- pop {r3-r5}
- mov r8, r3
- mov r9, r4
- mov r10, r5
- pop {r4-r7}
- pop {r0}
- bx r0
- thumb_func_end sub_8152134
-
- thumb_func_start sub_81521C0
-sub_81521C0: @ 81521C0
- push {r4-r7,lr}
- mov r7, r8
- push {r7}
- lsls r0, 24
- lsrs r4, r0, 24
- movs r5, 0
- cmp r4, 0
- beq _081521FE
- cmp r4, 0x40
- bls _081521D6
- movs r4, 0x40
-_081521D6:
- ldr r6, =gUnknown_0203ABB8
- movs r0, 0x8
- bl AllocZeroed
- str r0, [r6]
- cmp r0, 0
- beq _081521FE
- lsls r0, r4, 1
- adds r0, r4
- lsls r0, 4
- bl AllocZeroed
- ldr r1, [r6]
- str r0, [r1, 0x4]
- cmp r0, 0
- bne _08152208
- adds r0, r1, 0
- bl Free
- str r5, [r6]
-_081521FE:
- movs r0, 0
- b _08152244
- .pool
-_08152208:
- strb r4, [r1]
- cmp r5, r4
- bcs _08152242
- adds r3, r6, 0
- ldr r0, =gDummyOamData
- mov r12, r0
- movs r2, 0x4
- mov r8, r2
-_08152218:
- ldr r0, [r3]
- ldr r2, [r0, 0x4]
- lsls r1, r5, 1
- adds r1, r5
- lsls r1, 4
- adds r2, r1, r2
- mov r0, r12
- ldm r0!, {r6,r7}
- stm r2!, {r6,r7}
- ldr r0, [r3]
- ldr r0, [r0, 0x4]
- adds r1, r0
- ldrb r0, [r1, 0x19]
- mov r2, r8
- orrs r0, r2
- strb r0, [r1, 0x19]
- adds r0, r5, 0x1
- lsls r0, 24
- lsrs r5, r0, 24
- cmp r5, r4
- bcc _08152218
-_08152242:
- movs r0, 0x1
-_08152244:
- pop {r3}
- mov r8, r3
- pop {r4-r7}
- pop {r1}
- bx r1
- .pool
- thumb_func_end sub_81521C0
-
- thumb_func_start sub_8152254
-sub_8152254: @ 8152254
- push {r4-r7,lr}
- movs r3, 0
- ldr r0, =gUnknown_0203ABB8
- ldr r2, [r0]
- adds r5, r0, 0
- cmp r2, 0
- bne _0815226C
- movs r0, 0
- b _081522C4
- .pool
-_0815226C:
- ldrb r2, [r2]
- cmp r3, r2
- bcs _08152292
- ldr r0, =gMain+0x238
- mov r12, r0
- ldr r4, =gDummyOamData
- adds r2, r5, 0
-_0815227A:
- lsls r1, r3, 3
- add r1, r12
- adds r0, r4, 0
- ldm r0!, {r6,r7}
- stm r1!, {r6,r7}
- adds r0, r3, 0x1
- lsls r0, 24
- lsrs r3, r0, 24
- ldr r0, [r2]
- ldrb r0, [r0]
- cmp r3, r0
- bcc _0815227A
-_08152292:
- ldr r1, [r5]
- ldrb r0, [r1]
- lsls r2, r0, 1
- adds r2, r0
- ldr r0, [r1, 0x4]
- lsls r2, 4
- movs r1, 0
- bl memset
- ldr r0, [r5]
- ldr r0, [r0, 0x4]
- bl Free
- ldr r0, [r5]
- movs r4, 0
- str r4, [r0, 0x4]
- movs r1, 0
- movs r2, 0x8
- bl memset
- ldr r0, [r5]
- bl Free
- str r4, [r5]
- movs r0, 0x1
-_081522C4:
- pop {r4-r7}
- pop {r1}
- bx r1
- .pool
- thumb_func_end sub_8152254
-
- thumb_func_start sub_81522D4
-sub_81522D4: @ 81522D4
- push {r4-r7,lr}
- mov r7, r8
- push {r7}
- movs r6, 0
- ldr r0, =gUnknown_0203ABB8
- ldr r1, [r0]
- adds r3, r0, 0
- cmp r1, 0
- beq _081522EC
- ldr r0, [r1, 0x4]
- cmp r0, 0
- bne _081522F4
-_081522EC:
- movs r0, 0
- b _081523D2
- .pool
-_081522F4:
- ldrb r1, [r1]
- cmp r6, r1
- bcs _081523D0
- adds r7, r3, 0
- movs r0, 0x3
- mov r8, r0
-_08152300:
- ldr r0, [r7]
- ldr r1, [r0, 0x4]
- lsls r0, r6, 1
- adds r0, r6
- lsls r5, r0, 4
- adds r2, r5, r1
- ldrb r1, [r2, 0x19]
- movs r0, 0x3
- ands r0, r1
- cmp r0, 0x3
- bne _081523C2
- ldr r1, [r2, 0x2C]
- cmp r1, 0
- beq _08152322
- adds r0, r2, 0
- bl _call_via_r1
-_08152322:
- ldr r0, [r7]
- ldr r0, [r0, 0x4]
- adds r2, r5, r0
- ldrb r1, [r2, 0x19]
- movs r0, 0x4
- ands r0, r1
- cmp r0, 0
- beq _08152348
- lsls r0, r6, 3
- ldr r1, =gMain+0x238
- adds r0, r1
- ldr r1, =gDummyOamData
- ldm r1!, {r2,r3}
- stm r0!, {r2,r3}
- b _081523C0
- .pool
-_08152348:
- ldrb r0, [r2, 0xE]
- ldrb r4, [r2, 0xA]
- adds r0, r4
- strb r0, [r2]
- ldr r4, [r7]
- ldr r3, [r4, 0x4]
- adds r3, r5, r3
- movs r0, 0x8
- ldrsh r2, [r3, r0]
- movs r1, 0xC
- ldrsh r0, [r3, r1]
- adds r2, r0
- ldr r1, =0x000001ff
- adds r0, r1, 0
- ands r2, r0
- ldrh r0, [r3, 0x2]
- ldr r1, =0xfffffe00
- mov r12, r1
- mov r1, r12
- ands r0, r1
- orrs r0, r2
- strh r0, [r3, 0x2]
- ldr r3, [r4, 0x4]
- adds r3, r5, r3
- ldrb r0, [r3, 0x19]
- lsls r0, 27
- lsrs r0, 30
- mov r2, r8
- ands r0, r2
- lsls r0, 2
- ldrb r1, [r3, 0x5]
- movs r4, 0xD
- negs r4, r4
- adds r2, r4, 0
- ands r1, r2
- orrs r1, r0
- strb r1, [r3, 0x5]
- ldr r4, [r7]
- ldr r2, [r4, 0x4]
- adds r2, r5, r2
- ldrh r3, [r2, 0x14]
- ldr r1, =0x000003ff
- adds r0, r1, 0
- adds r1, r3, 0
- ands r1, r0
- mov r12, r1
- ldrh r0, [r2, 0x4]
- ldr r3, =0xfffffc00
- adds r1, r3, 0
- ands r0, r1
- mov r1, r12
- orrs r0, r1
- strh r0, [r2, 0x4]
- lsls r1, r6, 3
- ldr r2, =gMain+0x238
- ldr r0, [r4, 0x4]
- adds r1, r2
- adds r0, r5, r0
- ldm r0!, {r2,r3}
- stm r1!, {r2,r3}
-_081523C0:
- ldr r3, =gUnknown_0203ABB8
-_081523C2:
- adds r0, r6, 0x1
- lsls r0, 24
- lsrs r6, r0, 24
- ldr r0, [r3]
- ldrb r0, [r0]
- cmp r6, r0
- bcc _08152300
-_081523D0:
- movs r0, 0x1
-_081523D2:
- pop {r3}
- mov r8, r3
- pop {r4-r7}
- pop {r1}
- bx r1
- .pool
- thumb_func_end sub_81522D4
-
- thumb_func_start sub_81523F4
-sub_81523F4: @ 81523F4
- push {r4-r6,lr}
- adds r4, r0, 0
- lsls r1, 24
- lsrs r6, r1, 24
- cmp r4, 0
- beq _08152430
- ldrh r0, [r4, 0x10]
- bl GetSpriteTileStartByTag
- lsls r0, 16
- lsrs r5, r0, 16
- ldr r0, =0x0000ffff
- cmp r5, r0
- beq _08152430
- strb r6, [r4, 0x18]
- ldrb r0, [r4, 0x1]
- lsrs r0, 6
- ldrb r1, [r4, 0x3]
- lsrs r1, 6
- bl sub_80355F8
- lsls r0, 24
- lsrs r0, 24
- muls r0, r6
- adds r0, r5, r0
- strh r0, [r4, 0x14]
- movs r0, 0x1
- b _08152432
- .pool
-_08152430:
- movs r0, 0
-_08152432:
- pop {r4-r6}
- pop {r1}
- bx r1
- thumb_func_end sub_81523F4
-
- thumb_func_start sub_8152438
-sub_8152438: @ 8152438
- push {r4,lr}
- adds r4, r1, 0
- lsls r0, 24
- lsrs r2, r0, 24
- ldr r0, =gUnknown_0203ABB8
- ldr r0, [r0]
- cmp r0, 0
- beq _0815246C
- ldrb r1, [r0]
- cmp r2, r1
- bcs _0815246C
- ldr r1, [r0, 0x4]
- lsls r0, r2, 1
- adds r0, r2
- lsls r0, 4
- adds r3, r0, r1
- ldrb r1, [r3, 0x19]
- movs r0, 0x1
- ands r0, r1
- cmp r0, 0
- beq _0815246C
- str r4, [r3, 0x2C]
- adds r0, r2, 0
- b _0815246E
- .pool
-_0815246C:
- movs r0, 0xFF
-_0815246E:
- pop {r4}
- pop {r1}
- bx r1
- thumb_func_end sub_8152438
-
- thumb_func_start sub_8152474
-sub_8152474: @ 8152474
- push {r4,r5,lr}
- lsls r0, 24
- lsrs r3, r0, 24
- lsls r1, 24
- lsrs r4, r1, 24
- lsls r2, 16
- lsrs r5, r2, 16
- ldr r0, =gUnknown_0203ABB8
- ldr r0, [r0]
- cmp r0, 0
- beq _081524A8
- ldrb r1, [r0]
- cmp r3, r1
- bcs _081524A8
- ldr r1, [r0, 0x4]
- lsls r0, r3, 1
- adds r0, r3
- lsls r0, 4
- adds r2, r0, r1
- ldrb r1, [r2, 0x19]
- movs r0, 0x1
- ands r0, r1
- cmp r0, 0
- beq _081524A8
- cmp r4, 0x7
- bls _081524B0
-_081524A8:
- movs r0, 0xFF
- b _081524BC
- .pool
-_081524B0:
- lsls r1, r4, 1
- adds r0, r2, 0
- adds r0, 0x1A
- adds r0, r1
- strh r5, [r0]
- adds r0, r3, 0
-_081524BC:
- pop {r4,r5}
- pop {r1}
- bx r1
- thumb_func_end sub_8152474
-
- thumb_func_start sub_81524C4
-sub_81524C4: @ 81524C4
- push {r4-r7,lr}
- mov r7, r10
- mov r6, r9
- mov r5, r8
- push {r5-r7}
- sub sp, 0x10
- mov r9, r0
- ldr r0, [sp, 0x30]
- ldr r4, [sp, 0x34]
- ldr r5, [sp, 0x38]
- lsls r1, 16
- lsrs r1, 16
- str r1, [sp]
- lsls r2, 16
- lsrs r2, 16
- mov r8, r2
- lsls r3, 16
- lsrs r3, 16
- str r3, [sp, 0x4]
- lsls r0, 16
- lsrs r0, 16
- str r0, [sp, 0x8]
- lsls r4, 24
- lsrs r4, 24
- str r4, [sp, 0xC]
- lsls r5, 24
- lsrs r5, 24
- mov r10, r5
- movs r5, 0
- ldr r0, =gUnknown_0203ABB8
- ldr r0, [r0]
- cmp r0, 0
- beq _0815255E
- mov r1, r9
- cmp r1, 0
- bne _08152530
- b _0815255E
- .pool
-_08152514:
- adds r5, r2, 0
- adds r0, r5, 0
- movs r1, 0
- movs r2, 0x30
- bl memset
- strb r4, [r5, 0x16]
- ldrb r0, [r5, 0x19]
- movs r1, 0x1
- orrs r0, r1
- movs r1, 0x2
- orrs r0, r1
- strb r0, [r5, 0x19]
- b _0815255A
-_08152530:
- movs r4, 0
- ldrb r1, [r0]
- cmp r5, r1
- bcs _0815255A
- ldr r6, [r0, 0x4]
- adds r3, r1, 0
- movs r7, 0x1
-_0815253E:
- lsls r0, r4, 1
- adds r0, r4
- lsls r0, 4
- adds r2, r0, r6
- ldrb r1, [r2, 0x19]
- adds r0, r7, 0
- ands r0, r1
- cmp r0, 0
- beq _08152514
- adds r0, r4, 0x1
- lsls r0, 24
- lsrs r4, r0, 24
- cmp r4, r3
- bcc _0815253E
-_0815255A:
- cmp r5, 0
- bne _08152562
-_0815255E:
- movs r0, 0xFF
- b _081525C0
-_08152562:
- adds r1, r5, 0
- mov r0, r9
- ldm r0!, {r2,r3}
- stm r1!, {r2,r3}
- mov r0, sp
- ldrh r0, [r0]
- strh r0, [r5, 0x10]
- mov r1, r8
- strh r1, [r5, 0x12]
- mov r2, sp
- ldrh r2, [r2, 0x4]
- strh r2, [r5, 0x8]
- mov r3, sp
- ldrh r3, [r3, 0x8]
- strh r3, [r5, 0xA]
- mov r0, r8
- bl IndexOfSpritePaletteTag
- lsls r0, 4
- ldrb r1, [r5, 0x5]
- movs r4, 0xF
- ands r4, r1
- orrs r4, r0
- strb r4, [r5, 0x5]
- mov r0, r10
- cmp r0, 0x3
- bhi _081525B6
- movs r1, 0x3
- ands r1, r0
- lsls r3, r1, 3
- ldrb r2, [r5, 0x19]
- movs r0, 0x19
- negs r0, r0
- ands r0, r2
- orrs r0, r3
- strb r0, [r5, 0x19]
- lsls r1, 2
- movs r0, 0xD
- negs r0, r0
- ands r4, r0
- orrs r4, r1
- strb r4, [r5, 0x5]
-_081525B6:
- adds r0, r5, 0
- ldr r1, [sp, 0xC]
- bl sub_81523F4
- ldrb r0, [r5, 0x16]
-_081525C0:
- add sp, 0x10
- pop {r3-r5}
- mov r8, r3
- mov r9, r4
- mov r10, r5
- pop {r4-r7}
- pop {r1}
- bx r1
- thumb_func_end sub_81524C4
-
- thumb_func_start sub_81525D0
-sub_81525D0: @ 81525D0
- push {r4-r6,lr}
- lsls r0, 24
- lsrs r5, r0, 24
- ldr r6, =gUnknown_0203ABB8
- ldr r0, [r6]
- cmp r0, 0
- beq _081525F2
- ldr r1, [r0, 0x4]
- lsls r0, r5, 1
- adds r0, r5
- lsls r4, r0, 4
- adds r2, r4, r1
- ldrb r1, [r2, 0x19]
- movs r0, 0x1
- ands r0, r1
- cmp r0, 0
- bne _081525FC
-_081525F2:
- movs r0, 0xFF
- b _0815263C
- .pool
-_081525FC:
- adds r0, r2, 0
- movs r1, 0
- movs r2, 0x30
- bl memset
- ldr r0, [r6]
- ldr r0, [r0, 0x4]
- adds r0, r4, r0
- movs r1, 0xA0
- strb r1, [r0]
- ldr r3, [r6]
- ldr r2, [r3, 0x4]
- adds r2, r4, r2
- ldrh r1, [r2, 0x2]
- ldr r0, =0xfffffe00
- ands r0, r1
- movs r1, 0xF0
- orrs r0, r1
- strh r0, [r2, 0x2]
- ldr r1, [r3, 0x4]
- adds r1, r4, r1
- ldrb r0, [r1, 0x19]
- movs r2, 0x4
- orrs r0, r2
- strb r0, [r1, 0x19]
- lsls r1, r5, 3
- ldr r0, =gMain+0x238
- adds r1, r0
- ldr r0, =gDummyOamData
- ldm r0!, {r2,r3}
- stm r1!, {r2,r3}
- adds r0, r5, 0
-_0815263C:
- pop {r4-r6}
- pop {r1}
- bx r1
- .pool
- thumb_func_end sub_81525D0
-
- .align 2, 0 @ Don't pad with nop.
diff --git a/include/pokemon.h b/include/pokemon.h
index abfb360f0..9eddd8155 100644
--- a/include/pokemon.h
+++ b/include/pokemon.h
@@ -268,12 +268,12 @@ struct UnknownPokemonStruct3
struct Unknown_806F160_Struct
{
- u8 field_0_0 : 4;
- u8 field_0_1 : 4;
+ u8 field_0_0:4;
+ u8 field_0_1:4;
u8 field_1;
u8 magic;
- u8 field_3_0 : 4;
- u8 field_3_1 : 4;
+ u8 field_3_0:4;
+ u8 field_3_1:4;
void *bytes;
u8 **byteArrays;
struct SpriteTemplate *templates;
diff --git a/include/rom_8034C54.h b/include/rom_8034C54.h
index 9ad84ca13..4da324dd1 100644
--- a/include/rom_8034C54.h
+++ b/include/rom_8034C54.h
@@ -21,6 +21,6 @@ bool32 sub_8034D14(u32 id, s32 arg1, const struct UnkStruct3 *arg2);
void sub_8035044(u32 id, s32 arg1);
void sub_80353DC(u32 id);
void sub_803547C(u32 id, bool32 arg1);
-u8 sub_80355F8(u32 arg0, u32 arg1);
+u8 sub_80355F8(u32 shape, u32 size);
#endif // GUARD_ROM_8034C54_H
diff --git a/include/rom_81520A8.h b/include/rom_81520A8.h
new file mode 100644
index 000000000..2be12200f
--- /dev/null
+++ b/include/rom_81520A8.h
@@ -0,0 +1,33 @@
+#ifndef GUARD_ROM_81520A8_H
+#define GUARD_ROM_81520A8_H
+
+struct UnkStruct_81520A8
+{
+ struct OamData oam;
+ s16 x;
+ s16 y;
+ s16 xDelta;
+ s16 yDelta;
+ u16 tileTag;
+ u16 palTag;
+ u16 tileNum;
+ u8 id;
+ u8 filler17; // Unused.
+ u8 unk18;
+ u8 unk19_0:1;
+ u8 unk19_1:1;
+ u8 unk19_2:1;
+ u8 priority:2;
+ s16 data[8];
+ void (*callback)(struct UnkStruct_81520A8 *);
+};
+
+bool32 sub_81521C0(u8 count);
+bool32 sub_8152254(void);
+bool32 sub_81522D4(void);
+u8 sub_8152438(u8 id, void (*func)(struct UnkStruct_81520A8 *));
+u8 sub_8152474(u8 id, u8 dataArrayId, s16 dataValue);
+u8 sub_81524C4(const struct OamData *oam, u16 tileTag, u16 palTag, s16 x, s16 y, u8 arg5, u8 priority);
+u8 sub_81525D0(u8 id);
+
+#endif // GUARD_ROM_81520A8_H
diff --git a/ld_script.txt b/ld_script.txt
index e2ea3e542..430bbe981 100644
--- a/ld_script.txt
+++ b/ld_script.txt
@@ -198,7 +198,7 @@ SECTIONS {
asm/cable_car.o(.text);
src/math_util.o(.text);
asm/roulette_util.o(.text);
- asm/cable_car_util.o(.text);
+ src/rom_81520A8.o(.text);
src/save.o(.text);
src/mystery_event_script.o(.text);
asm/field_effect_helpers.o(.text);
diff --git a/src/hall_of_fame.c b/src/hall_of_fame.c
index 522d11d4f..2b0904672 100644
--- a/src/hall_of_fame.c
+++ b/src/hall_of_fame.c
@@ -29,6 +29,7 @@
#include "menu.h"
#include "trainer_pokemon_sprites.h"
#include "data2.h"
+#include "rom_81520A8.h"
struct HallofFameMon
{
@@ -91,13 +92,6 @@ extern void sub_80F9BCC(u16, u16, u8);
extern bool8 sub_80F9C1C(void);
extern void sub_81971D0(void);
extern void sub_8197200(void);
-extern void sub_8152254(void);
-extern void sub_81525D0(u8);
-extern void sub_8152438(u8, void*);
-extern void sub_8152474(u8, u8, u8);
-extern void sub_81522D4(void);
-extern bool32 sub_81521C0(u8);
-extern u8 sub_81524C4(const struct OamData *arg0, s16 arg1, s16 arg2, s16 arg3, s16 arg4, u8 arg5, s16 arg6);
// this file's functions
static void ClearVramOamPltt_LoadHofPal(void);
@@ -1444,53 +1438,28 @@ static void sub_81752C0(void)
FreeSpritePaletteByTag(0x3E9);
}
-struct UnknownStruct912B4
-{
- s16 field_0;
- s16 field_2;
- s16 field_4;
- s16 field_6;
- s16 field_8;
- s16 field_A;
- s16 field_C;
- s16 field_E;
- s16 field_10;
- s16 field_12;
- s16 field_14;
- s16 field_16;
- s16 field_18;
- s16 field_1A;
- s16 field_1C;
- s16 field_1E;
- s16 field_20;
- s16 field_22;
- s16 field_24;
- s16 field_26;
- s16 field_28;
-};
-
-static void sub_81752F4(struct UnknownStruct912B4 *unkStruct)
+static void sub_81752F4(struct UnkStruct_81520A8 *structPtr)
{
- if (unkStruct->field_E > 110)
+ if (structPtr->yDelta > 110)
{
- gTasks[unkStruct->field_28].data[15]--;
- sub_81525D0(unkStruct->field_16);
+ gTasks[structPtr->data[7]].data[15]--;
+ sub_81525D0(structPtr->id);
}
else
{
u8 var;
s32 rand;
- unkStruct->field_E++;
- unkStruct->field_E += unkStruct->field_1C;
+ structPtr->yDelta++;
+ structPtr->yDelta += structPtr->data[1];
- var = unkStruct->field_1A;
+ var = structPtr->data[0];
rand = Random();
rand &= 3;
rand += 8;
- unkStruct->field_C = (rand) * ((gSineTable[var])) / 256;
+ structPtr->xDelta = (rand) * ((gSineTable[var])) / 256;
- unkStruct->field_1A += 4;
+ structPtr->data[0] += 4;
}
}
diff --git a/src/rom_8034C54.c b/src/rom_8034C54.c
index da18c330c..1ef223c69 100644
--- a/src/rom_8034C54.c
+++ b/src/rom_8034C54.c
@@ -431,9 +431,9 @@ static bool32 SharesPalWithAnyActive(u32 id)
return FALSE;
}
-u8 sub_80355F8(u32 arg0, u32 arg1)
+u8 sub_80355F8(u32 shape, u32 size)
{
- return gUnknown_082FF1C8[arg0][arg1];
+ return gUnknown_082FF1C8[shape][size];
}
static void sub_8035608(void)
diff --git a/src/rom_81520A8.c b/src/rom_81520A8.c
new file mode 100644
index 000000000..f6d14d49c
--- /dev/null
+++ b/src/rom_81520A8.c
@@ -0,0 +1,218 @@
+#include "global.h"
+#include "rom_81520A8.h"
+#include "malloc.h"
+#include "main.h"
+#include "rom_8034C54.h"
+
+static EWRAM_DATA struct
+{
+ u8 count;
+ struct UnkStruct_81520A8 *unk4;
+} *sUnknown_0203ABB8 = NULL;
+
+void sub_81520A8(void *dest, u16 value, u8 left, u8 top, u8 width, u8 height) // Unused.
+{
+ u8 i;
+ u8 j;
+ u8 x;
+ u8 y;
+
+ for (i = 0, y = top; i < height; i++)
+ {
+ for (x = left, j = 0; j < width; j++)
+ {
+ *(u16 *)((dest) + (y * 64 + x * 2)) = value;
+ x = (x + 1) % 32;
+ }
+ y = (y + 1) % 32;
+ }
+}
+
+void sub_8152134(void *dest, const u16 *src, u8 left, u8 top, u8 width, u8 height) // Unused.
+{
+ u8 i;
+ u8 j;
+ u8 x;
+ u8 y;
+ const u16 *_src;
+
+ for (i = 0, _src = src, y = top; i < height; i++)
+ {
+ for (x = left, j = 0; j < width; j++)
+ {
+ *(u16 *)((dest) + (y * 64 + x * 2)) = *(_src++);
+ x = (x + 1) % 32;
+ }
+ y = (y + 1) % 32;
+ }
+}
+
+bool32 sub_81521C0(u8 count)
+{
+ u8 i = 0;
+
+ if (count == 0)
+ return FALSE;
+ if (count > 64)
+ count = 64;
+
+ sUnknown_0203ABB8 = AllocZeroed(sizeof(*sUnknown_0203ABB8));
+ if (sUnknown_0203ABB8 == NULL)
+ return FALSE;
+ sUnknown_0203ABB8->unk4 = AllocZeroed(count * sizeof(struct UnkStruct_81520A8));
+ if (sUnknown_0203ABB8->unk4 == NULL)
+ {
+ FREE_AND_SET_NULL(sUnknown_0203ABB8);
+ return FALSE;
+ }
+
+ sUnknown_0203ABB8->count = count;
+ for (i = 0; i < count; i++)
+ {
+ memcpy(&sUnknown_0203ABB8->unk4[i].oam, &gDummyOamData, sizeof(struct OamData));
+ sUnknown_0203ABB8->unk4[i].unk19_2 = TRUE;
+ }
+
+ return TRUE;
+}
+
+bool32 sub_8152254(void)
+{
+ u8 i = 0;
+
+ if (sUnknown_0203ABB8 == NULL)
+ return FALSE;
+
+ for (i = 0; i < sUnknown_0203ABB8->count; i++)
+ memcpy(&gMain.oamBuffer[i + 64], &gDummyOamData, sizeof(struct OamData));
+
+ memset(sUnknown_0203ABB8->unk4, 0, sUnknown_0203ABB8->count * sizeof(struct UnkStruct_81520A8));
+ FREE_AND_SET_NULL(sUnknown_0203ABB8->unk4);
+ memset(sUnknown_0203ABB8, 0, sizeof(*sUnknown_0203ABB8));
+ FREE_AND_SET_NULL(sUnknown_0203ABB8);
+
+ return TRUE;
+}
+
+bool32 sub_81522D4(void)
+{
+ u8 i = 0;
+
+ if (sUnknown_0203ABB8 == NULL || sUnknown_0203ABB8->unk4 == NULL)
+ return FALSE;
+
+ for (i = 0; i < sUnknown_0203ABB8->count; i++)
+ {
+ if (sUnknown_0203ABB8->unk4[i].unk19_0 && sUnknown_0203ABB8->unk4[i].unk19_1)
+ {
+ if (sUnknown_0203ABB8->unk4[i].callback != NULL)
+ sUnknown_0203ABB8->unk4[i].callback(&sUnknown_0203ABB8->unk4[i]);
+
+ if (sUnknown_0203ABB8->unk4[i].unk19_2)
+ {
+ memcpy(&gMain.oamBuffer[i + 64], &gDummyOamData, sizeof(struct OamData));
+ }
+ else
+ {
+ sUnknown_0203ABB8->unk4[i].oam.y = sUnknown_0203ABB8->unk4[i].y + sUnknown_0203ABB8->unk4[i].yDelta;
+ sUnknown_0203ABB8->unk4[i].oam.x = sUnknown_0203ABB8->unk4[i].x + sUnknown_0203ABB8->unk4[i].xDelta;
+ sUnknown_0203ABB8->unk4[i].oam.priority = sUnknown_0203ABB8->unk4[i].priority;
+ sUnknown_0203ABB8->unk4[i].oam.tileNum = sUnknown_0203ABB8->unk4[i].tileNum;
+ memcpy(&gMain.oamBuffer[i + 64], &sUnknown_0203ABB8->unk4[i], sizeof(struct OamData));
+ }
+ }
+ }
+
+ return TRUE;
+}
+
+static bool32 sub_81523F4(struct UnkStruct_81520A8 *structPtr, u8 arg1)
+{
+ u16 tileStart;
+
+ if (structPtr == NULL)
+ return FALSE;
+
+ tileStart = GetSpriteTileStartByTag(structPtr->tileTag);
+ if (tileStart == 0xFFFF)
+ return FALSE;
+
+ structPtr->unk18 = arg1;
+ structPtr->tileNum = (sub_80355F8(structPtr->oam.shape, structPtr->oam.size) * arg1) + tileStart;
+ return TRUE;
+}
+
+u8 sub_8152438(u8 id, void (*func)(struct UnkStruct_81520A8 *))
+{
+ if (sUnknown_0203ABB8 == NULL || id >= sUnknown_0203ABB8->count)
+ return 0xFF;
+ else if (!sUnknown_0203ABB8->unk4[id].unk19_0)
+ return 0xFF;
+
+ sUnknown_0203ABB8->unk4[id].callback = func;
+ return id;
+}
+
+u8 sub_8152474(u8 id, u8 dataArrayId, s16 dataValue)
+{
+ if (sUnknown_0203ABB8 == NULL || id >= sUnknown_0203ABB8->count)
+ return 0xFF;
+ else if (!sUnknown_0203ABB8->unk4[id].unk19_0 || dataArrayId >= ARRAY_COUNT(sUnknown_0203ABB8->unk4[id].data))
+ return 0xFF;
+
+ sUnknown_0203ABB8->unk4[id].data[dataArrayId] = dataValue;
+ return id;
+}
+
+u8 sub_81524C4(const struct OamData *oam, u16 tileTag, u16 palTag, s16 x, s16 y, u8 arg5, u8 priority)
+{
+ struct UnkStruct_81520A8 *structPtr = NULL;
+ u8 i;
+
+ if (sUnknown_0203ABB8 == NULL || oam == NULL)
+ return 0xFF;
+
+ for (i = 0; i < sUnknown_0203ABB8->count; i++)
+ {
+ if (!sUnknown_0203ABB8->unk4[i].unk19_0)
+ {
+ structPtr = &sUnknown_0203ABB8->unk4[i];
+ memset(structPtr, 0, sizeof(*structPtr));
+ structPtr->id = i;
+ structPtr->unk19_0 = TRUE;
+ structPtr->unk19_1 = TRUE;
+ break;
+ }
+ }
+
+ if (structPtr == NULL)
+ return 0xFF;
+
+ memcpy(&structPtr->oam, oam, sizeof(*oam));
+ structPtr->tileTag = tileTag;
+ structPtr->palTag = palTag;
+ structPtr->x = x;
+ structPtr->y = y;
+ structPtr->oam.paletteNum = IndexOfSpritePaletteTag(palTag);
+ if (priority < 4)
+ {
+ structPtr->priority = priority;
+ structPtr->oam.priority = priority;
+ }
+ sub_81523F4(structPtr, arg5);
+
+ return structPtr->id;
+}
+
+u8 sub_81525D0(u8 id)
+{
+ if (sUnknown_0203ABB8 == NULL || !sUnknown_0203ABB8->unk4[id].unk19_0)
+ return 0xFF;
+
+ memset(&sUnknown_0203ABB8->unk4[id], 0, sizeof(struct UnkStruct_81520A8));
+ sUnknown_0203ABB8->unk4[id].oam.y = 160;
+ sUnknown_0203ABB8->unk4[id].oam.x = 240;
+ sUnknown_0203ABB8->unk4[id].unk19_2 = TRUE;
+ memcpy(&gMain.oamBuffer[id + 64], &gDummyOamData, sizeof(struct OamData));
+ return id;
+}
diff --git a/sym_ewram.txt b/sym_ewram.txt
index ddd121bee..4b3f9d10c 100644
--- a/sym_ewram.txt
+++ b/sym_ewram.txt
@@ -504,9 +504,7 @@ gUnknown_0203ABB4: @ 203ABB4
gUnknown_0203ABB5: @ 203ABB5
.space 0x3
-gUnknown_0203ABB8: @ 203ABB8
- .space 0x4
-
+ .include "src/rom_81520A8.o"
.include "src/save.o"
.space 0x4 /*unused var?*/