mirror of https://github.com/zeldaret/tmc.git
Match sub_0802EA88 and sub_0802EB08
This commit is contained in:
parent
86ad4b1e00
commit
f3dd57eba6
|
@ -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
|
|
|
@ -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
|
|
|
@ -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)];
|
||||||
|
|
Loading…
Reference in New Issue