pmd-red/asm/code_8002774.s
2024-11-27 15:07:17 +01:00

421 lines
5.9 KiB
ArmAsm

#include "asm/constants/gba_constants.inc"
#include "asm/macros.inc"
.syntax unified
.text
thumb_func_start sub_8002774
sub_8002774:
sub sp, 0x4
str r0, [sp]
mov r0, sp
ldrb r1, [r0, 0x2]
movs r0, 0xF8
adds r2, r0, 0
ands r2, r1
lsls r2, 7
mov r1, sp
ldrb r3, [r1, 0x1]
adds r1, r0, 0
ands r1, r3
lsls r1, 2
orrs r2, r1
mov r1, sp
ldrb r1, [r1]
ands r0, r1
lsrs r0, 3
orrs r0, r2
add sp, 0x4
bx lr
thumb_func_end sub_8002774
thumb_func_start sub_80027A0
sub_80027A0:
push {r4,lr}
sub sp, 0x4
lsls r0, 16
lsrs r2, r0, 16
adds r3, r2, 0
mov r4, sp
movs r0, 0x1F
ands r0, r2
lsls r1, r0, 3
movs r0, 0x1
ands r0, r2
cmp r0, 0
beq _080027BE
movs r0, 0x7
orrs r1, r0
_080027BE:
strb r1, [r4]
mov r4, sp
movs r0, 0xF8
lsls r0, 2
ands r0, r2
lsrs r1, r0, 2
movs r0, 0x20
ands r0, r2
cmp r0, 0
beq _080027D6
movs r0, 0x7
orrs r1, r0
_080027D6:
strb r1, [r4, 0x1]
mov r2, sp
movs r0, 0xF8
lsls r0, 7
ands r0, r3
lsrs r1, r0, 7
movs r0, 0x80
lsls r0, 3
ands r3, r0
cmp r3, 0
beq _080027F0
movs r0, 0x7
orrs r1, r0
_080027F0:
strb r1, [r2, 0x2]
mov r0, sp
movs r1, 0
strb r1, [r0, 0x3]
ldr r0, [sp]
add sp, 0x4
pop {r4}
pop {r1}
bx r1
thumb_func_end sub_80027A0
thumb_func_start sub_8002804
sub_8002804:
push {r4,r5,lr}
adds r5, r0, 0
adds r4, r1, 0
movs r3, 0
_0800280C:
adds r1, r5, r3
adds r0, r2, r3
ldrb r0, [r0]
muls r0, r4
cmp r0, 0
bge _0800281A
adds r0, 0xFF
_0800281A:
asrs r0, 8
strb r0, [r1]
adds r3, 0x1
cmp r3, 0x3
ble _0800280C
pop {r4,r5}
pop {r0}
bx r0
thumb_func_end sub_8002804
thumb_func_start sub_800282C
sub_800282C:
push {r4-r7,lr}
mov r7, r10
mov r6, r9
mov r5, r8
push {r5-r7}
sub sp, 0x38
mov r9, r0
str r1, [sp, 0x20]
adds r7, r2, 0
mov r8, r3
adds r0, r1, 0
bl __floatsisf
adds r1, r0, 0
ldr r0, _08002904
bl __divsf3
str r0, [sp, 0x24]
movs r5, 0
mov r0, sp
adds r0, 0x10
str r0, [sp, 0x2C]
str r0, [sp, 0x34]
mov r10, sp
_0800285C:
adds r6, r7, r5
movs r4, 0
ldrsb r4, [r6, r4]
adds r0, r4, 0
bl __floatsisf
cmp r4, 0
bge _08002872
ldr r1, _08002908
bl __addsf3
_08002872:
mov r1, r10
adds r1, 0x4
mov r10, r1
subs r1, 0x4
stm r1!, {r0}
mov r1, r8
adds r0, r1, r5
ldrb r0, [r0]
ldrb r1, [r6]
subs r0, r1
bl __floatsisf
ldr r1, [sp, 0x24]
bl __mulsf3
ldr r1, [sp, 0x34]
stm r1!, {r0}
str r1, [sp, 0x34]
adds r5, 0x1
cmp r5, 0x3
ble _0800285C
ldr r0, [r7]
mov r1, r9
adds r1, 0x4
mov r9, r1
subs r1, 0x4
stm r1!, {r0}
movs r5, 0x1
ldr r0, [sp, 0x20]
subs r0, 0x1
str r0, [sp, 0x28]
mov r1, r8
ldr r1, [r1]
str r1, [sp, 0x30]
cmp r5, r0
bge _080028EE
_080028BA:
movs r6, 0
adds r5, 0x1
mov r10, r5
movs r0, 0x4
add r0, r9
mov r8, r0
mov r5, sp
ldr r7, [sp, 0x2C]
_080028CA:
mov r1, r9
adds r4, r1, r6
ldr r0, [r5]
ldm r7!, {r1}
bl __addsf3
stm r5!, {r0}
bl __fixunssfsi
strb r0, [r4]
adds r6, 0x1
cmp r6, 0x3
ble _080028CA
mov r9, r8
mov r5, r10
ldr r0, [sp, 0x28]
cmp r5, r0
blt _080028BA
_080028EE:
ldr r1, [sp, 0x30]
mov r0, r9
str r1, [r0]
add sp, 0x38
pop {r3-r5}
mov r8, r3
mov r9, r4
mov r10, r5
pop {r4-r7}
pop {r0}
bx r0
.align 2, 0
_08002904: .4byte 0x3f800000
_08002908: .4byte 0x43800000
thumb_func_end sub_800282C
thumb_func_start sub_800290C
sub_800290C:
push {lr}
ldr r3, [r0]
cmp r3, r1
ble _08002918
str r1, [r0]
b _08002920
_08002918:
negs r2, r1
cmp r3, r2
bge _08002920
str r2, [r0]
_08002920:
ldr r2, [r0, 0x4]
cmp r2, r1
bgt _0800292C
negs r1, r1
cmp r2, r1
bge _0800292E
_0800292C:
str r1, [r0, 0x4]
_0800292E:
pop {r0}
bx r0
thumb_func_end sub_800290C
thumb_func_start sub_8002934
sub_8002934:
push {r4-r6,lr}
mov r6, r10
mov r5, r9
mov r4, r8
push {r4-r6}
mov r10, r0
adds r6, r1, 0
mov r8, r2
adds r4, r3, 0
ldr r5, [sp, 0x1C]
adds r0, r4, r5
mov r9, r0
ldr r0, [r6]
muls r0, r4
ldr r1, [r2]
muls r1, r5
adds r0, r1
mov r1, r9
bl __divsi3
mov r1, r10
str r0, [r1]
ldr r0, [r6, 0x4]
muls r0, r4
mov r2, r8
ldr r1, [r2, 0x4]
muls r1, r5
adds r0, r1
mov r1, r9
bl __divsi3
mov r1, r10
str r0, [r1, 0x4]
pop {r3-r5}
mov r8, r3
mov r9, r4
mov r10, r5
pop {r4-r6}
pop {r0}
bx r0
thumb_func_end sub_8002934
thumb_func_start sub_8002984
sub_8002984:
push {r4,lr}
lsls r0, 24
asrs r4, r0, 24
lsls r1, 24
lsrs r1, 24
subs r0, r1, 0x1
cmp r0, 0x8
bhi _08002A68
lsls r0, 2
ldr r1, _080029A0
adds r0, r1
ldr r0, [r0]
mov pc, r0
.align 2, 0
_080029A0: .4byte _080029A4
.align 2, 0
_080029A4:
.4byte _080029C8
.4byte _080029D0
.4byte _080029D8
.4byte _080029E0
.4byte _080029E8
.4byte _080029F4
.4byte _08002A34
.4byte _08002A4E
.4byte _08002A5E
_080029C8:
cmp r4, 0
blt _08002A68
adds r4, 0x7
b _080029EE
_080029D0:
cmp r4, 0
blt _08002A68
adds r4, 0x1
b _080029EE
_080029D8:
cmp r4, 0
blt _08002A68
adds r4, 0x6
b _080029EE
_080029E0:
cmp r4, 0
blt _08002A68
adds r4, 0x2
b _080029EE
_080029E8:
cmp r4, 0
blt _08002A68
adds r4, 0x4
_080029EE:
movs r0, 0x7
ands r4, r0
b _08002A68
_080029F4:
movs r0, 0x1
ands r0, r4
cmp r0, 0
beq _08002A18
movs r0, 0x2
bl OtherRandInt
adds r1, r4, 0x7
lsls r0, 1
adds r1, r0
adds r0, r1, 0
cmp r1, 0
bge _08002A10
adds r0, r1, 0x7
_08002A10:
asrs r0, 3
lsls r0, 3
subs r0, r1, r0
b _08002A64
_08002A18:
movs r0, 0x3
bl OtherRandInt
adds r1, r4, 0x6
lsls r0, 1
adds r1, r0
adds r0, r1, 0
cmp r1, 0
bge _08002A2C
adds r0, r1, 0x7
_08002A2C:
asrs r0, 3
lsls r0, 3
subs r0, r1, r0
b _08002A64
_08002A34:
movs r0, 0x3
bl OtherRandInt
adds r1, r4, 0x7
adds r1, r0
adds r0, r1, 0
cmp r1, 0
bge _08002A46
adds r0, r1, 0x7
_08002A46:
asrs r0, 3
lsls r0, 3
subs r0, r1, r0
b _08002A64
_08002A4E:
movs r0, 0x8
bl OtherRandInt
movs r2, 0x2
negs r2, r2
adds r1, r2, 0
ands r0, r1
b _08002A64
_08002A5E:
movs r0, 0x8
bl OtherRandInt
_08002A64:
lsls r0, 24
asrs r4, r0, 24
_08002A68:
adds r0, r4, 0
pop {r4}
pop {r1}
bx r1
thumb_func_end sub_8002984
.align 2, 0 @ Don't pad with nop.