summaryrefslogtreecommitdiff
path: root/asm/multiboot.s
diff options
context:
space:
mode:
authorsceptillion <33798691+sceptillion@users.noreply.github.com>2017-12-16 23:54:22 -0800
committersceptillion <33798691+sceptillion@users.noreply.github.com>2017-12-16 23:54:22 -0800
commit670fef77ac4d9116d5fdc28c0da40622919a062b (patch)
tree61c0e925f059404473826ac775305ba5e2706ab1 /asm/multiboot.s
first commit
Diffstat (limited to 'asm/multiboot.s')
-rw-r--r--asm/multiboot.s924
1 files changed, 924 insertions, 0 deletions
diff --git a/asm/multiboot.s b/asm/multiboot.s
new file mode 100644
index 000000000..0ba2f50bf
--- /dev/null
+++ b/asm/multiboot.s
@@ -0,0 +1,924 @@
+ .include "asm/macros.inc"
+ .include "constants/constants.inc"
+
+ .syntax unified
+
+ .text
+
+ thumb_func_start sub_800BC20
+sub_800BC20: @ 800BC20
+ adds r2, r0, 0
+ movs r1, 0
+ strb r1, [r2, 0x1E]
+ strb r1, [r2, 0x18]
+ strb r1, [r2, 0x1D]
+ adds r3, r2, 0
+ adds r3, 0x4A
+ movs r0, 0xF
+ strb r0, [r3]
+ adds r0, r2, 0
+ adds r0, 0x48
+ strb r1, [r0]
+ strh r1, [r2, 0x16]
+ ldr r0, _0800BC4C @ =0x04000134
+ strh r1, [r0]
+ ldr r2, _0800BC50 @ =0x04000128
+ ldr r3, _0800BC54 @ =0x00002003
+ adds r0, r3, 0
+ strh r0, [r2]
+ ldr r0, _0800BC58 @ =0x0400012a
+ strh r1, [r0]
+ bx lr
+ .align 2, 0
+_0800BC4C: .4byte 0x04000134
+_0800BC50: .4byte 0x04000128
+_0800BC54: .4byte 0x00002003
+_0800BC58: .4byte 0x0400012a
+ thumb_func_end sub_800BC20
+
+ thumb_func_start sub_800BC5C
+sub_800BC5C: @ 800BC5C
+ push {r4-r7,lr}
+ mov r7, r10
+ mov r6, r9
+ mov r5, r8
+ push {r5-r7}
+ adds r7, r0, 0
+ bl sub_800C180
+ cmp r0, 0
+ beq _0800BC72
+ b _0800C03A
+_0800BC72:
+ adds r0, r7, 0
+ adds r0, 0x4A
+ ldrb r1, [r0]
+ mov r10, r0
+ cmp r1, 0xF
+ bls _0800BC86
+ subs r0, r1, 0x1
+ mov r1, r10
+ strb r0, [r1]
+ b _0800C03A
+_0800BC86:
+ adds r1, r7, 0
+ adds r1, 0x48
+ ldrb r0, [r1]
+ cmp r0, 0
+ beq _0800BCB0
+ movs r0, 0
+ strb r0, [r1]
+ ldr r0, _0800BCAC @ =0x04000128
+ ldrh r0, [r0]
+ movs r5, 0xFC
+ ands r5, r0
+ cmp r5, 0x8
+ beq _0800BCB0
+ adds r0, r7, 0
+ bl sub_800BC20
+ movs r0, 0x8
+ eors r0, r5
+ b _0800C03C
+ .align 2, 0
+_0800BCAC: .4byte 0x04000128
+_0800BCB0:
+ ldrb r0, [r7, 0x18]
+ cmp r0, 0xDF
+ bls _0800BD02
+ adds r0, r7, 0
+ bl sub_800C194
+ adds r5, r0, 0
+ cmp r5, 0
+ beq _0800BCC4
+ b _0800C03C
+_0800BCC4:
+ adds r0, r7, 0
+ adds r0, 0x4B
+ ldrb r0, [r0]
+ cmp r0, 0x1
+ bne _0800BCE0
+ ldrb r0, [r7, 0x18]
+ cmp r0, 0xE1
+ bls _0800BCE0
+ adds r0, r7, 0
+ bl sub_800C180
+ cmp r0, 0
+ bne _0800BCE0
+ b _0800C02A
+_0800BCE0:
+ adds r0, r7, 0
+ bl sub_800C180
+ cmp r0, 0
+ beq _0800BCEC
+ b _0800C03A
+_0800BCEC:
+ ldrh r0, [r7, 0x16]
+ cmp r0, 0
+ bne _0800BCFC
+ adds r0, r7, 0
+ bl sub_800BC20
+ movs r0, 0x71
+ b _0800C03C
+_0800BCFC:
+ subs r0, 0x1
+ strh r0, [r7, 0x16]
+ b _0800C03A
+_0800BD02:
+ ldrb r0, [r7, 0x18]
+ cmp r0, 0x2
+ bne _0800BD0A
+ b _0800BE40
+_0800BD0A:
+ cmp r0, 0x2
+ bgt _0800BD18
+ cmp r0, 0
+ beq _0800BD26
+ cmp r0, 0x1
+ beq _0800BDE2
+ b _0800BF78
+_0800BD18:
+ cmp r0, 0xD0
+ bne _0800BD1E
+ b _0800BE8C
+_0800BD1E:
+ cmp r0, 0xD1
+ bne _0800BD24
+ b _0800BF26
+_0800BD24:
+ b _0800BF78
+_0800BD26:
+ movs r3, 0xE
+ movs r5, 0x3
+ ldr r0, _0800BD6C @ =0x04000120
+ ldrh r0, [r0, 0x6]
+ adds r1, r0, 0
+ ldr r0, _0800BD70 @ =0x0000ffff
+ ldrb r2, [r7, 0x1E]
+ adds r6, r2, 0
+ cmp r1, r0
+ bne _0800BD4E
+ adds r4, r1, 0
+ ldr r1, _0800BD74 @ =0x04000126
+_0800BD3E:
+ asrs r3, 1
+ subs r1, 0x2
+ subs r5, 0x1
+ cmp r5, 0
+ beq _0800BD4E
+ ldrh r0, [r1]
+ cmp r0, r4
+ beq _0800BD3E
+_0800BD4E:
+ movs r0, 0xE
+ ands r3, r0
+ strb r3, [r7, 0x1D]
+ movs r5, 0x3
+ ldr r0, _0800BD6C @ =0x04000120
+ ldrh r0, [r0, 0x6]
+ adds r4, r0, 0
+ asrs r0, r2, 3
+ movs r1, 0x1
+ ands r0, r1
+ cmp r0, 0
+ beq _0800BD7C
+ ldr r0, _0800BD78 @ =0x00007208
+ b _0800BDA2
+ .align 2, 0
+_0800BD6C: .4byte 0x04000120
+_0800BD70: .4byte 0x0000ffff
+_0800BD74: .4byte 0x04000126
+_0800BD78: .4byte 0x00007208
+_0800BD7C:
+ subs r5, 0x1
+ cmp r5, 0
+ beq _0800BDA8
+ lsls r0, r5, 1
+ ldr r1, _0800BDD0 @ =0x04000120
+ adds r0, r1
+ ldrh r0, [r0]
+ adds r4, r0, 0
+ adds r0, r2, 0
+ asrs r0, r5
+ movs r1, 0x1
+ ands r0, r1
+ cmp r0, 0
+ beq _0800BD7C
+ adds r0, r1, 0
+ lsls r0, r5
+ movs r1, 0xE4
+ lsls r1, 7
+ orrs r0, r1
+_0800BDA2:
+ cmp r4, r0
+ beq _0800BD7C
+ movs r3, 0
+_0800BDA8:
+ adds r0, r3, 0
+ ands r0, r6
+ strb r0, [r7, 0x1E]
+ cmp r3, 0
+ bne _0800BDB8
+ movs r0, 0xF
+ mov r2, r10
+ strb r0, [r2]
+_0800BDB8:
+ mov r1, r10
+ ldrb r0, [r1]
+ cmp r0, 0
+ bne _0800BDD4
+ ldrb r0, [r7, 0x1D]
+ ldrb r2, [r7, 0x1E]
+ cmp r0, r2
+ beq _0800BDDA
+ adds r0, r7, 0
+ bl sub_800C098
+ b _0800BDE2
+ .align 2, 0
+_0800BDD0: .4byte 0x04000120
+_0800BDD4:
+ subs r0, 0x1
+ mov r1, r10
+ strb r0, [r1]
+_0800BDDA:
+ ldrb r1, [r7, 0x1E]
+ movs r2, 0xC4
+ lsls r2, 7
+ b _0800BEE2
+_0800BDE2:
+ adds r1, r7, 0
+ adds r1, 0x49
+ movs r0, 0
+ strb r0, [r1]
+ movs r5, 0x3
+ mov r12, r1
+ ldr r3, _0800BE38 @ =gUnknown_3000E6C
+_0800BDF0:
+ lsls r0, r5, 1
+ ldr r2, _0800BE3C @ =0x04000120
+ adds r0, r2
+ ldrh r0, [r0]
+ adds r4, r0, 0
+ asrs r0, r4, 8
+ subs r2, r5, 0x1
+ cmp r0, 0x72
+ bne _0800BE1A
+ lsls r0, r2, 1
+ adds r0, r3
+ strh r4, [r0]
+ movs r0, 0xFF
+ ands r4, r0
+ movs r0, 0x1
+ lsls r0, r5
+ cmp r4, r0
+ bne _0800BE1A
+ ldrb r0, [r1]
+ orrs r4, r0
+ strb r4, [r1]
+_0800BE1A:
+ adds r5, r2, 0
+ cmp r5, 0
+ bne _0800BDF0
+ ldrb r0, [r7, 0x1D]
+ mov r1, r12
+ ldrb r1, [r1]
+ cmp r0, r1
+ bne _0800BDDA
+ movs r0, 0x2
+ strb r0, [r7, 0x18]
+ mov r2, r12
+ ldrb r1, [r2]
+ movs r2, 0xC2
+ lsls r2, 7
+ b _0800BEE2
+ .align 2, 0
+_0800BE38: .4byte gUnknown_3000E6C
+_0800BE3C: .4byte 0x04000120
+_0800BE40:
+ movs r5, 0x3
+ movs r0, 0x49
+ adds r0, r7
+ mov r12, r0
+ mov r4, r12
+ movs r6, 0x1
+ ldr r1, _0800BE84 @ =gUnknown_3000E6C
+ mov r9, r1
+ ldr r2, _0800BE88 @ =0x04000120
+ mov r8, r2
+_0800BE54:
+ ldrb r3, [r4]
+ adds r0, r3, 0
+ asrs r0, r5
+ ands r0, r6
+ subs r2, r5, 0x1
+ cmp r0, 0
+ beq _0800BE7A
+ lsls r0, r5, 1
+ add r0, r8
+ ldrh r1, [r0]
+ lsls r0, r2, 1
+ add r0, r9
+ ldrh r0, [r0]
+ cmp r1, r0
+ beq _0800BE7A
+ adds r0, r6, 0
+ lsls r0, r5
+ eors r3, r0
+ strb r3, [r4]
+_0800BE7A:
+ adds r5, r2, 0
+ cmp r5, 0
+ bne _0800BE54
+ b _0800BFE0
+ .align 2, 0
+_0800BE84: .4byte gUnknown_3000E6C
+_0800BE88: .4byte 0x04000120
+_0800BE8C:
+ movs r3, 0x1
+ movs r5, 0x3
+ movs r0, 0x49
+ adds r0, r7
+ mov r12, r0
+ adds r6, r7, 0
+ adds r6, 0x19
+ ldr r1, _0800BEF0 @ =gUnknown_3000E6C
+ mov r8, r1
+_0800BE9E:
+ lsls r0, r5, 1
+ ldr r2, _0800BEF4 @ =0x04000120
+ adds r0, r2
+ ldrh r0, [r0]
+ adds r4, r0, 0
+ subs r2, r5, 0x1
+ adds r0, r6, r2
+ strb r4, [r0]
+ mov r0, r12
+ ldrb r1, [r0]
+ asrs r1, r5
+ movs r0, 0x1
+ ands r1, r0
+ cmp r1, 0
+ beq _0800BED2
+ asrs r0, r4, 8
+ subs r0, 0x72
+ cmp r0, 0x1
+ bls _0800BEC6
+ b _0800C030
+_0800BEC6:
+ lsls r0, r2, 1
+ add r0, r8
+ ldrh r0, [r0]
+ cmp r4, r0
+ bne _0800BED2
+ movs r3, 0
+_0800BED2:
+ adds r5, r2, 0
+ cmp r5, 0
+ bne _0800BE9E
+ cmp r3, 0
+ bne _0800BEF8
+ ldrb r1, [r7, 0x1C]
+ movs r2, 0xC6
+ lsls r2, 7
+_0800BEE2:
+ adds r0, r2, 0
+ orrs r1, r0
+ adds r0, r7, 0
+ bl sub_800C04C
+ b _0800C03C
+ .align 2, 0
+_0800BEF0: .4byte gUnknown_3000E6C
+_0800BEF4: .4byte 0x04000120
+_0800BEF8:
+ movs r0, 0xD1
+ strb r0, [r7, 0x18]
+ movs r3, 0x11
+ movs r5, 0x3
+ adds r1, r6, 0x2
+_0800BF02:
+ ldrb r0, [r1]
+ adds r3, r0
+ subs r1, 0x1
+ subs r5, 0x1
+ cmp r5, 0
+ bne _0800BF02
+ strb r3, [r7, 0x14]
+ movs r0, 0xFF
+ ands r3, r0
+ movs r1, 0xC8
+ lsls r1, 7
+ adds r0, r1, 0
+ orrs r3, r0
+ adds r0, r7, 0
+ adds r1, r3, 0
+ bl sub_800C04C
+ b _0800C03C
+_0800BF26:
+ movs r5, 0x3
+ movs r2, 0x49
+ ldrb r1, [r2, r7]
+ ldr r2, _0800BF64 @ =0x04000126
+ movs r3, 0x1
+_0800BF30:
+ ldrh r0, [r2]
+ adds r4, r0, 0
+ adds r0, r1, 0
+ asrs r0, r5
+ ands r0, r3
+ cmp r0, 0
+ beq _0800BF44
+ asrs r0, r4, 8
+ cmp r0, 0x73
+ bne _0800C030
+_0800BF44:
+ subs r2, 0x2
+ subs r5, 0x1
+ cmp r5, 0
+ bne _0800BF30
+ adds r0, r7, 0
+ bl MultiBoot
+ adds r5, r0, 0
+ cmp r5, 0
+ bne _0800BF68
+ movs r0, 0xE0
+ strb r0, [r7, 0x18]
+ adds r0, 0xB0
+ strh r0, [r7, 0x16]
+ b _0800C03A
+ .align 2, 0
+_0800BF64: .4byte 0x04000126
+_0800BF68:
+ adds r0, r7, 0
+ bl sub_800BC20
+ movs r0, 0x1E
+ mov r1, r10
+ strb r0, [r1]
+ movs r0, 0x70
+ b _0800C03C
+_0800BF78:
+ movs r5, 0x3
+ movs r2, 0x49
+ adds r2, r7
+ mov r12, r2
+ mov r8, r12
+ movs r0, 0x1
+ mov r9, r0
+_0800BF86:
+ mov r1, r8
+ ldrb r6, [r1]
+ adds r0, r6, 0
+ asrs r0, r5
+ mov r2, r9
+ ands r0, r2
+ cmp r0, 0
+ beq _0800BFC0
+ lsls r0, r5, 1
+ ldr r1, _0800BFDC @ =0x04000120
+ adds r0, r1
+ ldrh r0, [r0]
+ adds r4, r0, 0
+ asrs r2, r4, 8
+ ldrb r0, [r7, 0x18]
+ lsrs r0, 1
+ movs r1, 0x62
+ subs r1, r0
+ mov r3, r9
+ lsls r3, r5
+ cmp r2, r1
+ bne _0800BFBA
+ movs r0, 0xFF
+ ands r4, r0
+ cmp r4, r3
+ beq _0800BFC0
+_0800BFBA:
+ eors r6, r3
+ mov r2, r8
+ strb r6, [r2]
+_0800BFC0:
+ subs r5, 0x1
+ cmp r5, 0
+ bne _0800BF86
+ ldrb r0, [r7, 0x18]
+ cmp r0, 0xC4
+ bne _0800BFE0
+ mov r0, r12
+ ldrb r1, [r0]
+ movs r0, 0xE
+ ands r0, r1
+ strb r0, [r7, 0x1E]
+ strb r5, [r7, 0x18]
+ b _0800BDDA
+ .align 2, 0
+_0800BFDC: .4byte 0x04000120
+_0800BFE0:
+ mov r1, r12
+ ldrb r0, [r1]
+ cmp r0, 0
+ bne _0800BFF2
+ adds r0, r7, 0
+ bl sub_800BC20
+ movs r0, 0x50
+ b _0800C03C
+_0800BFF2:
+ ldrb r0, [r7, 0x18]
+ adds r0, 0x2
+ strb r0, [r7, 0x18]
+ lsls r0, 24
+ lsrs r0, 24
+ cmp r0, 0xC4
+ bne _0800C002
+ b _0800BDDA
+_0800C002:
+ ldrb r0, [r7, 0x18]
+ ldr r1, [r7, 0x28]
+ adds r0, r1
+ subs r1, r0, 0x3
+ ldrb r2, [r1]
+ lsls r2, 8
+ subs r0, 0x4
+ ldrb r1, [r0]
+ orrs r1, r2
+ adds r0, r7, 0
+ bl sub_800C04C
+ adds r5, r0, 0
+ cmp r5, 0
+ bne _0800C03C
+ adds r0, r7, 0
+ adds r0, 0x4B
+ ldrb r0, [r0]
+ cmp r0, 0x1
+ bne _0800C03A
+_0800C02A:
+ bl sub_800C298
+ b _0800BC86
+_0800C030:
+ adds r0, r7, 0
+ bl sub_800BC20
+ movs r0, 0x60
+ b _0800C03C
+_0800C03A:
+ movs r0, 0
+_0800C03C:
+ pop {r3-r5}
+ mov r8, r3
+ mov r9, r4
+ mov r10, r5
+ pop {r4-r7}
+ pop {r1}
+ bx r1
+ thumb_func_end sub_800BC5C
+
+ thumb_func_start sub_800C04C
+sub_800C04C: @ 800C04C
+ push {r4,lr}
+ adds r2, r0, 0
+ lsls r1, 16
+ lsrs r1, 16
+ ldr r3, _0800C078 @ =0x04000128
+ ldrh r0, [r3]
+ movs r4, 0x8C
+ ands r4, r0
+ cmp r4, 0x8
+ bne _0800C084
+ ldr r0, _0800C07C @ =0x0400012a
+ strh r1, [r0]
+ ldr r1, _0800C080 @ =0x00002083
+ adds r0, r1, 0
+ strh r0, [r3]
+ adds r1, r2, 0
+ adds r1, 0x48
+ movs r0, 0x1
+ strb r0, [r1]
+ movs r0, 0
+ b _0800C090
+ .align 2, 0
+_0800C078: .4byte 0x04000128
+_0800C07C: .4byte 0x0400012a
+_0800C080: .4byte 0x00002083
+_0800C084:
+ adds r0, r2, 0
+ bl sub_800BC20
+ movs r0, 0x8
+ eors r4, r0
+ adds r0, r4, 0
+_0800C090:
+ pop {r4}
+ pop {r1}
+ bx r1
+ thumb_func_end sub_800C04C
+
+ thumb_func_start sub_800C098
+sub_800C098: @ 800C098
+ push {lr}
+ adds r1, r0, 0
+ ldrb r0, [r1, 0x18]
+ cmp r0, 0
+ beq _0800C0AA
+ adds r0, r1, 0
+ bl sub_800BC20
+ b _0800C0B6
+_0800C0AA:
+ adds r2, r1, 0
+ adds r2, 0x4A
+ strb r0, [r2]
+ strb r0, [r1, 0x1E]
+ movs r0, 0x1
+ strb r0, [r1, 0x18]
+_0800C0B6:
+ pop {r0}
+ bx r0
+ thumb_func_end sub_800C098
+
+ thumb_func_start sub_800C0BC
+sub_800C0BC: @ 800C0BC
+ push {r4-r7,lr}
+ adds r4, r0, 0
+ adds r6, r1, 0
+ ldr r0, [sp, 0x14]
+ lsls r3, 24
+ lsrs r5, r3, 24
+ lsls r0, 24
+ lsrs r7, r0, 24
+ movs r3, 0
+ ldrb r0, [r4, 0x18]
+ cmp r0, 0
+ bne _0800C0F8
+ ldrb r0, [r4, 0x1E]
+ cmp r0, 0
+ beq _0800C0F8
+ adds r0, r4, 0
+ adds r0, 0x4A
+ ldrb r0, [r0]
+ cmp r0, 0
+ bne _0800C0F8
+ str r6, [r4, 0x20]
+ adds r2, 0xF
+ movs r0, 0x10
+ negs r0, r0
+ ands r2, r0
+ subs r0, 0xF0
+ adds r1, r2, r0
+ ldr r0, _0800C100 @ =0x0003ff00
+ cmp r1, r0
+ bls _0800C104
+_0800C0F8:
+ adds r0, r4, 0
+ bl sub_800BC20
+ b _0800C178
+ .align 2, 0
+_0800C100: .4byte 0x0003ff00
+_0800C104:
+ adds r0, r6, r2
+ str r0, [r4, 0x24]
+ lsls r1, r7, 24
+ movs r2, 0x80
+ lsls r2, 19
+ adds r0, r1, r2
+ asrs r0, 24
+ adds r2, r1, 0
+ cmp r0, 0x8
+ bhi _0800C164
+ lsls r0, 2
+ ldr r1, _0800C124 @ =_0800C128
+ adds r0, r1
+ ldr r0, [r0]
+ mov pc, r0
+ .align 2, 0
+_0800C124: .4byte _0800C128
+ .align 2, 0
+_0800C128:
+ .4byte _0800C14C
+ .4byte _0800C14C
+ .4byte _0800C14C
+ .4byte _0800C14C
+ .4byte _0800C156
+ .4byte _0800C15C
+ .4byte _0800C15C
+ .4byte _0800C15C
+ .4byte _0800C15C
+_0800C14C:
+ lsls r3, r5, 3
+ asrs r1, r2, 24
+ movs r0, 0x3
+ subs r0, r1
+ b _0800C162
+_0800C156:
+ movs r0, 0x38
+ adds r3, r5, 0
+ b _0800C162
+_0800C15C:
+ lsls r3, r5, 3
+ asrs r0, r2, 24
+ subs r0, 0x1
+_0800C162:
+ orrs r3, r0
+_0800C164:
+ movs r0, 0x3F
+ ands r3, r0
+ lsls r0, r3, 1
+ movs r2, 0x7F
+ negs r2, r2
+ adds r1, r2, 0
+ orrs r0, r1
+ strb r0, [r4, 0x1C]
+ movs r0, 0xD0
+ strb r0, [r4, 0x18]
+_0800C178:
+ pop {r4-r7}
+ pop {r0}
+ bx r0
+ thumb_func_end sub_800C0BC
+
+ thumb_func_start sub_800C180
+sub_800C180: @ 800C180
+ push {lr}
+ ldrb r0, [r0, 0x18]
+ cmp r0, 0xE9
+ beq _0800C18C
+ movs r0, 0
+ b _0800C18E
+_0800C18C:
+ movs r0, 0x1
+_0800C18E:
+ pop {r1}
+ bx r1
+ thumb_func_end sub_800C180
+
+ thumb_func_start sub_800C194
+sub_800C194: @ 800C194
+ push {r4-r6,lr}
+ adds r3, r0, 0
+ ldrb r0, [r3, 0x18]
+ cmp r0, 0xE0
+ beq _0800C1B0
+ cmp r0, 0xE0
+ blt _0800C1C0
+ cmp r0, 0xE8
+ bgt _0800C1C0
+ cmp r0, 0xE7
+ blt _0800C1C0
+ movs r4, 0x3
+ ldrb r5, [r3, 0x1E]
+ b _0800C220
+_0800C1B0:
+ movs r1, 0
+ movs r0, 0xE1
+ strb r0, [r3, 0x18]
+ str r1, [r3, 0x4]
+ movs r0, 0x80
+ lsls r0, 13
+ str r0, [r3]
+ b _0800C212
+_0800C1C0:
+ movs r4, 0x3
+ ldrb r5, [r3, 0x1E]
+ movs r6, 0x1
+ ldr r1, _0800C21C @ =0x04000126
+_0800C1C8:
+ ldrh r0, [r1]
+ adds r2, r0, 0
+ adds r0, r5, 0
+ asrs r0, r4
+ ands r0, r6
+ cmp r0, 0
+ beq _0800C1DC
+ ldr r0, [r3, 0x4]
+ cmp r2, r0
+ bne _0800C1B0
+_0800C1DC:
+ subs r1, 0x2
+ subs r4, 0x1
+ cmp r4, 0
+ bne _0800C1C8
+ ldrb r0, [r3, 0x18]
+ adds r0, 0x1
+ strb r0, [r3, 0x18]
+ ldr r1, [r3]
+ ldrh r0, [r3]
+ str r0, [r3, 0x4]
+ cmp r1, 0
+ bne _0800C20A
+ ldr r0, [r3, 0x28]
+ adds r1, r0, 0
+ adds r1, 0xAC
+ ldrb r1, [r1]
+ adds r0, 0xAD
+ ldrb r0, [r0]
+ lsls r0, 8
+ orrs r1, r0
+ str r1, [r3, 0x4]
+ lsls r1, 5
+ str r1, [r3]
+_0800C20A:
+ ldr r0, [r3]
+ lsrs r0, 5
+ str r0, [r3]
+_0800C210:
+ ldrh r1, [r3]
+_0800C212:
+ adds r0, r3, 0
+ bl sub_800C04C
+ b _0800C278
+ .align 2, 0
+_0800C21C: .4byte 0x04000126
+_0800C220:
+ lsls r0, r4, 1
+ ldr r1, _0800C268 @ =0x04000120
+ adds r0, r1
+ ldrh r0, [r0]
+ adds r2, r0, 0
+ adds r0, r5, 0
+ asrs r0, r4
+ movs r1, 0x1
+ ands r0, r1
+ cmp r0, 0
+ beq _0800C23C
+ ldr r0, [r3, 0x4]
+ cmp r2, r0
+ bne _0800C26C
+_0800C23C:
+ subs r4, 0x1
+ cmp r4, 0
+ bne _0800C220
+ ldrb r0, [r3, 0x18]
+ adds r0, 0x1
+ strb r0, [r3, 0x18]
+ lsls r0, 24
+ lsrs r0, 24
+ cmp r0, 0xE9
+ beq _0800C276
+ ldr r0, [r3, 0x28]
+ adds r1, r0, 0
+ adds r1, 0xAE
+ ldrb r1, [r1]
+ adds r0, 0xAF
+ ldrb r0, [r0]
+ lsls r0, 8
+ orrs r1, r0
+ str r1, [r3]
+ str r1, [r3, 0x4]
+ b _0800C210
+ .align 2, 0
+_0800C268: .4byte 0x04000120
+_0800C26C:
+ adds r0, r3, 0
+ bl sub_800BC20
+ movs r0, 0x71
+ b _0800C278
+_0800C276:
+ movs r0, 0
+_0800C278:
+ pop {r4-r6}
+ pop {r1}
+ bx r1
+ thumb_func_end sub_800C194
+
+ thumb_func_start sub_800C280
+sub_800C280: @ 800C280
+ mov r2, pc
+ lsrs r2, 24
+ movs r1, 0xC
+ cmp r2, 0x2
+ beq _0800C292
+ movs r1, 0xD
+ cmp r2, 0x8
+ beq _0800C292
+ movs r1, 0x4
+_0800C292:
+ subs r0, r1
+ bgt _0800C292
+ bx lr
+ thumb_func_end sub_800C280
+
+ thumb_func_start sub_800C298
+sub_800C298: @ 800C298
+ push {r4,r5,lr}
+ movs r2, 0
+ ldr r3, _0800C2CC @ =0x04000128
+ ldrh r1, [r3]
+ movs r0, 0x80
+ ands r0, r1
+ cmp r0, 0
+ beq _0800C2BC
+ ldr r5, _0800C2D0 @ =0x0000795c
+ movs r4, 0x80
+_0800C2AC:
+ adds r2, 0x1
+ cmp r2, r5
+ bgt _0800C2BC
+ ldrh r1, [r3]
+ adds r0, r4, 0
+ ands r0, r1
+ cmp r0, 0
+ bne _0800C2AC
+_0800C2BC:
+ movs r0, 0x96
+ lsls r0, 2
+ bl sub_800C280
+ pop {r4,r5}
+ pop {r0}
+ bx r0
+ .align 2, 0
+_0800C2CC: .4byte 0x04000128
+_0800C2D0: .4byte 0x0000795c
+ thumb_func_end sub_800C298
+
+ .align 2, 0 @ Don't pad with nop.