pokefirered/asm/roulette_util.s
2018-10-12 15:29:43 -04:00

1448 lines
21 KiB
ArmAsm

.include "asm/macros.inc"
.include "constants/constants.inc"
.syntax unified
.text
thumb_func_start sub_80D8BE4
sub_80D8BE4: @ 80D8BE4
push {lr}
movs r1, 0
strb r1, [r0]
strh r1, [r0, 0x2]
adds r0, 0x4
movs r2, 0xC0
bl memset
pop {r0}
bx r0
thumb_func_end sub_80D8BE4
thumb_func_start sub_80D8BF8
sub_80D8BF8: @ 80D8BF8
push {r4-r7,lr}
adds r3, r0, 0
lsls r1, 24
lsrs r6, r1, 24
cmp r6, 0xF
bhi _080D8C14
lsls r0, r6, 1
adds r0, r6
lsls r0, 2
adds r5, r3, r0
ldrb r7, [r5, 0x4]
lsrs r0, r7, 7
cmp r0, 0
beq _080D8C18
_080D8C14:
movs r0, 0xFF
b _080D8C76
_080D8C18:
ldrh r0, [r2]
movs r4, 0
strh r0, [r5, 0x8]
ldrh r0, [r2, 0x2]
strh r0, [r5, 0xA]
ldrb r0, [r2, 0x4]
strb r0, [r5, 0xC]
ldrb r0, [r2, 0x5]
strb r0, [r5, 0xD]
ldrb r0, [r2, 0x6]
strb r0, [r5, 0xE]
ldrb r3, [r2, 0x7]
lsls r0, r3, 27
lsrs r0, 27
ldrb r2, [r5, 0xF]
movs r1, 0x20
negs r1, r1
ands r1, r2
orrs r1, r0
movs r0, 0x60
ands r0, r3
movs r2, 0x61
negs r2, r2
ands r1, r2
orrs r1, r0
lsls r3, 24
asrs r3, 31
lsls r3, 7
movs r0, 0x7F
ands r1, r0
orrs r1, r3
strb r1, [r5, 0xF]
subs r0, 0xFF
ands r0, r7
movs r2, 0x80
orrs r0, r2
strb r0, [r5, 0x4]
strb r4, [r5, 0x6]
strb r4, [r5, 0x5]
lsls r1, 24
cmp r1, 0
bge _080D8C70
movs r0, 0xFF
b _080D8C72
_080D8C70:
movs r0, 0x1
_080D8C72:
strb r0, [r5, 0x7]
adds r0, r6, 0
_080D8C76:
pop {r4-r7}
pop {r1}
bx r1
thumb_func_end sub_80D8BF8
thumb_func_start sub_80D8C7C
sub_80D8C7C: @ 80D8C7C
push {r4,lr}
adds r2, r0, 0
lsls r1, 24
lsrs r1, 24
adds r4, r1, 0
cmp r4, 0xF
bhi _080D8CA8
lsls r0, r4, 1
adds r0, r4
lsls r0, 2
adds r1, r2, r0
ldrb r0, [r1, 0x4]
lsrs r0, 7
cmp r0, 0
beq _080D8CA8
adds r0, r1, 0x4
movs r1, 0
movs r2, 0xC
bl memset
adds r0, r4, 0
b _080D8CAA
_080D8CA8:
movs r0, 0xFF
_080D8CAA:
pop {r4}
pop {r1}
bx r1
thumb_func_end sub_80D8C7C
thumb_func_start sub_80D8CB0
sub_80D8CB0: @ 80D8CB0
push {r4-r7,lr}
mov r7, r10
mov r6, r9
mov r5, r8
push {r5-r7}
adds r5, r0, 0
movs r0, 0
mov r12, r0
ldrb r1, [r5, 0x8]
cmp r12, r1
bcc _080D8CC8
b _080D8E60
_080D8CC8:
movs r7, 0x1F
ldr r0, _080D8CF8 @ =0xfffffc1f
mov r10, r0
movs r1, 0x7D
negs r1, r1
mov r9, r1
movs r0, 0x1F
mov r8, r0
_080D8CD8:
ldrh r0, [r5, 0x6]
add r0, r12
lsls r0, 1
ldr r1, _080D8CFC @ =gPlttBufferFaded
adds r3, r0, r1
ldr r1, _080D8D00 @ =gPlttBufferUnfaded
adds r6, r0, r1
ldrb r0, [r5]
lsls r0, 25
lsrs r0, 25
cmp r0, 0x1
beq _080D8D04
cmp r0, 0x2
beq _080D8D62
b _080D8E4E
.align 2, 0
_080D8CF8: .4byte 0xfffffc1f
_080D8CFC: .4byte gPlttBufferFaded
_080D8D00: .4byte gPlttBufferUnfaded
_080D8D04:
ldr r0, [r3]
lsls r2, r0, 27
lsrs r0, r2, 27
movs r1, 0x3
ldrsb r1, [r5, r1]
adds r0, r1
cmp r0, 0x1F
bhi _080D8D26
lsrs r0, r2, 27
adds r0, r1
ands r0, r7
ldrb r2, [r3]
movs r1, 0x20
negs r1, r1
ands r1, r2
orrs r1, r0
strb r1, [r3]
_080D8D26:
ldr r0, [r3]
lsls r2, r0, 22
lsrs r0, r2, 27
movs r1, 0x3
ldrsb r1, [r5, r1]
adds r0, r1
cmp r0, 0x1F
bhi _080D8D4A
lsrs r0, r2, 27
adds r0, r1
mov r1, r8
ands r0, r1
lsls r0, 5
ldrh r2, [r3]
mov r1, r10
ands r1, r2
orrs r1, r0
strh r1, [r3]
_080D8D4A:
ldr r0, [r3]
lsls r2, r0, 17
lsrs r0, r2, 27
movs r1, 0x3
ldrsb r1, [r5, r1]
adds r0, r1
cmp r0, 0x1F
bls _080D8D5C
b _080D8E4E
_080D8D5C:
lsrs r0, r2, 27
adds r0, r1
b _080D8E40
_080D8D62:
movs r0, 0x3
ldrsb r0, [r5, r0]
cmp r0, 0
bge _080D8DD4
ldr r0, [r3]
lsls r4, r0, 27
lsrs r1, r4, 27
movs r2, 0x3
ldrsb r2, [r5, r2]
adds r1, r2
ldr r0, [r6]
lsls r0, 27
lsrs r0, 27
cmp r1, r0
blt _080D8D92
lsrs r0, r4, 27
adds r0, r2
ands r0, r7
ldrb r2, [r3]
movs r1, 0x20
negs r1, r1
ands r1, r2
orrs r1, r0
strb r1, [r3]
_080D8D92:
ldr r0, [r3]
lsls r4, r0, 22
lsrs r1, r4, 27
movs r2, 0x3
ldrsb r2, [r5, r2]
adds r1, r2
ldr r0, [r6]
lsls r0, 22
lsrs r0, 27
cmp r1, r0
blt _080D8DBC
lsrs r0, r4, 27
adds r0, r2
mov r1, r8
ands r0, r1
lsls r0, 5
ldrh r2, [r3]
mov r1, r10
ands r1, r2
orrs r1, r0
strh r1, [r3]
_080D8DBC:
ldr r0, [r3]
lsls r4, r0, 17
lsrs r1, r4, 27
movs r2, 0x3
ldrsb r2, [r5, r2]
adds r1, r2
ldr r0, [r6]
lsls r0, 17
lsrs r0, 27
cmp r1, r0
blt _080D8E4E
b _080D8E3C
_080D8DD4:
ldr r0, [r3]
lsls r4, r0, 27
lsrs r1, r4, 27
movs r2, 0x3
ldrsb r2, [r5, r2]
adds r1, r2
ldr r0, [r6]
lsls r0, 27
lsrs r0, 27
cmp r1, r0
bgt _080D8DFC
lsrs r0, r4, 27
adds r0, r2
ands r0, r7
ldrb r2, [r3]
movs r1, 0x20
negs r1, r1
ands r1, r2
orrs r1, r0
strb r1, [r3]
_080D8DFC:
ldr r0, [r3]
lsls r4, r0, 22
lsrs r1, r4, 27
movs r2, 0x3
ldrsb r2, [r5, r2]
adds r1, r2
ldr r0, [r6]
lsls r0, 22
lsrs r0, 27
cmp r1, r0
bgt _080D8E26
lsrs r0, r4, 27
adds r0, r2
mov r1, r8
ands r0, r1
lsls r0, 5
ldrh r2, [r3]
mov r1, r10
ands r1, r2
orrs r1, r0
strh r1, [r3]
_080D8E26:
ldr r0, [r3]
lsls r4, r0, 17
lsrs r1, r4, 27
movs r2, 0x3
ldrsb r2, [r5, r2]
adds r1, r2
ldr r0, [r6]
lsls r0, 17
lsrs r0, 27
cmp r1, r0
bgt _080D8E4E
_080D8E3C:
lsrs r0, r4, 27
adds r0, r2
_080D8E40:
ands r0, r7
lsls r0, 2
ldrb r2, [r3, 0x1]
mov r1, r9
ands r1, r2
orrs r1, r0
strb r1, [r3, 0x1]
_080D8E4E:
mov r0, r12
adds r0, 0x1
lsls r0, 24
lsrs r0, 24
mov r12, r0
ldrb r0, [r5, 0x8]
cmp r12, r0
bcs _080D8E60
b _080D8CD8
_080D8E60:
ldrb r1, [r5, 0x2]
adds r0, r1, 0x1
strb r0, [r5, 0x2]
ldrb r0, [r5, 0xB]
lsls r0, 27
lsls r1, 24
asrs r0, 3
cmp r1, r0
beq _080D8E76
movs r0, 0
b _080D8EAA
_080D8E76:
movs r0, 0
strb r0, [r5, 0x2]
movs r0, 0x3
ldrsb r0, [r5, r0]
negs r0, r0
strb r0, [r5, 0x3]
ldrb r2, [r5]
movs r1, 0x7F
movs r0, 0x7F
ands r0, r2
cmp r0, 0x1
bne _080D8E96
lsls r0, r2, 25
lsrs r0, 25
adds r0, 0x1
b _080D8E9C
_080D8E96:
lsls r0, r2, 25
lsrs r0, 25
subs r0, 0x1
_080D8E9C:
ands r0, r1
movs r1, 0x80
negs r1, r1
ands r1, r2
orrs r1, r0
strb r1, [r5]
movs r0, 0x1
_080D8EAA:
pop {r3-r5}
mov r8, r3
mov r9, r4
mov r10, r5
pop {r4-r7}
pop {r1}
bx r1
thumb_func_end sub_80D8CB0
thumb_func_start sub_80D8EB8
sub_80D8EB8: @ 80D8EB8
push {r4,r5,lr}
adds r3, r0, 0
movs r2, 0
ldrb r0, [r3]
lsls r0, 25
lsrs r0, 25
cmp r0, 0x1
beq _080D8ECE
cmp r0, 0x2
beq _080D8EFC
b _080D8F36
_080D8ECE:
ldrb r0, [r3, 0x8]
cmp r2, r0
bcs _080D8EEE
ldr r4, _080D8EF8 @ =gPlttBufferFaded
_080D8ED6:
ldrh r0, [r3, 0x6]
adds r0, r2
lsls r0, 1
adds r0, r4
ldrh r1, [r3, 0x4]
strh r1, [r0]
adds r0, r2, 0x1
lsls r0, 24
lsrs r2, r0, 24
ldrb r0, [r3, 0x8]
cmp r2, r0
bcc _080D8ED6
_080D8EEE:
ldrb r2, [r3]
lsls r1, r2, 25
lsrs r1, 25
adds r1, 0x1
b _080D8F28
.align 2, 0
_080D8EF8: .4byte gPlttBufferFaded
_080D8EFC:
ldrb r0, [r3, 0x8]
cmp r2, r0
bcs _080D8F20
ldr r5, _080D8F40 @ =gPlttBufferFaded
ldr r4, _080D8F44 @ =gPlttBufferUnfaded
_080D8F06:
ldrh r0, [r3, 0x6]
adds r0, r2
lsls r0, 1
adds r1, r0, r5
adds r0, r4
ldrh r0, [r0]
strh r0, [r1]
adds r0, r2, 0x1
lsls r0, 24
lsrs r2, r0, 24
ldrb r0, [r3, 0x8]
cmp r2, r0
bcc _080D8F06
_080D8F20:
ldrb r2, [r3]
lsls r1, r2, 25
lsrs r1, 25
subs r1, 0x1
_080D8F28:
movs r0, 0x7F
ands r1, r0
movs r0, 0x80
negs r0, r0
ands r0, r2
orrs r0, r1
strb r0, [r3]
_080D8F36:
movs r0, 0x1
pop {r4,r5}
pop {r1}
bx r1
.align 2, 0
_080D8F40: .4byte gPlttBufferFaded
_080D8F44: .4byte gPlttBufferUnfaded
thumb_func_end sub_80D8EB8
thumb_func_start task_tutorial_controls_fadein
task_tutorial_controls_fadein: @ 80D8F48
push {r4-r6,lr}
adds r4, r0, 0
movs r5, 0
ldrb r0, [r4]
cmp r0, 0
beq _080D8FAC
_080D8F54:
ldrh r0, [r4, 0x2]
asrs r0, r5
movs r1, 0x1
ands r0, r1
cmp r0, 0
beq _080D8FA2
lsls r1, r5, 1
adds r0, r1, r5
lsls r3, r0, 2
adds r2, r4, r3
ldrb r0, [r2, 0x5]
subs r0, 0x1
strb r0, [r2, 0x5]
lsls r0, 24
lsrs r0, 24
adds r6, r1, 0
cmp r0, 0xFF
bne _080D8FA2
ldrh r0, [r2, 0x8]
movs r2, 0x80
lsls r2, 8
adds r1, r2, 0
ands r0, r1
cmp r0, 0
beq _080D8F90
adds r0, r3, 0x4
adds r0, r4, r0
bl sub_80D8CB0
b _080D8F98
_080D8F90:
adds r0, r3, 0x4
adds r0, r4, r0
bl sub_80D8EB8
_080D8F98:
adds r0, r6, r5
lsls r0, 2
adds r0, r4, r0
ldrb r1, [r0, 0xD]
strb r1, [r0, 0x5]
_080D8FA2:
adds r0, r5, 0x1
lsls r0, 24
lsrs r5, r0, 24
cmp r5, 0xF
bls _080D8F54
_080D8FAC:
pop {r4-r6}
pop {r0}
bx r0
thumb_func_end task_tutorial_controls_fadein
thumb_func_start sub_80D8FB4
sub_80D8FB4: @ 80D8FB4
push {r4-r7,lr}
adds r3, r0, 0
lsls r1, 16
lsrs r6, r1, 16
movs r4, 0
ldrb r0, [r3]
adds r0, 0x1
strb r0, [r3]
movs r5, 0x1
movs r7, 0x80
negs r7, r7
_080D8FCA:
adds r0, r6, 0
asrs r0, r4
ands r0, r5
cmp r0, 0
beq _080D8FF8
lsls r0, r4, 1
adds r0, r4
lsls r0, 2
adds r2, r3, r0
ldrb r0, [r2, 0x4]
lsrs r0, 7
cmp r0, 0
beq _080D8FF8
adds r0, r5, 0
lsls r0, r4
ldrh r1, [r3, 0x2]
orrs r0, r1
strh r0, [r3, 0x2]
ldrb r1, [r2, 0x4]
adds r0, r7, 0
ands r0, r1
orrs r0, r5
strb r0, [r2, 0x4]
_080D8FF8:
adds r0, r4, 0x1
lsls r0, 24
lsrs r4, r0, 24
cmp r4, 0xF
bls _080D8FCA
pop {r4-r7}
pop {r0}
bx r0
thumb_func_end sub_80D8FB4
thumb_func_start sub_80D9008
sub_80D9008: @ 80D9008
push {r4-r7,lr}
sub sp, 0x4
adds r6, r0, 0
lsls r1, 16
lsrs r7, r1, 16
movs r5, 0
movs r3, 0x1
_080D9016:
ldrh r0, [r6, 0x2]
asrs r0, r5
ands r0, r3
cmp r0, 0
beq _080D907E
lsls r0, r5, 1
adds r0, r5
lsls r0, 2
adds r4, r6, r0
ldrb r0, [r4, 0x4]
lsrs r0, 7
cmp r0, 0
beq _080D907E
adds r0, r7, 0
asrs r0, r5
ands r0, r3
cmp r0, 0
beq _080D907E
ldrh r1, [r4, 0xA]
lsls r1, 1
ldr r0, _080D9074 @ =gPlttBufferFaded
adds r0, r1, r0
ldr r2, _080D9078 @ =gPlttBufferUnfaded
adds r1, r2
ldrb r2, [r4, 0xC]
lsls r2, 1
str r3, [sp]
bl memcpy
ldrb r0, [r4, 0x4]
movs r2, 0x80
negs r2, r2
adds r1, r2, 0
ands r0, r1
strb r0, [r4, 0x4]
movs r0, 0
strb r0, [r4, 0x6]
strb r0, [r4, 0x5]
ldrb r0, [r4, 0xF]
lsls r0, 24
ldr r3, [sp]
cmp r0, 0
bge _080D907C
movs r0, 0xFF
strb r0, [r4, 0x7]
b _080D907E
.align 2, 0
_080D9074: .4byte gPlttBufferFaded
_080D9078: .4byte gPlttBufferUnfaded
_080D907C:
strb r3, [r4, 0x7]
_080D907E:
adds r0, r5, 0x1
lsls r0, 24
lsrs r5, r0, 24
cmp r5, 0xF
bls _080D9016
ldr r0, _080D9094 @ =0x0000ffff
cmp r7, r0
bne _080D9098
movs r0, 0
strb r0, [r6]
b _080D909C
.align 2, 0
_080D9094: .4byte 0x0000ffff
_080D9098:
ldrh r0, [r6, 0x2]
bics r0, r7
_080D909C:
strh r0, [r6, 0x2]
add sp, 0x4
pop {r4-r7}
pop {r0}
bx r0
thumb_func_end sub_80D9008
thumb_func_start sub_80D90A8
sub_80D90A8: @ 80D90A8
push {r4,r5,lr}
adds r5, r0, 0
movs r4, 0
strh r4, [r5]
adds r0, r5, 0x4
movs r1, 0
movs r2, 0xC0
bl memset
_080D90BA:
lsls r0, r4, 1
adds r0, r4
lsls r0, 2
adds r0, r5, r0
strb r4, [r0, 0x4]
adds r0, r4, 0x1
lsls r0, 24
lsrs r4, r0, 24
cmp r4, 0xF
bls _080D90BA
pop {r4,r5}
pop {r0}
bx r0
thumb_func_end sub_80D90A8
thumb_func_start sub_80D90D4
sub_80D90D4: @ 80D90D4
push {r4,r5,lr}
adds r2, r0, 0
adds r5, r1, 0
movs r3, 0
movs r4, 0
ldrb r0, [r2, 0x5]
lsrs r0, 7
cmp r0, 0
bne _080D90EA
adds r4, r2, 0x4
b _080D9108
_080D90EA:
adds r0, r3, 0x1
lsls r0, 24
lsrs r3, r0, 24
cmp r3, 0xF
bhi _080D9108
lsls r0, r3, 1
adds r0, r3
lsls r1, r0, 2
adds r0, r2, r1
ldrb r0, [r0, 0x5]
lsrs r0, 7
cmp r0, 0
bne _080D90EA
adds r0, r1, 0x4
adds r4, r2, r0
_080D9108:
cmp r4, 0
beq _080D9136
ldrb r1, [r4, 0x1]
movs r0, 0x10
negs r0, r0
ands r0, r1
movs r1, 0x11
negs r1, r1
ands r0, r1
movs r1, 0x40
orrs r0, r1
movs r1, 0x80
orrs r0, r1
strb r0, [r4, 0x1]
movs r0, 0
strb r0, [r4, 0x2]
strb r0, [r4, 0x3]
adds r1, r4, 0x4
adds r0, r5, 0
ldm r0!, {r2,r4}
stm r1!, {r2,r4}
adds r0, r3, 0
b _080D9138
_080D9136:
movs r0, 0xFF
_080D9138:
pop {r4,r5}
pop {r1}
bx r1
thumb_func_end sub_80D90D4
thumb_func_start sub_80D9140
sub_80D9140: @ 80D9140
push {r4,r5,lr}
adds r4, r0, 0
ldrb r1, [r4, 0x1]
movs r2, 0x40
adds r0, r2, 0
ands r0, r1
cmp r0, 0
bne _080D9182
ldrb r1, [r4, 0xB]
adds r0, r2, 0
ands r0, r1
cmp r0, 0
beq _080D9182
ldrh r2, [r4, 0x6]
ldrb r0, [r4, 0x8]
adds r0, r2, r0
cmp r2, r0
bge _080D9182
ldr r5, _080D91B4 @ =gPlttBufferFaded
ldr r3, _080D91B8 @ =gPlttBufferUnfaded
_080D9168:
lsls r0, r2, 1
adds r1, r0, r5
adds r0, r3
ldrh r0, [r0]
strh r0, [r1]
adds r0, r2, 0x1
lsls r0, 16
lsrs r2, r0, 16
ldrh r0, [r4, 0x6]
ldrb r1, [r4, 0x8]
adds r0, r1
cmp r2, r0
blt _080D9168
_080D9182:
adds r0, r4, 0x4
movs r1, 0
movs r2, 0x8
bl memset
ldrb r1, [r4, 0x1]
movs r0, 0x10
negs r0, r0
ands r0, r1
movs r1, 0x11
negs r1, r1
ands r0, r1
subs r1, 0x10
ands r0, r1
movs r1, 0x40
orrs r0, r1
movs r1, 0x7F
ands r0, r1
strb r0, [r4, 0x1]
movs r0, 0
strb r0, [r4, 0x3]
strb r0, [r4, 0x2]
pop {r4,r5}
pop {r0}
bx r0
.align 2, 0
_080D91B4: .4byte gPlttBufferFaded
_080D91B8: .4byte gPlttBufferUnfaded
thumb_func_end sub_80D9140
thumb_func_start sub_80D91BC
sub_80D91BC: @ 80D91BC
push {r4-r6,lr}
adds r6, r0, 0
lsls r1, 16
lsrs r4, r1, 16
lsls r2, 24
movs r5, 0
cmp r2, 0
bne _080D91E0
movs r1, 0xF
ands r1, r4
lsls r0, r1, 1
adds r0, r1
lsls r0, 2
adds r0, 0x4
adds r0, r6, r0
bl sub_80D9140
b _080D920C
_080D91E0:
movs r0, 0x1
ands r0, r4
cmp r0, 0
beq _080D9200
lsls r0, r5, 1
adds r0, r5
lsls r1, r0, 2
adds r0, r6, r1
ldrb r0, [r0, 0x5]
lsrs r0, 7
cmp r0, 0
beq _080D9200
adds r0, r1, 0x4
adds r0, r6, r0
bl sub_80D9140
_080D9200:
lsrs r4, 1
adds r0, r5, 0x1
lsls r0, 16
lsrs r5, r0, 16
cmp r5, 0xF
bls _080D91E0
_080D920C:
pop {r4-r6}
pop {r0}
bx r0
thumb_func_end sub_80D91BC
thumb_func_start sub_80D9214
sub_80D9214: @ 80D9214
push {r4-r7,lr}
adds r5, r0, 0
lsls r1, 16
lsrs r4, r1, 16
lsls r2, 24
movs r3, 0
cmp r2, 0
bne _080D9248
movs r0, 0xF
adds r3, r0, 0
ands r3, r4
lsls r1, r3, 1
adds r1, r3
lsls r1, 2
adds r1, r5, r1
ldrb r2, [r1, 0x5]
movs r0, 0x41
negs r0, r0
ands r0, r2
strb r0, [r1, 0x5]
movs r0, 0x1
lsls r0, r3
ldrh r1, [r5]
orrs r0, r1
strh r0, [r5]
b _080D928C
_080D9248:
movs r6, 0x1
movs r7, 0x41
negs r7, r7
_080D924E:
adds r0, r4, 0
ands r0, r6
cmp r0, 0
beq _080D926C
lsls r0, r3, 1
adds r0, r3
lsls r0, 2
adds r2, r5, r0
ldrb r1, [r2, 0x5]
lsrs r0, r1, 7
cmp r0, 0
beq _080D926C
lsls r0, r1, 25
cmp r0, 0
blt _080D9272
_080D926C:
lsls r0, r4, 17
lsrs r4, r0, 16
b _080D9282
_080D9272:
adds r0, r7, 0
ands r0, r1
strb r0, [r2, 0x5]
adds r0, r6, 0
lsls r0, r3
ldrh r1, [r5]
orrs r0, r1
strh r0, [r5]
_080D9282:
adds r0, r3, 0x1
lsls r0, 24
lsrs r3, r0, 24
cmp r3, 0xF
bls _080D924E
_080D928C:
pop {r4-r7}
pop {r0}
bx r0
thumb_func_end sub_80D9214
thumb_func_start sub_80D9294
sub_80D9294: @ 80D9294
push {r4-r7,lr}
mov r7, r10
mov r6, r9
mov r5, r8
push {r5-r7}
mov r8, r0
lsls r1, 16
lsrs r7, r1, 16
lsls r2, 24
movs r0, 0
mov r12, r0
cmp r2, 0
bne _080D931C
movs r1, 0xF
ands r1, r7
lsls r0, r1, 1
adds r0, r1
lsls r0, 2
adds r0, 0x4
mov r1, r8
adds r3, r1, r0
ldrb r1, [r3, 0x1]
movs r0, 0xC0
ands r0, r1
cmp r0, 0x80
bne _080D93A6
ldrb r1, [r3, 0xB]
movs r0, 0x40
ands r0, r1
cmp r0, 0
beq _080D92FA
ldrh r2, [r3, 0x6]
ldrb r0, [r3, 0x8]
adds r0, r2, r0
cmp r2, r0
bge _080D92FA
ldr r5, _080D9314 @ =gPlttBufferFaded
ldr r4, _080D9318 @ =gPlttBufferUnfaded
_080D92E0:
lsls r0, r2, 1
adds r1, r0, r5
adds r0, r4
ldrh r0, [r0]
strh r0, [r1]
adds r0, r2, 0x1
lsls r0, 16
lsrs r2, r0, 16
ldrh r0, [r3, 0x6]
ldrb r1, [r3, 0x8]
adds r0, r1
cmp r2, r0
blt _080D92E0
_080D92FA:
ldrb r0, [r3, 0x1]
movs r1, 0x40
orrs r0, r1
strb r0, [r3, 0x1]
movs r1, 0x1
mov r2, r12
lsls r1, r2
mov r2, r8
ldrh r0, [r2]
bics r0, r1
strh r0, [r2]
b _080D93A6
.align 2, 0
_080D9314: .4byte gPlttBufferFaded
_080D9318: .4byte gPlttBufferUnfaded
_080D931C:
movs r0, 0x1
mov r9, r0
movs r1, 0x40
mov r10, r1
_080D9324:
mov r2, r12
lsls r0, r2, 1
add r0, r12
lsls r0, 2
adds r0, 0x4
mov r1, r8
adds r3, r1, r0
adds r0, r7, 0
mov r2, r9
ands r0, r2
cmp r0, 0
beq _080D9346
ldrb r1, [r3, 0x1]
movs r0, 0xC0
ands r0, r1
cmp r0, 0x80
beq _080D9350
_080D9346:
lsls r0, r7, 17
lsrs r7, r0, 16
mov r5, r12
adds r5, 0x1
b _080D939C
_080D9350:
ldrb r1, [r3, 0xB]
mov r0, r10
ands r0, r1
mov r5, r12
adds r5, 0x1
cmp r0, 0
beq _080D9386
ldrh r2, [r3, 0x6]
ldrb r0, [r3, 0x8]
adds r0, r2, r0
cmp r2, r0
bge _080D9386
ldr r6, _080D93B4 @ =gPlttBufferFaded
ldr r4, _080D93B8 @ =gPlttBufferUnfaded
_080D936C:
lsls r0, r2, 1
adds r1, r0, r6
adds r0, r4
ldrh r0, [r0]
strh r0, [r1]
adds r0, r2, 0x1
lsls r0, 16
lsrs r2, r0, 16
ldrh r0, [r3, 0x6]
ldrb r1, [r3, 0x8]
adds r0, r1
cmp r2, r0
blt _080D936C
_080D9386:
ldrb r1, [r3, 0x1]
mov r0, r10
orrs r0, r1
strb r0, [r3, 0x1]
mov r1, r9
mov r0, r12
lsls r1, r0
mov r2, r8
ldrh r0, [r2]
bics r0, r1
strh r0, [r2]
_080D939C:
lsls r0, r5, 24
lsrs r0, 24
mov r12, r0
cmp r0, 0xF
bls _080D9324
_080D93A6:
pop {r3-r5}
mov r8, r3
mov r9, r4
mov r10, r5
pop {r4-r7}
pop {r0}
bx r0
.align 2, 0
_080D93B4: .4byte gPlttBufferFaded
_080D93B8: .4byte gPlttBufferUnfaded
thumb_func_end sub_80D9294
thumb_func_start sub_80D93BC
sub_80D93BC: @ 80D93BC
push {r4-r7,lr}
mov r7, r10
mov r6, r9
mov r5, r8
push {r5-r7}
sub sp, 0x4
str r0, [sp]
movs r0, 0
mov r10, r0
ldr r1, [sp]
ldrh r0, [r1]
cmp r0, 0
bne _080D93D8
b _080D9562
_080D93D8:
movs r2, 0xF
mov r9, r2
movs r3, 0x10
negs r3, r3
mov r8, r3
movs r7, 0x1
_080D93E4:
mov r5, r10
lsls r0, r5, 1
add r0, r10
lsls r0, 2
adds r0, 0x4
ldr r1, [sp]
adds r4, r1, r0
ldrb r2, [r4, 0x1]
movs r3, 0xC0
ands r3, r2
cmp r3, 0x80
beq _080D93FE
b _080D9552
_080D93FE:
ldr r0, _080D944C @ =gPaletteFade
ldrb r1, [r0, 0x7]
adds r0, r3, 0
ands r0, r1
cmp r0, 0
beq _080D9414
ldrb r0, [r4, 0xB]
ands r3, r0
cmp r3, 0
beq _080D9414
b _080D9552
_080D9414:
ldrb r0, [r4, 0x2]
subs r0, 0x1
strb r0, [r4, 0x2]
lsls r0, 24
lsrs r0, 24
cmp r0, 0xFF
beq _080D9424
b _080D9552
_080D9424:
ldrb r0, [r4, 0x9]
strb r0, [r4, 0x2]
ldrh r0, [r4, 0x6]
ldrb r1, [r4, 0x8]
lsls r2, 28
lsrs r2, 28
ldrh r3, [r4, 0x4]
bl BlendPalette
ldrb r5, [r4, 0xB]
lsls r0, r5, 26
asrs r0, 30
cmp r0, 0x1
beq _080D9482
cmp r0, 0x1
bgt _080D9450
cmp r0, 0
beq _080D9456
b _080D953C
.align 2, 0
_080D944C: .4byte gPaletteFade
_080D9450:
cmp r0, 0x2
beq _080D94FE
b _080D953C
_080D9456:
ldrb r2, [r4, 0x1]
lsls r1, r2, 28
lsrs r0, r1, 28
adds r0, 0x1
mov r3, r9
ands r0, r3
mov r6, r8
adds r3, r6, 0
ands r3, r2
orrs r3, r0
strb r3, [r4, 0x1]
lsrs r1, 28
lsls r0, r5, 28
asrs r0, 28
cmp r1, r0
bne _080D953C
ldrb r0, [r4, 0x3]
adds r0, 0x1
strb r0, [r4, 0x3]
ands r3, r6
strb r3, [r4, 0x1]
b _080D953C
_080D9482:
ldrb r3, [r4, 0x1]
movs r0, 0x10
ands r0, r3
cmp r0, 0
beq _080D94C0
lsls r0, r3, 28
lsrs r0, 28
subs r0, 0x1
mov r5, r9
ands r0, r5
mov r2, r8
ands r2, r3
orrs r2, r0
strb r2, [r4, 0x1]
cmp r0, 0
bne _080D953C
ldrb r0, [r4, 0x3]
adds r0, 0x1
strb r0, [r4, 0x3]
lsls r0, r2, 27
lsrs r0, 31
eors r0, r7
ands r0, r7
lsls r0, 4
movs r3, 0x11
negs r3, r3
adds r1, r3, 0
ands r2, r1
orrs r2, r0
strb r2, [r4, 0x1]
b _080D953C
_080D94C0:
lsls r0, r5, 28
asrs r0, 28
subs r0, 0x1
mov r5, r9
ands r0, r5
lsls r2, r3, 28
lsrs r1, r2, 28
adds r1, 0x1
ands r1, r5
mov r5, r8
ands r3, r5
orrs r3, r1
strb r3, [r4, 0x1]
lsrs r2, 28
cmp r2, r0
bne _080D953C
ldrb r0, [r4, 0x3]
adds r0, 0x1
strb r0, [r4, 0x3]
lsls r0, r3, 27
lsrs r0, 31
eors r0, r7
ands r0, r7
lsls r0, 4
movs r2, 0x11
negs r2, r2
adds r1, r2, 0
ands r3, r1
orrs r3, r0
strb r3, [r4, 0x1]
b _080D953C
_080D94FE:
ldrb r2, [r4, 0x1]
movs r0, 0x10
ands r0, r2
cmp r0, 0
beq _080D950E
mov r0, r8
ands r0, r2
b _080D951C
_080D950E:
lsls r1, r5, 28
asrs r1, 28
mov r3, r9
ands r1, r3
mov r0, r8
ands r0, r2
orrs r0, r1
_080D951C:
strb r0, [r4, 0x1]
ldrb r2, [r4, 0x1]
lsls r0, r2, 27
lsrs r0, 31
eors r0, r7
ands r0, r7
lsls r0, 4
movs r5, 0x11
negs r5, r5
adds r1, r5, 0
ands r2, r1
orrs r2, r0
strb r2, [r4, 0x1]
ldrb r0, [r4, 0x3]
adds r0, 0x1
strb r0, [r4, 0x3]
_080D953C:
ldrb r1, [r4, 0xA]
cmp r1, 0xFF
beq _080D9552
ldrb r0, [r4, 0x3]
cmp r0, r1
bne _080D9552
ldrb r1, [r4]
ldr r0, [sp]
movs r2, 0
bl sub_80D9294
_080D9552:
mov r0, r10
adds r0, 0x1
lsls r0, 24
lsrs r0, 24
mov r10, r0
cmp r0, 0xF
bhi _080D9562
b _080D93E4
_080D9562:
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_80D93BC
thumb_func_start sub_80D9574
sub_80D9574: @ 80D9574
push {r4-r7,lr}
adds r6, r0, 0
ldr r0, [sp, 0x14]
ldr r4, [sp, 0x18]
lsls r1, 16
lsrs r7, r1, 16
lsls r2, 24
lsrs r2, 24
lsls r3, 24
lsls r0, 24
lsrs r5, r0, 24
lsls r4, 24
lsrs r4, 24
movs r1, 0
lsrs r3, 19
adds r3, r2
lsls r3, 1
adds r6, r3
cmp r1, r4
bcs _080D95BE
_080D959C:
lsls r0, r1, 6
adds r2, r6, r0
movs r0, 0
adds r3, r1, 0x1
cmp r0, r5
bcs _080D95B6
_080D95A8:
strh r7, [r2]
adds r2, 0x2
adds r0, 0x1
lsls r0, 24
lsrs r0, 24
cmp r0, r5
bcc _080D95A8
_080D95B6:
lsls r0, r3, 24
lsrs r1, r0, 24
cmp r1, r4
bcc _080D959C
_080D95BE:
pop {r4-r7}
pop {r0}
bx r0
thumb_func_end sub_80D9574
thumb_func_start sub_80D95C4
sub_80D95C4: @ 80D95C4
push {r4-r7,lr}
adds r7, r0, 0
ldr r0, [sp, 0x14]
ldr r4, [sp, 0x18]
lsls r2, 24
lsrs r2, 24
lsls r3, 24
lsls r0, 24
lsrs r5, r0, 24
lsls r4, 24
lsrs r6, r4, 24
movs r4, 0
lsrs r3, 19
adds r3, r2
lsls r3, 1
adds r7, r3
cmp r4, r6
bcs _080D960E
_080D95E8:
lsls r0, r4, 6
adds r2, r7, r0
movs r3, 0
adds r4, 0x1
cmp r3, r5
bcs _080D9606
_080D95F4:
ldrh r0, [r1]
strh r0, [r2]
adds r1, 0x2
adds r2, 0x2
adds r0, r3, 0x1
lsls r0, 24
lsrs r3, r0, 24
cmp r3, r5
bcc _080D95F4
_080D9606:
lsls r0, r4, 24
lsrs r4, r0, 24
cmp r4, r6
bcc _080D95E8
_080D960E:
pop {r4-r7}
pop {r0}
bx r0
thumb_func_end sub_80D95C4
.align 2, 0 @ Don't pad with nop.