open-goal-jak-project/game/mips2c/jak3_functions/generic_merc.cpp

3589 lines
202 KiB
C++

//--------------------------MIPS2C---------------------
// clang-format off
#include "game/mips2c/mips2c_private.h"
#include "game/kernel/jak3/kscheme.h"
namespace Mips2C::jak3 {
namespace generic_warp_dest {
u64 execute(void* c);
}
namespace generic_prepare_dma_single {
u64 execute_real(void* c);
}
namespace generic_prepare_dma_double {
u64 execute(void* c);
}
namespace generic_light_proc {
u64 execute(void* c);
}
namespace generic_envmap_proc {
u64 execute(void* c);
}
}
using ::jak3::intern_from_c;
namespace Mips2C::jak3 {
namespace generic_merc_init_asm {
struct Cache {
void* fake_scratchpad_data; // *fake-scratchpad-data*
void* gsf_buffer; // *gsf-buffer*
void* inv_init_table; // *inv-init-table*
void* math_camera; // *math-camera*
void* generic_envmap_proc; // generic-envmap-proc
void* generic_light_proc; // generic-light-proc
void* generic_prepare_dma_double; // generic-prepare-dma-double
void* generic_prepare_dma_single; // generic-prepare-dma-single
void* high_speed_reject; // high-speed-reject
void* mercneric_convert; // mercneric-convert
void* mercneric_vu0_block; // mercneric-vu0-block
void* upload_vu0_program; // upload-vu0-program
} cache;
u64 execute(void* ctxt) {
auto* c = (ExecutionContext*)ctxt;
bool bc = false;
u32 call_addr = 0;
c->daddiu(sp, sp, -16); // daddiu sp, sp, -16
c->sd(ra, 0, sp); // sd ra, 0(sp)
c->load_symbol2(t9, cache.upload_vu0_program); // lw t9, upload-vu0-program(s7)
c->load_symbol2(a0, cache.mercneric_vu0_block); // lw a0, mercneric-vu0-block(s7)
get_fake_spad_addr2(v1, cache.fake_scratchpad_data, 0, c);// lui v1, 28672
c->ori(a1, v1, 84); // ori a1, v1, 84
call_addr = c->gprs[t9].du32[0]; // function call:
c->sll(v0, ra, 0); // sll v0, ra, 0
c->jalr(call_addr); // jalr ra, t9
c->load_symbol2(v1, cache.math_camera); // lw v1, *math-camera*(s7)
c->addiu(a0, r0, 7136); // addiu a0, r0, 7136
get_fake_spad_addr2(a1, cache.fake_scratchpad_data, 0, c);// lui a1, 28672
c->daddu(a0, a0, a1); // daddu a0, a0, a1
c->load_symbol2(a1, cache.mercneric_convert); // lw a1, mercneric-convert(s7)
c->sw(a1, 324, a0); // sw a1, 324(a0)
c->load_symbol2(a1, cache.generic_prepare_dma_single);// lw a1, generic-prepare-dma-single(s7)
c->sw(a1, 328, a0); // sw a1, 328(a0)
c->load_symbol2(a1, cache.generic_prepare_dma_double);// lw a1, generic-prepare-dma-double(s7)
c->sw(a1, 332, a0); // sw a1, 332(a0)
c->load_symbol2(a1, cache.generic_light_proc); // lw a1, generic-light-proc(s7)
c->sw(a1, 336, a0); // sw a1, 336(a0)
c->load_symbol2(a1, cache.generic_envmap_proc); // lw a1, generic-envmap-proc(s7)
c->sw(a1, 340, a0); // sw a1, 340(a0)
c->load_symbol2(a1, cache.high_speed_reject); // lw a1, high-speed-reject(s7)
c->sw(a1, 344, a0); // sw a1, 344(a0)
c->sw(r0, 320, a0); // sw r0, 320(a0)
c->daddu(t0, r0, a0); // daddu t0, r0, a0
c->daddiu(t1, v1, 156); // daddiu t1, v1, 156
c->lq(a1, 0, t1); // lq a1, 0(t1)
c->lq(a2, 16, t1); // lq a2, 16(t1)
c->lq(a3, 32, t1); // lq a3, 32(t1)
c->lq(t1, 48, t1); // lq t1, 48(t1)
c->sq(a1, 0, t0); // sq a1, 0(t0)
c->sq(a2, 16, t0); // sq a2, 16(t0)
c->sq(a3, 32, t0); // sq a3, 32(t0)
c->sq(t1, 48, t0); // sq t1, 48(t0)
c->daddiu(t0, a0, 64); // daddiu t0, a0, 64
c->daddiu(t1, v1, 220); // daddiu t1, v1, 220
c->lq(a1, 0, t1); // lq a1, 0(t1)
c->lq(a2, 16, t1); // lq a2, 16(t1)
c->lq(a3, 32, t1); // lq a3, 32(t1)
c->lq(t1, 48, t1); // lq t1, 48(t1)
c->sq(a1, 0, t0); // sq a1, 0(t0)
c->sq(a2, 16, t0); // sq a2, 16(t0)
c->sq(a3, 32, t0); // sq a3, 32(t0)
c->sq(t1, 48, t0); // sq t1, 48(t0)
c->daddiu(t0, a0, 128); // daddiu t0, a0, 128
c->daddiu(t1, v1, 428); // daddiu t1, v1, 428
c->lq(a1, 0, t1); // lq a1, 0(t1)
c->lq(a2, 16, t1); // lq a2, 16(t1)
c->lq(a3, 32, t1); // lq a3, 32(t1)
c->lq(t1, 48, t1); // lq t1, 48(t1)
c->sq(a1, 0, t0); // sq a1, 0(t0)
c->sq(a2, 16, t0); // sq a2, 16(t0)
c->sq(a3, 32, t0); // sq a3, 32(t0)
c->sq(t1, 48, t0); // sq t1, 48(t0)
c->lui(a1, 16256); // lui a1, 16256
c->mtc1(f0, a1); // mtc1 f0, a1
c->lwc1(f1, 12, v1); // lwc1 f1, 12(v1)
c->divs(f1, f0, f1); // div.s f1, f0, f1
c->lui(a1, 16256); // lui a1, 16256
c->mtc1(f0, a1); // mtc1 f0, a1
c->lwc1(f2, 16, v1); // lwc1 f2, 16(v1)
c->divs(f0, f0, f2); // div.s f0, f0, f2
c->daddiu(a2, a0, 352); // daddiu a2, a0, 352
c->daddiu(a1, a0, 368); // daddiu a1, a0, 368
c->daddiu(a0, a0, 384); // daddiu a0, a0, 384
c->swc1(f1, 0, a2); // swc1 f1, 0(a2)
c->negs(f1, f1); // neg.s f1, f1
c->swc1(f1, 4, a2); // swc1 f1, 4(a2)
c->mtc1(f1, r0); // mtc1 f1, r0
c->swc1(f1, 8, a2); // swc1 f1, 8(a2)
c->mtc1(f1, r0); // mtc1 f1, r0
c->swc1(f1, 12, a2); // swc1 f1, 12(a2)
c->mtc1(f1, r0); // mtc1 f1, r0
c->swc1(f1, 0, a1); // swc1 f1, 0(a1)
c->mtc1(f1, r0); // mtc1 f1, r0
c->swc1(f1, 4, a1); // swc1 f1, 4(a1)
c->swc1(f0, 8, a1); // swc1 f0, 8(a1)
c->negs(f0, f0); // neg.s f0, f0
c->swc1(f0, 12, a1); // swc1 f0, 12(a1)
c->lui(a1, 15104); // lui a1, 15104
c->mtc1(f0, a1); // mtc1 f0, a1
c->swc1(f0, 0, a0); // swc1 f0, 0(a0)
c->lui(a1, 15104); // lui a1, 15104
c->mtc1(f0, a1); // mtc1 f0, a1
c->swc1(f0, 4, a0); // swc1 f0, 4(a0)
c->lui(a1, 16128); // lui a1, 16128
c->mtc1(f0, a1); // mtc1 f0, a1
c->swc1(f0, 8, a0); // swc1 f0, 8(a0)
c->lwc1(f0, 908, v1); // lwc1 f0, 908(v1)
c->swc1(f0, 12, a0); // swc1 f0, 12(a0)
c->load_symbol2(v1, cache.gsf_buffer); // lw v1, *gsf-buffer*(s7)
c->daddiu(a0, v1, 32); // daddiu a0, v1, 32
c->sw(a0, 0, v1); // sw a0, 0(v1)
c->daddiu(a0, v1, 448); // daddiu a0, v1, 448
c->sw(a0, 4, v1); // sw a0, 4(v1)
c->daddiu(a0, v1, 6608); // daddiu a0, v1, 6608
c->sw(a0, 8, v1); // sw a0, 8(v1)
c->daddiu(a0, v1, 2784); // daddiu a0, v1, 2784
c->sw(a0, 2752, v1); // sw a0, 2752(v1)
c->daddiu(a0, v1, 3200); // daddiu a0, v1, 3200
c->sw(a0, 2756, v1); // sw a0, 2756(v1)
c->daddiu(a0, v1, 6608); // daddiu a0, v1, 6608
c->sw(a0, 2760, v1); // sw a0, 2760(v1)
c->load_symbol2(v1, cache.gsf_buffer); // lw v1, *gsf-buffer*(s7)
c->daddiu(a0, v1, 5504); // daddiu a0, v1, 5504
c->mov64(a0, a0); // or a0, a0, r0
c->load_symbol2(a1, cache.inv_init_table); // lw a1, *inv-init-table*(s7)
c->mov64(a1, a1); // or a1, a1, r0
c->sq(r0, 0, a0); // sq r0, 0(a0)
c->sq(r0, 544, a0); // sq r0, 544(a0)
c->sq(r0, 16, a0); // sq r0, 16(a0)
c->sq(r0, 560, a0); // sq r0, 560(a0)
c->sq(r0, 208, a0); // sq r0, 208(a0)
c->sq(r0, 752, a0); // sq r0, 752(a0)
c->sq(r0, 224, a0); // sq r0, 224(a0)
c->sq(r0, 768, a0); // sq r0, 768(a0)
c->sq(r0, 240, a0); // sq r0, 240(a0)
c->sq(r0, 784, a0); // sq r0, 784(a0)
c->sq(r0, 384, a0); // sq r0, 384(a0)
c->sq(r0, 800, a0); // sq r0, 800(a0)
c->sq(r0, 400, a0); // sq r0, 400(a0)
c->sq(r0, 944, a0); // sq r0, 944(a0)
c->sq(r0, 416, a0); // sq r0, 416(a0)
c->sq(r0, 960, a0); // sq r0, 960(a0)
c->sq(r0, 432, a0); // sq r0, 432(a0)
c->sq(r0, 976, a0); // sq r0, 976(a0)
c->sq(r0, 448, a0); // sq r0, 448(a0)
c->sq(r0, 992, a0); // sq r0, 992(a0)
c->sq(r0, 464, a0); // sq r0, 464(a0)
c->sq(r0, 1008, a0); // sq r0, 1008(a0)
c->sq(r0, 480, a0); // sq r0, 480(a0)
c->sq(r0, 1024, a0); // sq r0, 1024(a0)
c->sq(r0, 496, a0); // sq r0, 496(a0)
c->sq(r0, 1040, a0); // sq r0, 1040(a0)
c->sq(r0, 512, a0); // sq r0, 512(a0)
c->sq(r0, 1056, a0); // sq r0, 1056(a0)
c->sq(r0, 528, a0); // sq r0, 528(a0)
c->sq(r0, 1072, a0); // sq r0, 1072(a0)
c->addiu(a2, r0, 8); // addiu a2, r0, 8
// nop // sll r0, r0, 0
block_1:
c->lhu(t1, 2, a1); // lhu t1, 2(a1)
c->daddiu(a2, a2, -1); // daddiu a2, a2, -1
c->lbu(a3, 0, a1); // lbu a3, 0(a1)
// nop // sll r0, r0, 0
c->lbu(t0, 1, a1); // lbu t0, 1(a1)
// nop // sll r0, r0, 0
c->daddu(t1, t1, a0); // daddu t1, t1, a0
c->daddiu(a1, a1, 4); // daddiu a1, a1, 4
block_2:
c->sb(t0, 0, t1); // sb t0, 0(t1)
c->daddiu(a3, a3, -1); // daddiu a3, a3, -1
c->sb(t0, 550, t1); // sb t0, 550(t1)
c->daddiu(t0, t0, 2); // daddiu t0, t0, 2
c->daddiu(t1, t1, 3); // daddiu t1, t1, 3
// nop // sll r0, r0, 0
bc = c->sgpr64(a3) != 0; // bne a3, r0, L170
// nop // sll r0, r0, 0
if (bc) {goto block_2;} // branch non-likely
bc = c->sgpr64(a2) != 0; // bne a2, r0, L169
// nop // sll r0, r0, 0
if (bc) {goto block_1;} // branch non-likely
c->daddu(a0, r0, v1); // daddu a0, r0, v1
c->mov64(a0, a0); // or a0, a0, r0
c->sq(r0, 416, a0); // sq r0, 416(a0)
c->sq(r0, 432, a0); // sq r0, 432(a0)
c->daddiu(v1, v1, 2752); // daddiu v1, v1, 2752
c->mov64(v1, v1); // or v1, v1, r0
c->sq(r0, 416, v1); // sq r0, 416(v1)
c->sq(r0, 432, v1); // sq r0, 432(v1)
c->gprs[v1].du64[0] = 0; // or v1, r0, r0
c->lui(v1, 4096); // lui v1, 4096
c->ori(v1, v1, 32768); // ori v1, v1, 32768
get_fake_spad_addr2(a0, cache.fake_scratchpad_data, 0, c);// lui a0, 28672
c->ori(a0, a0, 84); // ori a0, a0, 84
// dma sync
// c->lw(a1, 0, v1); // lw a1, 0(v1)
// c->andi(a1, a1, 256); // andi a1, a1, 256
// bc = c->sgpr64(a1) == 0; // beq a1, r0, L172
// DANGER jump to delay slot, this MUST be fixed manually!
// c->lw(a1, 0, a0); // lw a1, 0(a0)
// if (bc) {goto block_-1;} // branch non-likely
//
//
// block_5:
// c->lw(a1, 0, a0); // lw a1, 0(a0)
// // nop // sll r0, r0, 0
// c->lw(a2, 0, v1); // lw a2, 0(v1)
// // nop // sll r0, r0, 0
// c->andi(a2, a2, 256); // andi a2, a2, 256
// c->daddiu(a1, a1, 1); // daddiu a1, a1, 1
// bc = c->sgpr64(a2) != 0; // bne a2, r0, L171
// c->sw(a1, 0, a0); // sw a1, 0(a0)
// if (bc) {goto block_5;} // branch non-likely
c->gprs[v1].du64[0] = 0; // or v1, r0, r0
c->gprs[v0].du64[0] = 0; // or v0, r0, r0
c->ld(ra, 0, sp); // ld ra, 0(sp)
//jr ra // jr ra
c->daddiu(sp, sp, 16); // daddiu sp, sp, 16
goto end_of_function; // return
end_of_function:
return c->gprs[v0].du64[0];
}
void link() {
cache.fake_scratchpad_data = intern_from_c(-1, 0, "*fake-scratchpad-data*").c();
cache.gsf_buffer = intern_from_c(-1, 0, "*gsf-buffer*").c();
cache.inv_init_table = intern_from_c(-1, 0, "*inv-init-table*").c();
cache.math_camera = intern_from_c(-1, 0, "*math-camera*").c();
cache.generic_envmap_proc = intern_from_c(-1, 0, "generic-envmap-proc").c();
cache.generic_light_proc = intern_from_c(-1, 0, "generic-light-proc").c();
cache.generic_prepare_dma_double = intern_from_c(-1, 0, "generic-prepare-dma-double").c();
cache.generic_prepare_dma_single = intern_from_c(-1, 0, "generic-prepare-dma-single").c();
cache.high_speed_reject = intern_from_c(-1, 0, "high-speed-reject").c();
cache.mercneric_convert = intern_from_c(-1, 0, "mercneric-convert").c();
cache.mercneric_vu0_block = intern_from_c(-1, 0, "mercneric-vu0-block").c();
cache.upload_vu0_program = intern_from_c(-1, 0, "upload-vu0-program").c();
gLinkedFunctionTable.reg("generic-merc-init-asm", execute, 128);
}
} // namespace generic_merc_init_asm
} // namespace Mips2C
//--------------------------MIPS2C---------------------
// clang-format off
#include "game/mips2c/mips2c_private.h"
#include "game/kernel/jak3/kscheme.h"
using ::jak3::intern_from_c;
namespace Mips2C::jak3 {
namespace mercneric_convert {
struct Cache {
void* fake_scratchpad_data; // *fake-scratchpad-data*
} cache;
u8 vu0_data_mem[1024 * 4];
void sq_buffer(Mask mask, const Vf& data, u32 qw) {
ASSERT(qw * 16 < sizeof(vu0_data_mem));
for (int i = 0; i < 4; i++) {
if ((u64)mask & (1 << i)) {
memcpy(vu0_data_mem + qw * 16 + i * 4, data.data + i, 4);
}
}
}
void sq_xyzw(const Vf& data, u32 qw) {
memcpy(vu0_data_mem + qw * 16, data.data, 16);
}
void lq_buffer(Mask mask, Vf& data, u32 qw) {
ASSERT(qw * 16 < sizeof(vu0_data_mem));
for (int i = 0; i < 4; i++) {
if ((u64)mask & (1 << i)) {
memcpy(data.data + i, vu0_data_mem + qw * 16 + i * 4, 4);
}
}
}
void lq_xyzw(Vf& data, u32 qw) {
memcpy(data.data, vu0_data_mem + qw * 16, 16);
}
void vcallms_280(ExecutionContext* c, u16* vis) {
bool bc;
// 0.003921569 | maxw.x vf17, vf00, vf00 :i
c->vfs[vf17].vf.max(Mask::x, c->vf_src(vf00).vf, c->vf_src(vf00).vf.w()); c->I = 0.003921569;
// -65537.0 | maxi.y vf17, vf00, I :i
c->vfs[vf17].vf.maxi(Mask::y, c->vf_src(vf00).vf, c->I); c->I = -65537.0;
// iaddiu vi10, vi10, 0x88 | minii.z vf05, vf00, I
c->vfs[vf05].vf.minii(Mask::z, c->vf_src(vf00).vf, c->I); vis[vi10] = vis[vi10] + 0x88; /* 136 */
// iaddiu vi08, vi00, 0x8c | minii.z vf06, vf00, I
c->vfs[vf06].vf.minii(Mask::z, c->vf_src(vf00).vf, c->I); vis[vi08] = 0x8c; /* 140 */
// sqi.xyzw vf01, vi08 | minii.z vf07, vf00, I
c->vfs[vf07].vf.minii(Mask::z, c->vf_src(vf00).vf, c->I); sq_xyzw(c->vf_src(vf01).vf, vis[vi08]++);
// sqi.xyzw vf02, vi08 | minix.w vf05, vf00, vf27
c->vfs[vf05].vf.mini(Mask::w, c->vf_src(vf00).vf, c->vf_src(vf27).vf.x()); sq_xyzw(c->vf_src(vf02).vf, vis[vi08]++);
// sqi.xyzw vf03, vi08 | miniy.w vf06, vf00, vf27
c->vfs[vf06].vf.mini(Mask::w, c->vf_src(vf00).vf, c->vf_src(vf27).vf.y()); sq_xyzw(c->vf_src(vf03).vf, vis[vi08]++);
// sqi.xyzw vf04, vi08 | miniz.w vf07, vf00, vf27
c->vfs[vf07].vf.mini(Mask::w, c->vf_src(vf00).vf, c->vf_src(vf27).vf.z()); sq_xyzw(c->vf_src(vf04).vf, vis[vi08]++);
// BRANCH!
// ibne vi00, vi13, L1 | nop
bc = (vis[vi13] != 0);
// iaddiu vi05, vi00, 0x182 | nop
vis[vi05] = 0x182; /* 386 */
if (bc) { goto L1; }
// iaddiu vi05, vi00, 0x1ab | nop
vis[vi05] = 0x1ab; /* 427 */
L1:
// BRANCH!
// ibne vi00, vi12, L2 | nop
bc = (vis[vi12] != 0);
// iaddiu vi03, vi00, 0x146 | nop
vis[vi03] = 0x146; /* 326 */
if (bc) { goto L2; }
// ior vi03, vi05, vi00 | nop
vis[vi03] = vis[vi05];
L2:
// BRANCH!
// ibne vi00, vi11, L3 | nop
bc = (vis[vi11] != 0);
// iaddiu vi01, vi00, 0x13a | nop
vis[vi01] = 0x13a; /* 314 */
if (bc) { goto L3; }
// ior vi01, vi03, vi00 | nop
vis[vi01] = vis[vi03];
L3:
// lqi.xyzw vf29, vi10 | nop
lq_xyzw(c->vfs[vf29].vf, vis[vi10]++);
// iadd vi02, vi08, vi11 | nop
vis[vi02] = vis[vi08] + vis[vi11];
// iadd vi04, vi02, vi12 | nop
vis[vi04] = vis[vi02] + vis[vi12];
// iadd vi06, vi04, vi13 | nop
vis[vi06] = vis[vi04] + vis[vi13];
// mtir vi13, vf29.w | itof0.xyzw vf18, vf29 :e
c->vfs[vf18].vf.itof0(Mask::xyzw, c->vf_src(vf29).vf); vis[vi13] = c->vf_src(vf29).vf.w_as_u16();
// iaddiu vi09, vi00, 0x7f | nop
vis[vi09] = 0x7f; /* 127 */
}
void vcallms_303(ExecutionContext* c, u16* vis) {
// vf21.x coming into here is bad (should be < 1, I think)
// sq.xyzw vf23, 3(vi14) | mulx.xyzw vf11, vf20, vf19
c->vfs[vf11].vf.mul_xyzw(c->vf_src(vf20).vf, c->vf_src(vf19).vf.x()); sq_xyzw(c->vf_src(vf23).vf, vis[vi14] + 3);
// sq.xyzw vf24, 4(vi14) | mulx.xyzw vf12, vf21, vf19
c->vfs[vf12].vf.mul_xyzw(c->vf_src(vf21).vf, c->vf_src(vf19).vf.x()); sq_xyzw(c->vf_src(vf24).vf, vis[vi14] + 4);
// sq.xyzw vf25, 5(vi14) | mulx.xyzw vf13, vf22, vf19
c->vfs[vf13].vf.mul_xyzw(c->vf_src(vf22).vf, c->vf_src(vf19).vf.x()); sq_xyzw(c->vf_src(vf25).vf, vis[vi14] + 5);
// sq.xyzw vf26, 6(vi14) | nop
sq_xyzw(c->vf_src(vf26).vf, vis[vi14] + 6);
// sq.xyzw vf11, 0(vi14) | nop
sq_xyzw(c->vf_src(vf11).vf, vis[vi14]);
// sq.xyzw vf12, 1(vi14) | nop
sq_xyzw(c->vf_src(vf12).vf, vis[vi14] + 1);
// sq.xyzw vf13, 2(vi14) | nop :e
sq_xyzw(c->vf_src(vf13).vf, vis[vi14] + 2);
// nop | nop
}
void vcallms_311_case_314(ExecutionContext* c, u16* vis) {
// this is one of the most expensive operations.
// 00 mtir vi11, vf01.x | maddz.xyzw vf11, vf26, vf10
// 01 jr vi01 | mul.xyzw vf14, vf13, Q
// 02 sqi.xyzw vf04, vi08 | mulaw.xyzw ACC, vf20, vf08
// 03 rsqrt Q, vf00.w, vf16.x | maddaw.xyzw ACC, vf21, vf09
// 04 lq.xyzw vf24, -124(vi11) | maddaw.xyzw ACC, vf22, vf10
// 05 lq.xyzw vf25, -123(vi11) | maddw.xyzw vf15, vf23, vf00
// 06 lq.xyzw vf26, -122(vi11) | mul.xyzw vf16, vf11, vf11
// 07 lq.xyzw vf20, -128(vi11) | add.xyzw vf08, vf01, vf05
// 08 lq.xyzw vf21, -127(vi11) | add.xyzw vf09, vf02, vf06
// 09 lq.xyzw vf22, -126(vi11) | add.xyzw vf10, vf03, vf07
// 10 ibne vi08, vi02, L4 | adday.xyzw vf16, vf16
// 11 lq.xyzw vf23, -125(vi11) | maddz.xyzw vf16, vf17, vf16
// 12 ior vi01, vi03, vi00 | nop
// L4:
// 13 move.xyzw vf13, vf12 | mulaz.xyzw ACC, vf24, vf08 :e
// 14 move.xyzw vf12, vf11 | maddaz.xyzw ACC, vf25, vf09
// we've got:
// - mul by Q
// - calculate next Q
// - accumulated multiply part
// - lots of loading
// - adding part
c->acc.vf.madd_xyzw(c->vfs[vf11].vf, c->vf_src(vf26).vf, c->vf_src(vf10).vf.z());
vis[vi11] = c->vf_src(vf01).vf.x_as_u16();
c->vfs[vf14].vf.mul_xyzw(c->vf_src(vf13).vf, c->Q);
sq_xyzw(c->vf_src(vf04).vf, vis[vi08]++);
c->Q = 1.f / std::sqrt(c->vf_src(vf16).vf.x());
// c->acc.vf.mula_xyzw(c->vf_src(vf20).vf, c->vf_src(vf08).vf.w());
// c->acc.vf.madda_xyzw(c->vfs[vf21].vf, c->vfs[vf09].vf.w());
// c->acc.vf.madda_xyzw(c->vfs[vf22].vf, c->vfs[vf10].vf.w());
// c->acc.vf.madd_xyzw(c->vfs[vf15].vf, c->vf_src(vf23).vf, c->vf_src(vf00).vf.w());
__m128 acc = _mm_mul_ps(_mm_load_ps(c->vf_src(vf20).vf.data), _mm_set1_ps(c->vf_src(vf08).vf.w()));
acc = _mm_add_ps(_mm_mul_ps(_mm_load_ps(c->vf_src(vf21).vf.data), _mm_set1_ps(c->vf_src(vf09).vf.w())), acc);
acc = _mm_add_ps(_mm_mul_ps(_mm_load_ps(c->vf_src(vf22).vf.data), _mm_set1_ps(c->vf_src(vf10).vf.w())), acc);
acc = _mm_add_ps(_mm_load_ps(c->vf_src(vf23).vf.data), acc);
_mm_store_ps(c->vfs[vf15].vf.data, acc);
// lq_xyzw(c->vfs[vf20].vf, vis[vi11] + -128);
// lq_xyzw(c->vfs[vf21].vf, vis[vi11] + -127);
// lq_xyzw(c->vfs[vf22].vf, vis[vi11] + -126);
// lq_xyzw(c->vfs[vf23].vf, vis[vi11] + -125);
// lq_xyzw(c->vfs[vf24].vf, vis[vi11] + -124);
// lq_xyzw(c->vfs[vf25].vf, vis[vi11] + -123);
// lq_xyzw(c->vfs[vf26].vf, vis[vi11] + -122);
memcpy(c->vfs[vf20].vf.data, vu0_data_mem + (vis[vi11] - 128) * 16, 7 * 16);
c->vfs[vf16].vf.mul_xyzw(c->vf_src(vf11).vf, c->vf_src(vf11).vf);
c->vfs[vf08].vf.add_xyzw(c->vf_src(vf01).vf, c->vf_src(vf05).vf);
c->vfs[vf09].vf.add_xyzw(c->vf_src(vf02).vf, c->vf_src(vf06).vf);
c->vfs[vf10].vf.add_xyzw(c->vf_src(vf03).vf, c->vf_src(vf07).vf);
c->acc.vf.adda(Mask::xyzw, c->vfs[vf16].vf, c->vfs[vf16].vf.y());
c->acc.vf.madd_xyzw(c->vfs[vf16].vf, c->vf_src(vf17).vf, c->vf_src(vf16).vf.z());
c->acc.vf.mula_xyzw(c->vf_src(vf24).vf, c->vf_src(vf08).vf.z());
c->acc.vf.madda_xyzw(c->vfs[vf25].vf, c->vfs[vf09].vf.z());
c->vfs[vf13].vf.move(Mask::xyzw, c->vf_src(vf12).vf);
c->vfs[vf12].vf.move(Mask::xyzw, c->vf_src(vf11).vf);
// end integer thing.
if (vis[vi08] == vis[vi02]) {
vis[vi01] = vis[vi03];
}
}
void vcallms_311_case_326(ExecutionContext* c, u16* vis) {
bool bc;
// mtir vi11, vf01.x | maddz.xyzw vf11, vf26, vf10
c->acc.vf.madd_xyzw(c->vfs[vf11].vf, c->vf_src(vf26).vf, c->vf_src(vf10).vf.z()); vis[vi11] = c->vf_src(vf01).vf.x_as_u16();
// jr vi01 | mul.xyzw vf14, vf13, Q
c->vfs[vf14].vf.mul_xyzw(c->vf_src(vf13).vf, c->Q);
// sqi.xyzw vf04, vi08 | mulaw.xyzw ACC, vf20, vf08
c->acc.vf.mula_xyzw(c->vf_src(vf20).vf, c->vf_src(vf08).vf.w()); sq_xyzw(c->vf_src(vf04).vf, vis[vi08]++);
// rsqrt Q, vf00.w, vf16.x | maddaw.xyzw ACC, vf21, vf09
c->acc.vf.madda_xyzw(c->vfs[vf21].vf, c->vfs[vf09].vf.w()); c->Q = c->vf_src(vf00).vf.w() / std::sqrt(c->vf_src(vf16).vf.x());
// mtir vi12, vf01.y | maddaw.xyzw ACC, vf22, vf10
c->acc.vf.madda_xyzw(c->vfs[vf22].vf, c->vfs[vf10].vf.w()); vis[vi12] = c->vf_src(vf01).vf.y_as_u16();
// iand vi11, vi11, vi09 | maddw.xyzw vf15, vf23, vf00
c->acc.vf.madd_xyzw(c->vfs[vf15].vf, c->vf_src(vf23).vf, c->vf_src(vf00).vf.w()); vis[vi11] = vis[vi11] & vis[vi09];
// lq.xyzw vf19, 4(vi11) | mul.xyzw vf16, vf11, vf11
c->vfs[vf16].vf.mul_xyzw(c->vf_src(vf11).vf, c->vf_src(vf11).vf); lq_xyzw(c->vfs[vf19].vf, vis[vi11] + 4);
// BRANCH!
// ibeq vi09, vi11, L7 | add.xyzw vf08, vf01, vf05
c->vfs[vf08].vf.add_xyzw(c->vf_src(vf01).vf, c->vf_src(vf05).vf); bc = (vis[vi09] == vis[vi11]);
// iand vi12, vi12, vi09 | add.xyzw vf09, vf02, vf06
c->vfs[vf09].vf.add_xyzw(c->vf_src(vf02).vf, c->vf_src(vf06).vf); vis[vi12] = vis[vi12] & vis[vi09];
if (bc) { goto L7; }
// nop | muly.xyzw vf18, vf18, vf17
c->vfs[vf18].vf.mul_xyzw(c->vf_src(vf18).vf, c->vf_src(vf17).vf.y());
// lq.xyzw vf24, 4(vi12) | add.xyzw vf10, vf03, vf07
c->vfs[vf10].vf.add_xyzw(c->vf_src(vf03).vf, c->vf_src(vf07).vf); lq_xyzw(c->vfs[vf24].vf, vis[vi12] + 4);
// lq.xyzw vf27, 5(vi11) | adday.xyzw vf16, vf16
c->acc.vf.adda(Mask::xyzw, c->vfs[vf16].vf, c->vfs[vf16].vf.y()); lq_xyzw(c->vfs[vf27].vf, vis[vi11] + 5);
// lq.xyzw vf25, 5(vi12) | maddz.xyzw vf16, vf17, vf16
c->acc.vf.madd_xyzw(c->vfs[vf16].vf, c->vf_src(vf17).vf, c->vf_src(vf16).vf.z()); lq_xyzw(c->vfs[vf25].vf, vis[vi12] + 5);
// lq.xyzw vf28, 6(vi11) | mulax.xyzw ACC, vf19, vf18
c->acc.vf.mula_xyzw(c->vf_src(vf19).vf, c->vf_src(vf18).vf.x()); lq_xyzw(c->vfs[vf28].vf, vis[vi11] + 6);
// lq.xyzw vf26, 6(vi12) | maddy.xyzw vf24, vf24, vf18
c->acc.vf.madd_xyzw(c->vfs[vf24].vf, c->vf_src(vf24).vf, c->vf_src(vf18).vf.y()); lq_xyzw(c->vfs[vf26].vf, vis[vi12] + 6);
// lq.xyzw vf29, 0(vi11) | mulax.xyzw ACC, vf27, vf18
c->acc.vf.mula_xyzw(c->vf_src(vf27).vf, c->vf_src(vf18).vf.x()); lq_xyzw(c->vfs[vf29].vf, vis[vi11]);
// lq.xyzw vf20, 0(vi12) | maddy.xyzw vf25, vf25, vf18
c->acc.vf.madd_xyzw(c->vfs[vf25].vf, c->vf_src(vf25).vf, c->vf_src(vf18).vf.y()); lq_xyzw(c->vfs[vf20].vf, vis[vi12]);
// lq.xyzw vf19, 1(vi11) | mulax.xyzw ACC, vf28, vf18
c->acc.vf.mula_xyzw(c->vf_src(vf28).vf, c->vf_src(vf18).vf.x()); lq_xyzw(c->vfs[vf19].vf, vis[vi11] + 1);
// lq.xyzw vf21, 1(vi12) | maddy.xyzw vf26, vf26, vf18
c->acc.vf.madd_xyzw(c->vfs[vf26].vf, c->vf_src(vf26).vf, c->vf_src(vf18).vf.y()); lq_xyzw(c->vfs[vf21].vf, vis[vi12] + 1);
// lq.xyzw vf27, 2(vi11) | mulax.xyzw ACC, vf29, vf18
c->acc.vf.mula_xyzw(c->vf_src(vf29).vf, c->vf_src(vf18).vf.x()); lq_xyzw(c->vfs[vf27].vf, vis[vi11] + 2);
// lq.xyzw vf22, 2(vi12) | maddy.xyzw vf20, vf20, vf18
c->acc.vf.madd_xyzw(c->vfs[vf20].vf, c->vf_src(vf20).vf, c->vf_src(vf18).vf.y()); lq_xyzw(c->vfs[vf22].vf, vis[vi12] + 2);
// lq.xyzw vf28, 3(vi11) | mulax.xyzw ACC, vf19, vf18
c->acc.vf.mula_xyzw(c->vf_src(vf19).vf, c->vf_src(vf18).vf.x()); lq_xyzw(c->vfs[vf28].vf, vis[vi11] + 3);
// lq.xyzw vf23, 3(vi12) | maddy.xyzw vf21, vf21, vf18
c->acc.vf.madd_xyzw(c->vfs[vf21].vf, c->vf_src(vf21).vf, c->vf_src(vf18).vf.y()); lq_xyzw(c->vfs[vf23].vf, vis[vi12] + 3);
// nop | mulax.xyzw ACC, vf27, vf18
c->acc.vf.mula_xyzw(c->vf_src(vf27).vf, c->vf_src(vf18).vf.x());
// iaddiu vi01, vi00, 0x161 | maddy.xyzw vf22, vf22, vf18
c->acc.vf.madd_xyzw(c->vfs[vf22].vf, c->vf_src(vf22).vf, c->vf_src(vf18).vf.y()); vis[vi01] = 0x161; /* 353 */
// BRANCH!
// ibne vi08, vi04, L5 | mulax.xyzw ACC, vf28, vf18
c->acc.vf.mula_xyzw(c->vf_src(vf28).vf, c->vf_src(vf18).vf.x()); bc = (vis[vi08] != vis[vi04]);
// nop | maddy.xyzw vf23, vf23, vf18
c->acc.vf.madd_xyzw(c->vfs[vf23].vf, c->vf_src(vf23).vf, c->vf_src(vf18).vf.y());
if (bc) { goto L5; }
// ior vi01, vi05, vi00 | nop
vis[vi01] = vis[vi05];
L5:
// move.xyzw vf13, vf12 | mulaz.xyzw ACC, vf24, vf08 :e
c->acc.vf.mula_xyzw(c->vf_src(vf24).vf, c->vf_src(vf08).vf.z()); c->vfs[vf13].vf.move(Mask::xyzw, c->vf_src(vf12).vf);
// move.xyzw vf12, vf11 | maddaz.xyzw ACC, vf25, vf09
c->acc.vf.madda_xyzw(c->vfs[vf25].vf, c->vfs[vf09].vf.z()); c->vfs[vf12].vf.move(Mask::xyzw, c->vf_src(vf11).vf);
return;
L7:
// nop | add.xyzw vf10, vf03, vf07
c->vfs[vf10].vf.add_xyzw(c->vf_src(vf03).vf, c->vf_src(vf07).vf);
// BRANCH!
// ibne vi08, vi04, L8 | adday.xyzw vf16, vf16
c->acc.vf.adda(Mask::xyzw, c->vfs[vf16].vf, c->vfs[vf16].vf.y()); bc = (vis[vi08] != vis[vi04]);
// nop | maddz.xyzw vf16, vf17, vf16
c->acc.vf.madd_xyzw(c->vfs[vf16].vf, c->vf_src(vf17).vf, c->vf_src(vf16).vf.z());
if (bc) { goto L8; }
// ior vi01, vi05, vi00 | nop
vis[vi01] = vis[vi05];
L8:
// move.xyzw vf13, vf12 | mulaz.xyzw ACC, vf24, vf08 :e
c->acc.vf.mula_xyzw(c->vf_src(vf24).vf, c->vf_src(vf08).vf.z()); c->vfs[vf13].vf.move(Mask::xyzw, c->vf_src(vf12).vf);
// move.xyzw vf12, vf11 | maddaz.xyzw ACC, vf25, vf09
c->acc.vf.madda_xyzw(c->vfs[vf25].vf, c->vfs[vf09].vf.z()); c->vfs[vf12].vf.move(Mask::xyzw, c->vf_src(vf11).vf);
return;
}
void vcallms_311_case_353(ExecutionContext* c, u16* vis) {
bool bc;
// mtir vi11, vf01.x | maddz.xyzw vf11, vf26, vf10
c->acc.vf.madd_xyzw(c->vfs[vf11].vf, c->vf_src(vf26).vf, c->vf_src(vf10).vf.z()); vis[vi11] = c->vf_src(vf01).vf.x_as_u16();
// jr vi01 | mul.xyzw vf14, vf13, Q
c->vfs[vf14].vf.mul_xyzw(c->vf_src(vf13).vf, c->Q);
// sqi.xyzw vf04, vi08 | mulaw.xyzw ACC, vf20, vf08
c->acc.vf.mula_xyzw(c->vf_src(vf20).vf, c->vf_src(vf08).vf.w()); sq_xyzw(c->vf_src(vf04).vf, vis[vi08]++);
// rsqrt Q, vf00.w, vf16.x | maddaw.xyzw ACC, vf21, vf09
c->acc.vf.madda_xyzw(c->vfs[vf21].vf, c->vfs[vf09].vf.w()); c->Q = c->vf_src(vf00).vf.w() / std::sqrt(c->vf_src(vf16).vf.x());
// mtir vi12, vf01.y | maddaw.xyzw ACC, vf22, vf10
c->acc.vf.madda_xyzw(c->vfs[vf22].vf, c->vfs[vf10].vf.w()); vis[vi12] = c->vf_src(vf01).vf.y_as_u16();
// iand vi11, vi11, vi09 | maddw.xyzw vf15, vf23, vf00
c->acc.vf.madd_xyzw(c->vfs[vf15].vf, c->vf_src(vf23).vf, c->vf_src(vf00).vf.w()); vis[vi11] = vis[vi11] & vis[vi09];
// lq.xyzw vf19, 4(vi11) | mul.xyzw vf16, vf11, vf11
c->vfs[vf16].vf.mul_xyzw(c->vf_src(vf11).vf, c->vf_src(vf11).vf); lq_xyzw(c->vfs[vf19].vf, vis[vi11] + 4);
// BRANCH!
// ibeq vi09, vi11, L7 | add.xyzw vf08, vf01, vf05
c->vfs[vf08].vf.add_xyzw(c->vf_src(vf01).vf, c->vf_src(vf05).vf); bc = (vis[vi09] == vis[vi11]);
// iand vi12, vi12, vi09 | add.xyzw vf09, vf02, vf06
c->vfs[vf09].vf.add_xyzw(c->vf_src(vf02).vf, c->vf_src(vf06).vf); vis[vi12] = vis[vi12] & vis[vi09];
if (bc) { goto L7; }
// lq.xyzw vf24, 4(vi12) | add.xyzw vf10, vf03, vf07
c->vfs[vf10].vf.add_xyzw(c->vf_src(vf03).vf, c->vf_src(vf07).vf); lq_xyzw(c->vfs[vf24].vf, vis[vi12] + 4);
// lq.xyzw vf27, 5(vi11) | adday.xyzw vf16, vf16
c->acc.vf.adda(Mask::xyzw, c->vfs[vf16].vf, c->vfs[vf16].vf.y()); lq_xyzw(c->vfs[vf27].vf, vis[vi11] + 5);
// lq.xyzw vf25, 5(vi12) | maddz.xyzw vf16, vf17, vf16
c->acc.vf.madd_xyzw(c->vfs[vf16].vf, c->vf_src(vf17).vf, c->vf_src(vf16).vf.z()); lq_xyzw(c->vfs[vf25].vf, vis[vi12] + 5);
// lq.xyzw vf28, 6(vi11) | mulaz.xyzw ACC, vf19, vf18
c->acc.vf.mula_xyzw(c->vf_src(vf19).vf, c->vf_src(vf18).vf.z()); lq_xyzw(c->vfs[vf28].vf, vis[vi11] + 6);
// lq.xyzw vf26, 6(vi12) | maddw.xyzw vf24, vf24, vf18
c->acc.vf.madd_xyzw(c->vfs[vf24].vf, c->vf_src(vf24).vf, c->vf_src(vf18).vf.w()); lq_xyzw(c->vfs[vf26].vf, vis[vi12] + 6);
// lq.xyzw vf29, 0(vi11) | mulaz.xyzw ACC, vf27, vf18
c->acc.vf.mula_xyzw(c->vf_src(vf27).vf, c->vf_src(vf18).vf.z()); lq_xyzw(c->vfs[vf29].vf, vis[vi11]);
// lq.xyzw vf20, 0(vi12) | maddw.xyzw vf25, vf25, vf18
c->acc.vf.madd_xyzw(c->vfs[vf25].vf, c->vf_src(vf25).vf, c->vf_src(vf18).vf.w()); lq_xyzw(c->vfs[vf20].vf, vis[vi12]);
// lq.xyzw vf19, 1(vi11) | mulaz.xyzw ACC, vf28, vf18
c->acc.vf.mula_xyzw(c->vf_src(vf28).vf, c->vf_src(vf18).vf.z()); lq_xyzw(c->vfs[vf19].vf, vis[vi11] + 1);
// lq.xyzw vf21, 1(vi12) | maddw.xyzw vf26, vf26, vf18
c->acc.vf.madd_xyzw(c->vfs[vf26].vf, c->vf_src(vf26).vf, c->vf_src(vf18).vf.w()); lq_xyzw(c->vfs[vf21].vf, vis[vi12] + 1);
// lq.xyzw vf27, 2(vi11) | mulaz.xyzw ACC, vf29, vf18
c->acc.vf.mula_xyzw(c->vf_src(vf29).vf, c->vf_src(vf18).vf.z()); lq_xyzw(c->vfs[vf27].vf, vis[vi11] + 2);
// lq.xyzw vf22, 2(vi12) | maddw.xyzw vf20, vf20, vf18
c->acc.vf.madd_xyzw(c->vfs[vf20].vf, c->vf_src(vf20).vf, c->vf_src(vf18).vf.w()); lq_xyzw(c->vfs[vf22].vf, vis[vi12] + 2);
// lq.xyzw vf28, 3(vi11) | mulaz.xyzw ACC, vf19, vf18
c->acc.vf.mula_xyzw(c->vf_src(vf19).vf, c->vf_src(vf18).vf.z()); lq_xyzw(c->vfs[vf28].vf, vis[vi11] + 3);
// lq.xyzw vf23, 3(vi12) | maddw.xyzw vf21, vf21, vf18
c->acc.vf.madd_xyzw(c->vfs[vf21].vf, c->vf_src(vf21).vf, c->vf_src(vf18).vf.w()); lq_xyzw(c->vfs[vf23].vf, vis[vi12] + 3);
// lqi.xyzw vf29, vi10 | mulaz.xyzw ACC, vf27, vf18
c->acc.vf.mula_xyzw(c->vf_src(vf27).vf, c->vf_src(vf18).vf.z()); lq_xyzw(c->vfs[vf29].vf, vis[vi10]++);
// iaddiu vi01, vi00, 0x146 | maddw.xyzw vf22, vf22, vf18
c->acc.vf.madd_xyzw(c->vfs[vf22].vf, c->vf_src(vf22).vf, c->vf_src(vf18).vf.w()); vis[vi01] = 0x146; /* 326 */
// BRANCH!
// ibne vi08, vi04, L6 | mulaz.xyzw ACC, vf28, vf18
c->acc.vf.mula_xyzw(c->vf_src(vf28).vf, c->vf_src(vf18).vf.z()); bc = (vis[vi08] != vis[vi04]);
// nop | maddw.xyzw vf23, vf23, vf18
c->acc.vf.madd_xyzw(c->vfs[vf23].vf, c->vf_src(vf23).vf, c->vf_src(vf18).vf.w());
if (bc) { goto L6; }
// ior vi01, vi05, vi00 | nop
vis[vi01] = vis[vi05];
L6:
// mtir vi13, vf29.w | itof0.xyzw vf18, vf29
c->vfs[vf18].vf.itof0(Mask::xyzw, c->vf_src(vf29).vf); vis[vi13] = c->vf_src(vf29).vf.w_as_u16();
// move.xyzw vf13, vf12 | mulaz.xyzw ACC, vf24, vf08 :e
c->acc.vf.mula_xyzw(c->vf_src(vf24).vf, c->vf_src(vf08).vf.z()); c->vfs[vf13].vf.move(Mask::xyzw, c->vf_src(vf12).vf);
// move.xyzw vf12, vf11 | maddaz.xyzw ACC, vf25, vf09
c->acc.vf.madda_xyzw(c->vfs[vf25].vf, c->vfs[vf09].vf.z()); c->vfs[vf12].vf.move(Mask::xyzw, c->vf_src(vf11).vf);
return;
L7:
// nop | add.xyzw vf10, vf03, vf07
c->vfs[vf10].vf.add_xyzw(c->vf_src(vf03).vf, c->vf_src(vf07).vf);
// BRANCH!
// ibne vi08, vi04, L8 | adday.xyzw vf16, vf16
c->acc.vf.adda(Mask::xyzw, c->vfs[vf16].vf, c->vfs[vf16].vf.y()); bc = (vis[vi08] != vis[vi04]);
// nop | maddz.xyzw vf16, vf17, vf16
c->acc.vf.madd_xyzw(c->vfs[vf16].vf, c->vf_src(vf17).vf, c->vf_src(vf16).vf.z());
if (bc) { goto L8; }
// ior vi01, vi05, vi00 | nop
vis[vi01] = vis[vi05];
L8:
// move.xyzw vf13, vf12 | mulaz.xyzw ACC, vf24, vf08 :e
c->acc.vf.mula_xyzw(c->vf_src(vf24).vf, c->vf_src(vf08).vf.z()); c->vfs[vf13].vf.move(Mask::xyzw, c->vf_src(vf12).vf);
// move.xyzw vf12, vf11 | maddaz.xyzw ACC, vf25, vf09
c->acc.vf.madda_xyzw(c->vfs[vf25].vf, c->vfs[vf09].vf.z()); c->vfs[vf12].vf.move(Mask::xyzw, c->vf_src(vf11).vf);
return;
}
void vcallms_311_case_386(ExecutionContext* c, u16* vis) {
bool bc;
// mtir vi11, vf01.x | maddz.xyzw vf11, vf26, vf10
c->acc.vf.madd_xyzw(c->vfs[vf11].vf, c->vf_src(vf26).vf, c->vf_src(vf10).vf.z()); vis[vi11] = c->vf_src(vf01).vf.x_as_u16();
// jr vi01 | mul.xyzw vf14, vf13, Q
c->vfs[vf14].vf.mul_xyzw(c->vf_src(vf13).vf, c->Q);
// sqi.xyzw vf04, vi08 | mulaw.xyzw ACC, vf20, vf08
c->acc.vf.mula_xyzw(c->vf_src(vf20).vf, c->vf_src(vf08).vf.w()); sq_xyzw(c->vf_src(vf04).vf, vis[vi08]++);
// rsqrt Q, vf00.w, vf16.x | maddaw.xyzw ACC, vf21, vf09
c->acc.vf.madda_xyzw(c->vfs[vf21].vf, c->vfs[vf09].vf.w()); c->Q = c->vf_src(vf00).vf.w() / std::sqrt(c->vf_src(vf16).vf.x());
// mtir vi12, vf01.y | maddaw.xyzw ACC, vf22, vf10
c->acc.vf.madda_xyzw(c->vfs[vf22].vf, c->vfs[vf10].vf.w()); vis[vi12] = c->vf_src(vf01).vf.y_as_u16();
// iand vi11, vi11, vi09 | maddw.xyzw vf15, vf23, vf00
c->acc.vf.madd_xyzw(c->vfs[vf15].vf, c->vf_src(vf23).vf, c->vf_src(vf00).vf.w()); vis[vi11] = vis[vi11] & vis[vi09];
// lq.xyzw vf19, 4(vi11) | mul.xyzw vf16, vf11, vf11
c->vfs[vf16].vf.mul_xyzw(c->vf_src(vf11).vf, c->vf_src(vf11).vf); lq_xyzw(c->vfs[vf19].vf, vis[vi11] + 4);
// BRANCH!
// ibeq vi09, vi11, L10 | add.xyzw vf08, vf01, vf05
c->vfs[vf08].vf.add_xyzw(c->vf_src(vf01).vf, c->vf_src(vf05).vf); bc = (vis[vi09] == vis[vi11]);
// iand vi12, vi12, vi09 | add.xyzw vf09, vf02, vf06
c->vfs[vf09].vf.add_xyzw(c->vf_src(vf02).vf, c->vf_src(vf06).vf); vis[vi12] = vis[vi12] & vis[vi09];
if (bc) { goto L10; }
// nop | muly.xyzw vf18, vf18, vf17
c->vfs[vf18].vf.mul_xyzw(c->vf_src(vf18).vf, c->vf_src(vf17).vf.y());
// lq.xyzw vf27, 4(vi12) | add.xyzw vf10, vf03, vf07
c->vfs[vf10].vf.add_xyzw(c->vf_src(vf03).vf, c->vf_src(vf07).vf); lq_xyzw(c->vfs[vf27].vf, vis[vi12] + 4);
// lq.xyzw vf24, 4(vi13) | adday.xyzw vf16, vf16
c->acc.vf.adda(Mask::xyzw, c->vfs[vf16].vf, c->vfs[vf16].vf.y()); lq_xyzw(c->vfs[vf24].vf, vis[vi13] + 4);
// lq.xyzw vf28, 5(vi11) | maddz.xyzw vf16, vf17, vf16
c->acc.vf.madd_xyzw(c->vfs[vf16].vf, c->vf_src(vf17).vf, c->vf_src(vf16).vf.z()); lq_xyzw(c->vfs[vf28].vf, vis[vi11] + 5);
// lq.xyzw vf19, 5(vi12) | mulax.xyzw ACC, vf19, vf18
c->acc.vf.mula_xyzw(c->vf_src(vf19).vf, c->vf_src(vf18).vf.x()); lq_xyzw(c->vfs[vf19].vf, vis[vi12] + 5);
// lq.xyzw vf25, 5(vi13) | madday.xyzw ACC, vf27, vf18
c->acc.vf.madda_xyzw(c->vfs[vf27].vf, c->vfs[vf18].vf.y()); lq_xyzw(c->vfs[vf25].vf, vis[vi13] + 5);
// lq.xyzw vf27, 6(vi11) | maddz.xyzw vf24, vf24, vf18
c->acc.vf.madd_xyzw(c->vfs[vf24].vf, c->vf_src(vf24).vf, c->vf_src(vf18).vf.z()); lq_xyzw(c->vfs[vf27].vf, vis[vi11] + 6);
// lq.xyzw vf28, 6(vi12) | mulax.xyzw ACC, vf28, vf18
c->acc.vf.mula_xyzw(c->vf_src(vf28).vf, c->vf_src(vf18).vf.x()); lq_xyzw(c->vfs[vf28].vf, vis[vi12] + 6);
// lq.xyzw vf26, 6(vi13) | madday.xyzw ACC, vf19, vf18
c->acc.vf.madda_xyzw(c->vfs[vf19].vf, c->vfs[vf18].vf.y()); lq_xyzw(c->vfs[vf26].vf, vis[vi13] + 6);
// lq.xyzw vf19, 0(vi11) | maddz.xyzw vf25, vf25, vf18
c->acc.vf.madd_xyzw(c->vfs[vf25].vf, c->vf_src(vf25).vf, c->vf_src(vf18).vf.z()); lq_xyzw(c->vfs[vf19].vf, vis[vi11]);
// lq.xyzw vf27, 0(vi12) | mulax.xyzw ACC, vf27, vf18
c->acc.vf.mula_xyzw(c->vf_src(vf27).vf, c->vf_src(vf18).vf.x()); lq_xyzw(c->vfs[vf27].vf, vis[vi12]);
// lq.xyzw vf20, 0(vi13) | madday.xyzw ACC, vf28, vf18
c->acc.vf.madda_xyzw(c->vfs[vf28].vf, c->vfs[vf18].vf.y()); lq_xyzw(c->vfs[vf20].vf, vis[vi13]);
// lq.xyzw vf28, 1(vi11) | maddz.xyzw vf26, vf26, vf18
c->acc.vf.madd_xyzw(c->vfs[vf26].vf, c->vf_src(vf26).vf, c->vf_src(vf18).vf.z()); lq_xyzw(c->vfs[vf28].vf, vis[vi11] + 1);
// lq.xyzw vf19, 1(vi12) | mulax.xyzw ACC, vf19, vf18
c->acc.vf.mula_xyzw(c->vf_src(vf19).vf, c->vf_src(vf18).vf.x()); lq_xyzw(c->vfs[vf19].vf, vis[vi12] + 1);
// lq.xyzw vf21, 1(vi13) | madday.xyzw ACC, vf27, vf18
c->acc.vf.madda_xyzw(c->vfs[vf27].vf, c->vfs[vf18].vf.y()); lq_xyzw(c->vfs[vf21].vf, vis[vi13] + 1);
// lq.xyzw vf27, 2(vi11) | maddz.xyzw vf20, vf20, vf18
c->acc.vf.madd_xyzw(c->vfs[vf20].vf, c->vf_src(vf20).vf, c->vf_src(vf18).vf.z()); lq_xyzw(c->vfs[vf27].vf, vis[vi11] + 2);
// lq.xyzw vf28, 2(vi12) | mulax.xyzw ACC, vf28, vf18
c->acc.vf.mula_xyzw(c->vf_src(vf28).vf, c->vf_src(vf18).vf.x()); lq_xyzw(c->vfs[vf28].vf, vis[vi12] + 2);
// lq.xyzw vf22, 2(vi13) | madday.xyzw ACC, vf19, vf18
c->acc.vf.madda_xyzw(c->vfs[vf19].vf, c->vfs[vf18].vf.y()); lq_xyzw(c->vfs[vf22].vf, vis[vi13] + 2);
// lq.xyzw vf19, 3(vi11) | maddz.xyzw vf21, vf21, vf18
c->acc.vf.madd_xyzw(c->vfs[vf21].vf, c->vf_src(vf21).vf, c->vf_src(vf18).vf.z()); lq_xyzw(c->vfs[vf19].vf, vis[vi11] + 3);
// lq.xyzw vf27, 3(vi12) | mulax.xyzw ACC, vf27, vf18
c->acc.vf.mula_xyzw(c->vf_src(vf27).vf, c->vf_src(vf18).vf.x()); lq_xyzw(c->vfs[vf27].vf, vis[vi12] + 3);
// lq.xyzw vf23, 3(vi13) | madday.xyzw ACC, vf28, vf18
c->acc.vf.madda_xyzw(c->vfs[vf28].vf, c->vfs[vf18].vf.y()); lq_xyzw(c->vfs[vf23].vf, vis[vi13] + 3);
// lqi.xyzw vf29, vi10 | maddz.xyzw vf22, vf22, vf18
c->acc.vf.madd_xyzw(c->vfs[vf22].vf, c->vf_src(vf22).vf, c->vf_src(vf18).vf.z()); lq_xyzw(c->vfs[vf29].vf, vis[vi10]++);
// BRANCH!
// ibne vi08, vi06, L9 | mulax.xyzw ACC, vf19, vf18
c->acc.vf.mula_xyzw(c->vf_src(vf19).vf, c->vf_src(vf18).vf.x()); bc = (vis[vi08] != vis[vi06]);
// nop | madday.xyzw ACC, vf27, vf18
c->acc.vf.madda_xyzw(c->vfs[vf27].vf, c->vfs[vf18].vf.y());
if (bc) { goto L9; }
// iaddiu vi01, vi00, 0x1ab | nop
vis[vi01] = 0x1ab; /* 427 */
L9:
// nop | maddz.xyzw vf23, vf23, vf18
c->acc.vf.madd_xyzw(c->vfs[vf23].vf, c->vf_src(vf23).vf, c->vf_src(vf18).vf.z());
// mtir vi13, vf29.w | itof0.xyz vf18, vf29
c->vfs[vf18].vf.itof0(Mask::xyz, c->vf_src(vf29).vf); vis[vi13] = c->vf_src(vf29).vf.w_as_u16();
// move.xyzw vf13, vf12 | mulaz.xyzw ACC, vf24, vf08 :e
c->acc.vf.mula_xyzw(c->vf_src(vf24).vf, c->vf_src(vf08).vf.z()); c->vfs[vf13].vf.move(Mask::xyzw, c->vf_src(vf12).vf);
// move.xyzw vf12, vf11 | maddaz.xyzw ACC, vf25, vf09
c->acc.vf.madda_xyzw(c->vfs[vf25].vf, c->vfs[vf09].vf.z()); c->vfs[vf12].vf.move(Mask::xyzw, c->vf_src(vf11).vf);
return;
L10:
// nop | add.xyzw vf10, vf03, vf07
c->vfs[vf10].vf.add_xyzw(c->vf_src(vf03).vf, c->vf_src(vf07).vf);
// BRANCH!
// ibne vi08, vi06, L11 | adday.xyzw vf16, vf16
c->acc.vf.adda(Mask::xyzw, c->vfs[vf16].vf, c->vfs[vf16].vf.y()); bc = (vis[vi08] != vis[vi06]);
// nop | maddz.xyzw vf16, vf17, vf16
c->acc.vf.madd_xyzw(c->vfs[vf16].vf, c->vf_src(vf17).vf, c->vf_src(vf16).vf.z());
if (bc) { goto L11; }
// iaddiu vi01, vi00, 0x1ab | nop
vis[vi01] = 0x1ab; /* 427 */
L11:
// move.xyzw vf13, vf12 | mulaz.xyzw ACC, vf24, vf08 :e
c->acc.vf.mula_xyzw(c->vf_src(vf24).vf, c->vf_src(vf08).vf.z()); c->vfs[vf13].vf.move(Mask::xyzw, c->vf_src(vf12).vf);
// move.xyzw vf12, vf11 | maddaz.xyzw ACC, vf25, vf09
c->acc.vf.madda_xyzw(c->vfs[vf25].vf, c->vfs[vf09].vf.z()); c->vfs[vf12].vf.move(Mask::xyzw, c->vf_src(vf11).vf);
return;
}
void vcallms_311_case_427(ExecutionContext* c, u16* vis) {
// mtir vi11, vf01.x | maddz.xyzw vf11, vf26, vf10
c->acc.vf.madd_xyzw(c->vfs[vf11].vf, c->vf_src(vf26).vf, c->vf_src(vf10).vf.z()); vis[vi11] = c->vf_src(vf01).vf.x_as_u16();
// jr vi01 | mul.xyzw vf14, vf13, Q
c->vfs[vf14].vf.mul_xyzw(c->vf_src(vf13).vf, c->Q);
// sqi.xyzw vf04, vi08 | mulaw.xyzw ACC, vf20, vf08
c->acc.vf.mula_xyzw(c->vf_src(vf20).vf, c->vf_src(vf08).vf.w()); sq_xyzw(c->vf_src(vf04).vf, vis[vi08]++);
c->acc.vf.madda_xyzw(c->vfs[vf21].vf, c->vfs[vf09].vf.w()); c->Q = c->vf_src(vf00).vf.w() / std::sqrt(c->vf_src(vf16).vf.x());
// nop | maddaw.xyzw ACC, vf22, vf10
c->acc.vf.madda_xyzw(c->vfs[vf22].vf, c->vfs[vf10].vf.w());
// nop | maddw.xyzw vf15, vf23, vf00
c->acc.vf.madd_xyzw(c->vfs[vf15].vf, c->vf_src(vf23).vf, c->vf_src(vf00).vf.w());
// nop | mul.xyzw vf16, vf11, vf11
c->vfs[vf16].vf.mul_xyzw(c->vf_src(vf11).vf, c->vf_src(vf11).vf);
// nop | add.xyzw vf08, vf01, vf05
c->vfs[vf08].vf.add_xyzw(c->vf_src(vf01).vf, c->vf_src(vf05).vf);
// nop | add.xyzw vf09, vf02, vf06
c->vfs[vf09].vf.add_xyzw(c->vf_src(vf02).vf, c->vf_src(vf06).vf);
// nop | add.xyzw vf10, vf03, vf07
c->vfs[vf10].vf.add_xyzw(c->vf_src(vf03).vf, c->vf_src(vf07).vf);
// nop | adday.xyzw vf16, vf16
c->acc.vf.adda(Mask::xyzw, c->vfs[vf16].vf, c->vfs[vf16].vf.y());
// nop | maddz.xyzw vf16, vf17, vf16
c->acc.vf.madd_xyzw(c->vfs[vf16].vf, c->vf_src(vf17).vf, c->vf_src(vf16).vf.z());
// move.xyzw vf13, vf12 | mulaz.xyzw ACC, vf24, vf08 :e
c->acc.vf.mula_xyzw(c->vf_src(vf24).vf, c->vf_src(vf08).vf.z()); c->vfs[vf13].vf.move(Mask::xyzw, c->vf_src(vf12).vf);
// move.xyzw vf12, vf11 | maddaz.xyzw ACC, vf25, vf09
c->acc.vf.madda_xyzw(c->vfs[vf25].vf, c->vfs[vf09].vf.z()); c->vfs[vf12].vf.move(Mask::xyzw, c->vf_src(vf11).vf);
return;
}
void vcallms_311(ExecutionContext* c, u16* vis) {
switch(vis[vi01]) {
case 314:
vcallms_311_case_314(c, vis);
break;
case 326:
vcallms_311_case_326(c, vis);
break;
case 353:
vcallms_311_case_353(c, vis);
break;
case 386:
vcallms_311_case_386(c, vis);
break;
case 427:
vcallms_311_case_427(c, vis);
break;
default:
ASSERT_MSG(false, fmt::format("BAD JUMP {}", vis[vi01]));
}
}
u64 execute(void* ctxt) {
auto* c = (ExecutionContext*)ctxt;
bool bc = false;
u16 vis[16];
get_fake_spad_addr2(at, cache.fake_scratchpad_data, 0, c);// lui at, 28672
c->sq(s0, 7536, at); // sq s0, 7536(at)
c->sq(s1, 7552, at); // sq s1, 7552(at)
c->sq(s2, 7568, at); // sq s2, 7568(at)
c->sq(s3, 7584, at); // sq s3, 7584(at)
c->sq(s4, 7600, at); // sq s4, 7600(at)
c->sq(s5, 7616, at); // sq s5, 7616(at)
c->sq(s6, 7632, at); // sq s6, 7632(at)
c->sq(t8, 7648, at); // sq t8, 7648(at)
c->sq(t9, 7664, at); // sq t9, 7664(at)
c->sq(gp, 7680, at); // sq gp, 7680(at)
c->sq(sp, 7696, at); // sq sp, 7696(at)
c->sq(fp, 7712, at); // sq fp, 7712(at)
c->sq(ra, 7728, at); // sq ra, 7728(at)
// nop // sll r0, r0, 0
get_fake_spad_addr2(t2, cache.fake_scratchpad_data, 0, c);// lui t2, 28672
c->addiu(a0, r0, 0); // addiu a0, r0, 0
c->lbu(a1, 6955, t2); // lbu a1, 6955(t2)
c->addiu(a2, r0, 4); // addiu a2, r0, 4
c->lw(t0, 7444, t2); // lw t0, 7444(t2)
c->addiu(a3, r0, 1); // addiu a3, r0, 1
c->lw(v1, 7448, t2); // lw v1, 7448(t2)
c->and_(a3, a1, a3); // and a3, a1, a3
c->lw(a1, 24, t2); // lw a1, 24(t2)
c->movn(a0, a2, a3); // movn a0, a2, a3
c->lbu(a3, 6855, t2); // lbu a3, 6855(t2)
c->daddu(t1, a0, t2); // daddu t1, a0, t2
c->lbu(t3, 6852, t2); // lbu t3, 6852(t2)
c->daddiu(a2, a1, 128); // daddiu a2, a1, 128
c->lw(a0, 7428, t2); // lw a0, 7428(t2)
c->dsll(t4, a3, 3); // dsll t4, a3, 3
// nop // sll r0, r0, 0
c->andi(t3, t3, 1); // andi t3, t3, 1
c->lbu(a3, 10, t0); // lbu a3, 10(t0)
c->dsll(t5, t3, 1); // dsll t5, t3, 1
c->lbu(t3, 9, t0); // lbu t3, 9(t0)
c->daddu(t1, t1, t5); // daddu t1, t1, t5
// nop // sll r0, r0, 0
c->daddu(t4, t1, t4); // daddu t4, t1, t4
c->lbu(t1, 11953, t4); // lbu t1, 11953(t4)
// nop // sll r0, r0, 0
c->lbu(t5, 11952, t4); // lbu t5, 11952(t4)
// nop // sll r0, r0, 0
c->lw(t4, 7432, t2); // lw t4, 7432(t2)
c->sll(t6, a3, 4); // sll t6, a3, 4
c->daddu(t5, t5, t2); // daddu t5, t5, t2
c->daddu(t7, t1, t2); // daddu t7, t1, t2
c->lw(a3, 7436, t2); // lw a3, 7436(t2)
c->daddu(t1, t6, t0); // daddu t1, t6, t0
c->sw(t1, 7452, t2); // sw t1, 7452(t2)
// nop // sll r0, r0, 0
c->lbu(t0, 12, t1); // lbu t0, 12(t1)
// nop // sll r0, r0, 0
c->lq(t7, 11888, t7); // lq t7, 11888(t7)
// nop // sll r0, r0, 0
c->lq(s0, 11888, t5); // lq s0, 11888(t5)
// nop // sll r0, r0, 0
c->sq(t7, 96, a1); // sq t7, 96(a1)
c->daddiu(t5, v1, 5504); // daddiu t5, v1, 5504
c->sq(s0, 112, a1); // sq s0, 112(a1)
c->daddiu(v1, v1, 6048); // daddiu v1, v1, 6048
c->lbu(ra, 6857, t2); // lbu ra, 6857(t2)
c->movn(v1, t5, t3); // movn v1, t5, t3
c->sw(r0, 124, a1); // sw r0, 124(a1)
// nop // sll r0, r0, 0
c->lq(t7, 11744, t2); // lq t7, 11744(t2)
c->daddiu(t6, t1, 16); // daddiu t6, t1, 16
c->lq(s0, 11808, t2); // lq s0, 11808(t2)
c->addiu(t9, r0, 0); // addiu t9, r0, 0
c->lq(s4, 11824, t2); // lq s4, 11824(t2)
c->addiu(t5, r0, 0); // addiu t5, r0, 0
c->lq(gp, 11840, t2); // lq gp, 11840(t2)
c->addiu(t1, r0, -3); // addiu t1, r0, -3
c->lq(s5, 11856, t2); // lq s5, 11856(t2)
c->addiu(t8, r0, 6); // addiu t8, r0, 6
c->lq(t2, 11872, t2); // lq t2, 11872(t2)
c->andi(s3, ra, 4); // andi s3, ra, 4
c->sq(t7, 0, a1); // sq t7, 0(a1)
c->movz(t8, r0, t3); // movz t8, r0, t3
c->sq(s0, 16, a1); // sq s0, 16(a1)
c->addiu(ra, r0, 0); // addiu ra, r0, 0
c->sq(s4, 32, a1); // sq s4, 32(a1)
c->addiu(t7, r0, -32768); // addiu t7, r0, -32768
c->sq(gp, 48, a1); // sq gp, 48(a1)
c->movz(ra, t7, t0); // movz ra, t7, t0
c->sq(s5, 64, a1); // sq s5, 64(a1)
c->dsll(t7, s3, 18); // dsll t7, s3, 18
c->pextlw(t7, t7, t7); // pextlw t7, t7, t7
c->mfc1(r0, f31); // mfc1 r0, f31
// Unknown instr: pnor t7, r0, t7
c->mfc1(r0, f31); // mfc1 r0, f31
c->pand(t2, t2, t7); // pand t2, t2, t7
c->mfc1(r0, f31); // mfc1 r0, f31
bc = c->sgpr64(t3) == 0; // beq t3, r0, L87
c->sq(t2, 80, a1); // sq t2, 80(a1)
if (bc) {goto block_4;} // branch non-likely
c->lq(t7, 2944, t4); // lq t7, 2944(t4)
c->daddu(ra, t3, ra); // daddu ra, t3, ra
c->lq(s0, 2960, t4); // lq s0, 2960(t4)
c->addiu(gp, r0, -6); // addiu gp, r0, -6
c->lq(t3, 2976, t4); // lq t3, 2976(t4)
c->daddiu(t0, t0, 1); // daddiu t0, t0, 1
c->lq(t2, 2992, t4); // lq t2, 2992(t4)
c->daddiu(s5, t0, -3); // daddiu s5, t0, -3
bc = ((s64)c->sgpr64(s5)) <= 0; // blez s5, L89
c->lq(t4, 3008, t4); // lq t4, 3008(t4)
if (bc) {goto block_8;} // branch non-likely
c->daddiu(t9, t0, -5); // daddiu t9, t0, -5
// nop // sll r0, r0, 0
bc = ((s64)c->sgpr64(t9)) <= 0; // blez t9, L89
c->lh(t9, 172, t6); // lh t9, 172(t6)
if (bc) {goto block_8;} // branch non-likely
//beq r0, r0, L89 // beq r0, r0, L89
c->lh(t5, 332, t6); // lh t5, 332(t6)
goto block_8; // branch always
block_4:
c->daddiu(t2, t0, -3); // daddiu t2, t0, -3
// nop // sll r0, r0, 0
bc = ((s64)c->sgpr64(t2)) <= 0; // blez t2, L88
c->daddiu(t2, t0, -5); // daddiu t2, t0, -5
if (bc) {goto block_7;} // branch non-likely
bc = ((s64)c->sgpr64(t2)) <= 0; // blez t2, L88
c->lh(t9, 252, t6); // lh t9, 252(t6)
if (bc) {goto block_7;} // branch non-likely
// nop // sll r0, r0, 0
c->lh(t5, 412, t6); // lh t5, 412(t6)
block_7:
c->lh(gp, 12, t6); // lh gp, 12(t6)
// nop // sll r0, r0, 0
c->lh(ra, 28, t6); // lh ra, 28(t6)
// nop // sll r0, r0, 0
c->lq(t7, 0, t6); // lq t7, 0(t6)
// nop // sll r0, r0, 0
c->lq(s0, 16, t6); // lq s0, 16(t6)
// nop // sll r0, r0, 0
c->lq(t3, 32, t6); // lq t3, 32(t6)
// nop // sll r0, r0, 0
c->lq(t2, 48, t6); // lq t2, 48(t6)
// nop // sll r0, r0, 0
c->lq(t4, 64, t6); // lq t4, 64(t6)
c->daddiu(t6, t6, 80); // daddiu t6, t6, 80
block_8:
c->sq(t7, 0, a2); // sq t7, 0(a2)
c->daddu(gp, gp, t8); // daddu gp, gp, t8
c->sq(s0, 16, a2); // sq s0, 16(a2)
c->daddiu(t8, t8, 2); // daddiu t8, t8, 2
c->sq(t3, 32, a2); // sq t3, 32(a2)
c->daddu(t1, t1, ra); // daddu t1, t1, ra
c->sq(t2, 48, a2); // sq t2, 48(a2)
c->daddiu(t1, t1, 3); // daddiu t1, t1, 3
c->sq(t4, 64, a2); // sq t4, 64(a2)
c->andi(t1, t1, 255); // andi t1, t1, 255
c->sw(gp, 12, a2); // sw gp, 12(a2)
c->daddiu(a2, a2, 80); // daddiu a2, a2, 80
bc = ((s64)c->sgpr64(ra)) > 0; // bgtz ra, L88
c->sw(ra, -52, a2); // sw ra, -52(a2)
if (bc) {goto block_7;} // branch non-likely
c->sw(t1, 108, a1); // sw t1, 108(a1)
c->daddiu(a1, t9, 7); // daddiu a1, t9, 7
c->sq(t7, 2944, a0); // sq t7, 2944(a0)
c->daddiu(t5, t5, 7); // daddiu t5, t5, 7
c->sq(s0, 2960, a0); // sq s0, 2960(a0)
c->sra(a2, a1, 4); // sra a2, a1, 4
c->sq(t3, 2976, a0); // sq t3, 2976(a0)
c->sra(t3, t5, 4); // sra t3, t5, 4
c->sq(t2, 2992, a0); // sq t2, 2992(a0)
c->daddiu(a1, a3, 192); // daddiu a1, a3, 192
c->sq(t4, 3008, a0); // sq t4, 3008(a0)
c->dsll(a0, t0, 2); // dsll a0, t0, 2
c->sh(t1, 18, a3); // sh t1, 18(a3)
c->daddu(a0, a0, t0); // daddu a0, a0, t0
c->sb(t0, 16, a3); // sb t0, 16(a3)
c->daddiu(a0, a0, 7); // daddiu a0, a0, 7
c->dsubu(a0, t3, a2); // dsubu a0, t3, a2
c->lq(t0, 0, v1); // lq t0, 0(v1)
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
c->daddiu(t1, a2, -3); // daddiu t1, a2, -3
c->lq(a3, 16, v1); // lq a3, 16(v1)
// nop // sll r0, r0, 0
c->sq(t0, 0, a1); // sq t0, 0(a1)
bc = c->sgpr64(t1) == 0; // beq t1, r0, L90
c->lq(a2, 32, v1); // lq a2, 32(v1)
if (bc) {goto block_21;} // branch non-likely
c->daddiu(t0, t1, -1); // daddiu t0, t1, -1
c->sq(a3, 16, a1); // sq a3, 16(a1)
bc = c->sgpr64(t0) == 0; // beq t0, r0, L91
c->lq(a3, 48, v1); // lq a3, 48(v1)
if (bc) {goto block_22;} // branch non-likely
c->daddiu(t0, t0, -1); // daddiu t0, t0, -1
c->sq(a2, 32, a1); // sq a2, 32(a1)
bc = c->sgpr64(t0) == 0; // beq t0, r0, L92
c->lq(a2, 64, v1); // lq a2, 64(v1)
if (bc) {goto block_23;} // branch non-likely
c->daddiu(t0, t0, -1); // daddiu t0, t0, -1
c->sq(a3, 48, a1); // sq a3, 48(a1)
bc = c->sgpr64(t0) == 0; // beq t0, r0, L93
c->lq(a3, 80, v1); // lq a3, 80(v1)
if (bc) {goto block_24;} // branch non-likely
c->daddiu(t0, t0, -1); // daddiu t0, t0, -1
c->sq(a2, 64, a1); // sq a2, 64(a1)
bc = c->sgpr64(t0) == 0; // beq t0, r0, L94
c->lq(a2, 96, v1); // lq a2, 96(v1)
if (bc) {goto block_25;} // branch non-likely
c->daddiu(t0, t0, -1); // daddiu t0, t0, -1
c->sq(a3, 80, a1); // sq a3, 80(a1)
bc = c->sgpr64(t0) == 0; // beq t0, r0, L95
c->lq(a3, 112, v1); // lq a3, 112(v1)
if (bc) {goto block_26;} // branch non-likely
c->daddiu(t0, t0, -1); // daddiu t0, t0, -1
c->sq(a2, 96, a1); // sq a2, 96(a1)
bc = c->sgpr64(t0) == 0; // beq t0, r0, L96
c->lq(a2, 128, v1); // lq a2, 128(v1)
if (bc) {goto block_27;} // branch non-likely
c->daddiu(t0, t0, -1); // daddiu t0, t0, -1
c->sq(a3, 112, a1); // sq a3, 112(a1)
bc = c->sgpr64(t0) == 0; // beq t0, r0, L97
c->lq(a3, 144, v1); // lq a3, 144(v1)
if (bc) {goto block_28;} // branch non-likely
c->daddiu(t0, t0, -1); // daddiu t0, t0, -1
c->sq(a2, 128, a1); // sq a2, 128(a1)
bc = c->sgpr64(t0) == 0; // beq t0, r0, L98
c->lq(a2, 160, v1); // lq a2, 160(v1)
if (bc) {goto block_29;} // branch non-likely
c->daddiu(t0, t0, -1); // daddiu t0, t0, -1
c->sq(a3, 144, a1); // sq a3, 144(a1)
bc = c->sgpr64(t0) == 0; // beq t0, r0, L99
c->lq(a3, 176, v1); // lq a3, 176(v1)
if (bc) {goto block_30;} // branch non-likely
c->daddiu(a0, t0, -1); // daddiu a0, t0, -1
c->sq(a2, 160, a1); // sq a2, 160(a1)
bc = c->sgpr64(a0) == 0; // beq a0, r0, L100
c->lq(a0, 192, v1); // lq a0, 192(v1)
if (bc) {goto block_31;} // branch non-likely
// nop // sll r0, r0, 0
c->sq(a3, 176, a1); // sq a3, 176(a1)
// nop // sll r0, r0, 0
c->lq(v1, 208, v1); // lq v1, 208(v1)
// nop // sll r0, r0, 0
c->sq(a0, 192, a1); // sq a0, 192(a1)
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
c->sq(v1, 208, a1); // sq v1, 208(a1)
//beq r0, r0, L110 // beq r0, r0, L110
// nop // sll r0, r0, 0
goto block_41; // branch always
block_21:
c->daddiu(a0, a0, -1); // daddiu a0, a0, -1
c->sq(a3, 16, a1); // sq a3, 16(a1)
// nop // sll r0, r0, 0
c->lq(a3, 224, v1); // lq a3, 224(v1)
block_22:
c->daddiu(a0, a0, -1); // daddiu a0, a0, -1
c->sq(a2, 32, a1); // sq a2, 32(a1)
bc = c->sgpr64(a0) == 0; // beq a0, r0, L101
c->lq(a2, 240, v1); // lq a2, 240(v1)
if (bc) {goto block_32;} // branch non-likely
block_23:
c->daddiu(a0, a0, -1); // daddiu a0, a0, -1
c->sq(a3, 48, a1); // sq a3, 48(a1)
bc = c->sgpr64(a0) == 0; // beq a0, r0, L102
c->lq(a3, 256, v1); // lq a3, 256(v1)
if (bc) {goto block_33;} // branch non-likely
block_24:
c->daddiu(a0, a0, -1); // daddiu a0, a0, -1
c->sq(a2, 64, a1); // sq a2, 64(a1)
bc = c->sgpr64(a0) == 0; // beq a0, r0, L103
c->lq(a2, 272, v1); // lq a2, 272(v1)
if (bc) {goto block_34;} // branch non-likely
block_25:
c->daddiu(a0, a0, -1); // daddiu a0, a0, -1
c->sq(a3, 80, a1); // sq a3, 80(a1)
bc = c->sgpr64(a0) == 0; // beq a0, r0, L104
c->lq(a3, 288, v1); // lq a3, 288(v1)
if (bc) {goto block_35;} // branch non-likely
block_26:
c->daddiu(a0, a0, -1); // daddiu a0, a0, -1
c->sq(a2, 96, a1); // sq a2, 96(a1)
bc = c->sgpr64(a0) == 0; // beq a0, r0, L105
c->lq(a2, 304, v1); // lq a2, 304(v1)
if (bc) {goto block_36;} // branch non-likely
block_27:
c->daddiu(a0, a0, -1); // daddiu a0, a0, -1
c->sq(a3, 112, a1); // sq a3, 112(a1)
bc = c->sgpr64(a0) == 0; // beq a0, r0, L106
c->lq(a3, 320, v1); // lq a3, 320(v1)
if (bc) {goto block_37;} // branch non-likely
block_28:
c->daddiu(a0, a0, -1); // daddiu a0, a0, -1
c->sq(a2, 128, a1); // sq a2, 128(a1)
bc = c->sgpr64(a0) == 0; // beq a0, r0, L107
c->lq(a2, 336, v1); // lq a2, 336(v1)
if (bc) {goto block_38;} // branch non-likely
block_29:
c->daddiu(a0, a0, -1); // daddiu a0, a0, -1
c->sq(a3, 144, a1); // sq a3, 144(a1)
bc = c->sgpr64(a0) == 0; // beq a0, r0, L108
c->lq(a3, 352, v1); // lq a3, 352(v1)
if (bc) {goto block_39;} // branch non-likely
block_30:
c->daddiu(a0, a0, -1); // daddiu a0, a0, -1
c->sq(a2, 160, a1); // sq a2, 160(a1)
bc = c->sgpr64(a0) == 0; // beq a0, r0, L109
c->lq(a0, 368, v1); // lq a0, 368(v1)
if (bc) {goto block_40;} // branch non-likely
block_31:
// nop // sll r0, r0, 0
c->sq(a3, 176, a1); // sq a3, 176(a1)
// nop // sll r0, r0, 0
c->lq(v1, 384, v1); // lq v1, 384(v1)
// nop // sll r0, r0, 0
c->sq(a0, 192, a1); // sq a0, 192(a1)
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
c->sq(v1, 208, a1); // sq v1, 208(a1)
//beq r0, r0, L110 // beq r0, r0, L110
// nop // sll r0, r0, 0
goto block_41; // branch always
block_32:
// nop // sll r0, r0, 0
c->sq(a3, 48, a1); // sq a3, 48(a1)
// nop // sll r0, r0, 0
c->lq(a3, 400, v1); // lq a3, 400(v1)
block_33:
// nop // sll r0, r0, 0
c->sq(a2, 64, a1); // sq a2, 64(a1)
// nop // sll r0, r0, 0
c->lq(a2, 416, v1); // lq a2, 416(v1)
block_34:
// nop // sll r0, r0, 0
c->sq(a3, 80, a1); // sq a3, 80(a1)
// nop // sll r0, r0, 0
c->lq(a3, 432, v1); // lq a3, 432(v1)
block_35:
// nop // sll r0, r0, 0
c->sq(a2, 96, a1); // sq a2, 96(a1)
// nop // sll r0, r0, 0
c->lq(a2, 448, v1); // lq a2, 448(v1)
block_36:
// nop // sll r0, r0, 0
c->sq(a3, 112, a1); // sq a3, 112(a1)
// nop // sll r0, r0, 0
c->lq(a3, 464, v1); // lq a3, 464(v1)
block_37:
// nop // sll r0, r0, 0
c->sq(a2, 128, a1); // sq a2, 128(a1)
// nop // sll r0, r0, 0
c->lq(a2, 480, v1); // lq a2, 480(v1)
block_38:
// nop // sll r0, r0, 0
c->sq(a3, 144, a1); // sq a3, 144(a1)
// nop // sll r0, r0, 0
c->lq(a3, 496, v1); // lq a3, 496(v1)
block_39:
// nop // sll r0, r0, 0
c->sq(a2, 160, a1); // sq a2, 160(a1)
// nop // sll r0, r0, 0
c->lq(a0, 512, v1); // lq a0, 512(v1)
block_40:
// nop // sll r0, r0, 0
c->sq(a3, 176, a1); // sq a3, 176(a1)
// nop // sll r0, r0, 0
c->lq(v1, 528, v1); // lq v1, 528(v1)
// nop // sll r0, r0, 0
c->sq(a0, 192, a1); // sq a0, 192(a1)
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
c->sq(v1, 208, a1); // sq v1, 208(a1)
block_41:
get_fake_spad_addr2(v1, cache.fake_scratchpad_data, 0, c);// lui v1, 28672
// nop // sll r0, r0, 0
c->lw(a1, 7452, v1); // lw a1, 7452(v1)
// nop // sll r0, r0, 0
c->lw(a0, 7436, v1); // lw a0, 7436(v1)
// nop // sll r0, r0, 0
c->lbu(a2, 13, a1); // lbu a2, 13(a1)
// nop // sll r0, r0, 0
c->lbu(v1, 14, a1); // lbu v1, 14(a1)
c->daddiu(a0, a0, 32); // daddiu a0, a0, 32
c->lbu(a3, 15, a1); // lbu a3, 15(a1)
c->daddu(a1, a1, a2); // daddu a1, a1, a2
c->mult3(a3, v1, a3); // mult3 a3, v1, a3
c->mov64(a1, a1); // or a1, a1, r0
c->mov64(v1, v1); // or v1, v1, r0
c->mov64(a0, a0); // or a0, a0, r0
c->addiu(a2, r0, 513); // addiu a2, r0, 513
c->addiu(t0, r0, 257); // addiu t0, r0, 257
c->dsll(t2, a2, 18); // dsll t2, a2, 18
c->dsll(t1, t0, 16); // dsll t1, t0, 16
c->or_(a2, a2, t2); // or a2, a2, t2
c->or_(t0, t0, t1); // or t0, t0, t1
c->dsll32(t2, a2, 4); // dsll32 t2, a2, 4
c->dsll32(t1, t0, 0); // dsll32 t1, t0, 0
c->or_(a2, a2, t2); // or a2, a2, t2
c->or_(t0, t0, t1); // or t0, t0, t1
c->pcpyld(a2, a2, a2); // pcpyld a2, a2, a2
c->mfc1(r0, f31); // mfc1 r0, f31
c->pcpyld(t0, t0, t0); // pcpyld t0, t0, t0
c->mfc1(r0, f31); // mfc1 r0, f31
c->daddu(a3, a3, a1); // daddu a3, a3, a1
c->mfc1(r0, f31); // mfc1 r0, f31
c->lhu(t1, 0, a1); // lhu t1, 0(a1)
c->daddu(a1, a1, v1); // daddu a1, a1, v1
// nop // sll r0, r0, 0
c->mfc1(r0, f31); // mfc1 r0, f31
// nop // sll r0, r0, 0
c->pextlb(t1, t1, t1); // pextlb t1, t1, t1
//beq r0, r0, L112 // beq r0, r0, L112
c->pextlb(t2, t1, t1); // pextlb t2, t1, t1
goto block_43; // branch always
block_42:
c->daddu(a1, a1, v1); // daddu a1, a1, v1
c->daddiu(a0, a0, 32); // daddiu a0, a0, 32
c->pextlb(t2, t2, t2); // pextlb t2, t2, t2
c->sq(t1, -16, a0); // sq t1, -16(a0)
block_43:
c->pextlb(t1, t2, t2); // pextlb t1, t2, t2
c->mfc1(r0, f31); // mfc1 r0, f31
c->pand(t1, t1, a2); // pand t1, t1, a2
c->mfc1(r0, f31); // mfc1 r0, f31
c->pceqb(t1, t1, a2); // pceqb t1, t1, a2
c->mfc1(r0, f31); // mfc1 r0, f31
c->pand(t1, t1, t0); // pand t1, t1, t0
c->mfc1(r0, f31); // mfc1 r0, f31
c->pextlb(t2, t1, r0); // pextlb t2, t1, r0
c->lhu(t3, 0, a1); // lhu t3, 0(a1)
c->pextub(t1, t1, r0); // pextub t1, t1, r0
c->sq(t2, 0, a0); // sq t2, 0(a0)
bc = c->sgpr64(a1) != c->sgpr64(a3); // bne a1, a3, L111
c->pextlb(t2, t3, t3); // pextlb t2, t3, t3
if (bc) {goto block_42;} // branch non-likely
// nop // sll r0, r0, 0
c->sq(t1, 16, a0); // sq t1, 16(a0)
get_fake_spad_addr2(s4, cache.fake_scratchpad_data, 0, c);// lui s4, 28672
// nop // sll r0, r0, 0
c->lw(a0, 7444, s4); // lw a0, 7444(s4)
// nop // sll r0, r0, 0
c->lw(a1, 7436, s4); // lw a1, 7436(s4)
// nop // sll r0, r0, 0
c->lq(t8, 16, a0); // lq t8, 16(a0)
c->daddiu(s6, a0, 48); // daddiu s6, a0, 48
c->lbu(a3, 12, a0); // lbu a3, 12(a0)
// nop // sll r0, r0, 0
c->lbu(t2, 10, a0); // lbu t2, 10(a0)
c->pextlb(t9, r0, t8); // pextlb t9, r0, t8
vis[10] = c->gpr_src(a3).du16[0]; // ctc2.ni vi10, a3
c->pextlh(gp, r0, t9); // pextlh gp, r0, t9
c->mov128_vf_gpr(vf1, gp); // qmtc2.ni vf1, gp
c->pextuh(t9, r0, t9); // pextuh t9, r0, t9
c->mov128_vf_gpr(vf2, t9); // qmtc2.ni vf2, t9
c->pextub(t9, r0, t8); // pextub t9, r0, t8
c->lbu(a3, 4, a0); // lbu a3, 4(a0)
c->pextlh(gp, r0, t9); // pextlh gp, r0, t9
c->mov128_vf_gpr(vf3, gp); // qmtc2.ni vf3, gp
c->pextuh(t9, r0, t9); // pextuh t9, r0, t9
c->mov128_vf_gpr(vf4, t9); // qmtc2.ni vf4, t9
c->sll(t2, t2, 4); // sll t2, t2, 4
c->lbu(t0, 5, a0); // lbu t0, 5(a0)
c->daddu(t2, t2, a0); // daddu t2, t2, a0
c->lbu(t1, 6, a0); // lbu t1, 6(a0)
c->daddiu(s5, a3, -1); // daddiu s5, a3, -1
vis[11] = c->gpr_src(a3).du16[0]; // ctc2.ni vi11, a3
c->daddu(s5, s5, t0); // daddu s5, s5, t0
vis[12] = c->gpr_src(t0).du16[0]; // ctc2.ni vi12, t0
c->daddu(s5, s5, t1); // daddu s5, s5, t1
vis[13] = c->gpr_src(t1).du16[0]; // ctc2.ni vi13, t1
c->daddiu(t4, a1, 32); // daddiu t4, a1, 32
c->lqc2(vf27, 0, t2); // lqc2 vf27, 0(t2)
c->daddiu(t3, a1, 192); // daddiu t3, a1, 192
// Unknown instr: vcallms 280
vcallms_280(c, vis);
c->daddiu(v1, a1, 448); // daddiu v1, a1, 448
c->lhu(s1, 6820, s4); // lhu s1, 6820(s4)
c->pextlw(t3, t3, t3); // pextlw t3, t3, t3
c->lhu(s2, 6822, s4); // lhu s2, 6822(s4)
c->pcpyld(t3, t3, t3); // pcpyld t3, t3, t3
c->lqc2(vf19, 6800, s4); // lqc2 vf19, 6800(s4)
c->pcpyh(s1, s1); // pcpyh s1, s1
c->lbu(v0, 2, a0); // lbu v0, 2(a0)
c->addiu(t5, r0, 0); // addiu t5, r0, 0
c->lbu(at, 1, a0); // lbu at, 1(a0)
c->addiu(s4, r0, -1); // addiu s4, r0, -1
c->lui(a1, 19201); // lui a1, 19201
c->daddiu(v0, v0, 3); // daddiu v0, v0, 3
c->daddiu(a1, a1, 18304); // daddiu a1, a1, 18304
c->andi(v0, v0, 252); // andi v0, v0, 252
c->sll(at, at, 2); // sll at, at, 2
c->sll(v0, v0, 2); // sll v0, v0, 2
c->lq(t8, 32, a0); // lq t8, 32(a0)
c->daddu(v0, v0, a0); // daddu v0, v0, a0
c->lbu(t0, 13, a0); // lbu t0, 13(a0)
c->daddu(at, at, a0); // daddu at, at, a0
c->lbu(t2, 11, a0); // lbu t2, 11(a0)
c->pextlw(a1, a1, r0); // pextlw a1, a1, r0
bc = c->sgpr64(t0) == 0; // beq t0, r0, L115
c->pcpyld(a1, a1, a1); // pcpyld a1, a1, a1
if (bc) {goto block_49;} // branch non-likely
c->sll(t2, t2, 4); // sll t2, t2, 4
c->daddiu(a3, a0, 14); // daddiu a3, a0, 14
//beq r0, r0, L114 // beq r0, r0, L114
c->daddu(t2, t2, a0); // daddu t2, t2, a0
goto block_47; // branch always
block_46:
// Unknown instr: vcallms 303
vcallms_303(c, vis);
c->mov64(t0, t1); // or t0, t1, r0
block_47:
c->lbu(t1, 0, a3); // lbu t1, 0(a3)
c->daddiu(a3, a3, 1); // daddiu a3, a3, 1
c->lqc2(vf23, 64, t2); // lqc2 vf23, 64(t2)
// nop // sll r0, r0, 0
c->lqc2(vf24, 80, t2); // lqc2 vf24, 80(t2)
// nop // sll r0, r0, 0
c->lqc2(vf25, 96, t2); // lqc2 vf25, 96(t2)
// nop // sll r0, r0, 0
c->lqc2(vf26, 112, t2); // lqc2 vf26, 112(t2)
// nop // sll r0, r0, 0
c->lqc2(vf20, 16, t2); // lqc2 vf20, 16(t2)
// nop // sll r0, r0, 0
c->lqc2(vf21, 32, t2); // lqc2 vf21, 32(t2)
// nop // sll r0, r0, 0
c->lqc2(vf22, 48, t2); // lqc2 vf22, 48(t2)
c->daddiu(t2, t2, 128); // daddiu t2, t2, 128
bc = c->sgpr64(t1) != 0; // bne t1, r0, L113
vis[14] = c->gpr_src(t0).du16[0]; // ctc2.ni vi14, t0
if (bc) {goto block_46;} // branch non-likely
// Unknown instr: vcallms 303
vcallms_303(c, vis);
// nop // sll r0, r0, 0
block_49:
c->lq(a2, 0, v0); // lq a2, 0(v0)
c->pextlb(t9, r0, t8); // pextlb t9, r0, t8
c->mfc1(r0, f31); // mfc1 r0, f31
c->pextlh(gp, r0, t9); // pextlh gp, r0, t9
c->mfc1(r0, f31); // mfc1 r0, f31
c->pextlb(a3, r0, a2); // pextlb a3, r0, a2
c->mfc1(r0, f31); // mfc1 r0, f31
c->pextub(a2, r0, a2); // pextub a2, r0, a2
c->mov128_vf_gpr(vf4, gp); // qmtc2.ni vf4, gp
c->pextlh(t0, a1, a3); // pextlh t0, a1, a3
c->mov128_vf_gpr(vf1, t0); // qmtc2.ni vf1, t0
c->pextuh(a3, a1, a3); // pextuh a3, a1, a3
c->mov128_vf_gpr(vf2, a3); // qmtc2.ni vf2, a3
c->pextlh(t1, a1, a2); // pextlh t1, a1, a2
c->mov128_vf_gpr(vf3, t1); // qmtc2.ni vf3, t1
c->pextuh(t9, r0, t9); // pextuh t9, r0, t9
// Unknown instr: vcallms 311
vcallms_311(c, vis);
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
c->lq(t2, 16, v0); // lq t2, 16(v0)
// nop // sll r0, r0, 0
c->daddiu(at, at, -16); // daddiu at, at, -16
// nop // sll r0, r0, 0
c->mfc1(r0, f31); // mfc1 r0, f31
c->pextuh(a2, a1, a2); // pextuh a2, a1, a2
c->mfc1(r0, f31); // mfc1 r0, f31
c->pextlb(t0, r0, t2); // pextlb t0, r0, t2
c->mov128_vf_gpr(vf4, t9); // qmtc2.ni vf4, t9
c->pextlh(t1, a1, t0); // pextlh t1, a1, t0
c->mov128_vf_gpr(vf1, a2); // qmtc2.ni vf1, a2
c->pextuh(t0, a1, t0); // pextuh t0, a1, t0
c->mov128_vf_gpr(vf2, t1); // qmtc2.ni vf2, t1
c->pextub(t9, r0, t8); // pextub t9, r0, t8
c->mov128_vf_gpr(vf3, t0); // qmtc2.ni vf3, t0
c->pextlh(gp, r0, t9); // pextlh gp, r0, t9
// nop // sll r0, r0, 0
c->daddiu(v0, v0, -48); // daddiu v0, v0, -48
// Unknown instr: vcallms 311
vcallms_311(c, vis);
// nop // sll r0, r0, 0
c->addiu(t6, r0, 0); // addiu t6, r0, 0
// nop // sll r0, r0, 0
c->lwl(t6, 53, v0); // lwl t6, 53(v0)
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
c->mfc1(r0, f31); // mfc1 r0, f31
c->pextlb(t6, r0, t6); // pextlb t6, r0, t6
c->mfc1(r0, f31); // mfc1 r0, f31
c->pextlb(t6, r0, t6); // pextlb t6, r0, t6
c->lq(a3, 80, v0); // lq a3, 80(v0)
c->paddw(t6, t6, t3); // paddw t6, t6, t3
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
c->mfc1(r0, f31); // mfc1 r0, f31
c->pextub(t2, r0, t2); // pextub t2, r0, t2
c->mfc1(r0, f31); // mfc1 r0, f31
c->pextlh(t0, a1, t2); // pextlh t0, a1, t2
c->mov128_vf_gpr(vf4, gp); // qmtc2.ni vf4, gp
c->pextuh(t2, a1, t2); // pextuh t2, a1, t2
c->mov128_vf_gpr(vf1, t0); // qmtc2.ni vf1, t0
c->pextlb(t1, r0, a3); // pextlb t1, r0, a3
c->mov128_vf_gpr(vf2, t2); // qmtc2.ni vf2, t2
c->pextlh(a2, a1, t1); // pextlh a2, a1, t1
c->mov128_vf_gpr(vf3, a2); // qmtc2.ni vf3, a2
c->pextuh(t9, r0, t9); // pextuh t9, r0, t9
// nop // sll r0, r0, 0
c->daddiu(v1, v1, -64); // daddiu v1, v1, -64
// nop // sll r0, r0, 0
c->sqc2(vf15, 64, v1); // sqc2 vf15, 64(v1)
// Unknown instr: vcallms 311
vcallms_311(c, vis);
// nop // sll r0, r0, 0
c->lwr(s3, 56, v0); // lwr s3, 56(v0)
// nop // sll r0, r0, 0
c->lwl(s3, 69, v0); // lwl s3, 69(v0)
// nop // sll r0, r0, 0
c->mfc1(r0, f31); // mfc1 r0, f31
c->pcpyud(t6, t6, r0); // pcpyud t6, t6, r0
c->mfc1(r0, f31); // mfc1 r0, f31
c->pextlb(s3, r0, s3); // pextlb s3, r0, s3
// nop // sll r0, r0, 0
c->dsllv(s3, s3, s2); // dsllv s3, s3, s2
c->lq(t8, 0, s6); // lq t8, 0(s6)
c->paddh(s3, s3, s1); // paddh s3, s3, s1
c->lbu(t7, 0, t6); // lbu t7, 0(t6)
c->dsrl32(t6, t6, 0); // dsrl32 t6, t6, 0
c->mfc1(r0, f31); // mfc1 r0, f31
c->pextuh(t0, a1, t1); // pextuh t0, a1, t1
c->lbu(s0, 0, t6); // lbu s0, 0(t6)
c->pextub(a3, r0, a3); // pextub a3, r0, a3
c->mov128_vf_gpr(vf4, t9); // qmtc2.ni vf4, t9
c->pextlh(t2, a1, a3); // pextlh t2, a1, a3
c->mov128_vf_gpr(vf1, t0); // qmtc2.ni vf1, t0
c->pextuh(a3, a1, a3); // pextuh a3, a1, a3
c->mov128_vf_gpr(vf2, t2); // qmtc2.ni vf2, t2
c->pextlb(t9, r0, t8); // pextlb t9, r0, t8
c->mov128_vf_gpr(vf3, a3); // qmtc2.ni vf3, a3
c->pextlh(gp, r0, t9); // pextlh gp, r0, t9
// nop // sll r0, r0, 0
c->daddiu(s6, s6, 16); // daddiu s6, s6, 16
// nop // sll r0, r0, 0
c->sqc2(vf15, 96, v1); // sqc2 vf15, 96(v1)
// Unknown instr: vcallms 311
vcallms_311(c, vis);
c->sw(s3, 76, v1); // sw s3, 76(v1)
c->lwr(t6, 64, v0); // lwr t6, 64(v0)
c->daddu(t7, t7, t4); // daddu t7, t7, t4
c->lwl(t6, 77, v0); // lwl t6, 77(v0)
c->daddu(s0, s0, t4); // daddu s0, s0, t4
//beq r0, r0, L117 // beq r0, r0, L117
c->dsrl32(s3, s3, 0); // dsrl32 s3, s3, 0
goto block_51; // branch always
block_50:
// Unknown instr: vcallms 311
vcallms_311(c, vis);
c->sw(s3, 76, v1); // sw s3, 76(v1)
c->lwr(t6, 64, v0); // lwr t6, 64(v0)
c->daddu(t7, t7, t4); // daddu t7, t7, t4
c->lwl(t6, 77, v0); // lwl t6, 77(v0)
c->daddu(s0, s0, t4); // daddu s0, s0, t4
c->sw(a0, 60, v1); // sw a0, 60(v1)
c->dsrl32(s3, s3, 0); // dsrl32 s3, s3, 0
block_51:
c->sb(t5, 0, t7); // sb t5, 0(t7)
c->pextlb(t6, r0, t6); // pextlb t6, r0, t6
c->sb(t5, 0, s0); // sb t5, 0(s0)
c->pextlb(t6, r0, t6); // pextlb t6, r0, t6
c->lq(a2, 96, v0); // lq a2, 96(v0)
c->paddw(t6, t6, t3); // paddw t6, t6, t3
c->lbu(t7, 0, t6); // lbu t7, 0(t6)
c->dsrl32(t6, t6, 0); // dsrl32 t6, t6, 0
c->lw(a0, 16, at); // lw a0, 16(at)
c->pextlb(a3, r0, a2); // pextlb a3, r0, a2
c->lbu(s0, 0, t6); // lbu s0, 0(t6)
c->pextub(a2, r0, a2); // pextub a2, r0, a2
c->mov128_vf_gpr(vf4, gp); // qmtc2.ni vf4, gp
c->pextlh(t0, a1, a3); // pextlh t0, a1, a3
c->mov128_vf_gpr(vf1, t0); // qmtc2.ni vf1, t0
c->pextuh(a3, a1, a3); // pextuh a3, a1, a3
c->mov128_vf_gpr(vf2, a3); // qmtc2.ni vf2, a3
c->pextlh(t1, a1, a2); // pextlh t1, a1, a2
c->mov128_vf_gpr(vf3, t1); // qmtc2.ni vf3, t1
c->pextuh(t9, r0, t9); // pextuh t9, r0, t9
c->sqc2(vf14, 80, v1); // sqc2 vf14, 80(v1)
c->daddiu(at, at, 16); // daddiu at, at, 16
c->addiu(s4, s4, 2); // addiu s4, s4, 2
c->sqc2(vf15, 128, v1); // sqc2 vf15, 128(v1)
bc = c->sgpr64(t5) == c->sgpr64(s5); // beq t5, s5, L118
c->daddiu(t5, t5, 2); // daddiu t5, t5, 2
if (bc) {goto block_56;} // branch non-likely
// Unknown instr: vcallms 311
vcallms_311(c, vis);
c->sw(s3, 108, v1); // sw s3, 108(v1)
c->lwr(s3, 80, v0); // lwr s3, 80(v0)
c->daddu(t7, t7, t4); // daddu t7, t7, t4
c->lwl(s3, 93, v0); // lwl s3, 93(v0)
c->daddu(s0, s0, t4); // daddu s0, s0, t4
c->sw(a0, 92, v1); // sw a0, 92(v1)
c->pcpyud(t6, t6, r0); // pcpyud t6, t6, r0
c->sb(s4, 0, t7); // sb s4, 0(t7)
c->pextlb(s3, r0, s3); // pextlb s3, r0, s3
c->sb(s4, 0, s0); // sb s4, 0(s0)
c->dsllv(s3, s3, s2); // dsllv s3, s3, s2
c->lq(t2, 112, v0); // lq t2, 112(v0)
c->paddh(s3, s3, s1); // paddh s3, s3, s1
c->lbu(t7, 0, t6); // lbu t7, 0(t6)
c->dsrl32(t6, t6, 0); // dsrl32 t6, t6, 0
c->lw(a0, 4, at); // lw a0, 4(at)
c->pextuh(a2, a1, a2); // pextuh a2, a1, a2
c->lbu(s0, 0, t6); // lbu s0, 0(t6)
c->pextlb(t0, r0, t2); // pextlb t0, r0, t2
c->mov128_vf_gpr(vf4, t9); // qmtc2.ni vf4, t9
c->pextlh(t1, a1, t0); // pextlh t1, a1, t0
c->mov128_vf_gpr(vf1, a2); // qmtc2.ni vf1, a2
c->pextuh(t0, a1, t0); // pextuh t0, a1, t0
c->mov128_vf_gpr(vf2, t1); // qmtc2.ni vf2, t1
c->pextub(t9, r0, t8); // pextub t9, r0, t8
c->mov128_vf_gpr(vf3, t0); // qmtc2.ni vf3, t0
c->pextlh(gp, r0, t9); // pextlh gp, r0, t9
c->sqc2(vf14, 112, v1); // sqc2 vf14, 112(v1)
c->daddiu(v0, v0, 48); // daddiu v0, v0, 48
bc = c->sgpr64(s4) == c->sgpr64(s5); // beq s4, s5, L119
c->sqc2(vf15, 160, v1); // sqc2 vf15, 160(v1)
if (bc) {goto block_57;} // branch non-likely
// Unknown instr: vcallms 311
vcallms_311(c, vis);
c->sw(s3, 140, v1); // sw s3, 140(v1)
c->lwr(t6, 40, v0); // lwr t6, 40(v0)
c->daddu(t7, t7, t4); // daddu t7, t7, t4
c->lwl(t6, 53, v0); // lwl t6, 53(v0)
c->daddu(s0, s0, t4); // daddu s0, s0, t4
c->sw(a0, 124, v1); // sw a0, 124(v1)
c->dsrl32(s3, s3, 0); // dsrl32 s3, s3, 0
c->sb(t5, 0, t7); // sb t5, 0(t7)
c->pextlb(t6, r0, t6); // pextlb t6, r0, t6
c->sb(t5, 0, s0); // sb t5, 0(s0)
c->pextlb(t6, r0, t6); // pextlb t6, r0, t6
c->lq(a3, 80, v0); // lq a3, 80(v0)
c->paddw(t6, t6, t3); // paddw t6, t6, t3
c->lbu(t7, 0, t6); // lbu t7, 0(t6)
c->dsrl32(t6, t6, 0); // dsrl32 t6, t6, 0
c->lw(a0, 8, at); // lw a0, 8(at)
c->pextub(t2, r0, t2); // pextub t2, r0, t2
c->lbu(s0, 0, t6); // lbu s0, 0(t6)
c->pextlh(t0, a1, t2); // pextlh t0, a1, t2
c->mov128_vf_gpr(vf4, gp); // qmtc2.ni vf4, gp
c->pextuh(t2, a1, t2); // pextuh t2, a1, t2
c->mov128_vf_gpr(vf1, t0); // qmtc2.ni vf1, t0
c->pextlb(t1, r0, a3); // pextlb t1, r0, a3
c->mov128_vf_gpr(vf2, t2); // qmtc2.ni vf2, t2
c->pextlh(a2, a1, t1); // pextlh a2, a1, t1
c->mov128_vf_gpr(vf3, a2); // qmtc2.ni vf3, a2
c->pextuh(t9, r0, t9); // pextuh t9, r0, t9
c->sqc2(vf14, 144, v1); // sqc2 vf14, 144(v1)
c->daddiu(v1, v1, 128); // daddiu v1, v1, 128
c->addiu(s4, s4, 2); // addiu s4, s4, 2
c->sqc2(vf15, 64, v1); // sqc2 vf15, 64(v1)
bc = c->sgpr64(t5) == c->sgpr64(s5); // beq t5, s5, L120
c->daddiu(t5, t5, 2); // daddiu t5, t5, 2
if (bc) {goto block_58;} // branch non-likely
// Unknown instr: vcallms 311
vcallms_311(c, vis);
c->sw(s3, 44, v1); // sw s3, 44(v1)
c->lwr(s3, 56, v0); // lwr s3, 56(v0)
c->daddu(t7, t7, t4); // daddu t7, t7, t4
c->lwl(s3, 69, v0); // lwl s3, 69(v0)
c->daddu(s0, s0, t4); // daddu s0, s0, t4
c->sw(a0, 28, v1); // sw a0, 28(v1)
c->pcpyud(t6, t6, r0); // pcpyud t6, t6, r0
c->sb(s4, 0, t7); // sb s4, 0(t7)
c->pextlb(s3, r0, s3); // pextlb s3, r0, s3
c->sb(s4, 0, s0); // sb s4, 0(s0)
c->dsllv(s3, s3, s2); // dsllv s3, s3, s2
c->lq(t8, 0, s6); // lq t8, 0(s6)
c->paddh(s3, s3, s1); // paddh s3, s3, s1
c->lbu(t7, 0, t6); // lbu t7, 0(t6)
c->dsrl32(t6, t6, 0); // dsrl32 t6, t6, 0
c->lw(a0, 12, at); // lw a0, 12(at)
c->pextuh(t0, a1, t1); // pextuh t0, a1, t1
c->lbu(s0, 0, t6); // lbu s0, 0(t6)
c->pextub(a3, r0, a3); // pextub a3, r0, a3
c->mov128_vf_gpr(vf4, t9); // qmtc2.ni vf4, t9
c->pextlh(t2, a1, a3); // pextlh t2, a1, a3
c->mov128_vf_gpr(vf1, t0); // qmtc2.ni vf1, t0
c->pextuh(a3, a1, a3); // pextuh a3, a1, a3
c->mov128_vf_gpr(vf2, t2); // qmtc2.ni vf2, t2
c->pextlb(t9, r0, t8); // pextlb t9, r0, t8
c->mov128_vf_gpr(vf3, a3); // qmtc2.ni vf3, a3
c->pextlh(gp, r0, t9); // pextlh gp, r0, t9
c->sqc2(vf14, 48, v1); // sqc2 vf14, 48(v1)
c->daddiu(s6, s6, 16); // daddiu s6, s6, 16
bc = c->sgpr64(s4) != c->sgpr64(s5); // bne s4, s5, L116
c->sqc2(vf15, 96, v1); // sqc2 vf15, 96(v1)
if (bc) {goto block_50;} // branch non-likely
//beq r0, r0, L120 // beq r0, r0, L120
c->daddiu(v1, v1, 32); // daddiu v1, v1, 32
goto block_58; // branch always
block_56:
//beq r0, r0, L120 // beq r0, r0, L120
c->daddiu(v1, v1, 64); // daddiu v1, v1, 64
goto block_58; // branch always
block_57:
//beq r0, r0, L120 // beq r0, r0, L120
c->daddiu(v1, v1, 96); // daddiu v1, v1, 96
goto block_58; // branch always
block_58:
c->sw(a0, 28, v1); // sw a0, 28(v1)
c->daddiu(s5, s5, 1); // daddiu s5, s5, 1
c->daddiu(v1, v1, 32); // daddiu v1, v1, 32
// nop // sll r0, r0, 0
get_fake_spad_addr2(a3, cache.fake_scratchpad_data, 0, c);// lui a3, 28672
// nop // sll r0, r0, 0
c->lw(a0, 7444, a3); // lw a0, 7444(a3)
// nop // sll r0, r0, 0
c->lw(a1, 7436, a3); // lw a1, 7436(a3)
// nop // sll r0, r0, 0
c->lw(a3, 7440, a3); // lw a3, 7440(a3)
// nop // sll r0, r0, 0
c->sb(s5, 17, a1); // sb s5, 17(a1)
// nop // sll r0, r0, 0
c->lbu(s0, 0, a0); // lbu s0, 0(a0)
c->addiu(s4, r0, 0); // addiu s4, r0, 0
c->lbu(s1, 7, a0); // lbu s1, 7(a0)
c->addiu(t8, r0, 0); // addiu t8, r0, 0
c->lbu(s2, 8, a0); // lbu s2, 8(a0)
c->sll(s0, s0, 2); // sll s0, s0, 2
c->daddu(s0, s0, a0); // daddu s0, s0, a0
c->sll(s1, s1, 2); // sll s1, s1, 2
bc = c->sgpr64(s1) == 0; // beq s1, r0, L122
c->daddu(s1, s1, s0); // daddu s1, s1, s0
if (bc) {goto block_61;} // branch non-likely
block_59:
c->lbu(s3, 0, s0); // lbu s3, 0(s0)
c->daddu(s4, s4, t4); // daddu s4, s4, t4
c->lbu(s6, 1, s0); // lbu s6, 1(s0)
c->daddu(t8, t8, t4); // daddu t8, t8, t4
c->lbu(t9, 0, s4); // lbu t9, 0(s4)
c->daddu(s3, s3, t3); // daddu s3, s3, t3
c->lbu(s4, 0, s3); // lbu s4, 0(s3)
c->daddu(s6, s6, t3); // daddu s6, s6, t3
c->sb(t9, 0, t8); // sb t9, 0(t8)
c->daddiu(s0, s0, 4); // daddiu s0, s0, 4
bc = c->sgpr64(s0) != c->sgpr64(s1); // bne s0, s1, L121
c->lbu(t8, 0, s6); // lbu t8, 0(s6)
if (bc) {goto block_59;} // branch non-likely
// nop // sll r0, r0, 0
c->daddu(s4, s4, t4); // daddu s4, s4, t4
c->lbu(t9, 0, s4); // lbu t9, 0(s4)
c->daddu(t8, t8, t4); // daddu t8, t8, t4
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
c->sb(t9, 0, t8); // sb t9, 0(t8)
// nop // sll r0, r0, 0
block_61:
c->sll(s2, s2, 2); // sll s2, s2, 2
c->daddiu(t5, a3, 32); // daddiu t5, a3, 32
bc = c->sgpr64(s2) == 0; // beq s2, r0, L125
c->daddu(s2, s2, s1); // daddu s2, s2, s1
if (bc) {goto block_65;} // branch non-likely
c->lbu(s3, 0, s0); // lbu s3, 0(s0)
c->daddiu(t6, a3, 192); // daddiu t6, a3, 192
c->lbu(s6, 1, s0); // lbu s6, 1(s0)
c->daddiu(t7, a3, 448); // daddiu t7, a3, 448
// nop // sll r0, r0, 0
c->daddu(s3, s3, t6); // daddu s3, s3, t6
c->lbu(s3, 0, s3); // lbu s3, 0(s3)
c->daddu(s6, s6, t3); // daddu s6, s6, t3
c->lbu(s6, 0, s6); // lbu s6, 0(s6)
c->daddiu(v1, v1, -32); // daddiu v1, v1, -32
// nop // sll r0, r0, 0
c->daddu(s3, s3, t5); // daddu s3, s3, t5
c->lbu(s4, 0, s3); // lbu s4, 0(s3)
c->daddu(s6, s6, t4); // daddu s6, s6, t4
// nop // sll r0, r0, 0
c->daddiu(s0, s0, 4); // daddiu s0, s0, 4
c->sb(s5, 0, s6); // sb s5, 0(s6)
c->daddiu(s5, s5, 1); // daddiu s5, s5, 1
bc = c->sgpr64(s0) == c->sgpr64(s2); // beq s0, s2, L124
// nop // sll r0, r0, 0
if (bc) {goto block_64;} // branch non-likely
block_63:
c->lbu(s3, 0, s0); // lbu s3, 0(s0)
c->sll(s4, s4, 5); // sll s4, s4, 5
c->lbu(s6, 1, s0); // lbu s6, 1(s0)
c->daddu(s4, s4, t7); // daddu s4, s4, t7
c->lq(t9, 0, s4); // lq t9, 0(s4)
c->daddu(s3, s3, t6); // daddu s3, s3, t6
c->lbu(s3, 0, s3); // lbu s3, 0(s3)
c->daddu(s6, s6, t3); // daddu s6, s6, t3
c->lbu(s6, 0, s6); // lbu s6, 0(s6)
c->daddiu(v1, v1, 32); // daddiu v1, v1, 32
c->lq(gp, 16, s4); // lq gp, 16(s4)
c->daddu(s3, s3, t5); // daddu s3, s3, t5
c->lbu(s4, 0, s3); // lbu s4, 0(s3)
c->daddu(s6, s6, t4); // daddu s6, s6, t4
c->sq(t9, 0, v1); // sq t9, 0(v1)
c->daddiu(s0, s0, 4); // daddiu s0, s0, 4
c->sb(s5, 0, s6); // sb s5, 0(s6)
c->daddiu(s5, s5, 1); // daddiu s5, s5, 1
bc = c->sgpr64(s0) != c->sgpr64(s2); // bne s0, s2, L123
c->sq(gp, 16, v1); // sq gp, 16(v1)
if (bc) {goto block_63;} // branch non-likely
block_64:
// nop // sll r0, r0, 0
c->sll(s4, s4, 5); // sll s4, s4, 5
// nop // sll r0, r0, 0
c->daddu(s4, s4, t7); // daddu s4, s4, t7
c->lq(t9, 0, s4); // lq t9, 0(s4)
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
c->daddiu(v1, v1, 32); // daddiu v1, v1, 32
c->lq(gp, 16, s4); // lq gp, 16(s4)
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
c->sq(t9, 0, v1); // sq t9, 0(v1)
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
c->sq(gp, 16, v1); // sq gp, 16(v1)
block_65:
c->sh(s5, 20, a1); // sh s5, 20(a1)
get_fake_spad_addr2(at, cache.fake_scratchpad_data, 0, c);// lui at, 28672
c->lq(s0, 7536, at); // lq s0, 7536(at)
c->lq(s1, 7552, at); // lq s1, 7552(at)
c->lq(s2, 7568, at); // lq s2, 7568(at)
c->lq(s3, 7584, at); // lq s3, 7584(at)
c->lq(s4, 7600, at); // lq s4, 7600(at)
c->lq(s5, 7616, at); // lq s5, 7616(at)
c->lq(s6, 7632, at); // lq s6, 7632(at)
c->lq(t8, 7648, at); // lq t8, 7648(at)
c->lq(t9, 7664, at); // lq t9, 7664(at)
c->lq(gp, 7680, at); // lq gp, 7680(at)
c->lq(ra, 7728, at); // lq ra, 7728(at)
c->lq(sp, 7696, at); // lq sp, 7696(at)
//jr ra // jr ra
c->lq(fp, 7712, at); // lq fp, 7712(at)
goto end_of_function; // return
//jr ra // jr ra
c->daddu(sp, sp, r0); // daddu sp, sp, r0
goto end_of_function; // return
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
end_of_function:
return c->gprs[v0].du64[0];
}
void link() {
cache.fake_scratchpad_data = intern_from_c(-1, 0, "*fake-scratchpad-data*").c();
gLinkedFunctionTable.reg("mercneric-convert", execute, 128);
}
} // namespace mercneric_convert
} // namespace Mips2C
//--------------------------MIPS2C---------------------
// clang-format off
#include "game/mips2c/mips2c_private.h"
#include "game/kernel/jak3/kscheme.h"
using ::jak3::intern_from_c;
namespace Mips2C::jak3 {
namespace high_speed_reject {
struct Cache {
void* fake_scratchpad_data; // *fake-scratchpad-data*
} cache;
void vcallms_438(ExecutionContext* c, u16* vis) {
// nop | mulaz.xyzw ACC, vf09, vf01 158
c->acc.vf.mula_xyzw(c->vf_src(vf09).vf, c->vf_src(vf01).vf.z());
// nop | maddax.xyzw ACC, vf10, vf01 159
c->acc.vf.madda_xyzw(c->vfs[vf10].vf, c->vfs[vf01].vf.x());
// nop | maddy.xyzw vf01, vf11, vf01 160
u16 f1 = c->acc.vf.madd_flag(Mask::xyzw, c->vfs[vf01].vf, c->vf_src(vf11).vf, c->vf_src(vf01).vf.y());
// nop | mulaz.xyzw ACC, vf09, vf02 161
c->acc.vf.mula_xyzw(c->vf_src(vf09).vf, c->vf_src(vf02).vf.z());
// nop | maddax.xyzw ACC, vf10, vf02 162
c->acc.vf.madda_xyzw(c->vfs[vf10].vf, c->vfs[vf02].vf.x());
// nop | maddy.xyzw vf02, vf11, vf02 163
u16 f2 = c->acc.vf.madd_flag(Mask::xyzw, c->vfs[vf02].vf, c->vf_src(vf11).vf, c->vf_src(vf02).vf.y());
// fmand vi01, vi09 | mulaz.xyzw ACC, vf09, vf03 164
c->acc.vf.mula_xyzw(c->vf_src(vf09).vf, c->vf_src(vf03).vf.z()); vis[1] = vis[9] & f1;
// nop | maddax.xyzw ACC, vf10, vf03 165
c->acc.vf.madda_xyzw(c->vfs[vf10].vf, c->vfs[vf03].vf.x());
// nop | maddy.xyzw vf03, vf11, vf03 166
u16 f3 = c->acc.vf.madd_flag(Mask::xyzw, c->vfs[vf03].vf, c->vf_src(vf11).vf, c->vf_src(vf03).vf.y());
// fmand vi02, vi09 | mulaz.xyzw ACC, vf09, vf04 167
c->acc.vf.mula_xyzw(c->vf_src(vf09).vf, c->vf_src(vf04).vf.z()); vis[2] = vis[9] & f2;
// nop | maddax.xyzw ACC, vf10, vf04 168
c->acc.vf.madda_xyzw(c->vfs[vf10].vf, c->vfs[vf04].vf.x());
// nop | maddy.xyzw vf04, vf11, vf04 169
c->acc.vf.madd_flag(Mask::xyzw, c->vfs[vf04].vf, c->vf_src(vf11).vf, c->vf_src(vf04).vf.y());
// fmand vi03, vi09 | nop 170
// ASSERT(false);
vis[3] = vis[9] & f3;
// nop | nop 171
// nop | nop :e 172
// fmand vi04, vi09 | nop 173
// ASSERT(false);
vis[4] = vis[9] & f4;
}
void vcallms_454(ExecutionContext* c, u16* vis) {
// nop | mulaz.xyzw ACC, vf09, vf05 174
c->acc.vf.mula_xyzw(c->vf_src(vf09).vf, c->vf_src(vf05).vf.z());
// nop | maddax.xyzw ACC, vf10, vf05 175
c->acc.vf.madda_xyzw(c->vfs[vf10].vf, c->vfs[vf05].vf.x());
// nop | maddy.xyzw vf05, vf11, vf05 176
u16 f1 = c->acc.vf.madd_flag(Mask::xyzw, c->vfs[vf05].vf, c->vf_src(vf11).vf, c->vf_src(vf05).vf.y());
// nop | mulaz.xyzw ACC, vf09, vf06 177
c->acc.vf.mula_xyzw(c->vf_src(vf09).vf, c->vf_src(vf06).vf.z());
// nop | maddax.xyzw ACC, vf10, vf06 178
c->acc.vf.madda_xyzw(c->vfs[vf10].vf, c->vfs[vf06].vf.x());
// nop | maddy.xyzw vf06, vf11, vf06 179
u16 f2 = c->acc.vf.madd_flag(Mask::xyzw, c->vfs[vf06].vf, c->vf_src(vf11).vf, c->vf_src(vf06).vf.y());
// fmand vi05, vi09 | mulaz.xyzw ACC, vf09, vf07 180
c->acc.vf.mula_xyzw(c->vf_src(vf09).vf, c->vf_src(vf07).vf.z()); vis[5] = vis[9] & f1;
// nop | maddax.xyzw ACC, vf10, vf07 181
c->acc.vf.madda_xyzw(c->vfs[vf10].vf, c->vfs[vf07].vf.x());
// nop | maddy.xyzw vf07, vf11, vf07 182
u16 f3 = c->acc.vf.madd_flag(Mask::xyzw, c->vfs[vf07].vf, c->vf_src(vf11).vf, c->vf_src(vf07).vf.y());
// fmand vi06, vi09 | mulaz.xyzw ACC, vf09, vf08 183
c->acc.vf.mula_xyzw(c->vf_src(vf09).vf, c->vf_src(vf08).vf.z()); vis[5] = vis[9] & f2;
// nop | maddax.xyzw ACC, vf10, vf08 184
c->acc.vf.madda_xyzw(c->vfs[vf10].vf, c->vfs[vf08].vf.x());
// nop | maddy.xyzw vf08, vf11, vf08 185
u16 f4 =c->acc.vf.madd_flag(Mask::xyzw, c->vfs[vf08].vf, c->vf_src(vf11).vf, c->vf_src(vf08).vf.y());
// fmand vi07, vi09 | nop 186
vis[7] = vis[9] & f3;
// nop | nop 187
// nop | nop :e 188
// fmand vi08, vi09 | nop 189
// ASSERT(false);
vis[8] = vis[9] & f4;
}
u64 execute(void* ctxt) {
auto* c = (ExecutionContext*)ctxt;
bool bc = false;
u16 vis[16];
get_fake_spad_addr2(v1, cache.fake_scratchpad_data, 0, c);// lui v1, 28672
c->lw(a0, 7436, v1); // lw a0, 7436(v1)
c->daddiu(a1, a0, 448); // daddiu a1, a0, 448
c->lhu(a3, 20, a0); // lhu a3, 20(a0)
c->vmax_bc(DEST::xyzw, BC::w, vf9, vf0, vf0); // vmaxw.xyzw vf9, vf0, vf0
c->lqc2(vf10, 7488, v1); // lqc2 vf10, 7488(v1)
c->lqc2(vf11, 7504, v1); // lqc2 vf11, 7504(v1)
c->lqc2(vf1, 0, a1); // lqc2 vf1, 0(a1)
c->addiu(a0, r0, 240); // addiu a0, r0, 240
c->lqc2(vf2, 32, a1); // lqc2 vf2, 32(a1)
vis[9] = c->gpr_src(a0).du16[0]; // ctc2.i vi9, a0
c->lqc2(vf3, 64, a1); // lqc2 vf3, 64(a1)
c->lqc2(vf4, 96, a1); // lqc2 vf4, 96(a1)
c->daddiu(a0, r0, -1); // daddiu a0, r0, -1
// nop // sll r0, r0, 0
// Unknown instr: vcallms 438
vcallms_438(c, vis);
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
c->lqc2(vf5, 128, a1); // lqc2 vf5, 128(a1)
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
c->lqc2(vf6, 160, a1); // lqc2 vf6, 160(a1)
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
c->lwu(t0, 8, a1); // lwu t0, 8(a1)
c->lqc2(vf7, 192, a1); // lqc2 vf7, 192(a1)
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
c->gprs[a2].du64[0] = vis[1]; // cfc2.ni a2, vi1
c->lqc2(vf8, 224, a1); // lqc2 vf8, 224(a1)
c->srl(t0, t0, 31); // srl t0, t0, 31
c->or_(t0, a2, t0); // or t0, a2, t0
c->lwu(a2, 40, a1); // lwu a2, 40(a1)
bc = c->sgpr64(t0) == 0; // beq t0, r0, L85
c->and_(a0, a0, t0); // and a0, a0, t0
if (bc) {goto block_20;} // branch non-likely
c->daddiu(a1, a1, 128); // daddiu a1, a1, 128
c->daddiu(a3, a3, -1); // daddiu a3, a3, -1
bc = c->sgpr64(a3) == 0; // beq a3, r0, L84
c->gprs[t0].du64[0] = vis[2]; // cfc2.ni t0, vi2
if (bc) {goto block_18;} // branch non-likely
block_2:
// Unknown instr: vcallms 454
vcallms_454(c, vis);
c->srl(a2, a2, 31); // srl a2, a2, 31
c->or_(a2, t0, a2); // or a2, t0, a2
c->lwu(t0, -56, a1); // lwu t0, -56(a1)
bc = c->sgpr64(a2) == 0; // beq a2, r0, L85
c->and_(a0, a0, a2); // and a0, a0, a2
if (bc) {goto block_20;} // branch non-likely
c->lqc2(vf1, 128, a1); // lqc2 vf1, 128(a1)
c->daddiu(a2, a3, -1); // daddiu a2, a3, -1
bc = c->sgpr64(a2) == 0; // beq a2, r0, L84
c->gprs[a3].du64[0] = vis[3]; // cfc2.ni a3, vi3
if (bc) {goto block_18;} // branch non-likely
c->daddiu(a2, a2, -1); // daddiu a2, a2, -1
c->srl(t0, t0, 31); // srl t0, t0, 31
c->or_(t0, a3, t0); // or t0, a3, t0
c->lwu(a3, -24, a1); // lwu a3, -24(a1)
bc = c->sgpr64(t0) == 0; // beq t0, r0, L85
c->and_(a0, a0, t0); // and a0, a0, t0
if (bc) {goto block_20;} // branch non-likely
bc = c->sgpr64(a2) == 0; // beq a2, r0, L84
c->gprs[t0].du64[0] = vis[4]; // cfc2.ni t0, vi4
if (bc) {goto block_18;} // branch non-likely
c->lqc2(vf2, 160, a1); // lqc2 vf2, 160(a1)
c->srl(a3, a3, 31); // srl a3, a3, 31
c->or_(t0, t0, a3); // or t0, t0, a3
c->lwu(a3, 8, a1); // lwu a3, 8(a1)
bc = c->sgpr64(t0) == 0; // beq t0, r0, L85
c->and_(a0, a0, t0); // and a0, a0, t0
if (bc) {goto block_20;} // branch non-likely
c->lqc2(vf3, 192, a1); // lqc2 vf3, 192(a1)
c->daddiu(a2, a2, -1); // daddiu a2, a2, -1
bc = c->sgpr64(a2) == 0; // beq a2, r0, L84
c->gprs[t0].du64[0] = vis[5]; // cfc2.ni t0, vi5
if (bc) {goto block_18;} // branch non-likely
c->lqc2(vf4, 224, a1); // lqc2 vf4, 224(a1)
c->srl(a3, a3, 31); // srl a3, a3, 31
c->or_(t0, t0, a3); // or t0, t0, a3
c->lwu(a3, 40, a1); // lwu a3, 40(a1)
bc = c->sgpr64(t0) == 0; // beq t0, r0, L85
c->and_(a0, a0, t0); // and a0, a0, t0
if (bc) {goto block_20;} // branch non-likely
c->daddiu(a1, a1, 128); // daddiu a1, a1, 128
c->daddiu(a2, a2, -1); // daddiu a2, a2, -1
bc = c->sgpr64(a2) == 0; // beq a2, r0, L84
c->gprs[t0].du64[0] = vis[6]; // cfc2.ni t0, vi6
if (bc) {goto block_18;} // branch non-likely
// Unknown instr: vcallms 438
// vcallms_438(c, vis);
c->srl(a3, a3, 31); // srl a3, a3, 31
c->or_(t0, t0, a3); // or t0, t0, a3
c->lwu(a3, -56, a1); // lwu a3, -56(a1)
bc = c->sgpr64(t0) == 0; // beq t0, r0, L85
c->and_(a0, a0, t0); // and a0, a0, t0
if (bc) {goto block_20;} // branch non-likely
c->lqc2(vf5, 128, a1); // lqc2 vf5, 128(a1)
c->daddiu(a2, a2, -1); // daddiu a2, a2, -1
bc = c->sgpr64(a2) == 0; // beq a2, r0, L84
c->gprs[t0].du64[0] = vis[7]; // cfc2.ni t0, vi7
if (bc) {goto block_18;} // branch non-likely
c->daddiu(a2, a2, -1); // daddiu a2, a2, -1
c->srl(a3, a3, 31); // srl a3, a3, 31
c->or_(t0, t0, a3); // or t0, t0, a3
c->lwu(a3, -24, a1); // lwu a3, -24(a1)
bc = c->sgpr64(t0) == 0; // beq t0, r0, L85
c->and_(a0, a0, t0); // and a0, a0, t0
if (bc) {goto block_20;} // branch non-likely
bc = c->sgpr64(a2) == 0; // beq a2, r0, L84
c->gprs[t0].du64[0] = vis[8]; // cfc2.ni t0, vi8
if (bc) {goto block_18;} // branch non-likely
c->lqc2(vf6, 160, a1); // lqc2 vf6, 160(a1)
c->srl(a3, a3, 31); // srl a3, a3, 31
c->or_(a3, t0, a3); // or a3, t0, a3
c->lwu(t0, 8, a1); // lwu t0, 8(a1)
bc = c->sgpr64(a3) == 0; // beq a3, r0, L85
c->and_(a0, a0, a3); // and a0, a0, a3
if (bc) {goto block_20;} // branch non-likely
c->lqc2(vf7, 192, a1); // lqc2 vf7, 192(a1)
c->daddiu(a3, a2, -1); // daddiu a3, a2, -1
bc = c->sgpr64(a3) == 0; // beq a3, r0, L84
c->gprs[a2].du64[0] = vis[1]; // cfc2.ni a2, vi1
if (bc) {goto block_18;} // branch non-likely
c->lqc2(vf8, 224, a1); // lqc2 vf8, 224(a1)
c->srl(t0, t0, 31); // srl t0, t0, 31
c->or_(t0, a2, t0); // or t0, a2, t0
c->lwu(a2, 40, a1); // lwu a2, 40(a1)
bc = c->sgpr64(t0) == 0; // beq t0, r0, L85
c->and_(a0, a0, t0); // and a0, a0, t0
if (bc) {goto block_20;} // branch non-likely
c->daddiu(a1, a1, 128); // daddiu a1, a1, 128
c->daddiu(a3, a3, -1); // daddiu a3, a3, -1
bc = c->sgpr64(a3) != 0; // bne a3, r0, L83
c->gprs[t0].du64[0] = vis[2]; // cfc2.ni t0, vi2
if (bc) {goto block_2;} // branch non-likely
block_18:
bc = c->sgpr64(a0) == 0; // beq a0, r0, L85
// nop // sll r0, r0, 0
if (bc) {goto block_20;} // branch non-likely
c->sb(r0, 6853, v1); // sb r0, 6853(v1)
block_20:
//jr ra // jr ra
// nop // sll r0, r0, 0
goto end_of_function; // return
//jr ra // jr ra
c->daddu(sp, sp, r0); // daddu sp, sp, r0
goto end_of_function; // return
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
end_of_function:
return c->gprs[v0].du64[0];
}
void link() {
cache.fake_scratchpad_data = intern_from_c(-1, 0, "*fake-scratchpad-data*").c();
gLinkedFunctionTable.reg("high-speed-reject", execute, 128);
}
} // namespace high_speed_reject
} // namespace Mips2C
//--------------------------MIPS2C---------------------
// clang-format off
#include "game/mips2c/mips2c_private.h"
#include "game/kernel/jak3/kscheme.h"
using ::jak3::intern_from_c;
namespace Mips2C::jak3 {
namespace generic_translucent {
struct Cache {
void* fake_scratchpad_data; // *fake-scratchpad-data*
} cache;
u64 execute(void* ctxt) {
u32 qwc = 0;
u32 madr = 0;
u32 sadr = 0;
auto* c = (ExecutionContext*)ctxt;
bool bc = false;
[[maybe_unused]] u32 call_addr = 0;
c->daddiu(sp, sp, -16); // daddiu sp, sp, -16
c->sd(ra, 0, sp); // sd ra, 0(sp)
get_fake_spad_addr2(at, cache.fake_scratchpad_data, 0, c);// lui at, 28672
c->mov64(v1, a0); // or v1, a0, r0
c->daddiu(a0, at, 12064); // daddiu a0, at, 12064
c->lbu(a1, 6842, at); // lbu a1, 6842(at)
c->daddiu(a2, at, 6960); // daddiu a2, at, 6960
c->mov64(a2, a2); // or a2, a2, r0
c->movn(a0, a2, a1); // movn a0, a2, a1
c->lbu(a1, 6856, at); // lbu a1, 6856(at)
c->addiu(a2, r0, 128); // addiu a2, r0, 128
c->sltu(a2, a2, a1); // sltu a2, a2, a1
bc = c->sgpr64(a2) != 0; // bne a2, r0, L78
// nop // sll r0, r0, 0
if (bc) {goto block_2;} // branch non-likely
c->addiu(a3, r0, 100); // addiu a3, r0, 100
c->lw(a2, 24, at); // lw a2, 24(at)
c->sw(a3, 112, a2); // sw a3, 112(a2)
c->addiu(a3, r0, 66); // addiu a3, r0, 66
c->sw(a3, 120, a2); // sw a3, 120(a2)
c->sw(a1, 116, a2); // sw a1, 116(a2)
//beq r0, r0, L79 // beq r0, r0, L79
// nop // sll r0, r0, 0
goto block_3; // branch always
block_2:
c->gprs[a1].du64[0] = 0; // or a1, r0, r0
block_3:
c->sw(r0, 48, at); // sw r0, 48(at)
c->sw(a0, 52, at); // sw a0, 52(at)
c->sw(v1, 44, at); // sw v1, 44(at)
c->lwu(t9, 7468, at); // lwu t9, 7468(at)
call_addr = c->gprs[t9].du32[0]; // function call:
c->sll(v0, ra, 0); // sll v0, ra, 0
// c->jalr(call_addr); // jalr ra, t9
generic_prepare_dma_double::execute(c);
c->lwu(t9, 7472, at); // lwu t9, 7472(at)
call_addr = c->gprs[t9].du32[0]; // function call:
c->sll(v0, ra, 0); // sll v0, ra, 0
// c->jalr(call_addr); // jalr ra, t9
generic_light_proc::execute(c);
c->lwu(t9, 7476, at); // lwu t9, 7476(at)
call_addr = c->gprs[t9].du32[0]; // function call:
c->sll(v0, ra, 0); // sll v0, ra, 0
// c->jalr(call_addr); // jalr ra, t9
generic_envmap_proc::execute(c);
c->lw(v1, 24, at); // lw v1, 24(at)
c->lw(a0, 40, at); // lw a0, 40(at)
c->mov64(a3, v1); // or a3, v1, r0
// nop // sll r0, r0, 0
get_fake_spad_addr2(at, cache.fake_scratchpad_data, 0, c);// lui at, 28672
c->lui(a2, 4096); // lui a2, 4096
c->lwu(a1, 60, at); // lwu a1, 60(at)
c->ori(a2, a2, 53248); // ori a2, a2, 53248
// c->lw(t1, 0, a2); // lw t1, 0(a2)
// nop // sll r0, r0, 0
c->daddiu(t0, at, 92); // daddiu t0, at, 92
c->andi(a3, a3, 16383); // andi a3, a3, 16383
c->andi(t1, t1, 256); // andi t1, t1, 256
// nop // sll r0, r0, 0
// bc = c->sgpr64(t1) == 0; // beq t1, r0, L81
// nop // sll r0, r0, 0
// if (bc) {goto block_7;} // branch non-likely
//
// c->mov64(t1, a2); // or t1, a2, r0
// // nop // sll r0, r0, 0
//
// block_5:
// c->lw(t2, 0, t0); // lw t2, 0(t0)
// // nop // sll r0, r0, 0
// c->lw(t3, 0, t1); // lw t3, 0(t1)
// // nop // sll r0, r0, 0
// c->andi(t3, t3, 256); // andi t3, t3, 256
// c->daddiu(t2, t2, 1); // daddiu t2, t2, 1
// bc = c->sgpr64(t3) != 0; // bne t3, r0, L80
// c->sw(t2, 0, t0); // sw t2, 0(t0)
// if (bc) {goto block_5;} // branch non-likely
//
// c->gprs[t0].du64[0] = 0; // or t0, r0, r0
// block_7:
c->dsll(t0, a0, 4); // dsll t0, a0, 4
// c->sw(a3, 128, a2); // sw a3, 128(a2)
sadr = c->sgpr64(a3);
// nop // sll r0, r0, 0
// c->sw(a1, 16, a2); // sw a1, 16(a2)
madr = c->sgpr64(a1);
c->addiu(a3, r0, 256); // addiu a3, r0, 256
// c->sw(a0, 32, a2); // sw a0, 32(a2)
qwc = c->sgpr64(a0);
c->daddu(a0, a1, t0); // daddu a0, a1, t0
// c->sw(a3, 0, a2); // sw a3, 0(a2)
spad_from_dma_no_sadr_off(cache.fake_scratchpad_data, madr, sadr, qwc);
// nop // sll r0, r0, 0
c->sw(a0, 60, at); // sw a0, 60(at)
c->gprs[a0].du64[0] = 0; // or a0, r0, r0
c->xori(v1, v1, 4608); // xori v1, v1, 4608
c->sw(v1, 24, at); // sw v1, 24(at)
c->gprs[v0].du64[0] = 0; // or v0, r0, r0
c->ld(ra, 0, sp); // ld ra, 0(sp)
//jr ra // jr ra
c->daddiu(sp, sp, 16); // daddiu sp, sp, 16
goto end_of_function; // return
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
end_of_function:
return c->gprs[v0].du64[0];
}
void link() {
cache.fake_scratchpad_data = intern_from_c(-1, 0, "*fake-scratchpad-data*").c();
gLinkedFunctionTable.reg("generic-translucent", execute, 128);
}
} // namespace generic_translucent
} // namespace Mips2C
//--------------------------MIPS2C---------------------
// clang-format off
#include "game/mips2c/mips2c_private.h"
#include "game/kernel/jak3/kscheme.h"
using ::jak3::intern_from_c;
namespace Mips2C::jak3 {
namespace generic_merc_query {
struct Cache {
void* fake_scratchpad_data; // *fake-scratchpad-data*
void* vector_matrix; // vector-matrix*!
} cache;
u64 execute(void* ctxt) {
auto* c = (ExecutionContext*)ctxt;
bool bc = false;
u32 call_addr = 0;
c->daddiu(sp, sp, -96); // daddiu sp, sp, -96
c->sd(ra, 0, sp); // sd ra, 0(sp)
c->sq(s2, 16, sp); // sq s2, 16(sp)
c->sq(s3, 32, sp); // sq s3, 32(sp)
c->sq(s4, 48, sp); // sq s4, 48(sp)
c->sq(s5, 64, sp); // sq s5, 64(sp)
c->sq(gp, 80, sp); // sq gp, 80(sp)
c->mov64(s4, a0); // or s4, a0, r0
get_fake_spad_addr2(v1, cache.fake_scratchpad_data, 0, c);// lui v1, 28672
c->lwu(gp, 6836, v1); // lwu gp, 6836(v1)
c->lhu(s3, 20, s4); // lhu s3, 20(s4)
c->lw(s2, 24, gp); // lw s2, 24(gp)
c->lw(s5, 20, gp); // lw s5, 20(gp)
c->addiu(v1, r0, 7136); // addiu v1, r0, 7136
get_fake_spad_addr2(a0, cache.fake_scratchpad_data, 0, c);// lui a0, 28672
c->daddu(v1, v1, a0); // daddu v1, v1, a0
c->lwu(v1, 284, v1); // lwu v1, 284(v1)
bc = c->sgpr64(v1) != 0; // bne v1, r0, L73
c->mov64(v1, s7); // or v1, s7, r0
if (bc) {goto block_2;} // branch non-likely
c->addiu(s5, r0, 0); // addiu s5, r0, 0
c->lw(s2, 12, gp); // lw s2, 12(gp)
c->mov64(v1, s2); // or v1, s2, r0
block_2:
//beq r0, r0, L76 // beq r0, r0, L76
// nop // sll r0, r0, 0
goto block_6; // branch always
block_3:
c->lw(v1, 0, gp); // lw v1, 0(gp)
c->slt(v1, s5, v1); // slt v1, s5, v1
bc = c->sgpr64(v1) == 0; // beq v1, r0, L75
c->mov64(v1, s7); // or v1, s7, r0
if (bc) {goto block_5;} // branch non-likely
c->dsll(v1, s5, 4); // dsll v1, s5, 4
c->daddiu(v1, v1, 28); // daddiu v1, v1, 28
c->daddu(a1, v1, gp); // daddu a1, v1, gp
c->dsll(v1, s2, 5); // dsll v1, s2, 5
c->daddu(v1, v1, s4); // daddu v1, v1, s4
c->lwc1(f0, 448, v1); // lwc1 f0, 448(v1)
c->swc1(f0, 0, a1); // swc1 f0, 0(a1)
c->dsll(v1, s2, 5); // dsll v1, s2, 5
c->daddu(v1, v1, s4); // daddu v1, v1, s4
c->lwc1(f0, 452, v1); // lwc1 f0, 452(v1)
c->swc1(f0, 4, a1); // swc1 f0, 4(a1)
c->dsll(v1, s2, 5); // dsll v1, s2, 5
c->daddu(v1, v1, s4); // daddu v1, v1, s4
c->lwc1(f0, 456, v1); // lwc1 f0, 456(v1)
c->swc1(f0, 8, a1); // swc1 f0, 8(a1)
c->lui(v1, 16256); // lui v1, 16256
c->mtc1(f0, v1); // mtc1 f0, v1
c->swc1(f0, 12, a1); // swc1 f0, 12(a1)
c->load_symbol2(t9, cache.vector_matrix); // lw t9, vector-matrix*!(s7)
c->mov64(a0, a1); // or a0, a1, r0
c->addiu(v1, r0, 7264); // addiu v1, r0, 7264
get_fake_spad_addr2(a2, cache.fake_scratchpad_data, 0, c);// lui a2, 28672
c->daddu(a2, v1, a2); // daddu a2, v1, a2
call_addr = c->gprs[t9].du32[0]; // function call:
c->sll(v0, ra, 0); // sll v0, ra, 0
c->jalr(call_addr); // jalr ra, t9
c->daddiu(s5, s5, 1); // daddiu s5, s5, 1
c->mov64(v1, s5); // or v1, s5, r0
block_5:
c->lw(v1, 16, gp); // lw v1, 16(gp)
c->daddu(s2, s2, v1); // daddu s2, s2, v1
block_6:
c->slt(v1, s2, s3); // slt v1, s2, s3
bc = c->sgpr64(v1) != 0; // bne v1, r0, L74
// nop // sll r0, r0, 0
if (bc) {goto block_3;} // branch non-likely
c->mov64(v1, s7); // or v1, s7, r0
c->dsubu(v1, s2, s3); // dsubu v1, s2, s3
c->sw(v1, 24, gp); // sw v1, 24(gp)
c->sw(s5, 20, gp); // sw s5, 20(gp)
c->gprs[v0].du64[0] = 0; // or v0, r0, r0
c->ld(ra, 0, sp); // ld ra, 0(sp)
c->lq(gp, 80, sp); // lq gp, 80(sp)
c->lq(s5, 64, sp); // lq s5, 64(sp)
c->lq(s4, 48, sp); // lq s4, 48(sp)
c->lq(s3, 32, sp); // lq s3, 32(sp)
c->lq(s2, 16, sp); // lq s2, 16(sp)
//jr ra // jr ra
c->daddiu(sp, sp, 96); // daddiu sp, sp, 96
goto end_of_function; // return
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
end_of_function:
return c->gprs[v0].du64[0];
}
void link() {
cache.fake_scratchpad_data = intern_from_c(-1, 0, "*fake-scratchpad-data*").c();
cache.vector_matrix = intern_from_c(-1, 0, "vector-matrix*!").c();
gLinkedFunctionTable.reg("generic-merc-query", execute, 128);
}
} // namespace generic_merc_query
} // namespace Mips2C
//--------------------------MIPS2C---------------------
// clang-format off
#include "game/mips2c/mips2c_private.h"
#include "game/kernel/jak3/kscheme.h"
using ::jak3::intern_from_c;
namespace Mips2C::jak3 {
namespace generic_merc_death {
struct Cache {
void* fake_scratchpad_data; // *fake-scratchpad-data*
void* merc_death_spawn; // merc-death-spawn
void* vector_matrix; // vector-matrix*!
} cache;
u64 execute(void* ctxt) {
auto* c = (ExecutionContext*)ctxt;
bool bc = false;
u32 call_addr = 0;
c->daddiu(sp, sp, -144); // daddiu sp, sp, -144
c->sd(ra, 0, sp); // sd ra, 0(sp)
c->sq(s1, 48, sp); // sq s1, 48(sp)
c->sq(s2, 64, sp); // sq s2, 64(sp)
c->sq(s3, 80, sp); // sq s3, 80(sp)
c->sq(s4, 96, sp); // sq s4, 96(sp)
c->sq(s5, 112, sp); // sq s5, 112(sp)
c->sq(gp, 128, sp); // sq gp, 128(sp)
c->mov64(gp, a0); // or gp, a0, r0
get_fake_spad_addr2(v1, cache.fake_scratchpad_data, 0, c);// lui v1, 28672
c->lhu(s5, 6846, v1); // lhu s5, 6846(v1)
get_fake_spad_addr2(v1, cache.fake_scratchpad_data, 0, c);// lui v1, 28672
c->lhu(s3, 6844, v1); // lhu s3, 6844(v1)
c->lhu(s4, 20, gp); // lhu s4, 20(gp)
c->daddiu(s2, sp, 16); // daddiu s2, sp, 16
c->sq(r0, 0, s2); // sq r0, 0(s2)
c->daddiu(s1, sp, 32); // daddiu s1, sp, 32
c->sq(r0, 0, s1); // sq r0, 0(s1)
//beq r0, r0, L71 // beq r0, r0, L71
// nop // sll r0, r0, 0
goto block_2; // branch always
block_1:
c->dsll(v1, s5, 5); // dsll v1, s5, 5
c->daddu(v1, v1, gp); // daddu v1, v1, gp
c->lwc1(f0, 448, v1); // lwc1 f0, 448(v1)
c->swc1(f0, 0, s2); // swc1 f0, 0(s2)
c->dsll(v1, s5, 5); // dsll v1, s5, 5
c->daddu(v1, v1, gp); // daddu v1, v1, gp
c->lwc1(f0, 452, v1); // lwc1 f0, 452(v1)
c->swc1(f0, 4, s2); // swc1 f0, 4(s2)
c->dsll(v1, s5, 5); // dsll v1, s5, 5
c->daddu(v1, v1, gp); // daddu v1, v1, gp
c->lwc1(f0, 456, v1); // lwc1 f0, 456(v1)
c->swc1(f0, 8, s2); // swc1 f0, 8(s2)
c->lui(v1, 16256); // lui v1, 16256
c->mtc1(f0, v1); // mtc1 f0, v1
c->swc1(f0, 12, s2); // swc1 f0, 12(s2)
c->dsll(v1, s5, 5); // dsll v1, s5, 5
c->daddu(v1, v1, gp); // daddu v1, v1, gp
c->lwc1(f0, 464, v1); // lwc1 f0, 464(v1)
c->swc1(f0, 0, s1); // swc1 f0, 0(s1)
c->dsll(v1, s5, 5); // dsll v1, s5, 5
c->daddu(v1, v1, gp); // daddu v1, v1, gp
c->lwc1(f0, 468, v1); // lwc1 f0, 468(v1)
c->swc1(f0, 4, s1); // swc1 f0, 4(s1)
c->dsll(v1, s5, 5); // dsll v1, s5, 5
c->daddu(v1, v1, gp); // daddu v1, v1, gp
c->lwc1(f0, 472, v1); // lwc1 f0, 472(v1)
c->swc1(f0, 8, s1); // swc1 f0, 8(s1)
c->mtc1(f0, r0); // mtc1 f0, r0
c->swc1(f0, 12, s1); // swc1 f0, 12(s1)
c->load_symbol2(t9, cache.vector_matrix); // lw t9, vector-matrix*!(s7)
c->mov64(a0, s2); // or a0, s2, r0
c->mov64(a1, s2); // or a1, s2, r0
c->addiu(v1, r0, 7264); // addiu v1, r0, 7264
get_fake_spad_addr2(a2, cache.fake_scratchpad_data, 0, c);// lui a2, 28672
c->daddu(a2, v1, a2); // daddu a2, v1, a2
call_addr = c->gprs[t9].du32[0]; // function call:
c->sll(v0, ra, 0); // sll v0, ra, 0
c->jalr(call_addr); // jalr ra, t9
c->load_symbol2(t9, cache.vector_matrix); // lw t9, vector-matrix*!(s7)
c->mov64(a0, s1); // or a0, s1, r0
c->mov64(a1, s1); // or a1, s1, r0
c->addiu(v1, r0, 7264); // addiu v1, r0, 7264
get_fake_spad_addr2(a2, cache.fake_scratchpad_data, 0, c);// lui a2, 28672
c->daddu(a2, v1, a2); // daddu a2, v1, a2
call_addr = c->gprs[t9].du32[0]; // function call:
c->sll(v0, ra, 0); // sll v0, ra, 0
c->jalr(call_addr); // jalr ra, t9
c->load_symbol2(t9, cache.merc_death_spawn); // lw t9, merc-death-spawn(s7)
get_fake_spad_addr2(v1, cache.fake_scratchpad_data, 0, c);// lui v1, 28672
c->lwu(a0, 6848, v1); // lwu a0, 6848(v1)
c->mov64(a1, s2); // or a1, s2, r0
c->mov64(a2, s1); // or a2, s1, r0
call_addr = c->gprs[t9].du32[0]; // function call:
c->sll(v0, ra, 0); // sll v0, ra, 0
c->jalr(call_addr); // jalr ra, t9
c->daddu(s5, s5, s3); // daddu s5, s5, s3
block_2:
c->sltu(v1, s5, s4); // sltu v1, s5, s4
bc = c->sgpr64(v1) != 0; // bne v1, r0, L70
// nop // sll r0, r0, 0
if (bc) {goto block_1;} // branch non-likely
c->mov64(v1, s7); // or v1, s7, r0
c->dsubu(a0, s5, s4); // dsubu a0, s5, s4
get_fake_spad_addr2(v1, cache.fake_scratchpad_data, 0, c);// lui v1, 28672
c->sh(a0, 6846, v1); // sh a0, 6846(v1)
c->gprs[v0].du64[0] = 0; // or v0, r0, r0
c->ld(ra, 0, sp); // ld ra, 0(sp)
c->lq(gp, 128, sp); // lq gp, 128(sp)
c->lq(s5, 112, sp); // lq s5, 112(sp)
c->lq(s4, 96, sp); // lq s4, 96(sp)
c->lq(s3, 80, sp); // lq s3, 80(sp)
c->lq(s2, 64, sp); // lq s2, 64(sp)
c->lq(s1, 48, sp); // lq s1, 48(sp)
//jr ra // jr ra
c->daddiu(sp, sp, 144); // daddiu sp, sp, 144
goto end_of_function; // return
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
end_of_function:
return c->gprs[v0].du64[0];
}
void link() {
cache.fake_scratchpad_data = intern_from_c(-1, 0, "*fake-scratchpad-data*").c();
cache.merc_death_spawn = intern_from_c(-1, 0, "merc-death-spawn").c();
cache.vector_matrix = intern_from_c(-1, 0, "vector-matrix*!").c();
gLinkedFunctionTable.reg("generic-merc-death", execute, 256);
}
} // namespace generic_merc_death
} // namespace Mips2C
//--------------------------MIPS2C---------------------
// clang-format off
#include "game/mips2c/mips2c_private.h"
#include "game/kernel/jak3/kscheme.h"
using ::jak3::intern_from_c;
namespace Mips2C::jak3 {
namespace generic_merc_execute_asm {
struct Cache {
void* fake_scratchpad_data; // *fake-scratchpad-data*
void* gsf_buffer; // *gsf-buffer*
void* generic_merc_death; // generic-merc-death
void* generic_merc_query; // generic-merc-query
void* generic_translucent; // generic-translucent
void* generic_warp_dest; // generic-warp-dest
void* generic_warp_envmap_dest; // generic-warp-envmap-dest
void* generic_warp_source; // generic-warp-source
} cache;
u64 execute(void* ctxt) {
u32 madr, sadr, qwc;
auto* c = (ExecutionContext*)ctxt;
bool bc = false;
u32 call_addr = 0;
c->daddiu(sp, sp, -112); // daddiu sp, sp, -112
c->sd(ra, 0, sp); // sd ra, 0(sp)
c->sq(s1, 16, sp); // sq s1, 16(sp)
c->sq(s2, 32, sp); // sq s2, 32(sp)
c->sq(s3, 48, sp); // sq s3, 48(sp)
c->sq(s4, 64, sp); // sq s4, 64(sp)
c->sq(s5, 80, sp); // sq s5, 80(sp)
c->sq(gp, 96, sp); // sq gp, 96(sp)
get_fake_spad_addr2(v1, cache.fake_scratchpad_data, 0, c);// lui v1, 28672
c->lwu(v1, 7456, v1); // lwu v1, 7456(v1)
c->lwu(s2, 0, v1); // lwu s2, 0(v1)
c->addiu(v1, r0, 0); // addiu v1, r0, 0
c->addiu(gp, r0, 0); // addiu gp, r0, 0
c->addiu(s5, r0, 0); // addiu s5, r0, 0
c->load_symbol2(s4, cache.gsf_buffer); // lw s4, *gsf-buffer*(s7)
c->lui(v1, 4096); // lui v1, 4096
c->ori(s3, v1, 54272); // ori s3, v1, 54272
c->addiu(v1, r0, 624); // addiu v1, r0, 624
c->lui(a0, 4096); // lui a0, 4096
c->ori(a0, a0, 54272); // ori a0, a0, 54272
get_fake_spad_addr2(a1, cache.fake_scratchpad_data, 0, c);// lui a1, 28672
c->ori(a1, a1, 88); // ori a1, a1, 88
// dma sync
// c->lw(a2, 0, a0); // lw a2, 0(a0)
// c->andi(a2, a2, 256); // andi a2, a2, 256
// bc = c->sgpr64(a2) == 0; // beq a2, r0, L22
// DANGER jump to delay slot, this MUST be fixed manually!
// c->lw(a2, 0, a1); // lw a2, 0(a1)
// if (bc) {goto block_-1;} // branch non-likely
//
//
// block_1:
// c->lw(a2, 0, a1); // lw a2, 0(a1)
// // nop // sll r0, r0, 0
// c->lw(a3, 0, a0); // lw a3, 0(a0)
// // nop // sll r0, r0, 0
// c->andi(a3, a3, 256); // andi a3, a3, 256
// c->daddiu(a2, a2, 1); // daddiu a2, a2, 1
// bc = c->sgpr64(a3) != 0; // bne a3, r0, L21
// c->sw(a2, 0, a1); // sw a2, 0(a1)
// if (bc) {goto block_1;} // branch non-likely
c->gprs[a0].du64[0] = 0; // or a0, r0, r0
// c->sw(v1, 128, s3); // sw v1, 128(s3)
sadr = c->sgpr64(v1);
// c->sw(s2, 48, s3); // sw s2, 48(s3)
u32 tadr = c->sgpr64(s2);
// c->sw(r0, 32, s3); // sw r0, 32(s3)
// Unknown instr: sync.l
c->addiu(v1, r0, 324); // addiu v1, r0, 324
// c->sw(v1, 0, s3); // sw v1, 0(s3)
spad_to_dma_blerc_chain(cache.fake_scratchpad_data, sadr, tadr);
// Unknown instr: sync.l
//beq r0, r0, L68 // beq r0, r0, L68
// nop // sll r0, r0, 0
goto block_88; // branch always
block_4:
bc = c->sgpr64(gp) != 0; // bne gp, r0, L24
// nop // sll r0, r0, 0
if (bc) {goto block_6;} // branch non-likely
c->addiu(v1, r0, 624); // addiu v1, r0, 624
get_fake_spad_addr2(a0, cache.fake_scratchpad_data, 0, c);// lui a0, 28672
c->daddu(v1, v1, a0); // daddu v1, v1, a0
//beq r0, r0, L25 // beq r0, r0, L25
// nop // sll r0, r0, 0
goto block_7; // branch always
block_6:
c->addiu(v1, r0, 3648); // addiu v1, r0, 3648
get_fake_spad_addr2(a0, cache.fake_scratchpad_data, 0, c);// lui a0, 28672
c->daddu(v1, v1, a0); // daddu v1, v1, a0
block_7:
bc = c->sgpr64(gp) != 0; // bne gp, r0, L26
// nop // sll r0, r0, 0
if (bc) {goto block_9;} // branch non-likely
c->addiu(a0, r0, 3648); // addiu a0, r0, 3648
get_fake_spad_addr2(a1, cache.fake_scratchpad_data, 0, c);// lui a1, 28672
c->daddu(a0, a0, a1); // daddu a0, a0, a1
//beq r0, r0, L27 // beq r0, r0, L27
// nop // sll r0, r0, 0
goto block_10; // branch always
block_9:
c->addiu(a0, r0, 624); // addiu a0, r0, 624
get_fake_spad_addr2(a1, cache.fake_scratchpad_data, 0, c);// lui a1, 28672
c->daddu(a0, a0, a1); // daddu a0, a0, a1
block_10:
bc = c->sgpr64(gp) != 0; // bne gp, r0, L28
// nop // sll r0, r0, 0
if (bc) {goto block_12;} // branch non-likely
c->addiu(a1, r0, 3568); // addiu a1, r0, 3568
get_fake_spad_addr2(a2, cache.fake_scratchpad_data, 0, c);// lui a2, 28672
c->daddu(a1, a1, a2); // daddu a1, a1, a2
//beq r0, r0, L29 // beq r0, r0, L29
// nop // sll r0, r0, 0
goto block_13; // branch always
block_12:
c->addiu(a1, r0, 6592); // addiu a1, r0, 6592
get_fake_spad_addr2(a2, cache.fake_scratchpad_data, 0, c);// lui a2, 28672
c->daddu(a1, a1, a2); // daddu a1, a1, a2
block_13:
bc = c->sgpr64(gp) != 0; // bne gp, r0, L30
// nop // sll r0, r0, 0
if (bc) {goto block_15;} // branch non-likely
c->addiu(a1, r0, 6592); // addiu a1, r0, 6592
get_fake_spad_addr2(a2, cache.fake_scratchpad_data, 0, c);// lui a2, 28672
c->daddu(a1, a1, a2); // daddu a1, a1, a2
//beq r0, r0, L31 // beq r0, r0, L31
// nop // sll r0, r0, 0
goto block_16; // branch always
block_15:
c->addiu(a1, r0, 3568); // addiu a1, r0, 3568
get_fake_spad_addr2(a2, cache.fake_scratchpad_data, 0, c);// lui a2, 28672
c->daddu(a1, a1, a2); // daddu a1, a1, a2
block_16:
bc = c->sgpr64(gp) != 0; // bne gp, r0, L32
// nop // sll r0, r0, 0
if (bc) {goto block_18;} // branch non-likely
c->daddu(s1, r0, s4); // daddu s1, r0, s4
//beq r0, r0, L33 // beq r0, r0, L33
// nop // sll r0, r0, 0
goto block_19; // branch always
block_18:
c->daddiu(s1, s4, 2752); // daddiu s1, s4, 2752
block_19:
bc = c->sgpr64(gp) != 0; // bne gp, r0, L34
// nop // sll r0, r0, 0
if (bc) {goto block_21;} // branch non-likely
c->daddiu(a1, s4, 2752); // daddiu a1, s4, 2752
//beq r0, r0, L35 // beq r0, r0, L35
// nop // sll r0, r0, 0
goto block_22; // branch always
block_21:
c->daddu(a1, r0, s4); // daddu a1, r0, s4
block_22:
c->addiu(a2, r0, 7136); // addiu a2, r0, 7136
get_fake_spad_addr2(a3, cache.fake_scratchpad_data, 0, c);// lui a3, 28672
c->daddu(a2, a2, a3); // daddu a2, a2, a3
c->sw(gp, 280, a2); // sw gp, 280(a2)
c->sw(s5, 284, a2); // sw s5, 284(a2)
c->sw(v1, 292, a2); // sw v1, 292(a2)
c->sw(a0, 296, a2); // sw a0, 296(a2)
c->sw(s1, 300, a2); // sw s1, 300(a2)
c->sw(a1, 304, a2); // sw a1, 304(a2)
c->sw(s4, 312, a2); // sw s4, 312(a2)
c->mov64(a1, s4); // or a1, s4, r0
c->lui(a1, 4096); // lui a1, 4096
c->ori(a1, a1, 54272); // ori a1, a1, 54272
get_fake_spad_addr2(a2, cache.fake_scratchpad_data, 0, c);// lui a2, 28672
c->ori(a2, a2, 88); // ori a2, a2, 88
// dma sync
// c->lw(a3, 0, a1); // lw a3, 0(a1)
// c->andi(a3, a3, 256); // andi a3, a3, 256
// bc = c->sgpr64(a3) == 0; // beq a3, r0, L37
// DANGER jump to delay slot, this MUST be fixed manually!
// c->lw(a3, 0, a2); // lw a3, 0(a2)
// if (bc) {goto block_-1;} // branch non-likely
//
//
// block_23:
// c->lw(a3, 0, a2); // lw a3, 0(a2)
// // nop // sll r0, r0, 0
// c->lw(t0, 0, a1); // lw t0, 0(a1)
// // nop // sll r0, r0, 0
// c->andi(t0, t0, 256); // andi t0, t0, 256
// c->daddiu(a3, a3, 1); // daddiu a3, a3, 1
// bc = c->sgpr64(t0) != 0; // bne t0, r0, L36
// c->sw(a3, 0, a2); // sw a3, 0(a2)
// if (bc) {goto block_23;} // branch non-likely
c->gprs[a1].du64[0] = 0; // or a1, r0, r0
c->lwu(s2, 12, v1); // lwu s2, 12(v1)
bc = c->sgpr64(s2) == 0; // beq s2, r0, L38
c->mov64(a1, s7); // or a1, s7, r0
if (bc) {goto block_27;} // branch non-likely
c->daddu(a0, r0, a0); // daddu a0, r0, a0
c->andi(a0, a0, 65535); // andi a0, a0, 65535
// c->sw(a0, 128, s3); // sw a0, 128(s3)
sadr = c->sgpr64(a0);
// c->sw(s2, 48, s3); // sw s2, 48(s3)
tadr = c->sgpr64(s2);
// c->sw(r0, 32, s3); // sw r0, 32(s3)
// Unknown instr: sync.l
c->addiu(a0, r0, 324); // addiu a0, r0, 324
// c->sw(a0, 0, s3); // sw a0, 0(s3)
// hack - I don't really know why, but the andi above puts sadr into a 64 kb
// range instead of a 16 kB range. I believe the hardware will just mask it.
// or, maybe there's something else wrong? Not sure, but the transfer does seem to go
// to the right spot when I use this.
spad_to_dma_blerc_chain(cache.fake_scratchpad_data, sadr & 0x3fff, tadr);
// Unknown instr: sync.l
c->gprs[a0].du64[0] = 0; // or a0, r0, r0
block_27:
bc = c->sgpr64(s5) != 0; // bne s5, r0, L47
c->mov64(a0, s7); // or a0, s7, r0
if (bc) {goto block_44;} // branch non-likely
c->addiu(a0, r0, 6672); // addiu a0, r0, 6672
get_fake_spad_addr2(a1, cache.fake_scratchpad_data, 0, c);// lui a1, 28672
c->daddu(a1, a0, a1); // daddu a1, a0, a1
c->mov64(a2, v1); // or a2, v1, r0
c->lwu(a0, 8, v1); // lwu a0, 8(v1)
// nop // sll r0, r0, 0
c->daddiu(a3, a0, -4); // daddiu a3, a0, -4
c->mov64(a1, a1); // or a1, a1, r0
bc = ((s64)c->sgpr64(a3)) < 0; // bltz a3, L40
c->mov64(a2, a2); // or a2, a2, r0
if (bc) {goto block_30;} // branch non-likely
block_29:
// nop // sll r0, r0, 0
c->lq(t2, 0, a2); // lq t2, 0(a2)
// nop // sll r0, r0, 0
c->lq(a3, 16, a2); // lq a3, 16(a2)
c->daddiu(a0, a0, -4); // daddiu a0, a0, -4
c->lq(t0, 32, a2); // lq t0, 32(a2)
c->daddiu(a1, a1, 64); // daddiu a1, a1, 64
c->lq(t1, 48, a2); // lq t1, 48(a2)
c->daddiu(a2, a2, 64); // daddiu a2, a2, 64
c->sq(t2, -64, a1); // sq t2, -64(a1)
c->daddiu(t2, a0, -4); // daddiu t2, a0, -4
c->sq(a3, -48, a1); // sq a3, -48(a1)
// nop // sll r0, r0, 0
c->sq(t0, -32, a1); // sq t0, -32(a1)
bc = ((s64)c->sgpr64(t2)) >= 0; // bgez t2, L39
c->sq(t1, -16, a1); // sq t1, -16(a1)
if (bc) {goto block_29;} // branch non-likely
block_30:
bc = c->sgpr64(a0) == 0; // beq a0, r0, L41
c->lq(a3, 0, a2); // lq a3, 0(a2)
if (bc) {goto block_35;} // branch non-likely
c->daddiu(a2, a2, 16); // daddiu a2, a2, 16
c->daddiu(a1, a1, 16); // daddiu a1, a1, 16
c->daddiu(a0, a0, -1); // daddiu a0, a0, -1
c->sq(a3, -16, a1); // sq a3, -16(a1)
bc = c->sgpr64(a0) == 0; // beq a0, r0, L41
c->lq(a3, 0, a2); // lq a3, 0(a2)
if (bc) {goto block_35;} // branch non-likely
c->daddiu(a2, a2, 16); // daddiu a2, a2, 16
c->daddiu(a1, a1, 16); // daddiu a1, a1, 16
c->daddiu(a0, a0, -1); // daddiu a0, a0, -1
c->sq(a3, -16, a1); // sq a3, -16(a1)
bc = c->sgpr64(a0) == 0; // beq a0, r0, L41
c->lq(a3, 0, a2); // lq a3, 0(a2)
if (bc) {goto block_35;} // branch non-likely
c->daddiu(a2, a2, 16); // daddiu a2, a2, 16
c->daddiu(a1, a1, 16); // daddiu a1, a1, 16
c->daddiu(a0, a0, -1); // daddiu a0, a0, -1
c->sq(a3, -16, a1); // sq a3, -16(a1)
bc = c->sgpr64(a0) == 0; // beq a0, r0, L41
c->lq(a3, 0, a2); // lq a3, 0(a2)
if (bc) {goto block_35;} // branch non-likely
c->daddiu(a2, a2, 16); // daddiu a2, a2, 16
c->daddiu(a1, a1, 16); // daddiu a1, a1, 16
c->daddiu(a0, a0, -1); // daddiu a0, a0, -1
c->sq(a3, -16, a1); // sq a3, -16(a1)
block_35:
c->gprs[a0].du64[0] = 0; // or a0, r0, r0
get_fake_spad_addr2(a0, cache.fake_scratchpad_data, 0, c);// lui a0, 28672
c->lbu(a0, 6840, a0); // lbu a0, 6840(a0)
bc = c->sgpr64(a0) != 0; // bne a0, r0, L42
// nop // sll r0, r0, 0
if (bc) {goto block_37;} // branch non-likely
c->addiu(a0, r0, 8); // addiu a0, r0, 8
//beq r0, r0, L43 // beq r0, r0, L43
// nop // sll r0, r0, 0
goto block_38; // branch always
block_37:
c->addiu(a0, r0, 6); // addiu a0, r0, 6
block_38:
get_fake_spad_addr2(a1, cache.fake_scratchpad_data, 0, c);// lui a1, 28672
c->ori(a1, a1, 11984); // ori a1, a1, 11984
c->sh(a0, 0, a1); // sh a0, 0(a1)
c->addiu(a0, r0, 12048); // addiu a0, r0, 12048
get_fake_spad_addr2(a1, cache.fake_scratchpad_data, 0, c);// lui a1, 28672
c->daddu(a0, a0, a1); // daddu a0, a0, a1
get_fake_spad_addr2(a1, cache.fake_scratchpad_data, 0, c);// lui a1, 28672
c->lwu(a1, 6832, a1); // lwu a1, 6832(a1)
c->sw(a1, 0, a0); // sw a1, 0(a0)
c->sw(a1, 4, a0); // sw a1, 4(a0)
c->sw(a1, 8, a0); // sw a1, 8(a0)
c->sw(a1, 12, a0); // sw a1, 12(a0)
get_fake_spad_addr2(a1, cache.fake_scratchpad_data, 0, c);// lui a1, 28672
c->addiu(a0, a1, 7136); // addiu a0, a1, 7136
c->lbu(a2, 6841, a1); // lbu a2, 6841(a1)
c->addiu(a3, a1, 7200); // addiu a3, a1, 7200
c->addiu(a1, a1, 11808); // addiu a1, a1, 11808
c->movn(a0, a3, a2); // movn a0, a3, a2
c->lq(a2, 0, a0); // lq a2, 0(a0)
c->lq(a3, 16, a0); // lq a3, 16(a0)
c->lq(t0, 32, a0); // lq t0, 32(a0)
c->lq(a0, 48, a0); // lq a0, 48(a0)
c->sq(a2, 0, a1); // sq a2, 0(a1)
c->sq(a3, 16, a1); // sq a3, 16(a1)
c->sq(t0, 32, a1); // sq t0, 32(a1)
c->sq(a0, 48, a1); // sq a0, 48(a1)
get_fake_spad_addr2(a0, cache.fake_scratchpad_data, 0, c);// lui a0, 28672
c->lbu(a0, 6843, a0); // lbu a0, 6843(a0)
get_fake_spad_addr2(a1, cache.fake_scratchpad_data, 0, c);// lui a1, 28672
c->sb(a0, 6853, a1); // sb a0, 6853(a1)
get_fake_spad_addr2(at, cache.fake_scratchpad_data, 0, c);// lui at, 28672
c->lqc2(vf1, 6688, at); // lqc2 vf1, 6688(at)
c->lqc2(vf2, 6704, at); // lqc2 vf2, 6704(at)
c->lqc2(vf3, 6720, at); // lqc2 vf3, 6720(at)
c->lqc2(vf4, 6736, at); // lqc2 vf4, 6736(at)
c->lqc2(vf5, 6752, at); // lqc2 vf5, 6752(at)
c->lqc2(vf6, 6768, at); // lqc2 vf6, 6768(at)
c->lqc2(vf7, 6784, at); // lqc2 vf7, 6784(at)
c->sqc2(vf1, 12688, at); // sqc2 vf1, 12688(at)
c->sqc2(vf2, 12704, at); // sqc2 vf2, 12704(at)
c->sqc2(vf3, 12720, at); // sqc2 vf3, 12720(at)
c->sqc2(vf4, 12736, at); // sqc2 vf4, 12736(at)
c->sqc2(vf5, 12752, at); // sqc2 vf5, 12752(at)
c->sqc2(vf6, 12768, at); // sqc2 vf6, 12768(at)
c->sqc2(vf7, 12784, at); // sqc2 vf7, 12784(at)
get_fake_spad_addr2(a0, cache.fake_scratchpad_data, 0, c);// lui a0, 28672
c->lbu(a0, 6852, a0); // lbu a0, 6852(a0)
c->andi(a0, a0, 2); // andi a0, a0, 2
bc = c->sgpr64(a0) == 0; // beq a0, r0, L44
// nop // sll r0, r0, 0
if (bc) {goto block_40;} // branch non-likely
c->lui(a0, 12342); // lui a0, 12342
c->ori(a0, a0, 16384); // ori a0, a0, 16384
get_fake_spad_addr2(a1, cache.fake_scratchpad_data, 0, c);// lui a1, 28672
c->sw(a0, 11876, a1); // sw a0, 11876(a1)
c->lui(a0, 12342); // lui a0, 12342
c->ori(a1, a0, 49152); // ori a1, a0, 49152
get_fake_spad_addr2(a0, cache.fake_scratchpad_data, 0, c);// lui a0, 28672
c->sw(a1, 11872, a0); // sw a1, 11872(a0)
//beq r0, r0, L45 // beq r0, r0, L45
// nop // sll r0, r0, 0
goto block_41; // branch always
block_40:
c->lui(a0, 12350); // lui a0, 12350
c->ori(a0, a0, 16384); // ori a0, a0, 16384
get_fake_spad_addr2(a1, cache.fake_scratchpad_data, 0, c);// lui a1, 28672
c->sw(a0, 11876, a1); // sw a0, 11876(a1)
c->lui(a0, 12350); // lui a0, 12350
c->ori(a1, a0, 49152); // ori a1, a0, 49152
get_fake_spad_addr2(a0, cache.fake_scratchpad_data, 0, c);// lui a0, 28672
c->sw(a1, 11872, a0); // sw a1, 11872(a0)
block_41:
get_fake_spad_addr2(a0, cache.fake_scratchpad_data, 0, c);// lui a0, 28672
c->lbu(a0, 6856, a0); // lbu a0, 6856(a0)
c->addiu(a1, r0, 128); // addiu a1, r0, 128
c->sltu(a1, a1, a0); // sltu a1, a1, a0
bc = c->sgpr64(a1) != 0; // bne a1, r0, L46
c->mov64(a1, s7); // or a1, s7, r0
if (bc) {goto block_43;} // branch non-likely
c->lui(a1, 15360); // lui a1, 15360
c->mtc1(f0, a1); // mtc1 f0, a1
c->mtc1(f1, a0); // mtc1 f1, a0
c->cvtsw(f1, f1); // cvt.s.w f1, f1
c->muls(f0, f0, f1); // mul.s f0, f0, f1
get_fake_spad_addr2(a0, cache.fake_scratchpad_data, 0, c);// lui a0, 28672
c->lwc1(f1, 12796, a0); // lwc1 f1, 12796(a0)
c->muls(f0, f0, f1); // mul.s f0, f0, f1
get_fake_spad_addr2(a0, cache.fake_scratchpad_data, 0, c);// lui a0, 28672
c->swc1(f0, 12796, a0); // swc1 f0, 12796(a0)
c->mfc1(a1, f0); // mfc1 a1, f0
block_43:
c->lwu(a0, 8, v1); // lwu a0, 8(v1)
c->dsll(a0, a0, 4); // dsll a0, a0, 4
c->daddu(v1, v1, a0); // daddu v1, v1, a0
c->mov64(a0, v1); // or a0, v1, r0
block_44:
c->addiu(a0, r0, 7136); // addiu a0, r0, 7136
get_fake_spad_addr2(a1, cache.fake_scratchpad_data, 0, c);// lui a1, 28672
c->daddu(a0, a0, a1); // daddu a0, a0, a1
c->daddiu(v1, v1, 16); // daddiu v1, v1, 16
c->sw(v1, 308, a0); // sw v1, 308(a0)
get_fake_spad_addr2(v1, cache.fake_scratchpad_data, 0, c);// lui v1, 28672
c->lwu(t9, 7460, v1); // lwu t9, 7460(v1)
call_addr = c->gprs[t9].du32[0]; // function call:
c->sll(v0, ra, 0); // sll v0, ra, 0
// c->jalr(call_addr); // jalr ra, t9
mercneric_convert::execute(c);
get_fake_spad_addr2(v1, cache.fake_scratchpad_data, 0, c);// lui v1, 28672
c->addiu(a0, r0, 1); // addiu a0, r0, 1
c->lbu(a1, 6840, v1); // lbu a1, 6840(v1)
c->daddiu(a2, s1, 448); // daddiu a2, s1, 448
c->lbu(a3, 6843, v1); // lbu a3, 6843(v1)
bc = c->sgpr64(a1) == 0; // beq a1, r0, L49
c->lqc2(vf1, 0, a2); // lqc2 vf1, 0(a2)
if (bc) {goto block_50;} // branch non-likely
bc = c->sgpr64(a3) == 0; // beq a3, r0, L49
c->vmax_bc(DEST::xyzw, BC::w, vf9, vf0, vf0); // vmaxw.xyzw vf9, vf0, vf0
if (bc) {goto block_50;} // branch non-likely
c->sb(a0, 6853, v1); // sb a0, 6853(v1)
c->lqc2(vf10, 7488, v1); // lqc2 vf10, 7488(v1)
c->lqc2(vf11, 7504, v1); // lqc2 vf11, 7504(v1)
c->vmula_bc(DEST::xyzw, BC::z, vf9, vf1); // vmulaz.xyzw acc, vf9, vf1
c->lw(a0, 8, a2); // lw a0, 8(a2)
c->vmadda_bc(DEST::xyzw, BC::x, vf10, vf1); // vmaddax.xyzw acc, vf10, vf1
bc = ((s64)c->sgpr64(a0)) < 0; // bltz a0, L48
c->lw(v1, 7480, v1); // lw v1, 7480(v1)
if (bc) {goto block_48;} // branch non-likely
c->vmadd_bc(DEST::xyzw, BC::y, vf1, vf11, vf1); // vmaddy.xyzw vf1, vf11, vf1
c->mov128_gpr_vf(a0, vf1); // qmfc2.i a0, vf1
c->pcgtw(a0, r0, a0); // pcgtw a0, r0, a0
c->ppach(a0, r0, a0); // ppach a0, r0, a0
bc = c->sgpr64(a0) == 0; // beq a0, r0, L49
// DANGER jump to delay slot, this MUST be fixed manually!
// nop // sll r0, r0, 0
if (bc) {goto block_50;} // branch non-likely
block_48:
// nop // sll r0, r0, 0
call_addr = c->gprs[v1].du32[0]; // function call:
// nop // sll r0, r0, 0
c->jalr(call_addr); // jalr ra, v1
// high_speed_reject::execute(c);
block_50:
get_fake_spad_addr2(v1, cache.fake_scratchpad_data, 0, c);// lui v1, 28672
c->lwu(v1, 6836, v1); // lwu v1, 6836(v1)
bc = c->sgpr64(v1) == 0; // beq v1, r0, L50
c->mov64(v1, s7); // or v1, s7, r0
if (bc) {goto block_52;} // branch non-likely
c->load_symbol2(t9, cache.generic_merc_query); // lw t9, generic-merc-query(s7)
c->mov64(a0, s1); // or a0, s1, r0
call_addr = c->gprs[t9].du32[0]; // function call:
c->sll(v0, ra, 0); // sll v0, ra, 0
c->jalr(call_addr); // jalr ra, t9
c->mov64(v1, v0); // or v1, v0, r0
block_52:
get_fake_spad_addr2(v1, cache.fake_scratchpad_data, 0, c);// lui v1, 28672
c->lhu(v1, 6844, v1); // lhu v1, 6844(v1)
bc = c->sgpr64(v1) == 0; // beq v1, r0, L51
c->mov64(v1, s7); // or v1, s7, r0
if (bc) {goto block_54;} // branch non-likely
c->load_symbol2(t9, cache.generic_merc_death); // lw t9, generic-merc-death(s7)
c->mov64(a0, s1); // or a0, s1, r0
call_addr = c->gprs[t9].du32[0]; // function call:
c->sll(v0, ra, 0); // sll v0, ra, 0
c->jalr(call_addr); // jalr ra, t9
c->mov64(v1, v0); // or v1, v0, r0
block_54:
get_fake_spad_addr2(v1, cache.fake_scratchpad_data, 0, c);// lui v1, 28672
c->lw(v1, 7424, v1); // lw v1, 7424(v1)
get_fake_spad_addr2(a0, cache.fake_scratchpad_data, 0, c);// lui a0, 28672
c->lwu(a0, 60, a0); // lwu a0, 60(a0)
c->dsubu(v1, v1, a0); // dsubu v1, v1, a0
c->slt(v1, r0, v1); // slt v1, r0, v1
bc = c->sgpr64(v1) != 0; // bne v1, r0, L52
c->mov64(v1, s7); // or v1, s7, r0
if (bc) {goto block_56;} // branch non-likely
get_fake_spad_addr2(v1, cache.fake_scratchpad_data, 0, c);// lui v1, 28672
c->sb(r0, 6853, v1); // sb r0, 6853(v1)
get_fake_spad_addr2(v1, cache.fake_scratchpad_data, 0, c);// lui v1, 28672
c->sb(r0, 6843, v1); // sb r0, 6843(v1)
c->gprs[v1].du64[0] = 0; // or v1, r0, r0
block_56:
get_fake_spad_addr2(v1, cache.fake_scratchpad_data, 0, c);// lui v1, 28672
c->lbu(v1, 6853, v1); // lbu v1, 6853(v1)
bc = c->sgpr64(v1) == 0; // beq v1, r0, L66
c->mov64(v1, s7); // or v1, s7, r0
if (bc) {goto block_85;} // branch non-likely
c->addiu(v1, r0, 1); // addiu v1, r0, 1
get_fake_spad_addr2(a0, cache.fake_scratchpad_data, 0, c);// lui a0, 28672
c->lbu(a0, 6854, a0); // lbu a0, 6854(a0)
bc = c->sgpr64(a0) != c->sgpr64(v1); // bne a0, v1, L53
// nop // sll r0, r0, 0
if (bc) {goto block_59;} // branch non-likely
c->load_symbol2(t9, cache.generic_warp_source); // lw t9, generic-warp-source(s7)
c->mov64(a0, s1); // or a0, s1, r0
call_addr = c->gprs[t9].du32[0]; // function call:
c->sll(v0, ra, 0); // sll v0, ra, 0
c->jalr(call_addr); // jalr ra, t9
c->mov64(v1, v0); // or v1, v0, r0
//beq r0, r0, L66 // beq r0, r0, L66
// nop // sll r0, r0, 0
goto block_85; // branch always
block_59:
c->addiu(v1, r0, 2); // addiu v1, r0, 2
get_fake_spad_addr2(a0, cache.fake_scratchpad_data, 0, c);// lui a0, 28672
c->lbu(a0, 6854, a0); // lbu a0, 6854(a0)
bc = c->sgpr64(a0) != c->sgpr64(v1); // bne a0, v1, L56
// nop // sll r0, r0, 0
if (bc) {goto block_64;} // branch non-likely
get_fake_spad_addr2(v1, cache.fake_scratchpad_data, 0, c);// lui v1, 28672
c->lbu(v1, 6955, v1); // lbu v1, 6955(v1)
c->andi(v1, v1, 1); // andi v1, v1, 1
bc = c->sgpr64(v1) == 0; // beq v1, r0, L54
// nop // sll r0, r0, 0
if (bc) {goto block_62;} // branch non-likely
c->load_symbol2(t9, cache.generic_warp_envmap_dest);// lw t9, generic-warp-envmap-dest(s7)
c->mov64(a0, s1); // or a0, s1, r0
call_addr = c->gprs[t9].du32[0]; // function call:
c->sll(v0, ra, 0); // sll v0, ra, 0
c->jalr(call_addr); // jalr ra, t9
c->mov64(v1, v0); // or v1, v0, r0
//beq r0, r0, L55 // beq r0, r0, L55
// nop // sll r0, r0, 0
goto block_63; // branch always
block_62:
c->load_symbol2(t9, cache.generic_warp_dest); // lw t9, generic-warp-dest(s7)
c->mov64(a0, s1); // or a0, s1, r0
call_addr = c->gprs[t9].du32[0]; // function call:
c->sll(v0, ra, 0); // sll v0, ra, 0
// c->jalr(call_addr); // jalr ra, t9
generic_warp_dest::execute(c);
c->mov64(v1, v0); // or v1, v0, r0
block_63:
//beq r0, r0, L66 // beq r0, r0, L66
// nop // sll r0, r0, 0
goto block_85; // branch always
block_64:
get_fake_spad_addr2(v1, cache.fake_scratchpad_data, 0, c);// lui v1, 28672
c->lbu(v1, 6955, v1); // lbu v1, 6955(v1)
c->andi(v1, v1, 1); // andi v1, v1, 1
if (((s64)c->sgpr64(v1)) == ((s64)0)) { // beql v1, r0, L57
c->mov64(v1, s7); // or v1, s7, r0
goto block_67;
}
// block_66:
c->daddiu(v1, s7, 4); // daddiu v1, s7, 4
get_fake_spad_addr2(a0, cache.fake_scratchpad_data, 0, c);// lui a0, 28672
c->lbu(a0, 6852, a0); // lbu a0, 6852(a0)
c->andi(a0, a0, 1); // andi a0, a0, 1
c->movz(v1, s7, a0); // movz v1, s7, a0
block_67:
bc = c->sgpr64(s7) == c->sgpr64(v1); // beq s7, v1, L58
// nop // sll r0, r0, 0
if (bc) {goto block_69;} // branch non-likely
c->load_symbol2(t9, cache.generic_translucent); // lw t9, generic-translucent(s7)
c->mov64(a0, s1); // or a0, s1, r0
call_addr = c->gprs[t9].du32[0]; // function call:
c->sll(v0, ra, 0); // sll v0, ra, 0
c->jalr(call_addr); // jalr ra, t9
c->mov64(v1, v0); // or v1, v0, r0
//beq r0, r0, L66 // beq r0, r0, L66
// nop // sll r0, r0, 0
goto block_85; // branch always
block_69:
get_fake_spad_addr2(v1, cache.fake_scratchpad_data, 0, c);// lui v1, 28672
c->lbu(v1, 6955, v1); // lbu v1, 6955(v1)
c->andi(v1, v1, 1); // andi v1, v1, 1
if (((s64)c->sgpr64(v1)) == ((s64)0)) { // beql v1, r0, L59
c->mov64(v1, s7); // or v1, s7, r0
goto block_72;
}
// block_71:
get_fake_spad_addr2(v1, cache.fake_scratchpad_data, 0, c);// lui v1, 28672
c->lbu(v1, 6858, v1); // lbu v1, 6858(v1)
c->daddiu(a0, v1, -1); // daddiu a0, v1, -1
c->daddiu(v1, s7, 4); // daddiu v1, s7, 4
c->movz(v1, s7, a0); // movz v1, s7, a0
block_72:
bc = c->sgpr64(s7) == c->sgpr64(v1); // beq s7, v1, L63
// nop // sll r0, r0, 0
if (bc) {goto block_80;} // branch non-likely
get_fake_spad_addr2(at, cache.fake_scratchpad_data, 0, c);// lui at, 28672
c->mov64(v1, s1); // or v1, s1, r0
c->daddiu(a0, at, 12064); // daddiu a0, at, 12064
get_fake_spad_addr2(a1, cache.fake_scratchpad_data, 0, c);// lui a1, 28672
c->lbu(a1, 6842, a1); // lbu a1, 6842(a1)
bc = c->sgpr64(a1) == 0; // beq a1, r0, L60
c->mov64(a1, s7); // or a1, s7, r0
if (bc) {goto block_75;} // branch non-likely
c->addiu(a0, r0, 6960); // addiu a0, r0, 6960
get_fake_spad_addr2(a1, cache.fake_scratchpad_data, 0, c);// lui a1, 28672
c->daddu(a0, a0, a1); // daddu a0, a0, a1
c->mov64(a0, a0); // or a0, a0, r0
c->mov64(a1, a0); // or a1, a0, r0
block_75:
c->sw(r0, 48, at); // sw r0, 48(at)
c->sw(a0, 52, at); // sw a0, 52(at)
c->sw(v1, 44, at); // sw v1, 44(at)
get_fake_spad_addr2(v1, cache.fake_scratchpad_data, 0, c);// lui v1, 28672
c->lwu(t9, 7468, v1); // lwu t9, 7468(v1)
call_addr = c->gprs[t9].du32[0]; // function call:
c->sll(v0, ra, 0); // sll v0, ra, 0
// c->jalr(call_addr); // jalr ra, t9
generic_prepare_dma_double::execute(c);
get_fake_spad_addr2(v1, cache.fake_scratchpad_data, 0, c);// lui v1, 28672
c->lwu(t9, 7472, v1); // lwu t9, 7472(v1)
call_addr = c->gprs[t9].du32[0]; // function call:
c->sll(v0, ra, 0); // sll v0, ra, 0
// c->jalr(call_addr); // jalr ra, t9
generic_light_proc::execute(c);
get_fake_spad_addr2(v1, cache.fake_scratchpad_data, 0, c);// lui v1, 28672
c->lwu(t9, 7476, v1); // lwu t9, 7476(v1)
call_addr = c->gprs[t9].du32[0]; // function call:
c->sll(v0, ra, 0); // sll v0, ra, 0
// c->jalr(call_addr); // jalr ra, t9
generic_envmap_proc::execute(c);
c->lw(v1, 24, at); // lw v1, 24(at)
c->lw(a0, 40, at); // lw a0, 40(at)
c->mov64(a3, v1); // or a3, v1, r0
get_fake_spad_addr2(at, cache.fake_scratchpad_data, 0, c);// lui at, 28672
c->lui(a2, 4096); // lui a2, 4096
c->lwu(a1, 60, at); // lwu a1, 60(at)
c->ori(a2, a2, 53248); // ori a2, a2, 53248
// c->lw(t1, 0, a2); // lw t1, 0(a2)
// nop // sll r0, r0, 0
c->daddiu(t0, at, 92); // daddiu t0, at, 92
c->andi(a3, a3, 16383); // andi a3, a3, 16383
c->andi(t1, t1, 256); // andi t1, t1, 256
// nop // sll r0, r0, 0
// dma sync
// bc = c->sgpr64(t1) == 0; // beq t1, r0, L62
// // nop // sll r0, r0, 0
// if (bc) {goto block_79;} // branch non-likely
//
// c->mov64(t1, a2); // or t1, a2, r0
// // nop // sll r0, r0, 0
//
// block_77:
// c->lw(t2, 0, t0); // lw t2, 0(t0)
// // nop // sll r0, r0, 0
// c->lw(t3, 0, t1); // lw t3, 0(t1)
// // nop // sll r0, r0, 0
// c->andi(t3, t3, 256); // andi t3, t3, 256
// c->daddiu(t2, t2, 1); // daddiu t2, t2, 1
// bc = c->sgpr64(t3) != 0; // bne t3, r0, L61
// c->sw(t2, 0, t0); // sw t2, 0(t0)
// if (bc) {goto block_77;} // branch non-likely
//
// c->gprs[t0].du64[0] = 0; // or t0, r0, r0
// block_79:
c->dsll(t0, a0, 4); // dsll t0, a0, 4
// c->sw(a3, 128, a2); // sw a3, 128(a2)
sadr = c->sgpr64(a3);
// nop // sll r0, r0, 0
// c->sw(a1, 16, a2); // sw a1, 16(a2)
madr = c->sgpr64(a1);
c->addiu(a3, r0, 256); // addiu a3, r0, 256
// c->sw(a0, 32, a2); // sw a0, 32(a2)
qwc = c->sgpr64(a0);
c->daddu(a0, a1, t0); // daddu a0, a1, t0
// c->sw(a3, 0, a2); // sw a3, 0(a2)
spad_from_dma_no_sadr_off(cache.fake_scratchpad_data, madr, sadr, qwc);
// nop // sll r0, r0, 0
c->sw(a0, 60, at); // sw a0, 60(at)
c->gprs[a0].du64[0] = 0; // or a0, r0, r0
c->xori(v1, v1, 4608); // xori v1, v1, 4608
c->sw(v1, 24, at); // sw v1, 24(at)
//beq r0, r0, L66 // beq r0, r0, L66
// nop // sll r0, r0, 0
goto block_85; // branch always
block_80:
get_fake_spad_addr2(at, cache.fake_scratchpad_data, 0, c);// lui at, 28672
c->mov64(v1, s1); // or v1, s1, r0
c->sw(r0, 48, at); // sw r0, 48(at)
c->sw(v1, 44, at); // sw v1, 44(at)
c->sh(r0, 56, at); // sh r0, 56(at)
get_fake_spad_addr2(v1, cache.fake_scratchpad_data, 0, c);// lui v1, 28672
c->lwu(t9, 7464, v1); // lwu t9, 7464(v1)
call_addr = c->gprs[t9].du32[0]; // function call:
c->sll(v0, ra, 0); // sll v0, ra, 0
// c->jalr(call_addr); // jalr ra, t9
generic_prepare_dma_single::execute_real(c);
get_fake_spad_addr2(v1, cache.fake_scratchpad_data, 0, c);// lui v1, 28672
c->lwu(t9, 7472, v1); // lwu t9, 7472(v1)
call_addr = c->gprs[t9].du32[0]; // function call:
c->sll(v0, ra, 0); // sll v0, ra, 0
// c->jalr(call_addr); // jalr ra, t9
generic_light_proc::execute(c);
c->lw(v1, 24, at); // lw v1, 24(at)
c->lw(a0, 40, at); // lw a0, 40(at)
c->mov64(a3, v1); // or a3, v1, r0
get_fake_spad_addr2(at, cache.fake_scratchpad_data, 0, c);// lui at, 28672
c->lui(a2, 4096); // lui a2, 4096
c->lwu(a1, 60, at); // lwu a1, 60(at)
c->ori(a2, a2, 53248); // ori a2, a2, 53248
// c->lw(t1, 0, a2); // lw t1, 0(a2)
// nop // sll r0, r0, 0
c->daddiu(t0, at, 92); // daddiu t0, at, 92
c->andi(a3, a3, 16383); // andi a3, a3, 16383
c->andi(t1, t1, 256); // andi t1, t1, 256
// nop // sll r0, r0, 0
// dma sync
// bc = c->sgpr64(t1) == 0; // beq t1, r0, L65
// // nop // sll r0, r0, 0
// if (bc) {goto block_84;} // branch non-likely
//
// c->mov64(t1, a2); // or t1, a2, r0
// // nop // sll r0, r0, 0
//
// block_82:
// c->lw(t2, 0, t0); // lw t2, 0(t0)
// // nop // sll r0, r0, 0
// c->lw(t3, 0, t1); // lw t3, 0(t1)
// // nop // sll r0, r0, 0
// c->andi(t3, t3, 256); // andi t3, t3, 256
// c->daddiu(t2, t2, 1); // daddiu t2, t2, 1
// bc = c->sgpr64(t3) != 0; // bne t3, r0, L64
// c->sw(t2, 0, t0); // sw t2, 0(t0)
// if (bc) {goto block_82;} // branch non-likely
c->gprs[t0].du64[0] = 0; // or t0, r0, r0
// block_84:
c->dsll(t0, a0, 4); // dsll t0, a0, 4
// c->sw(a3, 128, a2); // sw a3, 128(a2)
sadr = c->sgpr64(a3);
// nop // sll r0, r0, 0
// c->sw(a1, 16, a2); // sw a1, 16(a2)
madr = c->sgpr64(a1);
c->addiu(a3, r0, 256); // addiu a3, r0, 256
// c->sw(a0, 32, a2); // sw a0, 32(a2)
qwc = c->sgpr64(a0);
c->daddu(a0, a1, t0); // daddu a0, a1, t0
// c->sw(a3, 0, a2); // sw a3, 0(a2)
spad_from_dma_no_sadr_off(cache.fake_scratchpad_data, madr, sadr, qwc);
// nop // sll r0, r0, 0
c->sw(a0, 60, at); // sw a0, 60(at)
c->gprs[a0].du64[0] = 0; // or a0, r0, r0
c->xori(v1, v1, 4608); // xori v1, v1, 4608
c->sw(v1, 24, at); // sw v1, 24(at)
block_85:
c->addiu(v1, r0, 1); // addiu v1, r0, 1
c->dsubu(gp, v1, gp); // dsubu gp, v1, gp
c->daddiu(s5, s5, 1); // daddiu s5, s5, 1
get_fake_spad_addr2(v1, cache.fake_scratchpad_data, 0, c);// lui v1, 28672
c->lhu(v1, 6946, v1); // lhu v1, 6946(v1)
bc = c->sgpr64(s5) != c->sgpr64(v1); // bne s5, v1, L67
c->mov64(v1, s7); // or v1, s7, r0
if (bc) {goto block_87;} // branch non-likely
c->addiu(s5, r0, 0); // addiu s5, r0, 0
c->mov64(v1, s5); // or v1, s5, r0
block_87:
c->mov64(v1, s2); // or v1, s2, r0
block_88:
bc = c->sgpr64(s2) != 0; // bne s2, r0, L23
// nop // sll r0, r0, 0
if (bc) {goto block_4;} // branch non-likely
c->mov64(v1, s7); // or v1, s7, r0
get_fake_spad_addr2(v1, cache.fake_scratchpad_data, 0, c);// lui v1, 28672
c->lwu(v1, 7456, v1); // lwu v1, 7456(v1)
c->sw(r0, 0, v1); // sw r0, 0(v1)
c->gprs[v0].du64[0] = 0; // or v0, r0, r0
c->ld(ra, 0, sp); // ld ra, 0(sp)
c->lq(gp, 96, sp); // lq gp, 96(sp)
c->lq(s5, 80, sp); // lq s5, 80(sp)
c->lq(s4, 64, sp); // lq s4, 64(sp)
c->lq(s3, 48, sp); // lq s3, 48(sp)
c->lq(s2, 32, sp); // lq s2, 32(sp)
c->lq(s1, 16, sp); // lq s1, 16(sp)
//jr ra // jr ra
c->daddiu(sp, sp, 112); // daddiu sp, sp, 112
goto end_of_function; // return
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
end_of_function:
return c->gprs[v0].du64[0];
}
void link() {
cache.fake_scratchpad_data = intern_from_c(-1, 0, "*fake-scratchpad-data*").c();
cache.gsf_buffer = intern_from_c(-1, 0, "*gsf-buffer*").c();
cache.generic_merc_death = intern_from_c(-1, 0, "generic-merc-death").c();
cache.generic_merc_query = intern_from_c(-1, 0, "generic-merc-query").c();
cache.generic_translucent = intern_from_c(-1, 0, "generic-translucent").c();
cache.generic_warp_dest = intern_from_c(-1, 0, "generic-warp-dest").c();
cache.generic_warp_envmap_dest = intern_from_c(-1, 0, "generic-warp-envmap-dest").c();
cache.generic_warp_source = intern_from_c(-1, 0, "generic-warp-source").c();
gLinkedFunctionTable.reg("generic-merc-execute-asm", execute, 256);
}
} // namespace generic_merc_execute_asm
} // namespace Mips2C
//--------------------------MIPS2C---------------------
// clang-format off
#include "game/mips2c/mips2c_private.h"
#include "game/kernel/jak3/kscheme.h"
using ::jak3::intern_from_c;
namespace Mips2C::jak3 {
namespace generic_merc_do_chain {
struct Cache {
void* display; // *display*
void* fake_scratchpad_data; // *fake-scratchpad-data*
void* dma_bucket_insert_tag; // dma-bucket-insert-tag
void* generic_merc_execute_asm; // generic-merc-execute-asm
void* generic_work_init; // generic-work-init
} cache;
u64 execute(void* ctxt) {
auto* c = (ExecutionContext*)ctxt;
bool bc = false;
u32 call_addr = 0;
c->daddiu(sp, sp, -80); // daddiu sp, sp, -80
c->sd(ra, 0, sp); // sd ra, 0(sp)
c->sq(s3, 16, sp); // sq s3, 16(sp)
c->sq(s4, 32, sp); // sq s4, 32(sp)
c->sq(s5, 48, sp); // sq s5, 48(sp)
c->sq(gp, 64, sp); // sq gp, 64(sp)
c->mov64(gp, a0); // or gp, a0, r0
c->mov64(s5, a1); // or s5, a1, r0
get_fake_spad_addr2(v1, cache.fake_scratchpad_data, 0, c);// lui v1, 28672
// printf("watch *0x%lx\n", (uintptr_t)(g_ee_main_mem + c->sgpr64(a0) + 60));
c->sw(gp, 7456, v1); // sw gp, 7456(v1)
c->daddiu(a0, gp, 8); // daddiu a0, gp, 8
c->lwu(v1, 0, gp); // lwu v1, 0(gp)
bc = c->sgpr64(v1) == 0; // beq v1, r0, L19
c->mov64(v0, s7); // or v0, s7, r0
if (bc) {goto block_7;} // branch non-likely
c->load_symbol2(v1, cache.display); // lw v1, *display*(s7)
c->lw(v1, 0, v1); // lw v1, 0(v1)
c->dsll(v1, v1, 2); // dsll v1, v1, 2
c->load_symbol2(a1, cache.display); // lw a1, *display*(s7)
c->daddu(v1, v1, a1); // daddu v1, v1, a1
c->lwu(v1, 8, v1); // lwu v1, 8(v1)
c->lwu(s3, 36, v1); // lwu s3, 36(v1)
c->lwu(s4, 4, s3); // lwu s4, 4(s3)
c->load_symbol2(t9, cache.generic_work_init); // lw t9, generic-work-init(s7)
call_addr = c->gprs[t9].du32[0]; // function call:
c->sll(v0, ra, 0); // sll v0, ra, 0
c->jalr(call_addr); // jalr ra, t9
c->lwu(v1, 4, s3); // lwu v1, 4(s3)
get_fake_spad_addr2(a0, cache.fake_scratchpad_data, 0, c);// lui a0, 28672
c->sw(v1, 60, a0); // sw v1, 60(a0)
c->load_symbol2(t9, cache.generic_merc_execute_asm);// lw t9, generic-merc-execute-asm(s7)
call_addr = c->gprs[t9].du32[0]; // function call:
c->sll(v0, ra, 0); // sll v0, ra, 0
c->jalr(call_addr); // jalr ra, t9
get_fake_spad_addr2(v1, cache.fake_scratchpad_data, 0, c);// lui v1, 28672
c->lwu(v1, 60, v1); // lwu v1, 60(v1)
c->sw(v1, 4, s3); // sw v1, 4(s3)
c->lui(v1, 4096); // lui v1, 4096
c->ori(v1, v1, 53248); // ori v1, v1, 53248
get_fake_spad_addr2(a0, cache.fake_scratchpad_data, 0, c);// lui a0, 28672
// dma sync
// c->ori(a0, a0, 92); // ori a0, a0, 92
// c->lw(a1, 0, v1); // lw a1, 0(v1)
// c->andi(a1, a1, 256); // andi a1, a1, 256
// bc = c->sgpr64(a1) == 0; // beq a1, r0, L17
// DANGER jump to delay slot, this MUST be fixed manually!
// c->lw(a1, 0, a0); // lw a1, 0(a0)
// if (bc) {goto block_-1;} // branch non-likely
//
//
// block_2:
// c->lw(a1, 0, a0); // lw a1, 0(a0)
// // nop // sll r0, r0, 0
// c->lw(a2, 0, v1); // lw a2, 0(v1)
// // nop // sll r0, r0, 0
// c->andi(a2, a2, 256); // andi a2, a2, 256
// c->daddiu(a1, a1, 1); // daddiu a1, a1, 1
// bc = c->sgpr64(a2) != 0; // bne a2, r0, L16
// c->sw(a1, 0, a0); // sw a1, 0(a0)
// if (bc) {goto block_2;} // branch non-likely
c->gprs[v1].du64[0] = 0; // or v1, r0, r0
c->lwu(a3, 4, s3); // lwu a3, 4(s3)
bc = c->sgpr64(s4) == c->sgpr64(a3); // beq s4, a3, L18
c->mov64(v1, s7); // or v1, s7, r0
if (bc) {goto block_6;} // branch non-likely
c->lwu(v1, 4, s3); // lwu v1, 4(s3)
c->lui(a0, 8192); // lui a0, 8192
c->sd(a0, 0, v1); // sd a0, 0(v1)
c->sw(r0, 8, v1); // sw r0, 8(v1)
c->sw(r0, 12, v1); // sw r0, 12(v1)
c->daddiu(v1, v1, 16); // daddiu v1, v1, 16
c->sw(v1, 4, s3); // sw v1, 4(s3)
c->load_symbol2(t9, cache.dma_bucket_insert_tag); // lw t9, dma-bucket-insert-tag(s7)
c->load_symbol2(v1, cache.display); // lw v1, *display*(s7)
c->lw(v1, 0, v1); // lw v1, 0(v1)
c->dsll(v1, v1, 2); // dsll v1, v1, 2
c->load_symbol2(a0, cache.display); // lw a0, *display*(s7)
c->daddu(v1, v1, a0); // daddu v1, v1, a0
c->lwu(v1, 8, v1); // lwu v1, 8(v1)
c->lwu(a0, 40, v1); // lwu a0, 40(v1)
c->lw(a1, 16, gp); // lw a1, 16(gp)
c->mov64(a2, s4); // or a2, s4, r0
call_addr = c->gprs[t9].du32[0]; // function call:
c->sll(v0, ra, 0); // sll v0, ra, 0
c->jalr(call_addr); // jalr ra, t9
c->mov64(v1, v0); // or v1, v0, r0
block_6:
c->lwu(v1, 4, s5); // lwu v1, 4(s5)
// Unknown instr: sync.l
// Unknown instr: cache dxwbin v1, 0
// Unknown instr: sync.l
// Unknown instr: cache dxwbin v1, 1
// Unknown instr: sync.l
c->gprs[v0].du64[0] = 0; // or v0, r0, r0
block_7:
c->ld(ra, 0, sp); // ld ra, 0(sp)
c->lq(gp, 64, sp); // lq gp, 64(sp)
c->lq(s5, 48, sp); // lq s5, 48(sp)
c->lq(s4, 32, sp); // lq s4, 32(sp)
c->lq(s3, 16, sp); // lq s3, 16(sp)
//jr ra // jr ra
c->daddiu(sp, sp, 80); // daddiu sp, sp, 80
goto end_of_function; // return
// nop // sll r0, r0, 0
// nop // sll r0, r0, 0
end_of_function:
return c->gprs[v0].du64[0];
}
void link() {
cache.display = intern_from_c(-1, 0, "*display*").c();
cache.fake_scratchpad_data = intern_from_c(-1, 0, "*fake-scratchpad-data*").c();
cache.dma_bucket_insert_tag = intern_from_c(-1, 0, "dma-bucket-insert-tag").c();
cache.generic_merc_execute_asm = intern_from_c(-1, 0, "generic-merc-execute-asm").c();
cache.generic_work_init = intern_from_c(-1, 0, "generic-work-init").c();
gLinkedFunctionTable.reg("generic-merc-do-chain", execute, 128);
}
} // namespace generic_merc_do_chain
} // namespace Mips2C