Match sub_0802EA88 and sub_0802EB08

This commit is contained in:
Tal Hayon 2022-08-12 19:26:57 +03:00
parent 86ad4b1e00
commit f3dd57eba6
3 changed files with 28 additions and 188 deletions

View File

@ -1,75 +0,0 @@
.syntax unified
.text
push {r4, r5, r6, lr}
adds r5, r0, #0
movs r6, #0
movs r3, #0
_0802EA90:
lsls r0, r3, #2
adds r4, r5, r0
adds r2, r3, #1
lsls r0, r2, #2
adds r1, r5, r0
ldrb r0, [r4, #1]
ldrb r3, [r1, #1]
cmp r0, r3
beq _0802EAC2
movs r6, #1
ldrb r0, [r1, #1]
ldrb r1, [r4, #1]
subs r0, r0, r1
movs r1, #0x1f
ands r0, r1
movs r3, #1
cmp r0, #0x10
ble _0802EAB6
movs r3, #0
_0802EAB6:
adds r0, r5, #0
adds r1, r2, #0
movs r2, #0x20
bl sub_0802EA48
b _0802EAC8
_0802EAC2:
adds r3, r2, #0
cmp r3, #4
bls _0802EA90
_0802EAC8:
movs r3, #0
movs r4, #0x1f
_0802EACC:
adds r2, r3, #1
lsls r0, r2, #2
adds r0, r5, r0
ldrb r1, [r0, #1]
lsls r0, r3, #2
adds r0, r5, r0
ldrb r0, [r0, #1]
subs r0, r1, r0
ands r0, r4
adds r3, r1, #0
adds r1, r2, #0
cmp r0, #0x10
ble _0802EAEE
cmp r0, #0x1e
bgt _0802EAF6
adds r3, #1
b _0802EAF4
_0802EAEE:
cmp r0, #1
ble _0802EAF6
subs r3, #1
_0802EAF4:
ands r3, r4
_0802EAF6:
lsls r0, r1, #2
adds r0, r5, r0
strb r3, [r0, #1]
adds r3, r1, #0
cmp r3, #4
bls _0802EACC
adds r0, r6, #0
pop {r4, r5, r6, pc}
.align 2, 0
.syntax divided

View File

@ -1,85 +0,0 @@
.syntax unified
.text
push {r4, r5, r6, r7, lr}
mov r7, r8
push {r7}
adds r5, r0, #0
adds r6, r1, #0
adds r7, r2, #0
movs r0, #0
mov r8, r0
movs r3, #0
_0802EB1A:
lsls r0, r3, #2
adds r4, r5, r0
adds r2, r3, #1
lsls r0, r2, #2
adds r1, r5, r0
ldrb r0, [r4, #0x19]
ldrb r3, [r1, #0x19]
cmp r0, r3
beq _0802EB4E
movs r0, #1
mov r8, r0
ldrb r0, [r1, #0x19]
ldrb r1, [r4, #0x19]
subs r0, r0, r1
movs r1, #0x1f
ands r0, r1
movs r3, #2
cmp r0, #0x10
ble _0802EB42
movs r3, #3
_0802EB42:
adds r0, r5, #0
adds r1, r2, #0
adds r2, r6, #0
bl sub_0802EA68
b _0802EB54
_0802EB4E:
adds r3, r2, #0
cmp r3, #4
bls _0802EB1A
_0802EB54:
movs r3, #0
movs r4, #0x1f
rsbs r6, r7, #0
ands r6, r4
_0802EB5C:
adds r2, r3, #1
lsls r0, r2, #2
adds r0, r5, r0
ldrb r1, [r0, #0x19]
lsls r0, r3, #2
adds r0, r5, r0
ldrb r0, [r0, #0x19]
subs r0, r1, r0
ands r0, r4
adds r3, r1, #0
adds r1, r2, #0
cmp r0, #0x10
ble _0802EB7E
cmp r6, r0
ble _0802EB86
adds r3, #1
b _0802EB84
_0802EB7E:
cmp r7, r0
bge _0802EB86
subs r3, #1
_0802EB84:
ands r3, r4
_0802EB86:
lsls r0, r1, #2
adds r0, r5, r0
strb r3, [r0, #0x19]
adds r3, r1, #0
cmp r3, #4
bls _0802EB5C
mov r0, r8
pop {r3}
mov r8, r3
pop {r4, r5, r6, r7, pc}
.align 2, 0
.syntax divided

View File

@ -1409,87 +1409,87 @@ void sub_0802EA68(Gleerok_HeapStruct* param_1, u32 param_2, u32 param_3, u32 par
param_1->filler2[param_2].unk0.HWORD = (param_1->filler2[param_2].unk0.HWORD + param_3) & 0x1fff; param_1->filler2[param_2].unk0.HWORD = (param_1->filler2[param_2].unk0.HWORD + param_3) & 0x1fff;
} }
NONMATCH("asm/non_matching/gleerok/sub_0802EA88.inc", bool32 sub_0802EA88(Gleerok_HeapStruct* this)) { bool32 sub_0802EA88(Gleerok_HeapStruct* this) {
s32 bVar2; s32 bVar2;
u32 uVar3; u32 uVar3;
u32 bVar4; u32 bVar4;
u32 uVar5; u32 i;
u32 uVar6; u32 uVar6;
uVar6 = FALSE; uVar6 = FALSE;
for (uVar5 = 0; uVar5 < 5; uVar5++) { for (i = 0; i < 5; i++) {
if (this->filler[uVar5].unk0.HALF.HI != this->filler[uVar5 + 1].unk0.HALF.HI) { if (this->filler[i].unk0.HALF.HI != this->filler[i + 1].unk0.HALF.HI) {
uVar6 = TRUE; uVar6 = TRUE;
if ((s32)((this->filler[uVar5 + 1].unk0.HALF.HI - this->filler[uVar5].unk0.HALF.HI) & 0x1fU) > 0x10) { if ((s32)((this->filler[i + 1].unk0.HALF.HI - this->filler[i].unk0.HALF.HI) & 0x1fU) > 0x10) {
uVar3 = 0; uVar3 = 0;
} else { } else {
uVar3 = 1; uVar3 = 1;
} }
sub_0802EA48(this, uVar5 + 1, 0x20, uVar3); sub_0802EA48(this, i + 1, 0x20, uVar3);
break; break;
} }
} }
for (uVar5 = 0; uVar5 <= 4; uVar5++) { for (i = 0; i <= 4; i++) {
bVar4 = this->filler[uVar5 + 1].unk0.HALF.HI; bVar4 = this->filler[i + 1].unk0.HALF.HI;
bVar2 = (bVar4 - this->filler[uVar5].unk0.HALF.HI) & 0x1f; bVar2 = (bVar4 - this->filler[i].unk0.HALF.HI) & 0x1f;
uVar3 = bVar4;
if (bVar2 >= 0x11) { if (bVar2 >= 0x11) {
if (bVar2 < 0x1f) { if (bVar2 < 0x1f) {
bVar4 = (bVar4 + 1) & 0x1f; uVar3++;
uVar3 &= 0x1f;
} }
} else { } else {
if (1 < bVar2) { if (1 < bVar2) {
bVar4 = (bVar4 - 1) & 0x1f; uVar3--;
uVar3 &= 0x1f;
} }
} }
this->filler[uVar5 + 1].unk0.HALF.HI = bVar4; this->filler[i + 1].unk0.HALF.HI = uVar3;
} }
return uVar6; return uVar6;
} }
END_NONMATCH
NONMATCH("asm/non_matching/gleerok/sub_0802EB08.inc", bool32 sub_0802EB08(Gleerok_HeapStruct* param_1, u32 param_2, s32 param_3) {
bool32 sub_0802EB08(Gleerok_HeapStruct* param_1, u32 param_2, s32 param_3)) {
s32 uVar2; s32 uVar2;
u32 bVar4; u32 bVar4;
u32 uVar5; u32 uVar5;
u32 uVar6; u32 i;
u32 uVar7; u32 uVar7;
uVar7 = FALSE; uVar7 = FALSE;
for (uVar6 = 0; uVar6 < 5; uVar6++) { for (i = 0; i < 5; i++) {
if (param_1->filler2[uVar6].unk0.HALF.HI != param_1->filler2[uVar6 + 1].unk0.HALF.HI) { if (param_1->filler2[i].unk0.HALF.HI != param_1->filler2[i + 1].unk0.HALF.HI) {
uVar7 = TRUE; uVar7 = TRUE;
if (0x10 < if (0x10 < (s32)((param_1->filler2[i + 1].unk0.HALF.HI - param_1->filler2[i].unk0.HALF.HI) & 0x1fU)) {
(s32)((param_1->filler2[uVar6 + 1].unk0.HALF.HI - param_1->filler2[uVar6].unk0.HALF.HI) & 0x1fU)) {
uVar5 = 3; uVar5 = 3;
} else { } else {
uVar5 = 2; uVar5 = 2;
} }
sub_0802EA68(param_1, uVar6 + 1, param_2, uVar5); sub_0802EA68(param_1, i + 1, param_2, uVar5);
break; break;
} }
} }
for (uVar6 = 0; uVar6 <= 4; uVar6++) { for (i = 0; i <= 4; i++) {
bVar4 = param_1->filler2[uVar6 + 1].unk0.HALF.HI; bVar4 = param_1->filler2[i + 1].unk0.HALF.HI;
uVar2 = (bVar4 - param_1->filler2[uVar6].unk0.HALF.HI) & 0x1f; uVar2 = (bVar4 - param_1->filler2[i].unk0.HALF.HI) & 0x1f;
uVar5 = bVar4;
if (uVar2 >= 0x11) { if (uVar2 >= 0x11) {
if ((-param_3 & 0x1f) > uVar2) { if ((-param_3 & 0x1f) > uVar2) {
bVar4 = (bVar4 + 1) & 0x1f; uVar5 = (uVar5 + 1) & 0x1f;
} }
} else { } else {
if (param_3 < (int)uVar2) { if (param_3 < (int)uVar2) {
bVar4 = (bVar4 - 1) & 0x1f; uVar5 = (uVar5 - 1) & 0x1f;
} }
} }
param_1->filler2[uVar6 + 1].unk0.HALF.HI = bVar4; param_1->filler2[i + 1].unk0.HALF.HI = uVar5;
} }
return uVar7; return uVar7;
} }
END_NONMATCH
void sub_0802EB9C(GleerokEntity* this) { void sub_0802EB9C(GleerokEntity* this) {
this->unk_74 = gUnk_080CD854[GetRandomByWeight(gUnk_080CD850)]; this->unk_74 = gUnk_080CD854[GetRandomByWeight(gUnk_080CD850)];