mirror of https://github.com/zeldaret/tp.git
741 lines
27 KiB
C++
741 lines
27 KiB
C++
//
|
|
// Generated By: dol2asm
|
|
// Translation Unit: J3DGD
|
|
//
|
|
|
|
#include "JSystem/J3DGraphBase/J3DGD.h"
|
|
#include "dol2asm.h"
|
|
#include "dolphin/gd.h"
|
|
#include "dolphin/os.h"
|
|
|
|
//
|
|
// Forward References:
|
|
//
|
|
|
|
extern "C" void J3DGDSetGenMode__FUcUcUcUc11_GXCullMode();
|
|
extern "C" void J3DGDSetGenMode_3Param__FUcUcUc();
|
|
extern "C" void J3DGDSetLightAttn__F10_GXLightIDffffff();
|
|
extern "C" void J3DGDSetLightColor__F10_GXLightID8_GXColor();
|
|
extern "C" void J3DGDSetLightPos__F10_GXLightIDfff();
|
|
extern "C" void J3DGDSetLightDir__F10_GXLightIDfff();
|
|
extern "C" void J3DGDSetVtxAttrFmtv__F9_GXVtxFmtPC17_GXVtxAttrFmtListb();
|
|
extern "C" void J3DGDSetTexCoordGen__F13_GXTexGenType12_GXTexGenSrc();
|
|
extern "C" void J3DGDSetTexCoordScale2__F13_GXTexCoordIDUsUcUcUsUcUc();
|
|
extern "C" void
|
|
J3DGDSetTexLookupMode__F11_GXTexMapID14_GXTexWrapMode14_GXTexWrapMode12_GXTexFilter12_GXTexFilterfffUcUc13_GXAnisotropy();
|
|
extern "C" void J3DGDSetTexImgAttr__F11_GXTexMapIDUsUs9_GXTexFmt();
|
|
extern "C" void J3DGDSetTexImgPtr__F11_GXTexMapIDPv();
|
|
extern "C" void J3DGDSetTexImgPtrRaw__F11_GXTexMapIDUl();
|
|
extern "C" void J3DGDSetTexTlut__F11_GXTexMapIDUl10_GXTlutFmt();
|
|
extern "C" void J3DGDLoadTlut__FPvUl11_GXTlutSize();
|
|
extern "C" void J3DGDSetIndTexMtx__F14_GXIndTexMtxIDPA3_fSc();
|
|
extern "C" void
|
|
J3DGDSetIndTexCoordScale__F16_GXIndTexStageID14_GXIndTexScale14_GXIndTexScale14_GXIndTexScale14_GXIndTexScale();
|
|
extern "C" void
|
|
J3DGDSetIndTexOrder__FUl13_GXTexCoordID11_GXTexMapID13_GXTexCoordID11_GXTexMapID13_GXTexCoordID11_GXTexMapID13_GXTexCoordID11_GXTexMapID();
|
|
extern "C" void
|
|
J3DGDSetTevOrder__F13_GXTevStageID13_GXTexCoordID11_GXTexMapID12_GXChannelID13_GXTexCoordID11_GXTexMapID12_GXChannelID();
|
|
extern "C" void J3DGDSetTevKColor__F14_GXTevKColorID8_GXColor();
|
|
extern "C" void J3DGDSetTevColorS10__F11_GXTevRegID11_GXColorS10();
|
|
extern "C" void J3DGDSetFog__F10_GXFogTypeffff8_GXColor();
|
|
extern "C" void J3DGDSetFogRangeAdj__FUcUsP14_GXFogAdjTable();
|
|
extern "C" void J3DFifoLoadPosMtxImm__FPA4_fUl();
|
|
extern "C" void J3DFifoLoadNrmMtxImm__FPA4_fUl();
|
|
extern "C" void J3DFifoLoadNrmMtxImm3x3__FPA3_fUl();
|
|
extern "C" void J3DFifoLoadNrmMtxToTexMtx__FPA4_fUl();
|
|
extern "C" void J3DFifoLoadNrmMtxToTexMtx3x3__FPA3_fUl();
|
|
extern "C" void J3DFifoLoadTexCached__F11_GXTexMapIDUl15_GXTexCacheSizeUl15_GXTexCacheSize();
|
|
|
|
//
|
|
// External References:
|
|
//
|
|
|
|
extern "C" void GDOverflowed();
|
|
extern "C" void __cvt_fp2unsigned();
|
|
extern "C" void _savegpr_14();
|
|
extern "C" void _savegpr_23();
|
|
extern "C" void _savegpr_24();
|
|
extern "C" void _savegpr_25();
|
|
extern "C" void _savegpr_27();
|
|
extern "C" void _savegpr_29();
|
|
extern "C" void _restgpr_14();
|
|
extern "C" void _restgpr_23();
|
|
extern "C" void _restgpr_24();
|
|
extern "C" void _restgpr_25();
|
|
extern "C" void _restgpr_27();
|
|
extern "C" void _restgpr_29();
|
|
|
|
//
|
|
// Declarations:
|
|
//
|
|
|
|
/* 8030D098-8030D210 3079D8 0178+00 0/0 1/1 0/0 .text J3DGDSetGenMode__FUcUcUcUc11_GXCullMode */
|
|
void J3DGDSetGenMode(u8 texGenNum, u8 colorChanNum, u8 tevStageNum, u8 indTexStageNum,
|
|
GXCullMode cullMode) {
|
|
GDOverflowCheck(0xa);
|
|
J3DGDWriteBPCmd(0xfe07fc3f);
|
|
static u8 cm2hw[4] = {0, 2, 1, 3};
|
|
J3DGDWriteBPCmd(texGenNum | colorChanNum << 4 | (tevStageNum - 1) << 0xa |
|
|
cm2hw[cullMode] << 0xe | indTexStageNum << 0x10);
|
|
}
|
|
|
|
/* 8030D210-8030D364 307B50 0154+00 0/0 1/1 0/0 .text J3DGDSetGenMode_3Param__FUcUcUc */
|
|
void J3DGDSetGenMode_3Param(u8 texGenNum, u8 tevStageNum, u8 indTexStageNum) {
|
|
GDOverflowCheck(0xa);
|
|
J3DGDWriteBPCmd(0xfe073c0f);
|
|
J3DGDWriteBPCmd(texGenNum | (tevStageNum - 1) << 0xa | indTexStageNum << 0x10);
|
|
}
|
|
|
|
/* 8030D364-8030D65C 307CA4 02F8+00 0/0 1/1 0/0 .text J3DGDSetLightAttn__F10_GXLightIDffffff */
|
|
void J3DGDSetLightAttn(GXLightID id, f32 a0, f32 a1, f32 a2, f32 k0, f32 k1, f32 k2) {
|
|
J3DGDWriteXFCmdHdr(0x0604 + __GDLightID2Offset(id), 6);
|
|
J3DGDWrite_f32(a0);
|
|
J3DGDWrite_f32(a1);
|
|
J3DGDWrite_f32(a2);
|
|
J3DGDWrite_f32(k0);
|
|
J3DGDWrite_f32(k1);
|
|
J3DGDWrite_f32(k2);
|
|
}
|
|
|
|
/* 8030D65C-8030D76C 307F9C 0110+00 0/0 1/1 0/0 .text J3DGDSetLightColor__F10_GXLightID8_GXColor
|
|
*/
|
|
void J3DGDSetLightColor(GXLightID id, GXColor color) {
|
|
J3DGDWriteXFCmd(0x0603 + __GDLightID2Offset(id),
|
|
(color.r << 24) | (color.g << 16) | (color.b << 8) | (color.a << 0));
|
|
}
|
|
|
|
/* 8030D76C-8030D938 3080AC 01CC+00 0/0 1/1 0/0 .text J3DGDSetLightPos__F10_GXLightIDfff
|
|
*/
|
|
void J3DGDSetLightPos(GXLightID id, f32 x, f32 y, f32 z) {
|
|
J3DGDWriteXFCmdHdr(0x060A + __GDLightID2Offset(id), 3);
|
|
J3DGDWrite_f32(x);
|
|
J3DGDWrite_f32(y);
|
|
J3DGDWrite_f32(z);
|
|
}
|
|
|
|
/* 8030D938-8030DB04 308278 01CC+00 0/0 1/1 0/0 .text J3DGDSetLightDir__F10_GXLightIDfff
|
|
*/
|
|
void J3DGDSetLightDir(GXLightID id, f32 x, f32 y, f32 z) {
|
|
J3DGDWriteXFCmdHdr(0x060D + __GDLightID2Offset(id), 3);
|
|
J3DGDWrite_f32(x);
|
|
J3DGDWrite_f32(y);
|
|
J3DGDWrite_f32(z);
|
|
}
|
|
|
|
/* 8030DB04-8030E064 308444 0560+00 1/0 1/1 0/0 .text
|
|
* J3DGDSetVtxAttrFmtv__F9_GXVtxFmtPC17_GXVtxAttrFmtListb */
|
|
void J3DGDSetVtxAttrFmtv(GXVtxFmt fmt, GXVtxAttrFmtList const* fmtList, bool param_2) {
|
|
u32 pos_cnt = GX_POS_XYZ;
|
|
u32 pos_type = GX_F32;
|
|
u32 pos_shift = 0;
|
|
u32 nrm_cnt = GX_NRM_XYZ;
|
|
u32 nrm_type = GX_F32;
|
|
u32 local_34 = 0;
|
|
u32 clr0_cnt = GX_CLR_RGBA;
|
|
u32 clr0_type = GX_RGBA8;
|
|
u32 clr1_cnt = GX_CLR_RGBA;
|
|
u32 clr1_type = GX_RGBA8;
|
|
u32 tex0_cnt = GX_TEX_ST;
|
|
u32 tex0_type = GX_F32;
|
|
u32 tex0_shift = 0;
|
|
u32 tex1_cnt = GX_TEX_ST;
|
|
u32 tex1_type = GX_F32;
|
|
u32 tex1_shift = 0;
|
|
u32 tex2_cnt = GX_TEX_ST;
|
|
u32 tex2_type = GX_F32;
|
|
u32 tex2_shift = 0;
|
|
u32 tex3_cnt = GX_TEX_ST;
|
|
u32 tex3_type = GX_F32;
|
|
u32 tex3_shift = 0;
|
|
u32 tex4_cnt = GX_TEX_ST;
|
|
u32 tex4_type = GX_F32;
|
|
u32 tex4_shift = 0;
|
|
u32 tex5_cnt = GX_TEX_ST;
|
|
u32 tex5_type = GX_F32;
|
|
u32 tex5_shift = 0;
|
|
u32 tex6_cnt = GX_TEX_ST;
|
|
u32 tex6_type = GX_F32;
|
|
u32 tex6_shift = 0;
|
|
u32 tex7_cnt = GX_TEX_ST;
|
|
u32 tex7_type = GX_F32;
|
|
u32 tex7_shift = 0;
|
|
for (; fmtList->mAttrib != GX_VA_NULL; fmtList++) {
|
|
switch (fmtList->mAttrib) {
|
|
case GX_VA_POS:
|
|
pos_cnt = fmtList->mCompCnt;
|
|
pos_type = fmtList->mCompType;
|
|
pos_shift = fmtList->mCompShift;
|
|
break;
|
|
case GX_VA_NRM:
|
|
case GX_VA_NBT:
|
|
nrm_type = fmtList->mCompType;
|
|
if (fmtList->mCompCnt == GX_NRM_NBT3) {
|
|
nrm_cnt = GX_NRM_NBT;
|
|
local_34 = 1;
|
|
} else {
|
|
if (param_2) {
|
|
nrm_cnt = GX_NRM_NBT;
|
|
} else {
|
|
nrm_cnt = fmtList->mCompCnt;
|
|
}
|
|
local_34 = 0;
|
|
}
|
|
break;
|
|
case GX_VA_CLR0:
|
|
clr0_cnt = fmtList->mCompCnt;
|
|
clr0_type = fmtList->mCompType;
|
|
break;
|
|
case GX_VA_CLR1:
|
|
clr1_cnt = fmtList->mCompCnt;
|
|
clr1_type = fmtList->mCompType;
|
|
break;
|
|
case GX_VA_TEX0:
|
|
tex0_cnt = fmtList->mCompCnt;
|
|
tex0_type = fmtList->mCompType;
|
|
tex0_shift = fmtList->mCompShift;
|
|
break;
|
|
case GX_VA_TEX1:
|
|
tex1_cnt = fmtList->mCompCnt;
|
|
tex1_type = fmtList->mCompType;
|
|
tex1_shift = fmtList->mCompShift;
|
|
break;
|
|
case GX_VA_TEX2:
|
|
tex2_cnt = fmtList->mCompCnt;
|
|
tex2_type = fmtList->mCompType;
|
|
tex2_shift = fmtList->mCompShift;
|
|
break;
|
|
case GX_VA_TEX3:
|
|
tex3_cnt = fmtList->mCompCnt;
|
|
tex3_type = fmtList->mCompType;
|
|
tex3_shift = fmtList->mCompShift;
|
|
break;
|
|
case GX_VA_TEX4:
|
|
tex4_cnt = fmtList->mCompCnt;
|
|
tex4_type = fmtList->mCompType;
|
|
tex4_shift = fmtList->mCompShift;
|
|
break;
|
|
case GX_VA_TEX5:
|
|
tex5_cnt = fmtList->mCompCnt;
|
|
tex5_type = fmtList->mCompType;
|
|
tex5_shift = fmtList->mCompShift;
|
|
break;
|
|
case GX_VA_TEX6:
|
|
tex6_cnt = fmtList->mCompCnt;
|
|
tex6_type = fmtList->mCompType;
|
|
tex6_shift = fmtList->mCompShift;
|
|
break;
|
|
case GX_VA_TEX7:
|
|
tex7_cnt = fmtList->mCompCnt;
|
|
tex7_type = fmtList->mCompType;
|
|
tex7_shift = fmtList->mCompShift;
|
|
break;
|
|
}
|
|
}
|
|
GDOverflowCheck(0x12);
|
|
J3DGDWriteCPCmd(GX_CP_REG_VAT_GRP0 + fmt,
|
|
pos_cnt | pos_type << 1 | pos_shift << 4 | nrm_cnt << 9 | nrm_type << 0xa |
|
|
clr0_cnt << 0xd | clr0_type << 0xe | clr1_cnt << 0x11 | clr1_type << 0x12 |
|
|
tex0_cnt << 0x15 | tex0_type << 0x16 | tex0_shift << 0x19 | 0x40000000 |
|
|
local_34 << 0x1f);
|
|
J3DGDWriteCPCmd(GX_CP_REG_VAT_GRP1 + fmt,
|
|
tex1_cnt | tex1_type << 1 | tex1_shift << 4 | tex2_cnt << 9 | tex2_type << 0xa |
|
|
tex2_shift << 0xd | tex3_cnt << 0x12 | tex3_type << 0x13 |
|
|
tex3_shift << 0x16 | tex4_cnt << 0x1b | tex4_type << 0x1c | 0x80000000);
|
|
J3DGDWriteCPCmd(GX_CP_REG_VAT_GRP2 + fmt,
|
|
tex4_shift | tex5_cnt << 5 | tex5_type << 6 | tex5_shift << 9 |
|
|
tex6_cnt << 0xe | tex6_type << 0xf | tex6_shift << 0x12 | tex7_cnt << 0x17 |
|
|
tex7_type << 0x18 | tex7_shift << 0x1b);
|
|
}
|
|
|
|
/* 8030E064-8030E234 3089A4 01D0+00 1/0 1/1 0/0 .text
|
|
* J3DGDSetTexCoordGen__F13_GXTexGenType12_GXTexGenSrc */
|
|
void J3DGDSetTexCoordGen(GXTexGenType texGenType, GXTexGenSrc texGenSrc) {
|
|
u32 input_form = 0;
|
|
u32 proj_type = 0;
|
|
u32 src_row = 5;
|
|
u32 bump_src_tex = 5;
|
|
u32 bump_src_light = 0;
|
|
u32 texgen_type;
|
|
switch (texGenSrc) {
|
|
case GX_TG_POS:
|
|
src_row = 0;
|
|
input_form = 1;
|
|
break;
|
|
case GX_TG_NRM:
|
|
src_row = 1;
|
|
input_form = 1;
|
|
break;
|
|
case GX_TG_BINRM:
|
|
src_row = 3;
|
|
input_form = 1;
|
|
break;
|
|
case GX_TG_TANGENT:
|
|
src_row = 4;
|
|
input_form = 1;
|
|
break;
|
|
case GX_TG_COLOR0:
|
|
src_row = 2;
|
|
break;
|
|
case GX_TG_COLOR1:
|
|
src_row = 2;
|
|
break;
|
|
case GX_TG_TEX0:
|
|
src_row = 5;
|
|
break;
|
|
case GX_TG_TEX1:
|
|
src_row = 6;
|
|
break;
|
|
case GX_TG_TEX2:
|
|
src_row = 7;
|
|
break;
|
|
case GX_TG_TEX3:
|
|
src_row = 8;
|
|
break;
|
|
case GX_TG_TEX4:
|
|
src_row = 9;
|
|
break;
|
|
case GX_TG_TEX5:
|
|
src_row = 10;
|
|
break;
|
|
case GX_TG_TEX6:
|
|
src_row = 11;
|
|
break;
|
|
case GX_TG_TEX7:
|
|
src_row = 12;
|
|
break;
|
|
case GX_TG_TEXCOORD0:
|
|
bump_src_tex = 0;
|
|
break;
|
|
case GX_TG_TEXCOORD1:
|
|
bump_src_tex = 1;
|
|
break;
|
|
case GX_TG_TEXCOORD2:
|
|
bump_src_tex = 2;
|
|
break;
|
|
case GX_TG_TEXCOORD3:
|
|
bump_src_tex = 3;
|
|
break;
|
|
case GX_TG_TEXCOORD4:
|
|
bump_src_tex = 4;
|
|
break;
|
|
case GX_TG_TEXCOORD5:
|
|
bump_src_tex = 5;
|
|
break;
|
|
case GX_TG_TEXCOORD6:
|
|
bump_src_tex = 6;
|
|
break;
|
|
}
|
|
switch (texGenType) {
|
|
case GX_TG_MTX2x4:
|
|
texgen_type = 0;
|
|
break;
|
|
case GX_TG_MTX3x4:
|
|
texgen_type = 0;
|
|
proj_type = 1;
|
|
break;
|
|
case GX_TG_BUMP0:
|
|
case GX_TG_BUMP1:
|
|
case GX_TG_BUMP2:
|
|
case GX_TG_BUMP3:
|
|
case GX_TG_BUMP4:
|
|
case GX_TG_BUMP5:
|
|
case GX_TG_BUMP6:
|
|
case GX_TG_BUMP7:
|
|
texgen_type = 1;
|
|
bump_src_light = texGenType - 2;
|
|
break;
|
|
case GX_TG_SRTG:
|
|
if (texGenSrc == GX_TG_COLOR0) {
|
|
texgen_type = 2;
|
|
} else {
|
|
texgen_type = 3;
|
|
}
|
|
break;
|
|
}
|
|
J3DGDWrite_u32(
|
|
proj_type << (31 - GX_XF_TEX_PROJTYPE_END) | input_form << (31 - GX_XF_TEX_INPUTFORM_END) |
|
|
texgen_type << (31 - GX_XF_TEX_TEXGENTYPE_END) | src_row << (31 - GX_XF_TEX_SRCROW_END) |
|
|
bump_src_tex << (31 - GX_XF_TEX_BUMPSRCTEX_END) |
|
|
bump_src_light << (31 - GX_XF_TEX_BUMPSRCLIGHT_END));
|
|
}
|
|
|
|
/* 8030E234-8030E438 308B74 0204+00 0/0 16/16 0/0 .text
|
|
* J3DGDSetTexCoordScale2__F13_GXTexCoordIDUsUcUcUsUcUc */
|
|
void J3DGDSetTexCoordScale2(GXTexCoordID param_0, u16 param_1, u8 param_2, u8 param_3, u16 param_4,
|
|
u8 param_5, u8 param_6) {
|
|
GDOverflowCheck(0xf);
|
|
J3DGDWriteBPCmd(0xfe03ffff);
|
|
J3DGDWriteBPCmd((param_1 - 1) | param_2 << 0x10 | param_3 << 0x11 |
|
|
(param_0 * 2 + 0x30) << 0x18);
|
|
J3DGDWriteBPCmd((param_4 - 1) | param_5 << 0x10 | param_6 << 0x11 |
|
|
(param_0 * 2 + 0x31) << 0x18);
|
|
}
|
|
|
|
/* 8045090C-80450914 00038C 0008+00 1/1 0/0 0/0 .sdata J3DGDTexMode0Ids */
|
|
static u8 J3DGDTexMode0Ids[8] = {
|
|
0x80, 0x81, 0x82, 0x83, 0xA0, 0xA1, 0xA2, 0xA3,
|
|
};
|
|
|
|
/* 80450914-8045091C 000394 0008+00 1/1 0/0 0/0 .sdata J3DGDTexMode1Ids */
|
|
static u8 J3DGDTexMode1Ids[8] = {
|
|
0x84, 0x85, 0x86, 0x87, 0xA4, 0xA5, 0xA6, 0xA7,
|
|
};
|
|
|
|
/* 8045091C-80450924 00039C 0008+00 1/1 0/0 0/0 .sdata J3DGDTexImage0Ids */
|
|
static u8 J3DGDTexImage0Ids[8] = {
|
|
0x88, 0x89, 0x8A, 0x8B, 0xA8, 0xA9, 0xAA, 0xAB,
|
|
};
|
|
|
|
/* 80450924-8045092C 0003A4 0008+00 2/2 0/0 0/0 .sdata J3DGDTexImage3Ids */
|
|
static u8 J3DGDTexImage3Ids[8] = {
|
|
0x94, 0x95, 0x96, 0x97, 0xB4, 0xB5, 0xB6, 0xB7,
|
|
};
|
|
|
|
/* 8045092C-80450934 0003AC 0008+00 1/1 0/0 0/0 .sdata J3DGDTexTlutIds */
|
|
static u8 J3DGDTexTlutIds[8] = {
|
|
0x98, 0x99, 0x9A, 0x9B, 0xB8, 0xB9, 0xBA, 0xBB,
|
|
};
|
|
|
|
/* 80450934-8045093C 0003B4 0006+02 1/1 0/0 0/0 .sdata GX2HWFiltConv */
|
|
static u8 GX2HWFiltConv[6] = {
|
|
0x00, 0x04, 0x01, 0x05, 0x02, 0x06,
|
|
};
|
|
|
|
/* 8030E438-8030E5D4 308D78 019C+00 0/0 1/1 0/0 .text
|
|
* J3DGDSetTexLookupMode__F11_GXTexMapID14_GXTexWrapMode14_GXTexWrapMode12_GXTexFilter12_GXTexFilterfffUcUc13_GXAnisotropy
|
|
*/
|
|
void J3DGDSetTexLookupMode(GXTexMapID param_0, GXTexWrapMode param_1, GXTexWrapMode param_2,
|
|
GXTexFilter param_3, GXTexFilter param_4, f32 param_5, f32 param_6,
|
|
f32 param_7, u8 param_8, u8 param_9, GXAnisotropy param_10) {
|
|
J3DGDWriteBPCmd(param_1 | param_2 << 2 | (param_4 == GX_LINEAR) << 4 |
|
|
GX2HWFiltConv[param_3] << 5 | (param_9 == 0) << 8 |
|
|
((int)(param_7 * 32.0f) & 0xff) << 9 | param_10 << 0x13 | param_8 << 0x15 |
|
|
J3DGDTexMode0Ids[param_0] << 0x18);
|
|
J3DGDWriteBPCmd(((int)(param_5 * 16.0f) & 0xff) | ((int)(param_6 * 16.0f) & 0xff) << 8 |
|
|
J3DGDTexMode1Ids[param_0] << 0x18);
|
|
}
|
|
|
|
/* 8030E5D4-8030E67C 308F14 00A8+00 0/0 1/1 0/0 .text
|
|
* J3DGDSetTexImgAttr__F11_GXTexMapIDUsUs9_GXTexFmt */
|
|
void J3DGDSetTexImgAttr(GXTexMapID param_0, u16 param_1, u16 param_2, GXTexFmt param_3) {
|
|
J3DGDWriteBPCmd((param_1 - 1) | (param_2 - 1) << 0xa | param_3 << 0x14 |
|
|
J3DGDTexImage0Ids[param_0] << 0x18);
|
|
}
|
|
|
|
/* 8030E67C-8030E70C 308FBC 0090+00 0/0 1/1 0/0 .text J3DGDSetTexImgPtr__F11_GXTexMapIDPv
|
|
*/
|
|
void J3DGDSetTexImgPtr(GXTexMapID param_0, void* param_1) {
|
|
J3DGDWriteBPCmd(OSCachedToPhysical(param_1) >> 5 | J3DGDTexImage3Ids[param_0] << 0x18);
|
|
}
|
|
|
|
/* 8030E70C-8030E7E0 30904C 00D4+00 0/0 1/1 0/0 .text J3DGDSetTexImgPtrRaw__F11_GXTexMapIDUl */
|
|
void J3DGDSetTexImgPtrRaw(GXTexMapID param_0, u32 param_1) {
|
|
GDOverflowCheck(5);
|
|
J3DGDWriteBPCmd(param_1 | J3DGDTexImage3Ids[param_0] << 0x18);
|
|
}
|
|
|
|
/* 8030E7E0-8030E878 309120 0098+00 0/0 1/1 0/0 .text
|
|
* J3DGDSetTexTlut__F11_GXTexMapIDUl10_GXTlutFmt */
|
|
void J3DGDSetTexTlut(GXTexMapID param_0, u32 param_1, GXTlutFmt param_2) {
|
|
J3DGDWriteBPCmd((param_1 - 0x80000) >> 9 | param_2 << 0xa | J3DGDTexTlutIds[param_0] << 0x18);
|
|
}
|
|
|
|
/* 8030E878-8030EB30 3091B8 02B8+00 0/0 1/1 0/0 .text J3DGDLoadTlut__FPvUl11_GXTlutSize
|
|
*/
|
|
void J3DGDLoadTlut(void* param_0, u32 param_1, GXTlutSize param_2) {
|
|
J3DGDWriteBPCmd(0xfeffff00);
|
|
J3DGDWriteBPCmd(0x0f000000);
|
|
J3DGDWriteBPCmd(OSCachedToPhysical(param_0) >> 5 | 0x64000000);
|
|
J3DGDWriteBPCmd((param_1 - 0x80000) >> 9 | param_2 << 0xa | 0x65000000);
|
|
J3DGDWriteBPCmd(0xfeffff00);
|
|
J3DGDWriteBPCmd(0x0f000000);
|
|
}
|
|
|
|
/* 8030EB30-8030EE10 309470 02E0+00 0/0 2/2 0/0 .text J3DGDSetIndTexMtx__F14_GXIndTexMtxIDPA3_fSc
|
|
*/
|
|
void J3DGDSetIndTexMtx(GXIndTexMtxID id, Mtx3P mtx, s8 exp) {
|
|
s32 mtx32[6];
|
|
u32 idx;
|
|
|
|
switch (id) {
|
|
case GX_ITM_0:
|
|
case GX_ITM_1:
|
|
case GX_ITM_2:
|
|
idx = (u32)(id - GX_ITM_0);
|
|
break;
|
|
case GX_ITM_S0:
|
|
case GX_ITM_S1:
|
|
case GX_ITM_S2:
|
|
idx = (u32)(id - GX_ITM_S0);
|
|
break;
|
|
case GX_ITM_T0:
|
|
case GX_ITM_T1:
|
|
case GX_ITM_T2:
|
|
idx = (u32)(id - GX_ITM_T0);
|
|
break;
|
|
default:
|
|
idx = 0;
|
|
break;
|
|
}
|
|
|
|
exp += 17;
|
|
|
|
mtx32[0] = (s32)(mtx[0][0] * 1024.0f) & 0x7FF;
|
|
mtx32[1] = (s32)(mtx[1][0] * 1024.0f) & 0x7FF;
|
|
|
|
mtx32[2] = (s32)(mtx[0][1] * 1024.0f) & 0x7FF;
|
|
mtx32[3] = (s32)(mtx[1][1] * 1024.0f) & 0x7FF;
|
|
|
|
mtx32[4] = (s32)(mtx[0][2] * 1024.0f) & 0x7FF;
|
|
mtx32[5] = (s32)(mtx[1][2] * 1024.0f) & 0x7FF;
|
|
|
|
GDOverflowCheck(15);
|
|
|
|
J3DGDWriteBPCmd((mtx32[0] << 0) | (mtx32[1] << 11) | (((exp >> 0) & 0x03) << 22) |
|
|
(0x06 + idx * 3) << 24);
|
|
J3DGDWriteBPCmd((mtx32[2] << 0) | (mtx32[3] << 11) | (((exp >> 2) & 0x03) << 22) |
|
|
(0x07 + idx * 3) << 24);
|
|
J3DGDWriteBPCmd((mtx32[4] << 0) | (mtx32[5] << 11) | (((exp >> 4) & 0x03) << 22) |
|
|
(0x08 + idx * 3) << 24);
|
|
}
|
|
|
|
/* 8030EE10-8030EF08 309750 00F8+00 0/0 2/2 0/0 .text
|
|
* J3DGDSetIndTexCoordScale__F16_GXIndTexStageID14_GXIndTexScale14_GXIndTexScale14_GXIndTexScale14_GXIndTexScale
|
|
*/
|
|
void J3DGDSetIndTexCoordScale(GXIndTexStageID stage, GXIndTexScale scale0, GXIndTexScale scale1,
|
|
GXIndTexScale scale2, GXIndTexScale scale3) {
|
|
GDOverflowCheck(5);
|
|
J3DGDWriteBPCmd(scale0 | scale1 << 4 | scale2 << 8 | scale3 << 0xc |
|
|
((stage >> 1) + GX_BP_REG_RAS1_SS0) << 0x18);
|
|
}
|
|
|
|
/* 8030EF08-8030F108 309848 0200+00 0/0 2/2 0/0 .text
|
|
* J3DGDSetIndTexOrder__FUl13_GXTexCoordID11_GXTexMapID13_GXTexCoordID11_GXTexMapID13_GXTexCoordID11_GXTexMapID13_GXTexCoordID11_GXTexMapID
|
|
*/
|
|
void J3DGDSetIndTexOrder(u32 count, GXTexCoordID coord0, GXTexMapID map0, GXTexCoordID coord1,
|
|
GXTexMapID map1, GXTexCoordID coord2, GXTexMapID map2, GXTexCoordID coord3,
|
|
GXTexMapID map3) {
|
|
GDOverflowCheck(0xa);
|
|
J3DGDWriteBPCmd(map0 & 7 | (coord0 & 7) << 3 | (map1 & 7) << 6 | (coord1 & 7) << 9 |
|
|
(map2 & 7) << 0xc | (coord2 & 7) << 0xf | (map3 & 7) << 0x12 |
|
|
(coord3 & 7) << 0x15 | GX_BP_REG_RAS1_IREF << 0x18);
|
|
u32 imask = 0;
|
|
for (u32 i = 0; i < count; i++) {
|
|
switch (i) {
|
|
case 0:
|
|
imask |= 1 << (map0 & 7);
|
|
break;
|
|
case 1:
|
|
imask |= 1 << (map1 & 7);
|
|
break;
|
|
case 2:
|
|
imask |= 1 << (map2 & 7);
|
|
break;
|
|
case 3:
|
|
imask |= 1 << (map3 & 7);
|
|
break;
|
|
}
|
|
}
|
|
J3DGDWriteBPCmd(imask | GX_BP_REG_INDIMASK << 0x18);
|
|
}
|
|
|
|
/* 8030F108-8030F294 309A48 018C+00 0/0 9/9 0/0 .text
|
|
* J3DGDSetTevOrder__F13_GXTevStageID13_GXTexCoordID11_GXTexMapID12_GXChannelID13_GXTexCoordID11_GXTexMapID12_GXChannelID
|
|
*/
|
|
void J3DGDSetTevOrder(GXTevStageID stage, GXTexCoordID coord0, GXTexMapID map0,
|
|
GXChannelID channel0, GXTexCoordID coord1, GXTexMapID map1,
|
|
GXChannelID channel1) {
|
|
coord0 = coord0 >= GX_MAXCOORD ? GX_TEXCOORD0 : coord0;
|
|
coord1 = coord1 >= GX_MAXCOORD ? GX_TEXCOORD0 : coord1;
|
|
GDOverflowCheck(5);
|
|
static u8 c2r[32] = {0, 1, 0, 1, 0, 1, 7, 5, 6, 0, 0, 0, 0, 0, 0, 7,
|
|
0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0};
|
|
J3DGDWriteBPCmd((map0 & 7) | coord0 << 3 |
|
|
(map0 != GX_TEXMAP_NULL && !(map0 & GX_TEXMAP_DISABLE)) << 6 |
|
|
c2r[channel0 & 0xf] << 7 | (map1 & 7) << 0xc | coord1 << 0xf |
|
|
(map1 != GX_TEXMAP_NULL && !(map1 & GX_TEXMAP_DISABLE)) << 0x12 |
|
|
c2r[channel1 & 0xf] << 0x13 | (stage / 2 + GX_BP_REG_RAS1_TREF0) << 0x18);
|
|
}
|
|
|
|
/* 8030F294-8030F3FC 309BD4 0168+00 0/0 11/11 0/0 .text
|
|
* J3DGDSetTevKColor__F14_GXTevKColorID8_GXColor */
|
|
void J3DGDSetTevKColor(GXTevKColorID id, GXColor color) {
|
|
u32 cmd0 = color.r | color.a << 0xc | 0x800000 | (id * 2 + GX_BP_REG_TEVREG0LO) << 0x18;
|
|
u32 cmd1 = color.b | color.g << 0xc | 0x800000 | (id * 2 + GX_BP_REG_TEVREG0HI) << 0x18;
|
|
GDOverflowCheck(0xa);
|
|
J3DGDWriteBPCmd(cmd0);
|
|
J3DGDWriteBPCmd(cmd1);
|
|
}
|
|
|
|
/* 8030F3FC-8030F630 309D3C 0234+00 0/0 11/11 0/0 .text
|
|
* J3DGDSetTevColorS10__F11_GXTevRegID11_GXColorS10 */
|
|
void J3DGDSetTevColorS10(GXTevRegID id, GXColorS10 color) {
|
|
u32 cmd0 =
|
|
(color.r & 0x7ff) | (color.a & 0x7ff) << 0xc | (id * 2 + GX_BP_REG_TEVREG0LO) << 0x18;
|
|
u32 cmd1 =
|
|
(color.b & 0x7ff) | (color.g & 0x7ff) << 0xc | (id * 2 + GX_BP_REG_TEVREG0HI) << 0x18;
|
|
GDOverflowCheck(0x14);
|
|
J3DGDWriteBPCmd(cmd0);
|
|
J3DGDWriteBPCmd(cmd1);
|
|
J3DGDWriteBPCmd(cmd1);
|
|
J3DGDWriteBPCmd(cmd1);
|
|
}
|
|
|
|
/* 8030F630-8030F994 309F70 0364+00 0/0 3/3 0/0 .text J3DGDSetFog__F10_GXFogTypeffff8_GXColor */
|
|
void J3DGDSetFog(GXFogType fogType, f32 param_1, f32 param_2, f32 nearZ, f32 farZ, GXColor color) {
|
|
f32 fvar1, fvar2, fvar3;
|
|
if (farZ == nearZ || param_2 == param_1) {
|
|
fvar1 = 0.0f;
|
|
fvar2 = 0.5f;
|
|
fvar3 = 0.0f;
|
|
} else {
|
|
fvar1 = (farZ * nearZ) / ((farZ - nearZ) * (param_2 - param_1));
|
|
fvar2 = farZ / (farZ - nearZ);
|
|
fvar3 = param_1 / (param_2 - param_1);
|
|
}
|
|
u32 shift = 1;
|
|
for (; fvar2 > 1.0; fvar2 *= 0.5f) {
|
|
shift++;
|
|
}
|
|
for (; fvar2 > 0.0f && fvar2 < 0.5; fvar2 *= 2.0f) {
|
|
shift--;
|
|
}
|
|
f32 fvar4 = (fvar1 / (1 << shift));
|
|
u32 param1 = fvar2 * 8388638.0f;
|
|
u32 param0 = *(u32*)&fvar4;
|
|
u32 param3 = *(u32*)&fvar3;
|
|
J3DGDWriteBPCmd(param0 >> 0xc | GX_BP_REG_FOGPARAM0 << 0x18);
|
|
J3DGDWriteBPCmd(param1 | GX_BP_REG_FOGPARAM1 << 0x18);
|
|
J3DGDWriteBPCmd(shift | GX_BP_REG_FOGPARAM2 << 0x18);
|
|
J3DGDWriteBPCmd(param3 >> 0xc | fogType << 0x15 | GX_BP_REG_FOGPARAM3 << 0x18);
|
|
J3DGDWriteBPCmd(color.b | color.g << 8 | color.r << 0x10 | GX_BP_REG_FOGCOLOR << 0x18);
|
|
}
|
|
|
|
/* 8030F994-8030FAE0 30A2D4 014C+00 0/0 3/3 0/0 .text J3DGDSetFogRangeAdj__FUcUsP14_GXFogAdjTable
|
|
*/
|
|
void J3DGDSetFogRangeAdj(u8 param_0, u16 param_1, GXFogAdjTable* table) {
|
|
if (param_0 != 0) {
|
|
for (int i = 0; i < 0xa; i += 2) {
|
|
J3DGDWriteBPCmd((i / 2 + GX_BP_REG_FOGRANGEK0) << 0x18 | table->fogVals[i + 1] << 0xc |
|
|
table->fogVals[i]);
|
|
}
|
|
}
|
|
u32 cmd = GX_BP_REG_FOGRANGE << 0x18 | (param_1 + 0x156) | param_0 << 0xa;
|
|
J3DGDWriteBPCmd(cmd);
|
|
}
|
|
|
|
/* 8030FAE0-8030FB60 30A420 0080+00 0/0 10/10 0/0 .text J3DFifoLoadPosMtxImm__FPA4_fUl */
|
|
void J3DFifoLoadPosMtxImm(MtxP mtx, u32 addr) {
|
|
J3DFifoWriteXFCmdHdr((addr & 0x3fff) << 2, 0xc);
|
|
J3DGXCmd1f32ptr(&mtx[0][0]);
|
|
J3DGXCmd1f32ptr(&mtx[0][1]);
|
|
J3DGXCmd1f32ptr(&mtx[0][2]);
|
|
J3DGXCmd1f32ptr(&mtx[0][3]);
|
|
J3DGXCmd1f32ptr(&mtx[1][0]);
|
|
J3DGXCmd1f32ptr(&mtx[1][1]);
|
|
J3DGXCmd1f32ptr(&mtx[1][2]);
|
|
J3DGXCmd1f32ptr(&mtx[1][3]);
|
|
J3DGXCmd1f32ptr(&mtx[2][0]);
|
|
J3DGXCmd1f32ptr(&mtx[2][1]);
|
|
J3DGXCmd1f32ptr(&mtx[2][2]);
|
|
J3DGXCmd1f32ptr(&mtx[2][3]);
|
|
}
|
|
|
|
/* 8030FB60-8030FBCC 30A4A0 006C+00 0/0 9/9 0/0 .text J3DFifoLoadNrmMtxImm__FPA4_fUl */
|
|
void J3DFifoLoadNrmMtxImm(MtxP mtx, u32 addr) {
|
|
J3DFifoWriteXFCmdHdr(addr * 3 + 0x400, 9);
|
|
J3DGXCmd1f32ptr(&mtx[0][0]);
|
|
J3DGXCmd1f32ptr(&mtx[0][1]);
|
|
J3DGXCmd1f32ptr(&mtx[0][2]);
|
|
J3DGXCmd1f32ptr(&mtx[1][0]);
|
|
J3DGXCmd1f32ptr(&mtx[1][1]);
|
|
J3DGXCmd1f32ptr(&mtx[1][2]);
|
|
J3DGXCmd1f32ptr(&mtx[2][0]);
|
|
J3DGXCmd1f32ptr(&mtx[2][1]);
|
|
J3DGXCmd1f32ptr(&mtx[2][2]);
|
|
}
|
|
|
|
/* 8030FBCC-8030FC38 30A50C 006C+00 0/0 3/3 0/0 .text J3DFifoLoadNrmMtxImm3x3__FPA3_fUl
|
|
*/
|
|
void J3DFifoLoadNrmMtxImm3x3(Mtx3P mtx, u32 addr) {
|
|
J3DFifoWriteXFCmdHdr(addr * 3 + 0x400, 9);
|
|
J3DGXCmd1f32ptr(&mtx[0][0]);
|
|
J3DGXCmd1f32ptr(&mtx[0][1]);
|
|
J3DGXCmd1f32ptr(&mtx[0][2]);
|
|
J3DGXCmd1f32ptr(&mtx[1][0]);
|
|
J3DGXCmd1f32ptr(&mtx[1][1]);
|
|
J3DGXCmd1f32ptr(&mtx[1][2]);
|
|
J3DGXCmd1f32ptr(&mtx[2][0]);
|
|
J3DGXCmd1f32ptr(&mtx[2][1]);
|
|
J3DGXCmd1f32ptr(&mtx[2][2]);
|
|
}
|
|
|
|
/* 8030FC38-8030FCD0 30A578 0098+00 0/0 4/4 0/0 .text J3DFifoLoadNrmMtxToTexMtx__FPA4_fUl
|
|
*/
|
|
void J3DFifoLoadNrmMtxToTexMtx(MtxP mtx, u32 addr) {
|
|
J3DFifoWriteXFCmdHdr((addr & 0x3fff) << 2, 0xc);
|
|
J3DGXCmd1f32ptr(&mtx[0][0]);
|
|
J3DGXCmd1f32ptr(&mtx[0][1]);
|
|
J3DGXCmd1f32ptr(&mtx[0][2]);
|
|
J3DGXCmd1f32(0.0f);
|
|
J3DGXCmd1f32ptr(&mtx[1][0]);
|
|
J3DGXCmd1f32ptr(&mtx[1][1]);
|
|
J3DGXCmd1f32ptr(&mtx[1][2]);
|
|
J3DGXCmd1f32(0.0f);
|
|
J3DGXCmd1f32ptr(&mtx[2][0]);
|
|
J3DGXCmd1f32ptr(&mtx[2][1]);
|
|
J3DGXCmd1f32ptr(&mtx[2][2]);
|
|
J3DGXCmd1f32(0.0f);
|
|
}
|
|
|
|
/* 8030FCD0-8030FD68 30A610 0098+00 0/0 2/2 0/0 .text J3DFifoLoadNrmMtxToTexMtx3x3__FPA3_fUl */
|
|
void J3DFifoLoadNrmMtxToTexMtx3x3(Mtx3P mtx, u32 addr) {
|
|
J3DFifoWriteXFCmdHdr((addr & 0x3fff) << 2, 0xc);
|
|
J3DGXCmd1f32ptr(&mtx[0][0]);
|
|
J3DGXCmd1f32ptr(&mtx[0][1]);
|
|
J3DGXCmd1f32ptr(&mtx[0][2]);
|
|
J3DGXCmd1f32(0.0f);
|
|
J3DGXCmd1f32ptr(&mtx[1][0]);
|
|
J3DGXCmd1f32ptr(&mtx[1][1]);
|
|
J3DGXCmd1f32ptr(&mtx[1][2]);
|
|
J3DGXCmd1f32(0.0f);
|
|
J3DGXCmd1f32ptr(&mtx[2][0]);
|
|
J3DGXCmd1f32ptr(&mtx[2][1]);
|
|
J3DGXCmd1f32ptr(&mtx[2][2]);
|
|
J3DGXCmd1f32(0.0f);
|
|
}
|
|
|
|
/* 8045093C-80450944 0003BC 0008+00 1/1 0/0 0/0 .sdata J3DTexImage1Ids */
|
|
SECTION_SDATA static u8 J3DTexImage1Ids[8] = {
|
|
0x8C, 0x8D, 0x8E, 0x8F, 0xAC, 0xAD, 0xAE, 0xAF,
|
|
};
|
|
|
|
/* 80450944-8045094C 0003C4 0008+00 1/1 0/0 0/0 .sdata J3DTexImage2Ids */
|
|
SECTION_SDATA static u8 J3DTexImage2Ids[8] = {
|
|
0x90, 0x91, 0x92, 0x93, 0xB0, 0xB1, 0xB2, 0xB3,
|
|
};
|
|
|
|
/* 8030FD68-8030FDE8 30A6A8 0080+00 0/0 1/1 0/0 .text
|
|
* J3DFifoLoadTexCached__F11_GXTexMapIDUl15_GXTexCacheSizeUl15_GXTexCacheSize */
|
|
#ifdef NONMATCHING
|
|
void J3DFifoLoadTexCached(GXTexMapID id, u32 param_1, GXTexCacheSize param_2, u32 param_3,
|
|
GXTexCacheSize param_4) {
|
|
J3DFifoLoadBPCmd(param_1 >> 5 | (param_2 + 3) << 0xf | (param_2 + 3) << 0x12 |
|
|
J3DTexImage1Ids[id] << 0x18);
|
|
if (param_4 != GX_TEXCACHE_NONE && param_3 < 0x100000) {
|
|
J3DFifoLoadBPCmd(param_3 >> 5 | (param_4 + 3) << 0xf | (param_4 + 3) << 0x12 |
|
|
J3DTexImage2Ids[id] << 0x18);
|
|
}
|
|
}
|
|
#else
|
|
#pragma push
|
|
#pragma optimization_level 0
|
|
#pragma optimizewithasm off
|
|
asm void J3DFifoLoadTexCached(_GXTexMapID param_0, u32 param_1, _GXTexCacheSize param_2,
|
|
u32 param_3, _GXTexCacheSize param_4) {
|
|
nofralloc
|
|
#include "asm/JSystem/J3DGraphBase/J3DGD/J3DFifoLoadTexCached__F11_GXTexMapIDUl15_GXTexCacheSizeUl15_GXTexCacheSize.s"
|
|
}
|
|
#pragma pop
|
|
#endif
|