From d00e62c4277ada6a64a8dc4653fd954c7790582b Mon Sep 17 00:00:00 2001 From: kabiskac Date: Fri, 14 Jun 2024 19:29:25 +0200 Subject: [PATCH] Decompiled most of m406Dll/map.c --- include/REL/m406Dll.h | 12 +- src/REL/m406Dll/main.c | 2 +- src/REL/m406Dll/map.c | 3372 ++++++++++++++++++++++++++++++++++++++++ 3 files changed, 3379 insertions(+), 7 deletions(-) create mode 100644 src/REL/m406Dll/map.c diff --git a/include/REL/m406Dll.h b/include/REL/m406Dll.h index e782bf1d..656521ae 100644 --- a/include/REL/m406Dll.h +++ b/include/REL/m406Dll.h @@ -4,16 +4,16 @@ #include "game/object.h" #include "game/process.h" -u32 fn_1_122C(void); -// ? fn_1_2308(Process *); -// ? fn_1_2BEC(void); +s32 fn_1_122C(void); +omObjData *fn_1_2308(Process *arg0); +void fn_1_2BEC(void); void fn_1_3064(s32 arg0); void fn_1_696C(float arg8); void fn_1_6B5C(void); void fn_1_B104(float arg8); void fn_1_B25C(void); -// ? fn_1_B41C(void); -// ? fn_1_D65C(Process *); -// ? fn_1_D8B0(void); +void fn_1_B41C(void); +void fn_1_D65C(Process *arg0); +void fn_1_D8B0(void); #endif diff --git a/src/REL/m406Dll/main.c b/src/REL/m406Dll/main.c index 81c9f1dd..bba597cb 100644 --- a/src/REL/m406Dll/main.c +++ b/src/REL/m406Dll/main.c @@ -377,7 +377,7 @@ void fn_1_1168(omObjData *object) } } -u32 fn_1_122C(void) +s32 fn_1_122C(void) { return lbl_1_bss_1C; } diff --git a/src/REL/m406Dll/map.c b/src/REL/m406Dll/map.c new file mode 100644 index 00000000..7e7bba99 --- /dev/null +++ b/src/REL/m406Dll/map.c @@ -0,0 +1,3372 @@ +#include "ext_math.h" +#include "game/audio.h" +#include "game/gamework_data.h" +#include "game/hsfdraw.h" +#include "game/hsfman.h" +#include "game/hsfmotion.h" +#include "game/sprite.h" + +#include "REL/m406Dll.h" + +typedef struct UnkM406Struct { + /* 0x00 */ u8 unk_00; + /* 0x01 */ u8 unk_01; + /* 0x02 */ char unk02[2]; + /* 0x04 */ float unk_04; + /* 0x08 */ float unk_08; + /* 0x0C */ float unk_0C; + /* 0x10 */ Vec unk_10; + /* 0x1C */ Vec unk_1C; + /* 0x28 */ float unk_28; + /* 0x2C */ float unk_2C; +} UnkM406Struct; /* size = 0x30 */ + +typedef struct UnkM406Struct2 { + /* 0x00 */ float unk_00; + /* 0x04 */ float unk_04; + /* 0x08 */ Vec unk_08; + /* 0x14 */ Vec unk_14; +} UnkM406Struct2; /* size = 0x20 */ + +typedef struct UnkM406Struct3 { + /* 0x00 */ s32 unk_00; + /* 0x04 */ float unk_04; + /* 0x08 */ s32 unk_08; + /* 0x0C */ s32 unk_0C; + /* 0x10 */ float unk_10; + /* 0x14 */ float unk_14; + /* 0x18 */ Vec unk_18; + /* 0x24 */ struct UnkM406Struct5 *unk_24; +} UnkM406Struct3; /* size = 0x28 */ + +typedef struct UnkM406Struct4 { + /* 0x00 */ s32 unk_00; + /* 0x04 */ s32 unk_04; + /* 0x08 */ s32 unk_08; + /* 0x0C */ s32 unk_0C; + /* 0x10 */ float unk_10; + /* 0x14 */ float unk_14; + /* 0x18 */ float unk_18; + /* 0x1C */ float unk_1C; + /* 0x20 */ float unk_20; + /* 0x24 */ float unk_24; + /* 0x28 */ float unk_28; + /* 0x2C */ float unk_2C; + /* 0x30 */ Vec unk_30; + /* 0x3C */ Vec unk_3C; +} UnkM406Struct4; /* size = 0x48 */ + +typedef struct UnkM406Unk120Struct { + /* 0x00 */ s32 unk_00; + /* 0x04 */ s32 unk_04; + /* 0x08 */ s32 unk_08; + /* 0x0C */ float unk_0C; + /* 0x10 */ float unk_10; + /* 0x14 */ float unk_14; + /* 0x18 */ float unk_18; + /* 0x1C */ float unk_1C; + /* 0x20 */ s32 unk_20; + /* 0x24 */ s32 unk_24; + /* 0x28 */ s32 unk_28; + /* 0x2C */ UnkM406Struct3 *unk_2C; + /* 0x30 */ UnkM406Struct4 *unk_30; + /* 0x34 */ Vec unk_34; + /* 0x40 */ Vec unk_40; + /* 0x4C */ Mtx unk_4C; + /* 0x7C */ s32 unk_7C; + /* 0x80 */ s32 unk_80; + /* 0x84 */ Vec *unk_84; + /* 0x88 */ Vec *unk_88; + /* 0x8C */ Vec2f *unk_8C; + /* 0x90 */ GXColor *unk_90; + /* 0x94 */ UnkM406Struct *unk_94; + /* 0x98 */ s32 unk_98; + /* 0x9C */ s16 (*unk_9C)[4]; + /* 0xA0 */ u32 unk_A0; + /* 0xA4 */ void *unk_A4; + /* 0xA8 */ u8 *unk_A8; + /* 0xAC */ s32 unk_AC; + /* 0xB0 */ s32 unk_B0; + /* 0xB4 */ float unk_B4; + /* 0xB8 */ float unk_B8; + /* 0xBC */ u8 *unk_BC; + /* 0xC0 */ s32 unk_C0; + /* 0xC4 */ s32 unk_C4; + /* 0xC8 */ float unk_C8; + /* 0xCC */ float unk_CC; +} UnkM406Unk120Struct; /* size = 0xD0 */ + +typedef struct UnkM406Struct5 { + /* 0x00 */ s16 unk_00; + /* 0x02 */ s16 unk_02; + /* 0x04 */ Vec unk_04; + /* 0x10 */ float unk_10; + /* 0x14 */ float unk_14; + /* 0x18 */ float unk_18; + /* 0x1C */ char unk1C[0xC]; + /* 0x28 */ float unk_28; + /* 0x2C */ float unk_2C; + /* 0x30 */ Vec unk_30; + /* 0x3C */ GXColor unk_3C; + /* 0x40 */ s32 unk_40; +} UnkM406Struct5; /* size = 0x44 */ // most likely UnkM426Struct8 + +typedef struct UnkM406Struct9 { + /* 0x00 */ s16 unk00; + /* 0x02 */ s16 unk_02; + /* 0x04 */ s16 unk_04; + /* 0x06 */ char unk06[2]; +} UnkM406Struct9; /* size = 0x08 */ + +typedef void (*UnkM406Unk120Struct2Hook)(struct model_data *, struct UnkM406Unk120Struct2 *, Mtx); + +typedef struct UnkM406Unk120Struct2 { + /* 0x00 */ s16 unk_00; + /* 0x02 */ s16 unk_02; + /* 0x04 */ char unk04[0x18]; + /* 0x1C */ UnkM406Struct9 *unk_1C; + /* 0x20 */ u8 unk_20; + /* 0x21 */ u8 unk_21; + /* 0x22 */ u8 unk_22; + /* 0x23 */ char unk23; + /* 0x24 */ s16 unk_24; + /* 0x26 */ s16 unk_26; + /* 0x28 */ s32 unk_28; + /* 0x2C */ s32 unk_2C; + /* 0x30 */ u32 unk_30; + /* 0x34 */ u32 unk_34; + /* 0x38 */ AnimData *unk_38; + /* 0x3C */ UnkM406Struct5 *unk_3C; + /* 0x40 */ Vec *unk_40; + /* 0x44 */ Vec2f *unk_44; + /* 0x48 */ void *unk_48; + /* 0x4C */ UnkM406Unk120Struct2Hook unk_4C; + /* 0x50 */ ModelData *unk_50; +} UnkM406Unk120Struct2; /* size = 0x54 */ // strongly assumed to be a copy of UnkModelDataUnk120Struct + +typedef struct UnkM406Struct6 { + /* 0x00 */ s32 unk_00; + /* 0x04 */ s32 unk_04; +} UnkM406Struct6; /* size = 0x08 */ // probably the same as UnkM426Struct13 + +typedef struct UnkM406Struct7 { + /* 0x00 */ u8 unk_00; + /* 0x01 */ u8 unk_01; + /* 0x02 */ char unk02[2]; + /* 0x04 */ s32 unk_04; + /* 0x08 */ s32 unk_08; + /* 0x0C */ float unk_0C; + /* 0x10 */ float unk_10; + /* 0x14 */ float unk_14; + /* 0x18 */ float unk_18; + /* 0x1C */ Mtx unk_1C; +} UnkM406Struct7; /* size = 0x4C */ + +typedef struct UnkM406Struct8 { + /* 0x00 */ AnimData *unk_00; + /* 0x04 */ AnimData *unk_04; + /* 0x08 */ AnimData *unk_08; + /* 0x0C */ AnimData *unk_0C; + /* 0x10 */ s32 unk_10; + /* 0x14 */ s32 unk_14; + /* 0x18 */ s32 unk_18; + /* 0x1C */ s32 unk_1C; + /* 0x20 */ s32 unk_20; + /* 0x24 */ float unk_24; + /* 0x28 */ float unk_28; +} UnkM406Struct8; /* size = 0x2C */ + +typedef struct UnkM406Struct10 { + /* 0x00 */ s32 unk_00; + /* 0x04 */ s32 unk_04; + /* 0x08 */ AnimData *unk_08; +} UnkM406Struct10; /* size = 0x0C */ + +void fn_1_292C(omObjData *object); +void fn_1_2C24(omObjData *object); +void fn_1_3158(void); +void fn_1_4568(void); +void fn_1_45BC(ModelData *arg0, Mtx arg1); +void fn_1_6304(ModelData *arg0, Mtx arg1); +void fn_1_64F8(UnkM406Struct2 *arg0); +s32 fn_1_66F4(float arg8, float *arg0); +void fn_1_67CC(ModelData *arg0); +void fn_1_6F24(void); +void fn_1_6FFC(void); +void fn_1_717C(void); +s32 fn_1_71C4(Vec arg0, Vec arg1, float arg8, float arg9, GXColor arg2); +void fn_1_7718(void); +void fn_1_77F0(void); +void fn_1_79B0(void); +s32 fn_1_79F8(Vec arg0, Vec arg1, float arg8, float arg9, GXColor arg2); +UnkM406Struct5 *fn_1_7B2C(s32 arg0); +void fn_1_7B9C(void); +void fn_1_7C4C(void); +void fn_1_7DAC(void); +s32 fn_1_7DB0(Vec arg0, Vec arg1, float arg8, GXColor arg2); +void fn_1_7ED0(void); +void fn_1_7F80(void); +void fn_1_8100(void); +s32 fn_1_8104(Vec arg0, Vec arg1, float arg8, GXColor arg2); +void fn_1_8244(s32 arg0, s32 arg1, float arg8, float arg9); +void fn_1_8F98(void); +void fn_1_91E0(void); +void fn_1_94BC(void); +void fn_1_9F78(void); +void fn_1_A278(void); +void fn_1_A2C8(ModelData *arg0, UnkM406Unk120Struct2 *arg1, Mtx arg2); +void fn_1_ADB4(ModelData *arg0, Mtx arg1); +void fn_1_B1E0(float arg8); +s16 fn_1_B474(AnimData *arg0, s16 arg1); +void fn_1_BC18(ModelData *arg0, Mtx arg1); +s16 fn_1_C4F4(s16 arg0); +void fn_1_C86C(ModelData *arg0, Mtx arg1); +void fn_1_CDD8(s32 arg0, float arg8, float arg9, float argA, float argB); +void fn_1_CF24(s32 arg0, u8 arg1, u8 arg2, u8 arg3); +s16 fn_1_D06C(ModelData *arg0, Mtx arg1, Mtx arg2, float arg8); +void fn_1_D13C(LightData *arg0, s16 arg1, Mtx arg2, Mtx arg3, float arg8); +void fn_1_D488(float arg8, Vec *arg0, Vec *arg1, Vec *arg2); +void fn_1_D518(Mtx arg0, Vec *arg1); +float fn_1_D5CC(Vec *arg0, Vec *arg1, float arg8, float arg9); + +extern u32 GlobalCounter; + +Vec lbl_1_data_F0[0x46] = { + { -495.876f, 50.005f, -0.0f }, + { -500.023f, -2841.226f, -5007.74f }, + { -502.015f, -7170.411f, -12506.11f }, + { -515.622f, -8314.231f, -14487.27f }, + { -515.6f, -8761.908f, -15262.67f }, + { -508.661f, -9195.703f, -16014.02f }, + { -494.762f, -9629.499f, -16765.38f }, + { -473.947f, -10063.294f, -17516.73f }, + { -471.378f, -10495.727f, -18265.73f }, + { -495.719f, -10915.74f, -18993.21f }, + { -552.519f, -11337.781f, -19724.21f }, + { -621.485f, -11611.703f, -20198.66f }, + { -731.018f, -11887.653f, -20676.62f }, + { -950.131f, -12303.607f, -21397.07f }, + { -1209.766f, -12735.795f, -22145.64f }, + { -1469.474f, -13170.012f, -22897.73f }, + { -1627.69f, -13466.252f, -23410.83f }, + { -1757.595f, -13772.641f, -23941.51f }, + { -1838.731f, -14079.026f, -24472.19f }, + { -1871.186f, -14393.528f, -25016.92f }, + { -1834.734f, -14703.97f, -25554.62f }, + { -1749.541f, -15014.414f, -26092.33f }, + { -1623.78f, -15312.685f, -26608.94f }, + { -1384.433f, -15761.101f, -27385.62f }, + { -1124.798f, -16191.259f, -28130.68f }, + { -775.859f, -16769.535f, -29132.28f }, + { -568.923f, -17183.457f, -29849.22f }, + { -398.537f, -17621.73f, -30608.33f }, + { -187.485f, -18055.945f, -31360.41f }, + { 96.491f, -18634.223f, -32362.02f }, + { 254.886f, -19042.057f, -33068.41f }, + { 315.738f, -19315.977f, -33542.85f }, + { 331.965f, -19581.783f, -34003.24f }, + { 291.397f, -19839.473f, -34449.57f }, + { 189.969f, -20091.07f, -34885.35f }, + { -12.871f, -20340.645f, -35317.62f }, + { -325.245f, -20598.332f, -35763.96f }, + { -747.265f, -20870.219f, -36234.88f }, + { -1230.024f, -21152.258f, -36723.38f }, + { -2276.853f, -21730.535f, -37724.99f }, + { -2759.968f, -22028.799f, -38241.6f }, + { -3189.989f, -22343.3f, -38786.33f }, + { -3514.533f, -22669.979f, -39352.15f }, + { -3620.335f, -22840.408f, -39647.35f }, + { -3693.358f, -23018.965f, -39956.61f }, + { -3705.528f, -23193.463f, -40258.85f }, + { -3693.358f, -23367.96f, -40561.09f }, + { -3551.37f, -23698.695f, -41133.94f }, + { -3307.945f, -24019.275f, -41689.2f }, + { -2995.571f, -24323.633f, -42216.36f }, + { -2646.686f, -24621.904f, -42732.99f }, + { -1920.124f, -25200.174f, -43734.58f }, + { -1457.648f, -25612.07f, -44448.0f }, + { -1238.474f, -25871.78f, -44897.83f }, + { -1084.316f, -26137.584f, -45358.22f }, + { -958.555f, -26417.594f, -45843.21f }, + { -861.049f, -26697.596f, -46328.19f }, + { -783.97f, -26979.635f, -46816.69f }, + { -715.004f, -27261.672f, -47305.2f }, + { -617.584f, -27979.957f, -48549.3f }, + { -548.553f, -28700.271f, -49796.93f }, + { -491.712f, -29278.535f, -50798.51f }, + { -475.485f, -29856.814f, -51800.12f }, + { -479.514f, -30433.059f, -52798.2f }, + { -505.531f, -34619.363f, -60049.28f }, + { -513.632f, -34659.062f, -60100.39f }, + { -509.573f, -34721.215f, -60151.54f }, + { -509.589f, -34805.496f, -60191.15f }, + { -509.587f, -34970.055f, -60233.17f }, + { -509.591f, -45195.266f, -61377.84f }, +}; + +Vec lbl_1_data_438[0x46] = { + { 497.979f, 49.997f, 0.0f }, + { 501.235f, -2841.251f, -5007.79f }, + { 497.983f, -7170.06f, -12505.5f }, + { 479.876f, -8314.231f, -14487.27f }, + { 479.899f, -8761.908f, -15262.67f }, + { 486.837f, -9195.703f, -16014.02f }, + { 500.736f, -9629.499f, -16765.38f }, + { 521.552f, -10063.294f, -17516.73f }, + { 524.121f, -10495.727f, -18265.73f }, + { 503.13f, -10936.027f, -19028.35f }, + { 446.486f, -11379.887f, -19797.14f }, + { 364.665f, -11685.236f, -20326.02f }, + { 245.082f, -11987.438f, -20849.45f }, + { 18.48f, -12434.451f, -21623.7f }, + { -252.156f, -12875.162f, -22387.03f }, + { -497.617f, -13300.134f, -23123.1f }, + { -655.129f, -13580.305f, -23608.37f }, + { -768.419f, -13847.879f, -24071.83f }, + { -843.945f, -14131.193f, -24562.54f }, + { -875.687f, -14393.528f, -25016.92f }, + { -850.353f, -14653.739f, -25467.62f }, + { -768.533f, -14927.61f, -25941.98f }, + { -642.655f, -15201.48f, -26416.33f }, + { -428.664f, -15620.156f, -27141.5f }, + { -170.569f, -16051.424f, -27888.48f }, + { 188.182f, -16636.941f, -28902.62f }, + { 408.467f, -17083.947f, -29676.86f }, + { 572.186f, -17512.059f, -30418.37f }, + { 786.178f, -17940.18f, -31159.9f }, + { 1075.696f, -18525.695f, -32174.04f }, + { 1245.631f, -18972.703f, -32948.28f }, + { 1315.06f, -19274.898f, -33471.7f }, + { 1327.648f, -19592.842f, -34022.39f }, + { 1283.591f, -19907.637f, -34567.64f }, + { 1157.714f, -20235.021f, -35134.68f }, + { 887.077f, -20562.406f, -35701.73f }, + { 496.857f, -20883.496f, -36257.87f }, + { 31.029f, -21188.842f, -36786.75f }, + { -491.693f, -21487.889f, -37304.71f }, + { -1517.594f, -22057.664f, -38291.59f }, + { -1958.808f, -22331.527f, -38765.94f }, + { -2323.853f, -22595.953f, -39223.93f }, + { -2588.195f, -22850.938f, -39665.58f }, + { -2651.134f, -22964.264f, -39861.87f }, + { -2695.42f, -23074.441f, -40052.7f }, + { -2714.302f, -23187.768f, -40248.99f }, + { -2689.126f, -23316.832f, -40472.53f }, + { -2594.718f, -23552.928f, -40881.46f }, + { -2393.337f, -23814.195f, -41334.0f }, + { -2116.406f, -24081.771f, -41797.45f }, + { -1782.831f, -24371.38f, -42299.07f }, + { -1059.036f, -24941.158f, -43285.95f }, + { -561.404f, -25391.299f, -44065.62f }, + { -290.767f, -25709.24f, -44616.31f }, + { -108.245f, -26024.033f, -45161.55f }, + { 23.926f, -26323.088f, -45679.52f }, + { 130.922f, -26625.29f, -46202.95f }, + { 212.947f, -26918.023f, -46709.98f }, + { 275.886f, -27213.93f, -47222.51f }, + { 376.588f, -27941.104f, -48482.01f }, + { 452.187f, -28658.824f, -49725.14f }, + { 508.832f, -29241.193f, -50733.83f }, + { 521.5f, -29814.105f, -51726.14f }, + { 515.985f, -30433.059f, -52798.2f }, + { 503.81f, -34617.785f, -60046.38f }, + { 495.709f, -34657.49f, -60097.48f }, + { 499.768f, -34719.64f, -60148.64f }, + { 499.752f, -34803.92f, -60188.25f }, + { 499.754f, -34968.48f, -60230.3f }, + { 499.75f, -45193.69f, -61374.92f }, +}; + +Vec lbl_1_data_780[3] = { + { 725.7116f, -20607.168f, -35686.844f }, + { -3135.352f, -23367.234f, -40490.824f }, + { -282.94498f, -26285.674f, -45528.754f }, +}; + +s16 lbl_1_data_7A4 = -1; + +s32 lbl_1_data_7A8[7] = { + DATA_MAKE_NUM(DATADIR_M406, 35), + DATA_MAKE_NUM(DATADIR_M406, 36), + DATA_MAKE_NUM(DATADIR_M406, 37), + DATA_MAKE_NUM(DATADIR_M406, 38), + DATA_MAKE_NUM(DATADIR_M406, 39), + DATA_MAKE_NUM(DATADIR_M406, 40), + DATA_MAKE_NUM(DATADIR_M406, 41), +}; + +s32 lbl_1_data_7C4[7] = { + DATA_MAKE_NUM(DATADIR_M406, 48), + DATA_MAKE_NUM(DATADIR_M406, 49), + DATA_MAKE_NUM(DATADIR_M406, 50), + DATA_MAKE_NUM(DATADIR_M406, 51), + DATA_MAKE_NUM(DATADIR_M406, 52), + DATA_MAKE_NUM(DATADIR_M406, 53), + 0, +}; + +s32 lbl_1_data_7E0[6] = { + DATA_MAKE_NUM(DATADIR_M406, 42), + DATA_MAKE_NUM(DATADIR_M406, 43), + DATA_MAKE_NUM(DATADIR_M406, 44), + DATA_MAKE_NUM(DATADIR_M406, 45), + DATA_MAKE_NUM(DATADIR_M406, 46), + DATA_MAKE_NUM(DATADIR_M406, 47), +}; + +Vec lbl_1_data_7F8 = { 0.0f, 0.0f, 0.0f }; + +Vec lbl_1_data_804 = { -1.0f, -2.0f, -1.0f }; + +GXColor lbl_1_data_810 = { 0xFF, 0xFF, 0xFF, 0xFF }; + +Vec lbl_1_data_814 = { 0.0f, 2500.0f, -500.0f }; + +Vec lbl_1_data_820 = { 0.0f, 1.0f, 0.0f }; + +Vec lbl_1_data_82C = { 0.0f, 0.0f, 0.0f }; + +Vec lbl_1_data_838 = { 0.0f, 0.0f, 0.0f }; + +Vec lbl_1_data_844 = { 0.0f, 1.0f, -1.0f }; + +GXColor lbl_1_data_850[8] = { + { 0xFF, 0xFF, 0xFF, 0xFF }, + { 0xC4, 0x2F, 0, 0 }, + { 0x45, 0x1C, 0x40, 0 }, + { 0xC4, 0x2F, 0, 0 }, + { 0, 0, 0, 0 }, + { 0, 0, 0, 0 }, + { 0, 0, 0, 0 }, + { 0x80, 0x80, 0x80, 0xFF }, +}; + +Process *lbl_1_bss_D4; +omObjData *lbl_1_bss_D0; +omObjData *lbl_1_bss_CC; +omObjData *lbl_1_bss_C8; +omObjData *lbl_1_bss_C4; +s32 lbl_1_bss_C0; +s32 lbl_1_bss_BC; +UnkM406Struct2 *lbl_1_bss_B8; +s32 lbl_1_bss_B4; +UnkM406Struct10 *lbl_1_bss_B0; +UnkM406Struct10 *lbl_1_bss_AC; +UnkM406Struct6 *lbl_1_bss_A8; +UnkM406Struct6 *lbl_1_bss_A4; +UnkM406Struct7 *lbl_1_bss_A0; +UnkM406Struct8 *lbl_1_bss_9C; +s32 lbl_1_bss_98; +char lbl_1_bss_8C[0xC]; +UnkM406Struct5 lbl_1_bss_48; +Vec lbl_1_bss_3C; +s32 lbl_1_bss_30[3]; + +extern LightData Hu3DLocalLight[0x20]; + +omObjData *fn_1_2308(Process *arg0) +{ + s32 var_r31; + s32 var_r30; + s32 var_r28; + + lbl_1_bss_D4 = arg0; + lbl_1_bss_C0 = 0; + lbl_1_bss_BC = 1; + lbl_1_bss_98 = -1; + omMakeGroupEx(arg0, 1, 1); + omMakeGroupEx(arg0, 2, 1); + omMakeGroupEx(arg0, 3, 1); + lbl_1_bss_D0 = omAddObjEx(arg0, 127, 0, 0, -1, fn_1_292C); + var_r28 = Hu3DGLightCreateV(&lbl_1_data_7F8, &lbl_1_data_804, &lbl_1_data_810); + Hu3DGLightStaticSet(var_r28, 1); + Hu3DGLightInfinitytSet(var_r28); + lbl_1_bss_CC = omAddObjEx(arg0, 0x7E, 0x15, 0, 1, fn_1_2C24); + for (var_r31 = 0; var_r31 < 7; var_r31++) { + var_r30 = lbl_1_bss_CC->model[var_r31] = Hu3DModelCreateFile(lbl_1_data_7A8[var_r31]); + Hu3DModelShadowMapSet(var_r30); + Hu3DModelAttrSet(var_r30, 1); + if (var_r31 < 6) { + fn_1_CDD8(var_r30, 1.25f, 1.05f, 1.0f, 1.0f); + } + if (var_r31 < 6) { + var_r30 = Hu3DModelCreateFile(lbl_1_data_7C4[var_r31]); + lbl_1_bss_CC->model[var_r31 + 7] = var_r30; + } else { + var_r30 = -1; + lbl_1_bss_CC->model[var_r31 + 7] = var_r30; + } + if (var_r30 != -1) { + Hu3DModelAttrSet(var_r30, 1); + Hu3DModelLayerSet(var_r30, 5); + } + } + var_r30 = Hu3DModelCreateFile(DATA_MAKE_NUM(DATADIR_M406, 54)); + lbl_1_bss_CC->model[14] = var_r30; + Hu3DModelPosSet(var_r30, 0.0f, 10.0f, 0.0f); + Hu3DModelAttrSet(var_r30, 1); + Hu3DModelLayerSet(var_r30, 5); + lbl_1_bss_C8 = omAddObjEx(arg0, 0x7D, 6, 0, 2, NULL); + for (var_r31 = 0; var_r31 < 6; var_r31++) { + lbl_1_bss_C8->model[var_r31] = Hu3DModelCreateFile(lbl_1_data_7E0[var_r31]); + Hu3DModelAttrSet(lbl_1_bss_C8->model[var_r31], 1); + } + lbl_1_bss_C4 = omAddObjEx(arg0, 0x7D, 3, 0, 3, NULL); + lbl_1_bss_C4->trans.x = lbl_1_data_780->x; + lbl_1_bss_C4->trans.y = lbl_1_data_780->y; + lbl_1_bss_C4->trans.z = lbl_1_data_780->z; + lbl_1_bss_C4->scale.x = lbl_1_bss_C4->scale.y = lbl_1_bss_C4->scale.z = 3.0f; + for (var_r31 = 0; var_r31 < 3; var_r31++) { + if (var_r31 == 0) { + lbl_1_bss_C4->model[var_r31] = Hu3DModelCreateFile(DATA_MAKE_NUM(DATADIR_M406, 34)); + } else { + lbl_1_bss_C4->model[var_r31] = Hu3DModelLink(*lbl_1_bss_C4->model); + } + Hu3DModelShadowSet(lbl_1_bss_C4->model[var_r31]); + Hu3DModelScaleSet(lbl_1_bss_C4->model[var_r31], lbl_1_bss_C4->scale.x, lbl_1_bss_C4->scale.y, lbl_1_bss_C4->scale.z); + Hu3DModelPosSet(lbl_1_bss_C4->model[var_r31], lbl_1_data_780[var_r31].x, lbl_1_data_780[var_r31].y, lbl_1_data_780[var_r31].z); + } + fn_1_3158(); + fn_1_6F24(); + fn_1_7718(); + fn_1_7B9C(); + fn_1_7ED0(); + fn_1_8F98(); + lbl_1_bss_30[0] = 1; + fn_1_9F78(); + fn_1_B104(0.0f); + fn_1_B1E0(0.0f); + Hu3DShadowCreate(45.0f, 1000.0f, 250000.0f); + Hu3DShadowTPLvlSet(0.3f); + Hu3DShadowPosSet(&lbl_1_data_814, &lbl_1_data_820, &lbl_1_data_82C); + return lbl_1_bss_D0; +} + +void fn_1_292C(omObjData *object) +{ + Vec sp24; + Vec sp18; + Vec spC; + float sp8; + + float var_f31; + float var_f30; + float var_f29; + + var_f29 = 1000.0f + CZoom; + var_f31 = -65.0f; + var_f30 = 110.0f; + sp8 = 0.0f; + spC.x = Center.x; + spC.y = Center.y; + spC.z = Center.z; + + sp18.x = spC.x + (var_f29 * (sind(var_f30) * cosd(var_f31))); + sp18.y = spC.y + (var_f29 * -sind(var_f31)); + sp18.z = spC.z + (var_f29 * (cosd(var_f30) * cosd(var_f31))); + sp24.x = sind(var_f30) * sind(var_f31); + sp24.y = cosd(var_f31); + sp24.z = cosd(var_f30) * sind(var_f31); + Hu3DShadowPosSet(&sp18, &sp24, &spC); +} + +void fn_1_2BEC(void) +{ + fn_1_4568(); + fn_1_717C(); + fn_1_79B0(); + fn_1_7DAC(); + fn_1_8100(); + fn_1_94BC(); + fn_1_A278(); +} + +void fn_1_2C24(omObjData *object) +{ + float var_f31; + + s32 var_r30; + s32 var_r29; + + if (!lbl_1_bss_C0) { + for (var_r30 = 0; var_r30 < 6; var_r30++) { + var_f31 = -(5000.0f + (10000.0f * var_r30)); + if (fabs(Center.z - var_f31) > 10000.0 || !lbl_1_bss_BC) { + if (object->model[var_r30] != -1) { + Hu3DModelAttrSet(object->model[var_r30], 1); + } + var_r29 = var_r30 + 7; + if (object->model[var_r29] != -1) { + Hu3DModelAttrSet(object->model[var_r29], 1); + } + } else { + if (object->model[var_r30] != -1) { + Hu3DModelAttrReset(object->model[var_r30], 1); + } + var_r29 = var_r30 + 7; + if (object->model[var_r29] != -1) { + Hu3DModelAttrReset(object->model[var_r29], 1); + } + } + } + var_r29 = 14; + if (object->model[var_r29] != -1) { + var_f31 = 25000.0f; + if (fabs(Center.z - var_f31) < 15000.0) { + Hu3DModelAttrSet(object->model[var_r29], 1); + } else { + Hu3DModelAttrReset(object->model[var_r29], 1); + } + } + var_r29 = 6; + if (object->model[var_r29] != -1) { + Hu3DModelAttrSet(object->model[var_r29], 1); + } + for (var_r30 = 0; var_r30 < 3; var_r30++) { + if (fabs(Center.z - lbl_1_data_780[var_r30].z) > 10000.0) { + Hu3DModelAttrSet(lbl_1_bss_C4->model[var_r30], 1); + } else { + Hu3DModelAttrReset(lbl_1_bss_C4->model[var_r30], 1); + } + } + return; + } + for (var_r30 = 0; var_r30 < 6; var_r30++) { + if (object->model[var_r30] != -1) { + Hu3DModelAttrSet(object->model[var_r30], 1); + } + var_r29 = var_r30 + 7; + if (object->model[var_r29] != -1) { + Hu3DModelAttrSet(object->model[var_r29], 1); + } + } + var_r29 = 6; + if (object->model[var_r29] != -1) { + Hu3DModelAttrReset(object->model[var_r29], 1); + } + for (var_r30 = 0; var_r30 < 3; var_r30++) { + Hu3DModelAttrSet(lbl_1_bss_C4->model[var_r30], 1); + } +} + +void fn_1_3064(s32 arg0) +{ + s32 var_r31; + + if (lbl_1_bss_C0 = arg0) { + for (var_r31 = 0; var_r31 < 6; var_r31++) { + if (lbl_1_bss_CC->model[var_r31] != -1) { + Hu3DModelKill(lbl_1_bss_CC->model[var_r31]); + } + lbl_1_bss_CC->model[var_r31] = -1; + } + if (lbl_1_bss_CC->model[6] == -1) { + lbl_1_bss_CC->model[6] = Hu3DModelCreateFile(DATA_MAKE_NUM(DATADIR_M406, 41)); + } + } +} + +void fn_1_3158(void) +{ + UnkM406Struct2 *sp10[2]; // TODO sp10 should probably be a void* + s32 sp8[2]; + + float var_f31; + float var_f30; + float var_f29; + float var_f28; + + UnkM406Unk120Struct *var_r31; + UnkM406Struct *var_r30; + s32 var_r29; + UnkM406Struct4 *var_r28; + UnkM406Struct3 *var_r27; + ModelData *var_r26; + s32 var_r25; + Vec *var_r24; + GXColor *var_r23; + s16(*var_r22)[4]; + Vec *var_r21; + Vec2f *var_r20; + s32 var_r19; + void *var_r18; + ModelData *var_r17; + + var_r19 = lbl_1_data_7A4 = Hu3DHookFuncCreate(fn_1_45BC); + var_r26 = &Hu3DData[var_r19]; + var_r31 = HuMemDirectMallocNum(HEAP_DATA, sizeof(UnkM406Unk120Struct), var_r26->unk_48); + var_r26->unk_120 = var_r31; + memset(var_r31, 0, sizeof(UnkM406Unk120Struct)); + + sp8[0] = Hu3DHookFuncCreate(fn_1_6304); + Hu3DModelLayerSet(sp8[0], 7); + var_r17 = &Hu3DData[sp8[0]]; + var_r17->unk_120 = var_r31; + + sp8[1] = Hu3DLLightCreateV(var_r19, &lbl_1_data_838, &lbl_1_data_844, lbl_1_data_850); + Hu3DLLightStaticSet(var_r19, sp8[1], 1); + Hu3DLLightInfinitytSet(var_r19, sp8[1]); + + var_r31->unk_00 = 0; + var_r31->unk_04 = var_r19; + var_r31->unk_08 = 0; + var_r31->unk_0C = 0.0f; + var_r31->unk_10 = 0.0f; + var_r31->unk_14 = 2000.0f; + var_r31->unk_28 = 0; + var_r31->unk_A8 = HuDataReadNum(DATA_MAKE_NUM(DATADIR_M406, 61), MEMORY_DEFAULT_NUM); + var_r31->unk_AC = 0x80; + var_r31->unk_B0 = 0x80; + var_r31->unk_B4 = 0.0f; + var_r31->unk_B8 = 0.0f; + var_r31->unk_BC = HuDataReadNum(DATA_MAKE_NUM(DATADIR_M406, 62), MEMORY_DEFAULT_NUM); + var_r31->unk_C0 = 0x80; + var_r31->unk_C4 = 0x80; + var_r31->unk_C8 = 0.0f; + var_r31->unk_CC = 0.0f; + var_r31->unk_2C = HuMemDirectMallocNum(HEAP_DATA, 105 * sizeof(UnkM406Struct3), var_r26->unk_48); + memset(var_r31->unk_2C, 0, 105 * sizeof(UnkM406Struct3)); + var_r27 = var_r31->unk_2C; + + for (var_r29 = 0; var_r29 < 105; var_r29++, var_r27++) { + var_r27->unk_00 = var_r29 / 3; + var_r27->unk_04 = 0.33333334f * (var_r29 % 3); + switch (var_r29 % 4) { + case 0: + var_r25 = var_r27->unk_08 = frand() & 0x1F; + break; + case 1: + var_r27->unk_08 = var_r25 + 10; + break; + default: + var_r27->unk_08 = var_r25 + 20; + break; + } + var_r27->unk_0C = -1; + var_r27->unk_10 = 0.0f; + if (var_r29 == 0 || var_r29 == 104) { + var_r27->unk_14 = 0.3f; + } + if (var_r29 == 1 || var_r29 == 103) { + var_r27->unk_14 = 0.6f; + } else { + var_r27->unk_14 = 1.0f; + } + var_r27->unk_18.x = var_r27->unk_18.y = var_r27->unk_18.z = 0.0f; + var_r27->unk_24 = 0; + } + var_r31->unk_30 = HuMemDirectMallocNum(HEAP_DATA, 12 * sizeof(UnkM406Struct4), var_r26->unk_48); + memset(var_r31->unk_30, 0, 12 * sizeof(UnkM406Struct4)); + var_r28 = var_r31->unk_30; + + for (var_r29 = 0; var_r29 < 12; var_r29++, var_r28++) { + switch (var_r29) { + case 0: + var_r28->unk_00 = Hu3DModelCreateFile(DATA_MAKE_NUM(DATADIR_M406, 56)); + break; + case 1: + var_r28->unk_00 = Hu3DModelCreateFile(DATA_MAKE_NUM(DATADIR_M406, 57)); + break; + case 2: + var_r28->unk_00 = Hu3DModelCreateFile(DATA_MAKE_NUM(DATADIR_M406, 58)); + break; + default: + var_r28->unk_00 = Hu3DModelLink(var_r31->unk_30[var_r29 % 3].unk_00); + break; + } + if (var_r29 < 3) { + fn_1_CF24(var_r28->unk_00, 184, 207, 214); + } + var_r28->unk_04 = frand() & 1; + var_r28->unk_08 = 0; + var_r28->unk_0C = frand() % 60; + var_r28->unk_10 = 0.2f + (0.6f * (0.007874016f * (frand() & 0x7F))); + var_r28->unk_14 = var_r28->unk_18 = 0.0f; + var_r28->unk_1C = 0.0f; + var_r28->unk_20 = var_r28->unk_24 = 0.0f; + var_r28->unk_28 = 0.0f; + var_r28->unk_2C = 0.0f; + var_r28->unk_3C.x = var_r28->unk_3C.y = var_r28->unk_3C.z = 0.0f; + } + + var_r31->unk_34.x = var_r31->unk_34.y = var_r31->unk_34.z = 0.0f; + var_r31->unk_40.x = var_r31->unk_40.y = var_r31->unk_40.z = 0.0f; + var_r31->unk_7C = 0; + + var_r31->unk_80 = 1050; + var_r31->unk_84 = HuMemDirectMallocNum(HEAP_DATA, var_r31->unk_80 * sizeof(Vec), var_r26->unk_48); + memset(var_r31->unk_84, 0, var_r31->unk_80 * sizeof(Vec)); + + var_r31->unk_88 = HuMemDirectMallocNum(HEAP_DATA, var_r31->unk_80 * sizeof(Vec), var_r26->unk_48); + memset(var_r31->unk_88, 0, var_r31->unk_80 * sizeof(Vec)); + + var_r31->unk_8C = HuMemDirectMallocNum(HEAP_DATA, var_r31->unk_80 * sizeof(Vec2f), var_r26->unk_48); + memset(var_r31->unk_8C, 0, var_r31->unk_80 * sizeof(Vec2f)); + + var_r31->unk_90 = HuMemDirectMallocNum(HEAP_DATA, var_r31->unk_80 * sizeof(GXColor), var_r26->unk_48); + memset(var_r31->unk_90, 0, var_r31->unk_80 * sizeof(GXColor)); + + var_r31->unk_94 = HuMemDirectMallocNum(HEAP_DATA, var_r31->unk_80 * sizeof(UnkM406Struct), var_r26->unk_48); + memset(var_r31->unk_94, 0, var_r31->unk_80 * sizeof(UnkM406Struct)); + + var_r31->unk_98 = 986; + var_r31->unk_9C = HuMemDirectMallocNum(HEAP_DATA, var_r31->unk_98 * 8, var_r26->unk_48); + memset(var_r31->unk_9C, 0, var_r31->unk_98 * 8); + + var_r24 = var_r31->unk_84; + var_r21 = var_r31->unk_88; + var_r20 = var_r31->unk_8C; + var_r23 = var_r31->unk_90; + var_r30 = var_r31->unk_94; + var_f30 = -500.0f; + var_f29 = -1000.0f; + var_f28 = 0.0f; + for (var_r29 = 0; var_r29 < 30; var_r29++) { + for (var_r25 = 0; var_r25 < 35; var_r25++) { + var_r24->x = var_f30; + var_r24->y = var_f28; + var_r24->z = var_f29; + + var_f30 += 29.411764f; + var_f28 = 0.0f; + + var_r21->x = 0.0f; + var_r21->z = 0.0f; + var_r21->y = 1.0f; + + var_r20->x = 0.0f; + var_r20->y = 0.0f; + + var_r23->r = var_r23->g = var_r23->b = var_r23->a = 0xFF; + if (var_r29 == 0) { + var_r30->unk_01 = 1; + if (var_r29 < 6) { + var_r30->unk_08 = (6 - var_r29) / 6.0f; + } else { + var_r30->unk_08 = 1.0f; + } + } else { + var_r30->unk_01 = 0; + var_r30->unk_08 = 0.0f; + } + if (!var_r25 || var_r25 == 34 || !var_r29) { + var_r30->unk_00 = 0; + var_r30->unk_04 = 0.0f; + } else { + var_r30->unk_00 = 1; + if (var_r29 < 3) { + var_r30->unk_04 = 0.5f + (0.5f * (var_r29 / 3.0f)); + var_r30->unk_04 = sind(90.0f * var_r30->unk_04); + } else { + var_r30->unk_04 = 1.0f; + } + } + var_r30->unk_10.x = var_r24->x; + var_r30->unk_10.y = var_r24->y; + var_r30->unk_10.z = var_r24->z; + var_r30->unk_1C.x = var_r30->unk_1C.y = var_r30->unk_1C.z = 0.0f; + var_r30->unk_0C = 200.0 * sind(90.0f * (var_r29 / 29.0f)); + if (var_r25 < 6) { + var_f31 = var_r25 / 6.0f; + var_r30->unk_04 = var_r30->unk_04 * sind(90.0f * var_f31); + var_r30->unk_0C = var_r30->unk_0C * sind(90.0f * var_f31); + } else if (var_r25 > 28) { + var_f31 = (var_r25 - 28) / 6.0f; + var_r30->unk_04 = var_r30->unk_04 * cosd(90.0f * var_f31); + var_r30->unk_0C = var_r30->unk_0C * cosd(90.0f * var_f31); + } + var_r30->unk_28 = var_r25 / 34.0f; + var_r30->unk_2C = (var_r29 * 2) / 29.0f; + if (var_r30->unk_28 > 1.0f) { + var_r30->unk_28 = fmod(var_r30->unk_28, 1.0); + } + if (var_r30->unk_2C > 1.0f) { + var_r30->unk_2C = fmod(var_r30->unk_2C, 1.0); + } + var_r24++; + var_r21++; + var_r20++; + var_r23++; + var_r30++; + } + var_f30 = -500.0f; + var_f29 += 68.965515f; + } + var_r22 = var_r31->unk_9C; + for (var_r29 = 0; var_r29 < 29; var_r29++) { + for (var_r25 = 0; var_r25 < 34; var_r22++, var_r25++) { + (*var_r22)[0] = var_r25 + (var_r29 * 35); + (*var_r22)[1] = var_r25 + 1 + (var_r29 * 35); + (*var_r22)[2] = var_r25 + 1 + ((var_r29 + 1) * 35); + (*var_r22)[3] = var_r25 + ((var_r29 + 1) * 35); + } + } + var_r18 = HuMemDirectMallocNum(HEAP_DATA, 0x10000, var_r26->unk_48); + sp10[0] = var_r18; + DCFlushRange(var_r18, 0x10000); + GXBeginDisplayList(sp10[0], 0x10000); + GXBegin(GX_TRIANGLESTRIP, GX_VTXFMT0, 70); + for (var_r29 = 0; var_r29 < 35; var_r29++) { + // TODO fix up + GXUnknownu16(var_r29 + 35); + GXUnknownu16(var_r29 + 35); + GXUnknownu16(var_r29 + 35); + GXUnknownu16(var_r29); + GXUnknownu16(var_r29); + GXUnknownu16(var_r29); + } + var_r31->unk_A0 = GXEndDisplayList(); + if (var_r31->unk_A0 >= 0x10000) { + OSReport("ERROR! GList test size over! \n"); + } + var_r31->unk_A4 = HuMemDirectMallocNum(HEAP_DATA, var_r31->unk_A0, var_r26->unk_48); + memcpy(var_r31->unk_A4, var_r18, var_r31->unk_A0); + DCFlushRange(var_r31->unk_A4, var_r31->unk_A0); + HuMemDirectFree(var_r18); + lbl_1_bss_B4 = 70; + lbl_1_bss_B8 = HuMemDirectMallocNum(HEAP_DATA, lbl_1_bss_B4 * 32, var_r26->unk_48); + memset(lbl_1_bss_B8, 0, lbl_1_bss_B4 * 32); + fn_1_64F8(lbl_1_bss_B8); + sp10[1] = &lbl_1_bss_B8[lbl_1_bss_B4 - 1]; + var_r31->unk_18 = sp10[1]->unk_04; + var_r31->unk_1C = 0.0f; + var_r31->unk_20 = -1; + var_r31->unk_24 = 0; +} + +GXColor lbl_1_data_88F = { 0xFF, 0xFF, 0xFF, 0xFF }; +GXColor lbl_1_data_893 = { 0xB3, 0xBB, 0xC2, 0xFF }; +GXColor lbl_1_data_897 = { 0xFF, 0xFF, 0xFF, 0xFF }; +GXColor lbl_1_data_89B = { 0xFF, 0xFF, 0xFF, 0x40 }; +GXColor lbl_1_data_89F = { 0xFF, 0xFF, 0xFF, 0xFF }; + +float lbl_1_data_8A4[4] = { 1000.0f, 200.0f, 600.0f, 1200.0f }; + +float lbl_1_data_8B4[4] = { 1.0f, 0.6f, 0.3f, 0.425f }; + +Vec lbl_1_data_8C4 = { 0.0f, -34700.0f, -62094.0f }; + +Vec lbl_1_data_8D0 = { 0.0f, 1.0f, 0.0f }; + +GXColor lbl_1_data_8DC = { 0xFF, 0xFF, 0xFF, 0xFF }; + +Vec lbl_1_data_8E0[4] = { + { -0.5f, 0.5f, 0.0f }, + { 0.5f, 0.5f, 0.0f }, + { 0.5f, -0.5f, 0.0f }, + { -0.5f, -0.5f, 0.0f }, +}; + +Vec2f lbl_1_data_910[4] = { { 0.0f, 0.0f }, { 0.25f, 0.0f }, { 0.25f, 0.25f }, { 0.0f, 0.25f } }; + +Vec lbl_1_data_930[4] = { + { 0.0f, 0.5f, 0.0f }, + { 0.5f, 0.0f, 0.0f }, + { 0.0f, -0.5f, 0.0f }, + { -0.5f, 0.0f, 0.0f }, +}; + +void fn_1_4084(void) +{ + Vec sp28; + Vec sp1C; + Vec sp10; + void *spC; + float sp8; + + float var_f31; + float var_f30; + float var_f29; + float var_f28; + + UnkM406Unk120Struct *var_r31; + s32 var_r30; + UnkM406Struct *var_r29; + Vec *var_r28; + s32 var_r27; + s32 var_r26; + ModelData *var_r25; + + spC = lbl_1_bss_B8; + var_r25 = &Hu3DData[lbl_1_data_7A4]; + var_r31 = var_r25->unk_120; + if (!var_r31->unk_28) { + if (++var_r31->unk_24 >= 1 && var_r31->unk_20 == -1) { + sp28.x = 0.5f * (var_r31->unk_34.x + var_r31->unk_40.x); + sp28.y = 0.5f * (var_r31->unk_34.y + var_r31->unk_40.y); + sp28.z = 0.5f * (var_r31->unk_34.z + var_r31->unk_40.z); + var_r31->unk_20 = HuAudFXEmiterPlay(1337, &sp28); + } else if (var_r31->unk_20 != -1) { + sp28.x = 0.5f * (var_r31->unk_34.x + var_r31->unk_40.x); + sp28.y = 0.5f * (var_r31->unk_34.y + var_r31->unk_40.y); + sp28.z = 0.5f * (var_r31->unk_34.z + var_r31->unk_40.z); + HuAudFXEmiterUpDate(var_r31->unk_20, &sp28); + } + } else if (var_r31->unk_20 != -1) { + HuAudFXStop(var_r31->unk_20); + var_r31->unk_20 = -1; + } + var_r31->unk_0C = var_r31->unk_0C + var_r31->unk_10; + if (var_r31->unk_0C > var_r31->unk_18) { + var_r31->unk_1C = var_r31->unk_0C - var_r31->unk_18; + var_r31->unk_0C = var_r31->unk_18; + } else { + var_r31->unk_1C = 0.0f; + } + var_r28 = var_r31->unk_84; + var_r29 = var_r31->unk_94; + var_f30 = 0.0f; + var_f28 = var_r31->unk_14 / 29.0f; + + for (var_r27 = 0; var_r27 < 30; var_r27++) { + var_r30 = fn_1_66F4(var_r31->unk_0C - var_f30, &sp8); + var_f30 += var_f28; + if (var_r30 < 0) { + var_r30 = 0; + sp1C = lbl_1_data_F0[var_r30]; + sp10 = lbl_1_data_438[var_r30]; + } else if (var_r30 < (lbl_1_bss_B4 - 1)) { + fn_1_D488(sp8, &lbl_1_data_F0[var_r30], &lbl_1_data_F0[var_r30 + 1], &sp1C); + fn_1_D488(sp8, &lbl_1_data_438[var_r30], &lbl_1_data_438[var_r30 + 1], &sp10); + } else { + var_r30 = lbl_1_bss_B4 - 1; + sp1C = lbl_1_data_F0[var_r30]; + sp10 = lbl_1_data_438[var_r30]; + } + if (var_r27 == 0) { + var_r31->unk_34 = sp1C; + var_r31->unk_40 = sp10; + var_r31->unk_7C = var_r30; + var_f29 = atan2d(var_r31->unk_40.x - var_r31->unk_34.x, var_r31->unk_40.z - var_r31->unk_34.z); + mtxRot(var_r31->unk_4C, 0.0f, var_f29, 0.0f); + } + for (var_r26 = 0, var_f31 = 0.0f; var_r26 < 35; var_r28++, var_r29++, var_r26++) { + fn_1_D488(var_f31, &sp1C, &sp10, var_r28); + var_r29->unk_10 = *var_r28; + var_f31 += 0.029411765f; + var_r29->unk_1C = lbl_1_bss_B8[var_r30].unk_08; + } + } +} + +void fn_1_4568(void) +{ + UnkM406Unk120Struct *var_r31; + ModelData *var_r30; + + var_r30 = &Hu3DData[lbl_1_data_7A4]; + var_r31 = var_r30->unk_120; + HuMemDirectFree(var_r31->unk_A8); +} + +void fn_1_45BC(ModelData *arg0, Mtx arg1) +{ + Mtx sp10; + + UnkM406Unk120Struct *var_r31; + s16 var_r30; + s16 var_r29; + s16 var_r26; + + var_r31 = arg0->unk_120; + if (!var_r31->unk_08) { + fn_1_6304(arg0, arg1); + } + if (!var_r31->unk_28) { + GXLoadPosMtxImm(arg1, 0); + PSMTXInvXpose(arg1, sp10); + GXLoadNrmMtxImm(sp10, 0); + var_r26 = fn_1_D06C(arg0, Hu3DCameraMtx, Hu3DCameraMtxXPose, 2.0f); + GXSetNumTevStages(1); + GXSetNumTexGens(0); + GXSetNumChans(1); + GXSetTexCoordGen2(GX_TEXCOORD0, GX_TG_MTX2x4, GX_TG_NRM, 0x36, GX_FALSE, 125); + GXSetTevOrder(GX_TEVSTAGE0, GX_TEXCOORD_NULL, GX_TEXMAP_NULL, GX_COLOR0A0); + GXSetTevOp(GX_TEVSTAGE0, GX_REPLACE); + GXSetTevColorIn(GX_TEVSTAGE0, GX_CC_RASC, GX_CC_ZERO, GX_CC_ZERO, GX_CC_ZERO); + GXSetTevColorOp(GX_TEVSTAGE0, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, GX_TRUE, GX_TEVPREV); + GXSetTevAlphaIn(GX_TEVSTAGE0, GX_CA_RASA, GX_CA_ZERO, GX_CA_ZERO, GX_CA_ZERO); + GXSetTevAlphaOp(GX_TEVSTAGE0, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, GX_TRUE, GX_TEVPREV); + GXSetChanCtrl(GX_COLOR0A0, GX_TRUE, GX_SRC_REG, GX_SRC_REG, var_r26, GX_DF_CLAMP, GX_AF_SPEC); + GXSetAlphaCompare(GX_GEQUAL, 1, GX_AOP_AND, GX_GEQUAL, 1); + GXSetZMode(GX_TRUE, GX_LEQUAL, GX_TRUE); + GXSetZCompLoc(GX_TRUE); + GXSetBlendMode(GX_BM_BLEND, GX_BL_SRCALPHA, GX_BL_INVSRCALPHA, GX_LO_NOOP); + GXSetChanAmbColor(GX_COLOR0A0, lbl_1_data_893); + GXSetChanMatColor(GX_COLOR0A0, lbl_1_data_88F); + DCFlushRangeNoSync(var_r31->unk_84, var_r31->unk_80 * sizeof(Vec)); + DCFlushRangeNoSync(var_r31->unk_88, var_r31->unk_80 * sizeof(Vec)); + DCFlushRangeNoSync(var_r31->unk_8C, var_r31->unk_80 * sizeof(Vec2f)); + DCFlushRangeNoSync(var_r31->unk_90, var_r31->unk_80 * sizeof(GXColor)); + PPCSync(); + GXClearVtxDesc(); + GXSetVtxDesc(GX_VA_POS, GX_INDEX16); + GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_POS, GX_POS_XYZ, GX_F32, 0); + GXSetArray(GX_VA_POS, var_r31->unk_84, sizeof(Vec)); + GXSetVtxDesc(GX_VA_NRM, GX_INDEX16); + GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_NRM, GX_NRM_XYZ, GX_F32, 0); + GXSetArray(GX_VA_NRM, var_r31->unk_88, sizeof(Vec)); + GXSetVtxDesc(GX_VA_CLR0, GX_INDEX16); + GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_CLR0, GX_CLR_RGBA, GX_RGBA8, 0); + GXSetArray(GX_VA_CLR0, var_r31->unk_90, 4); + GXCallDisplayList(var_r31->unk_A4, var_r31->unk_A0); + for (var_r30 = 1; var_r30 < 29; var_r30++) { + var_r29 = var_r30 * 35; + GXSetArray(GX_VA_POS, &var_r31->unk_84[var_r29], sizeof(Vec)); + GXSetArray(GX_VA_NRM, &var_r31->unk_88[var_r29], sizeof(Vec)); + GXSetArray(GX_VA_CLR0, &var_r31->unk_90[var_r29], sizeof(GXColor)); + GXCallDisplayList(var_r31->unk_A4, var_r31->unk_A0); + } + } +} + +void fn_1_4964(ModelData *arg0) +{ + UnkM406Struct5 spD0; + Vec spC4; + Vec spB8; + Vec spAC; + Vec spA0; + Vec2f sp50; + Vec2f sp48; + GXColor sp3C; + float sp38; + + float var_f31; + float var_f30; + float var_f29; + + UnkM406Struct4 *var_r31; + UnkM406Unk120Struct *var_r30; + UnkM406Struct3 *var_r29; + UnkM406Struct *var_r28; + s32 var_r27; + s32 var_r26; + Vec *var_r25; + s32 var_r24; + s32 var_r23; + s32 var_r22; + Vec *var_r21; + Vec2f *var_r20; + GXColor *var_r19; + + var_r30 = arg0->unk_120; + if (var_r30->unk_28) { + if (!omPauseChk()) { + fn_1_67CC(arg0); + } + return; + } + if (!omPauseChk()) { + var_r30->unk_B4 += 0.005f; + var_r30->unk_B8 += (0.007499999832361937 + (0.001 * var_r30->unk_1C)); + if (fabs(var_r30->unk_B4) > 1.0) { // 1.0 or 1.0f? + var_r30->unk_B4 = fmod(var_r30->unk_B4, 1.0); + } + if (var_r30->unk_B4 < 0.0f) { + var_r30->unk_B4 += 1.0f; + } + if (fabs(var_r30->unk_B8) > 1.0) { + var_r30->unk_B8 = fmod(var_r30->unk_B8, 1.0); + } + if (var_r30->unk_B8 < 0.0f) { + var_r30->unk_B8 += 1.0f; + } + var_r30->unk_C8 += -0.005f; + var_r30->unk_CC += (-0.007499999832361937 + (0.001 * var_r30->unk_1C)); + if (fabs(var_r30->unk_C8) > 1.0) { + var_r30->unk_C8 = fmod(var_r30->unk_C8, 1.0); + } + if (var_r30->unk_C8 < 0.0f) { + var_r30->unk_C8 += 1.0f; + } + if (fabs(var_r30->unk_CC) > 1.0) { + var_r30->unk_CC = fmod(var_r30->unk_CC, 1.0); + } + if (var_r30->unk_CC < 0.0f) { + var_r30->unk_CC += 1.0f; + } + } + var_r25 = var_r30->unk_84; + var_r21 = var_r30->unk_88; + var_r20 = var_r30->unk_8C; + var_r19 = var_r30->unk_90; + var_r28 = var_r30->unk_94; + sp50.x = var_r30->unk_AC - 1; + sp50.y = var_r30->unk_B0 - 1; + sp48.x = var_r30->unk_C0 - 1; + sp48.y = var_r30->unk_C4 - 1; + for (var_r27 = 0; var_r27 < var_r30->unk_80; var_r27++) { + *var_r25 = var_r28->unk_10; + if (var_r28->unk_00 || var_r28->unk_01) { + var_r23 = (s32)(sp50.x * (var_r28->unk_28 + var_r30->unk_B4)) & 0x7F; + var_r22 = (s32)(sp50.y * (var_r28->unk_2C + var_r30->unk_B8)) & 0x7F; + var_f31 = var_r30->unk_A8[(var_r22 * var_r30->unk_AC) + var_r23]; + var_r23 = (s32)(sp48.x * (var_r28->unk_28 + var_r30->unk_C8)) & 0x7F; + var_r22 = (s32)(sp48.y * (var_r28->unk_2C + var_r30->unk_CC)) & 0x7F; + var_f31 += var_r30->unk_BC[(var_r22 * var_r30->unk_C0) + var_r23]; + if (var_r28->unk_00) { + var_r25->y = var_r28->unk_10.y + var_r28->unk_0C + (100.0f * (0.003921569f * (var_r28->unk_04 * var_f31))); + } + if (var_r28->unk_01) { + var_r25->z = var_r28->unk_10.z - (50.0f * (0.003921569f * (var_r28->unk_08 * var_f31))); + } + } + var_r25++; + var_r21++; + var_r20++; + var_r19++; + var_r28++; + } + if (omPauseChk()) { + return; + } + for (var_r27 = 0; var_r27 < 5; var_r27++) { + var_r26 = (u32)frand() % 34; + fn_1_D488(0.007874016f * (frand() & 0x7F), &var_r30->unk_84[var_r26], &var_r30->unk_84[var_r26 + 1], &spC4); + spC4.x += 10.0f * var_r30->unk_94->unk_1C.x; + spC4.z += 10.0f * var_r30->unk_94->unk_1C.z; + spA0.y = 5.0f + (5.0f * (0.007874016f * (frand() & 0x7F))); + spA0.x = spA0.z = 0.0f; + var_r26 = (frand() & 0x1F) + 0xE0; + sp3C.r = 0.96f * var_r26; + sp3C.g = 0.98f * var_r26; + sp3C.b = (float)var_r26; + sp3C.a = 0xC8; + fn_1_71C4(spC4, spA0, 100.0f + (50.0f * (0.007874016f * (frand() & 0x7F))), -0.1f, sp3C); + } + var_r29 = var_r30->unk_2C; + spD0 = lbl_1_bss_48; + memset(&spD0, 0, sizeof(UnkM406Struct5)); + for (var_r27 = 0; var_r27 < 105; var_r27++, var_r29++) { + fn_1_D488(var_r29->unk_04, &var_r30->unk_84[var_r29->unk_00], &var_r30->unk_84[var_r29->unk_00 + 1], &var_r29->unk_18); + if (var_r29->unk_08 >= 0) { + var_r29->unk_08--; + } else { + var_r29->unk_24 = fn_1_7B2C(var_r29->unk_0C); + if (var_r29->unk_24 == NULL) { + var_r29->unk_24 = &lbl_1_bss_48; + } + if (var_r29->unk_24->unk_28 <= 0.0f) { + spC4 = var_r29->unk_18; + spA0.x = spA0.y = spA0.z = 0.0f; + var_r26 = (frand() & 0x1F) + 0xE0; + sp3C.r = 0.96f * var_r26; + sp3C.g = 0.98f * var_r26; + sp3C.b = (float)var_r26; + sp3C.a = 0xFF; + if (frand() & 1) { + var_f31 = 0.05f; + } else { + var_f31 = -0.05f; + } + var_r29->unk_10 = 0.01f * (100.0f * (0.007874016f * (frand() & 0x7F))); + var_r29->unk_0C = fn_1_79F8(spC4, spA0, 75.0f + (var_r29->unk_14 * (75.0f * (0.007874016f * (frand() & 0x7F)))), var_f31, sp3C); + } else { + var_r29->unk_18.y += var_r29->unk_10; + var_r29->unk_24->unk_30 = var_r29->unk_18; + } + } + } + sp3C.r = sp3C.g = sp3C.b = sp3C.a = 0xFF; + fn_1_D488(0.007874016f * (frand() & 0x7F), &var_r30->unk_84[0], &var_r30->unk_84[34], &spC4); + if ((frand() & 3) == 0) { + var_f31 = 45.0f + (30.0f * (0.007874016f * (frand() & 0x7F))); + var_f29 = 0.75f + (0.75f * (0.007874016f * (frand() & 0x7F))); + } else { + var_f31 = -(15.0f * (0.007874016f * (frand() & 0x7F))); + var_f29 = 1.75f + (0.75f * (0.007874016f * (frand() & 0x7F))); + } + if (var_r30->unk_10 != 0.0f) { + var_f30 = 15.000001f / var_r30->unk_10; + } else { + var_f30 = 1.0f; + } + spA0.y = var_f30 * ((7.5000005f * var_f29) * sind(var_f31)); + var_f30 = (0.75f * var_r30->unk_10) + (7.5000005f * var_f29) * cosd(var_f31); + var_f30 = var_f30; + spA0.x = var_r30->unk_94->unk_1C.x * var_f30; + spA0.z = var_r30->unk_94->unk_1C.z * var_f30; + + fn_1_7DB0(spC4, spA0, 7.5f, sp3C); + var_r31 = var_r30->unk_30; + for (var_r27 = 0; var_r27 < 12; var_r27++, var_r31++) { + if (var_r31->unk_08 == 0) { + if (var_r31->unk_0C <= 0) { + var_f30 = 0.5f + (0.75f * (0.007874016f * (frand() & 0x7F))); + Hu3DModelScaleSet(var_r31->unk_00, var_f30, var_f30, var_f30); + var_r31->unk_04 = frand() & 1; + switch (var_r31->unk_04) { + case 0: + var_r31->unk_10 = 0.1f + (0.8f * (0.007874016f * (frand() & 0x7F))); + var_r31->unk_14 = var_r31->unk_18 = 0.0f; + var_r31->unk_20 = var_r31->unk_24 = 0.0f; + var_r31->unk_08 = 0; + var_r31->unk_0C = 0; + var_r31->unk_1C = 100.0f * (0.5f + (0.75f * (0.007874016f * (frand() & 0x7F)))); + var_r31->unk_28 = 0.0f; + var_r31->unk_2C = 15.0f + (15.0f * (0.007874016f * (frand() & 0x7F))); + break; + case 1: + var_r31->unk_10 = 0.1f + (0.8f * (0.007874016f * (frand() & 0x7F))); + var_r31->unk_14 = var_r31->unk_18 = 0.0f; + var_r31->unk_20 = var_r31->unk_24 = 0.0f; + var_r31->unk_08 = 0; + var_r31->unk_0C = 0; + var_r31->unk_1C = 100.0f * (0.5f + (0.007874016f * (frand() & 0x7F))); + var_r31->unk_28 = 100.0f * (0.07f + (0.03f * (0.007874016f * (frand() & 0x7F)))); + var_r31->unk_2C = 15.0f + (15.0f * (0.007874016f * (frand() & 0x7F))); + break; + default: + break; + } + } else { + Hu3DModelAttrSet(var_r31->unk_00, 1); + var_r31->unk_08 = -1; + var_r31->unk_0C--; + } + } else if (var_r31->unk_08 >= 0) { + var_r24 = fn_1_66F4(var_r30->unk_0C + var_r31->unk_18, &sp38); + if (var_r24 >= 0 && var_r24 < (lbl_1_bss_B4 - 1)) { + fn_1_D488(sp38, &lbl_1_data_F0[var_r24], &lbl_1_data_F0[var_r24++], &spB8); + fn_1_D488(sp38, &lbl_1_data_438[var_r24], &lbl_1_data_438[var_r24 + 1], &spAC); + fn_1_D488(var_r31->unk_10, &spB8, &spAC, &var_r31->unk_3C); + Hu3DModelAttrReset(var_r31->unk_00, 1); + switch (var_r31->unk_04) { + case 0: + var_r31->unk_18 = var_r31->unk_1C * sind(5.0f * var_r31->unk_08); + var_r31->unk_20 = var_r31->unk_20 - var_r31->unk_2C; + Hu3DModelPosSet(var_r31->unk_00, var_r31->unk_3C.x, var_r31->unk_3C.y, var_r31->unk_3C.z); + Hu3DModelRotSet(var_r31->unk_00, var_r31->unk_20, var_r31->unk_24, 0.0f); + break; + case 1: + var_r31->unk_18 = var_r31->unk_1C * sind((float)var_r31->unk_08); + var_r31->unk_20 = var_r31->unk_20 - var_r31->unk_2C; + var_r31->unk_14 = var_r31->unk_14 + var_r31->unk_28; + if (var_r31->unk_14 < 0.0f) { + var_f30 = 0.65 + (0.15 * (0.007874016f * (frand() & 0x7F))); + var_f30 = var_f30; + var_r31->unk_14 = 0.0f; + var_r31->unk_28 = var_r31->unk_28 * -var_f30; + } + var_r31->unk_28 = var_r31->unk_28 - 0.32666668f; + var_r31->unk_3C.y += var_r31->unk_14; + Hu3DModelPosSet(var_r31->unk_00, var_r31->unk_3C.x, var_r31->unk_3C.y, var_r31->unk_3C.z); + Hu3DModelRotSet(var_r31->unk_00, var_r31->unk_20, var_r31->unk_24, 0.0f); + break; + default: + break; + } + } else { + Hu3DModelAttrSet(var_r31->unk_00, 1); + var_r31->unk_08 = -1; + } + } + if (var_r31->unk_18 < (-0.1f * var_r31->unk_1C)) { + var_r31->unk_08 = -1; + var_r31->unk_0C = frand() & 0x1F; + } + var_r31->unk_08++; + } + var_r30->unk_00++; +} + +void fn_1_6174(ModelData *arg0) +{ + Vec sp20; + Vec sp14; + Vec sp8; + + UnkM406Unk120Struct *var_r31; + s16(*var_r30)[4]; + s32 var_r29; + Vec *var_r28; + + var_r31 = arg0->unk_120; + memset(var_r31->unk_88, 0, var_r31->unk_80 * sizeof(Vec)); + for (var_r29 = 0, var_r30 = var_r31->unk_9C; var_r29 < var_r31->unk_98; var_r29++, var_r30++) { + PSVECSubtract(&var_r31->unk_84[(*var_r30)[1]], &var_r31->unk_84[(*var_r30)[0]], &sp14); + PSVECSubtract(&var_r31->unk_84[(*var_r30)[2]], &var_r31->unk_84[(*var_r30)[1]], &sp8); + PSVECCrossProduct(&sp14, &sp8, &sp20); + + PSVECAdd(&var_r31->unk_88[(*var_r30)[0]], &sp20, &var_r31->unk_88[(*var_r30)[0]]); + PSVECAdd(&var_r31->unk_88[(*var_r30)[1]], &sp20, &var_r31->unk_88[(*var_r30)[1]]); + PSVECAdd(&var_r31->unk_88[(*var_r30)[2]], &sp20, &var_r31->unk_88[(*var_r30)[2]]); + PSVECAdd(&var_r31->unk_88[(*var_r30)[3]], &sp20, &var_r31->unk_88[(*var_r30)[3]]); + } + for (var_r29 = 0, var_r28 = var_r31->unk_88; var_r29 < var_r31->unk_80; var_r29++) { + PSVECNormalize(var_r28, var_r28); + } +} + +void fn_1_6304(ModelData *arg0, Mtx arg1) +{ + UnkM406Unk120Struct *var_r28; + ModelData *var_r27; + + var_r28 = arg0->unk_120; + var_r27 = &Hu3DData[var_r28->unk_04]; + if (!omPauseChk() && lbl_1_bss_30[0]) { + fn_1_4084(); + fn_1_6FFC(); + fn_1_77F0(); + fn_1_7C4C(); + fn_1_7F80(); + fn_1_91E0(); + } + fn_1_4964(var_r27); + fn_1_6174(var_r27); + var_r28->unk_08 = 1; +} + +void fn_1_64F8(UnkM406Struct2 *arg0) +{ + float var_f31; + + UnkM406Struct2 *var_r31; + s32 var_r30; + UnkM406Struct2 *var_r28; + + for (var_r30 = 0, var_r31 = arg0; var_r30 < lbl_1_bss_B4; var_r30++, var_r31++) { + var_r31->unk_14.x = 0.5f * (lbl_1_data_F0[var_r30].x + lbl_1_data_438[var_r30].x); + var_r31->unk_14.y = 0.5f * (lbl_1_data_F0[var_r30].y + lbl_1_data_438[var_r30].y); + var_r31->unk_14.z = 0.5f * (lbl_1_data_F0[var_r30].z + lbl_1_data_438[var_r30].z); + } + for (var_r30 = 0, var_r31 = arg0; var_r30 < lbl_1_bss_B4; var_r30++, var_r31++) { + if (var_r30 < lbl_1_bss_B4 - 1) { + var_r28 = &arg0[var_r30 + 1]; + PSVECSubtract(&var_r28->unk_14, &var_r31->unk_14, &var_r31->unk_08); + var_r31->unk_00 = PSVECMag(&var_r31->unk_08); + PSVECNormalize(&var_r31->unk_08, &var_r31->unk_08); + } else { + var_r31->unk_00 = 100000.0f; + var_r31->unk_08.x = 0.0f; + var_r31->unk_08.y = 0.0f; + var_r31->unk_08.z = -1.0f; + } + var_r31->unk_04 = var_f31; + var_f31 += var_r31->unk_00; + } +} + +s32 fn_1_66F4(float arg8, float *arg0) +{ + UnkM406Struct2 *var_r31; + s32 var_r30; + + for (var_r30 = 0, var_r31 = lbl_1_bss_B8; var_r30 < lbl_1_bss_B4; var_r30++, var_r31++) { + if (arg8 < (var_r31->unk_04 + var_r31->unk_00)) { + *arg0 = (arg8 - var_r31->unk_04) / var_r31->unk_00; + if (*arg0 < 0.0f) { + *arg0 = 0.0f; + } + break; + } + } + if (var_r30 >= lbl_1_bss_B4) { + if (arg0) { + *arg0 = 0.0f; + } + return -1; + } + return var_r30; +} + +void fn_1_67CC(ModelData *arg0) +{ + UnkM406Struct4 *var_r31; + s32 var_r30; + UnkM406Unk120Struct *var_r29; + + var_r29 = arg0->unk_120; + var_r31 = var_r29->unk_30; + for (var_r30 = 0; var_r30 < 12; var_r30++, var_r31++) { + if (var_r31->unk_04 != 3 || var_r31->unk_0C > 0) { + Hu3DModelAttrSet(var_r31->unk_00, 1); + var_r31->unk_0C--; + } else { + var_r31->unk_20 = var_r31->unk_20 - var_r31->unk_2C; + var_r31->unk_3C.x += var_r31->unk_30.x; + var_r31->unk_3C.y += var_r31->unk_30.y; + var_r31->unk_3C.z += var_r31->unk_30.z; + var_r31->unk_30.y -= 0.49f; + Hu3DModelPosSet(var_r31->unk_00, var_r31->unk_3C.x, var_r31->unk_3C.y, var_r31->unk_3C.z); + Hu3DModelRotSet(var_r31->unk_00, var_r31->unk_20, var_r31->unk_24, 0.0f); + Hu3DModelAttrReset(var_r31->unk_00, 1); + if (++var_r31->unk_08 >= 600.0f) { + Hu3DModelAttrSet(var_r31->unk_00, 1); + var_r31->unk_04 = 0; + var_r31->unk_08 = 0; + } + } + } +} + +void fn_1_696C(float arg8) +{ + UnkM406Unk120Struct *var_r31; + ModelData *var_r30; + + if (lbl_1_data_7A4 >= 0) { + var_r30 = &Hu3DData[lbl_1_data_7A4]; + var_r31 = var_r30->unk_120; + var_r31->unk_10 = arg8; + } +} + +void fn_1_69C0(Vec *arg0) +{ + UnkM406Unk120Struct *var_r31; + ModelData *var_r30; + + arg0->x = arg0->y = arg0->z = 0.0f; + if (lbl_1_data_7A4 >= 0) { + var_r30 = &Hu3DData[lbl_1_data_7A4]; + var_r31 = var_r30->unk_120; + *arg0 = var_r31->unk_94[17].unk_10; + } +} + +s32 fn_1_6A44(Vec *arg0) +{ + Vec sp20; + Vec sp14; + Vec sp8; + + float var_f31; + + UnkM406Unk120Struct *var_r31; + ModelData *var_r29; + + if (lbl_1_data_7A4 < 0) { + return 0; + } + var_r29 = &Hu3DData[lbl_1_data_7A4]; + var_r31 = var_r29->unk_120; + PSVECAdd(&var_r31->unk_34, &var_r31->unk_40, &sp8); + PSVECScale(&sp8, &sp8, 0.5f); + PSVECSubtract(&var_r31->unk_34, &sp8, &sp20); + PSVECSubtract(&var_r31->unk_40, &sp8, &sp14); + var_f31 = fn_1_D5CC(&sp20, &sp14, arg0->x - sp8.x, arg0->z - sp8.z); + if (var_f31 <= 0.0f) { + return 0; + } + return 1; +} + +void fn_1_6B5C(void) +{ + UnkM406Unk120Struct *var_r31; + ModelData *var_r30; + + if (lbl_1_data_7A4 >= 0) { + var_r30 = &Hu3DData[lbl_1_data_7A4]; + var_r31 = var_r30->unk_120; + var_r31->unk_28 = 1; + } +} + +void fn_1_6BB4(Vec *arg0) +{ + Vec sp30; + Vec sp24; + + float var_f31; + + s32 var_r30; + s32 var_r29; + + for (var_r30 = 0; var_r30 < 32; var_r30++) { + sp30.x = arg0->x + (100.0f * ((0.007874016f * (frand() & 0x7F)) - 0.5f)); + sp30.y = arg0->y; + sp30.z = arg0->z - 100.0f; + sp24.x = 2.0f * (0.5f - (0.007874016f * (frand() & 0x7F))); + sp24.z = -2.0f * (1.0f + (1.2f * (0.007874016f * (frand() & 0x7F)))); + sp24.y = 7.5000005f * (1.0f + (0.7f * (0.007874016f * (frand() & 0x7F)))); + var_f31 = 5.5f + (5.5f * (0.007874016f * (frand() & 0x7F))); + + var_r29 = fn_1_8104(sp30, sp24, var_f31, lbl_1_data_897); + fn_1_8244(var_r29, (s32)(60.0f * (0.007874016f * (frand() & 0x7F))) + 60, 0.32666668f, 0.99f); + } +} + +void fn_1_6F24(void) +{ + s32 sp8; + + UnkM406Struct10 *var_r31; + UnkM406Unk120Struct2 *var_r30; + ModelData *var_r29; + AnimData *var_r28; + + var_r31 = lbl_1_bss_B0 = HuMemDirectMallocNum(HEAP_SYSTEM, sizeof(UnkM406Struct10), MEMORY_DEFAULT_NUM); + memset(var_r31, 0, sizeof(UnkM406Struct10)); + var_r28 = HuSprAnimRead(HuDataReadNum(DATA_MAKE_NUM(DATADIR_M406, 63), MEMORY_DEFAULT_NUM)); + var_r31->unk_08 = var_r28; + var_r31->unk_00 = sp8 = fn_1_B474(var_r28, 0x800); + Hu3DModelLayerSet(var_r31->unk_00, 2); + var_r31->unk_04 = 0; + var_r29 = &Hu3DData[var_r31->unk_00]; + var_r30 = var_r29->unk_120; + var_r30->unk_20 = 0; +} + +void fn_1_6FFC(void) +{ + UnkM406Struct5 *var_r31; + UnkM406Struct10 *var_r30; + UnkM406Unk120Struct2 *var_r29; + s32 var_r28; + ModelData *var_r27; + + var_r30 = lbl_1_bss_B0; + if (var_r30->unk_04 <= 0) { + Hu3DModelAttrSet(var_r30->unk_00, 1); + return; + } + Hu3DModelAttrReset(var_r30->unk_00, 1); + var_r27 = &Hu3DData[var_r30->unk_00]; + var_r29 = var_r27->unk_120; + var_r31 = var_r29->unk_3C; + for (var_r28 = 0; var_r28 < var_r29->unk_26; var_r28++, var_r31++) { + if (var_r31->unk_28 <= 0.0f) { + continue; + } + var_r31->unk_30.x += var_r31->unk_04.x; + var_r31->unk_30.y += var_r31->unk_04.y; + var_r31->unk_30.z += var_r31->unk_04.z; + var_r31->unk_2C += var_r31->unk_18; + if (var_r31->unk_2C >= 360.0f) { + var_r31->unk_2C -= 360.0f; + } + var_r31->unk_40 = var_r31->unk_00 >> 1; + var_r31->unk_00++; + if (var_r31->unk_40 >= 16) { + var_r31->unk_40 = 0; + var_r31->unk_00 = 0; + var_r31->unk_28 = 0.0f; + var_r30->unk_04--; + } + } +} + +void fn_1_717C(void) +{ + UnkM406Struct10 *var_r31; + + var_r31 = lbl_1_bss_B0; + Hu3DModelAttrSet(var_r31->unk_00, 1); + HuSprAnimKill(var_r31->unk_08); +} + +s32 fn_1_71C4(Vec arg0, Vec arg1, float arg8, float arg9, GXColor arg2) +{ + UnkM406Struct5 *var_r31; + UnkM406Unk120Struct2 *var_r30; + s32 var_r29; + UnkM406Struct10 *var_r28; + ModelData *var_r27; + + var_r28 = lbl_1_bss_B0; + var_r27 = &Hu3DData[var_r28->unk_00]; + var_r30 = var_r27->unk_120; + var_r31 = var_r30->unk_3C; + for (var_r29 = 0; var_r29 < var_r30->unk_26; var_r29++, var_r31++) { + if (var_r31->unk_28 <= 0.0f) { + break; + } + } + if (var_r29 >= var_r30->unk_26) { + return -1; + } + var_r31->unk_00 = var_r31->unk_02 = 0; + + var_r31->unk_30.x = arg0.x; + var_r31->unk_30.y = arg0.y; + var_r31->unk_30.z = arg0.z; + + var_r31->unk_04.x = arg1.x; + var_r31->unk_04.y = arg1.y; + var_r31->unk_04.z = arg1.z; + + var_r31->unk_18 = arg9; + var_r31->unk_28 = arg8; + + var_r31->unk_3C.r = arg2.r; + var_r31->unk_3C.g = arg2.g; + var_r31->unk_3C.b = arg2.b; + var_r31->unk_3C.a = arg2.a; + + var_r31->unk_2C = 0.0f; + var_r31->unk_40 = 0; + var_r31->unk_00 = 0; + var_r28->unk_04++; + + return var_r29; +} + +// TODO maybe pass struct by value +s32 fn_1_72F8(Vec *arg0, Vec *arg1, GXColor *arg2, float arg8, float arg9, float argA) +{ + Vec sp54; + Vec sp48; + s32 sp14; + s32 sp10; + + float var_f31; + + sp48.x = arg1->z; + sp48.z = arg1->x; + sp48.y = 0.0f; + + var_f31 = 0.5f * argA; + + sp54.x = arg0->x + (sp48.x * var_f31); + sp54.y = arg0->y + (sp48.y * var_f31); + sp54.z = arg0->z + (sp48.z * var_f31); + sp14 = fn_1_71C4(sp54, *arg1, arg8, arg9, *arg2); + + sp54.x = arg0->x - (sp48.x * var_f31); + sp54.y = arg0->y - (sp48.y * var_f31); + sp54.z = arg0->z - (sp48.z * var_f31); + + sp10 = fn_1_71C4(sp54, *arg1, arg8, -arg9, *arg2); + return (sp14 << 16) | sp10; +} + +UnkM406Struct5 *fn_1_76A8(s32 arg0) +{ + UnkM406Unk120Struct2 *var_r31; + UnkM406Struct10 *var_r30; + ModelData *var_r29; + + var_r30 = lbl_1_bss_B0; + var_r29 = &Hu3DData[var_r30->unk_00]; + var_r31 = var_r29->unk_120; + if (arg0 < 0 || arg0 >= var_r31->unk_26) { + return 0; + } + return &var_r31->unk_3C[arg0]; +} + +void fn_1_7718(void) +{ + s32 sp8; + + UnkM406Struct10 *var_r31; + UnkM406Unk120Struct2 *var_r30; + ModelData *var_r29; + AnimData *var_r28; + + var_r31 = lbl_1_bss_AC = HuMemDirectMallocNum(HEAP_SYSTEM, sizeof(UnkM406Struct10), MEMORY_DEFAULT_NUM); + memset(var_r31, 0, sizeof(UnkM406Struct10)); + var_r28 = HuSprAnimRead(HuDataReadNum(DATA_MAKE_NUM(DATADIR_M406, 63), MEMORY_DEFAULT_NUM)); + var_r31->unk_08 = var_r28; + var_r31->unk_00 = sp8 = fn_1_B474(var_r28, 105); + Hu3DModelLayerSet(var_r31->unk_00, 2); + var_r31->unk_04 = 0; + var_r29 = &Hu3DData[var_r31->unk_00]; + var_r30 = var_r29->unk_120; + var_r30->unk_20 = 0; +} + +void fn_1_77F0(void) +{ + UnkM406Struct5 *var_r31; + UnkM406Struct10 *var_r30; + UnkM406Unk120Struct2 *var_r29; + s32 var_r28; + ModelData *var_r27; + + var_r30 = lbl_1_bss_AC; + if (var_r30->unk_04 <= 0) { + Hu3DModelAttrSet(var_r30->unk_00, 1); + return; + } + Hu3DModelAttrReset(var_r30->unk_00, 1); + var_r27 = &Hu3DData[var_r30->unk_00]; + var_r29 = var_r27->unk_120; + var_r31 = var_r29->unk_3C; + if (fn_1_122C() < 3) { + var_r29->unk_22 |= 1; + } else { + var_r29->unk_22 &= 0xFFFFFFFE; + } + for (var_r28 = 0; var_r28 < var_r29->unk_26; var_r28++, var_r31++) { + if (var_r31->unk_28 <= 0.0f) { + continue; + } + var_r31->unk_30.x += var_r31->unk_04.x; + var_r31->unk_30.y += var_r31->unk_04.y; + var_r31->unk_30.z += var_r31->unk_04.z; + var_r31->unk_2C += var_r31->unk_18; + if (var_r31->unk_2C >= 360.0f) { + var_r31->unk_2C = var_r31->unk_2C - 360.0f; + } + var_r31->unk_40 = var_r31->unk_00 / 2; + var_r31->unk_00++; + if (var_r31->unk_40 >= 0x10) { + var_r31->unk_40 = 0; + var_r31->unk_00 = 0; + var_r31->unk_02 = 0; + var_r31->unk_28 = 0.0f; + var_r30->unk_04--; + } + } +} + +void fn_1_79B0(void) +{ + UnkM406Struct10 *var_r31; + + var_r31 = lbl_1_bss_AC; + Hu3DModelAttrSet(var_r31->unk_00, 1); + HuSprAnimKill(var_r31->unk_08); +} + +s32 fn_1_79F8(Vec arg0, Vec arg1, float arg8, float arg9, GXColor arg2) +{ + UnkM406Struct5 *var_r31; + UnkM406Unk120Struct2 *var_r30; + s32 var_r29; + UnkM406Struct10 *var_r28; + ModelData *var_r27; + + var_r28 = lbl_1_bss_AC; + var_r27 = &Hu3DData[var_r28->unk_00]; + var_r30 = var_r27->unk_120; + var_r31 = var_r30->unk_3C; + for (var_r29 = 0; var_r29 < var_r30->unk_26; var_r29++, var_r31++) { + if (var_r31->unk_28 <= 0.0f) { + break; + } + } + if (var_r29 >= var_r30->unk_26) { + return -1; + } + var_r31->unk_00 = var_r31->unk_02 = 0; + + var_r31->unk_30.x = arg0.x; + var_r31->unk_30.y = arg0.y; + var_r31->unk_30.z = arg0.z; + + var_r31->unk_04.x = arg1.x; + var_r31->unk_04.y = arg1.y; + var_r31->unk_04.z = arg1.z; + + var_r31->unk_18 = arg9; + var_r31->unk_28 = arg8; + + var_r31->unk_3C.r = arg2.r; + var_r31->unk_3C.g = arg2.g; + var_r31->unk_3C.b = arg2.b; + var_r31->unk_3C.a = arg2.a; + + var_r31->unk_2C = 0.0f; + var_r31->unk_40 = 0; + var_r31->unk_00 = 0; + var_r28->unk_04++; + + return var_r29; +} + +UnkM406Struct5 *fn_1_7B2C(s32 arg0) +{ + UnkM406Unk120Struct2 *var_r31; + UnkM406Struct10 *var_r30; + ModelData *var_r29; + + var_r30 = lbl_1_bss_AC; + var_r29 = &Hu3DData[var_r30->unk_00]; + var_r31 = var_r29->unk_120; + if (arg0 < 0 || arg0 >= var_r31->unk_26) { + return NULL; + } + return &var_r31->unk_3C[arg0]; +} + +void fn_1_7B9C(void) +{ + s32 sp8; + + UnkM406Struct6 *var_r31; + UnkM406Unk120Struct2 *var_r30; + ModelData *var_r29; + + var_r31 = lbl_1_bss_A8 = HuMemDirectMallocNum(HEAP_SYSTEM, sizeof(UnkM406Struct6), MEMORY_DEFAULT_NUM); + memset(var_r31, 0, sizeof(UnkM406Struct6)); + var_r31->unk_00 = sp8 = fn_1_C4F4(512); + Hu3DModelLayerSet(var_r31->unk_00, 3); + var_r31->unk_04 = 0; + var_r29 = &Hu3DData[var_r31->unk_00]; + var_r30 = var_r29->unk_120; + var_r30->unk_20 = 0; +} + +void fn_1_7C4C(void) +{ + UnkM406Struct5 *var_r31; + UnkM406Struct6 *var_r30; + UnkM406Unk120Struct2 *var_r29; + s32 var_r28; + ModelData *var_r27; + + var_r30 = lbl_1_bss_A8; + if (var_r30->unk_04 <= 0) { + Hu3DModelAttrSet(var_r30->unk_00, 1); + return; + } + Hu3DModelAttrReset(var_r30->unk_00, 1); + var_r27 = &Hu3DData[var_r30->unk_00]; + var_r29 = var_r27->unk_120; + var_r31 = var_r29->unk_3C; + for (var_r28 = 0; var_r28 < var_r29->unk_26; var_r28++, var_r31++) { + if (var_r31->unk_28 <= 0.0f) { + continue; + } + var_r31->unk_30.x += var_r31->unk_04.x; + var_r31->unk_30.y += var_r31->unk_04.y; + var_r31->unk_30.z += var_r31->unk_04.z; + var_r31->unk_04.y -= 0.32666668f; + if (++var_r31->unk_00 > 60 || var_r31->unk_30.y < var_r31->unk_14 - 200.0f) { + var_r31->unk_00 = 0; + var_r31->unk_28 = 0.0f; + var_r30->unk_04--; + } + } +} + +void fn_1_7DAC(void) { } + +s32 fn_1_7DB0(Vec arg0, Vec arg1, float arg8, GXColor arg2) +{ + UnkM406Struct5 *var_r31; + UnkM406Unk120Struct2 *var_r30; + s32 var_r29; + UnkM406Struct6 *var_r28; + ModelData *var_r27; + + var_r28 = lbl_1_bss_A8; + var_r27 = &Hu3DData[var_r28->unk_00]; + var_r30 = var_r27->unk_120; + var_r31 = var_r30->unk_3C; + for (var_r29 = 0; var_r29 < var_r30->unk_26; var_r29++, var_r31++) { + if (var_r31->unk_28 <= 0.0f) { + break; + } + } + if (var_r29 >= var_r30->unk_26) { + return -1; + } + var_r31->unk_00 = var_r31->unk_02 = 0; + + var_r31->unk_30.x = arg0.x; + var_r31->unk_30.y = arg0.y; + var_r31->unk_30.z = arg0.z; + + var_r31->unk_04.x = arg1.x; + var_r31->unk_04.y = arg1.y; + var_r31->unk_04.z = arg1.z; + + var_r31->unk_14 = arg0.y; + var_r31->unk_28 = arg8; + var_r31->unk_3C = arg2; + var_r31->unk_00 = 0; + var_r28->unk_04++; + + return var_r29; +} + +void fn_1_7ED0(void) +{ + s32 sp8; + + UnkM406Struct6 *var_r31; + UnkM406Unk120Struct2 *var_r30; + ModelData *var_r29; + + var_r31 = lbl_1_bss_A4 = HuMemDirectMallocNum(HEAP_SYSTEM, sizeof(UnkM406Struct6), MEMORY_DEFAULT_NUM); + memset(var_r31, 0, sizeof(UnkM406Struct6)); + var_r31->unk_00 = sp8 = fn_1_C4F4(512); + Hu3DModelLayerSet(var_r31->unk_00, 3); + var_r31->unk_04 = 0; + var_r29 = &Hu3DData[var_r31->unk_00]; + var_r30 = var_r29->unk_120; + var_r30->unk_20 = 0; +} + +void fn_1_7F80(void) +{ + UnkM406Struct5 *var_r31; + UnkM406Struct6 *var_r30; + UnkM406Unk120Struct2 *var_r29; + s32 var_r28; + ModelData *var_r27; + + var_r30 = lbl_1_bss_A4; + if (var_r30->unk_04 <= 0) { + Hu3DModelAttrSet(var_r30->unk_00, 1); + return; + } + Hu3DModelAttrReset(var_r30->unk_00, 1); + var_r27 = &Hu3DData[var_r30->unk_00]; + var_r29 = var_r27->unk_120; + var_r31 = var_r29->unk_3C; + for (var_r28 = 0; var_r28 < var_r29->unk_26; var_r28++, var_r31++) { + if (var_r31->unk_28 <= 0.0f) { + continue; + } + var_r31->unk_30.x += var_r31->unk_04.x; + var_r31->unk_30.y += var_r31->unk_04.y; + var_r31->unk_30.z += var_r31->unk_04.z; + var_r31->unk_04.y -= var_r31->unk_14; + if (var_r31->unk_10 != 0.0f) { + var_r31->unk_28 *= var_r31->unk_10; + } + if (++var_r31->unk_00 > var_r31->unk_02 || var_r31->unk_04.y <= 0.0f) { + var_r31->unk_00 = 0; + var_r31->unk_28 = 0.0f; + var_r30->unk_04 = var_r30->unk_04 - 1; + } + } +} + +void fn_1_8100(void) { } + +s32 fn_1_8104(Vec arg0, Vec arg1, float arg8, GXColor arg2) +{ + UnkM406Struct5 *var_r31; + UnkM406Unk120Struct2 *var_r30; + s32 var_r29; + UnkM406Struct6 *var_r28; + ModelData *var_r27; + + var_r28 = lbl_1_bss_A4; + var_r27 = &Hu3DData[var_r28->unk_00]; + var_r30 = var_r27->unk_120; + var_r31 = var_r30->unk_3C; + for (var_r29 = 0; var_r29 < var_r30->unk_26; var_r29++, var_r31++) { + if (var_r31->unk_28 <= 0.0f) { + break; + } + } + if (var_r29 >= var_r30->unk_26) { + return -1; + } + var_r31->unk_00 = var_r31->unk_02 = 0; + + var_r31->unk_30.x = arg0.x; + var_r31->unk_30.y = arg0.y; + var_r31->unk_30.z = arg0.z; + + var_r31->unk_04.x = arg1.x; + var_r31->unk_04.y = arg1.y; + var_r31->unk_04.z = arg1.z; + + var_r31->unk_14 = 0.49f; + var_r31->unk_10 = 0.0f; + var_r31->unk_02 = 30; + + var_r31->unk_28 = arg8; + + var_r31->unk_3C.r = arg2.r; + var_r31->unk_3C.g = arg2.g; + var_r31->unk_3C.b = arg2.b; + var_r31->unk_3C.a = arg2.a; + + var_r31->unk_00 = 0; + var_r28->unk_04++; + + return var_r29; +} + +void fn_1_8244(s32 arg0, s32 arg1, float arg8, float arg9) +{ + UnkM406Struct5 *var_r31; + UnkM406Unk120Struct2 *var_r30; + UnkM406Struct6 *var_r29; + ModelData *var_r28; + + var_r29 = lbl_1_bss_A4; + var_r28 = &Hu3DData[var_r29->unk_00]; + var_r30 = var_r28->unk_120; + if (arg0 < 0 || arg0 >= var_r30->unk_26) { + return; + } + var_r31 = &var_r30->unk_3C[arg0]; + var_r31->unk_10 = arg9; + var_r31->unk_14 = arg8; + var_r31->unk_02 = arg1; +} + +void fn_1_82C8(Mtx arg0, s32 arg1, float arg8) +{ + Mtx spBC; + Mtx sp8C; + Vec sp80; + Vec sp74; + Vec sp68; + Vec sp5C; + Vec sp50; + Vec sp44; + + float var_f31; + float var_f30; + float var_f29; + + s32 var_r28; + + sp80.x = arg0[0][3]; + sp80.y = arg0[1][3]; + sp80.z = arg0[2][3]; + sp74.x = sp74.z = 0.0f; + sp74.y = atan2d(arg0[0][0], arg0[2][0]); + PSMTXCopy(arg0, sp8C); + sp8C[0][3] = sp8C[1][3] = sp8C[2][3] = spBC[0][3] = 0.0f; + sp68.x = -25.0f; + sp68.z = -50.0f; + sp68.y = 0.0f; + fn_1_D518(sp8C, &sp68); + sp68.x += sp80.x; + sp68.y += sp80.y; + sp68.z += sp80.z; + + sp5C.x = -25.0f; + sp5C.z = 50.0f; + sp5C.y = 0.0f; + fn_1_D518(sp8C, &sp5C); + sp5C.x += sp80.x; + sp5C.y += sp80.y; + sp5C.z += sp80.z; + mtxRotCat(sp8C, 0.0f, 180.0f + (90.0f - (45.0f * (0.007874016f * (frand() & 0x7F)))), 0.0f); + lbl_1_data_89B.b = arg8; + var_f30 = sp8C[0][2]; + var_f29 = sp8C[3][2]; + for (var_r28 = 0; var_r28 < (arg1 >> 1); var_r28++) { + fn_1_D488(0.007874016f * (frand() & 0x7F), &sp68, &sp5C, &sp50); + sp50.x += 100.0f * (0.1f * ((0.007874016f * (frand() & 0x7F)) - 0.5f)); + sp50.y += 100.0f * (0.1f * ((0.007874016f * (frand() & 0x7F)) - 0.5f)); + sp50.z += 100.0f * (0.1f * ((0.007874016f * (frand() & 0x7F)) - 0.5f)); + + sp44.x = 2.0f * var_f30 * (1.0f + (0.007874016f * (frand() & 0x7F))); + sp44.z = 2.0f * var_f29 * (1.0f + (0.007874016f * (frand() & 0x7F))); + sp44.z = 5.0f * (1.0f + (0.7f * (0.007874016f * (frand() & 0x7F)))); + var_f31 = 5.0f + (15.0f * (0.007874016f * (frand() & 0x7F))); + + fn_1_8104(sp50, sp44, var_f31, lbl_1_data_89B); + } + sp68.x = -25.0f; + sp68.z = -50.0f; + sp68.y = 0.0f; + fn_1_D518(sp8C, &sp68); + sp68.x += sp80.x; + sp68.y += sp80.y; + sp68.z = sp68.z + sp80.z; + sp5C.x = -25.0f; + sp5C.z = 50.0f; + sp5C.y = 0.0f; + fn_1_D518(sp8C, &sp5C); + sp5C.x += sp80.x; + sp5C.y += sp80.y; + sp5C.z += sp80.z; + for (var_r28 = 0; var_r28 < (arg1 >> 1); var_r28++) { + fn_1_D488(0.007874016f * (frand() & 0x7F), &sp68, &sp5C, &sp50); + sp50.x += 100.0f * (0.1f * ((0.007874016f * (frand() & 0x7F)) - 0.5f)); + sp50.y += 100.0f * (0.1f * ((0.007874016f * (frand() & 0x7F)) - 0.5f)); + sp50.z += 100.0f * (0.1f * ((0.007874016f * (frand() & 0x7F)) - 0.5f)); + + sp44.x = 2.0f * var_f30 * (1.0f + (0.007874016f * (frand() & 0x7F))); + sp44.z = 2.0f * var_f29 * (1.0f + (0.007874016f * (frand() & 0x7F))); + sp44.y = 5.0f * (1.0f + (0.7f * (0.007874016f * (frand() & 0x7F)))); + var_f31 = 5.0f + (15.0f * (0.007874016f * (frand() & 0x7F))); + + fn_1_8104(sp50, sp44, var_f31, lbl_1_data_89B); + } +} + +void fn_1_8F98(void) +{ + UnkM406Struct7 *var_r31; + s32 var_r30; + + var_r31 = lbl_1_bss_A0 = HuMemDirectMallocNum(HEAP_SYSTEM, 128 * sizeof(UnkM406Struct7), MEMORY_DEFAULT_NUM); + memset(lbl_1_bss_A0, 0, 128 * sizeof(UnkM406Struct7)); + for (var_r30 = 0, var_r31 = lbl_1_bss_A0; var_r30 < 64; var_r30++, var_r31++) { + var_r31->unk_00 = 0; + var_r31->unk_01 = 0; + var_r31->unk_08 = 0; + var_r31->unk_0C = 0.0f; + var_r31->unk_10 = 0.0f; + var_r31->unk_14 = 6.0f; + var_r31->unk_18 = 1.0f; + PSMTXIdentity(var_r31->unk_1C); + if (var_r30 == 0) { + var_r31->unk_04 = Hu3DModelCreateFile(DATA_MAKE_NUM(DATADIR_M406, 59)); + } else { + var_r31->unk_04 = Hu3DModelLink(lbl_1_bss_A0->unk_04); + } + Hu3DModelLayerSet(var_r31->unk_04, 3); + Hu3DModelAttrSet(var_r31->unk_04, 1); + } + + for (var_r30 = 0, var_r31 = &lbl_1_bss_A0[64]; var_r30 < 64; var_r30++, var_r31++) { + var_r31->unk_00 = 0; + var_r31->unk_01 = 0; + var_r31->unk_08 = 0; + var_r31->unk_0C = 0.0f; + var_r31->unk_10 = 0.0f; + var_r31->unk_14 = 6.0f; + var_r31->unk_18 = 1.0f; + PSMTXIdentity(var_r31->unk_1C); + if (var_r30 == 0) { + var_r31->unk_04 = Hu3DModelCreateFile(DATA_MAKE_NUM(DATADIR_M406, 60)); + } else { + var_r31->unk_04 = Hu3DModelLink(lbl_1_bss_A0[64].unk_04); + } + Hu3DModelLayerSet(var_r31->unk_04, 3); + Hu3DModelAttrSet(var_r31->unk_04, 1); + } +} + +void fn_1_91E0(void) +{ + Mtx sp8; + + float var_f31; + float var_f30; + + UnkM406Struct7 *var_r31; + ModelData *var_r30; + s32 var_r29; + + var_r31 = lbl_1_bss_A0; + for (var_r29 = 0, var_r31 = lbl_1_bss_A0; var_r29 < 64; var_r29++, var_r31++) { + if (!var_r31->unk_00) { + continue; + } + var_f30 = var_r31->unk_0C / var_r31->unk_14; + var_f31 = var_r31->unk_18 * cosd((90.0f * var_f30)); + var_f31 = var_f31; + var_r30 = &Hu3DData[var_r31->unk_04]; + PSMTXScale(sp8, var_f31, var_f31, var_f31); + PSMTXConcat(var_r31->unk_1C, sp8, var_r30->unk_F0); + var_r30->unk_F0[0][3] = var_r31->unk_1C[0][3]; + var_r30->unk_F0[1][3] = var_r31->unk_1C[1][3]; + var_r30->unk_F0[2][3] = var_r31->unk_1C[2][3]; + Hu3DModelTPLvlSet(var_r31->unk_04, 1.0f - var_f30); + if ((var_r31->unk_0C += var_r31->unk_10) >= var_r31->unk_14) { + Hu3DModelAttrSet(var_r31->unk_04, 1); + var_r31->unk_00 = 0; + var_r31->unk_0C = 0.0f; + } + var_r31->unk_08++; + } + for (var_r29 = 0, var_r31 = &lbl_1_bss_A0[64]; var_r29 < 64; var_r29++, var_r31++) { + if (!var_r31->unk_00) { + continue; + } + var_f30 = var_r31->unk_0C / var_r31->unk_14; + var_f31 = var_r31->unk_18 * cosd((90.0f * var_f30)); + var_f31 = var_f31; + var_r30 = &Hu3DData[var_r31->unk_04]; + PSMTXScale(sp8, var_f31, var_f31, var_f31); + PSMTXConcat(var_r31->unk_1C, sp8, var_r30->unk_F0); + var_r30->unk_F0[0][3] = var_r31->unk_1C[0][3]; + var_r30->unk_F0[1][3] = var_r31->unk_1C[1][3]; + var_r30->unk_F0[2][3] = var_r31->unk_1C[2][3]; + Hu3DModelTPLvlSet(var_r31->unk_04, 1.0f - var_f30); + if ((var_r31->unk_0C += var_r31->unk_10) >= var_r31->unk_14) { + Hu3DModelAttrSet(var_r31->unk_04, 1); + var_r31->unk_00 = 0; + var_r31->unk_0C = 0.0f; + } + var_r31->unk_08++; + } +} + +void fn_1_94BC(void) { } + +s32 fn_1_94C0(Mtx arg0, s32 arg1, s32 arg2) +{ + Mtx spA0; + Mtx sp70; + Vec sp64; + Vec sp58; + Vec sp4C; + Vec sp40; + Vec sp34; + Vec sp28; + + float var_f31; + float var_f30; + float var_f29; + + UnkM406Struct7 *var_r31; + s32 var_r28; + ModelData *var_r27; + + sp64.x = arg0[0][3]; + sp64.y = arg0[1][3]; + sp64.z = arg0[2][3]; + sp58.x = sp58.z = 0.0f; + sp58.y = atan2d(arg0[0][0], arg0[2][0]); + PSMTXCopy(arg0, spA0); + spA0[0][3] = spA0[1][3] = spA0[2][3] = spA0[3][3] = 0.0f; + if (!arg2) { + sp4C.x = 25.0f; + sp4C.z = -50.0f; + sp4C.y = 0.0f; + fn_1_D518(spA0, &sp4C); + sp4C.x += sp64.x; + sp4C.y += sp64.y; + sp4C.z += sp64.z; + sp40.x = 25.0f; + sp40.z = 50.0f; + sp40.y = 0.0f; + fn_1_D518(spA0, &sp40); + sp40.x += sp64.x; + sp40.y += sp64.y; + sp40.z += sp64.z; + mtxRotCat(spA0, 0.0f, 180.0f + (45.0f * (0.007874016f * (frand() & 0x7F))), 0.0f); + } else { + sp4C = sp64; + sp4C.x = -25.0f; + sp4C.z = -50.0f; + sp4C.y = 0.0f; + fn_1_D518(spA0, &sp4C); + sp4C.x += sp64.x; + sp4C.y += sp64.y; + sp4C.z += sp64.z; + sp40 = sp64; + sp40.x = -25.0f; + sp40.z = 50.0f; + sp40.y = 0.0f; + fn_1_D518(spA0, &sp40); + sp40.x += sp64.x; + sp40.y += sp64.y; + sp40.z += sp64.z; + mtxRotCat(spA0, 0.0f, 180.0f - (45.0f * (0.007874016f * (frand() & 0x7F))), 0.0f); + } + var_f30 = spA0[0][2]; + var_f29 = spA0[2][2]; + for (var_r28 = 0; var_r28 < arg1; var_r28++) { + fn_1_D488(0.007874016f * (frand() & 0x7F), &sp4C, &sp40, &sp34); + sp34.x += 100.0f * (0.1f * ((0.007874016f * (frand() & 0x7F)) - 0.5f)); + sp34.y += 100.0f * (0.1f * ((0.007874016f * (frand() & 0x7F)) - 0.5f)); + sp34.z += 100.0f * (0.1f * ((0.007874016f * (frand() & 0x7F)) - 0.5f)); + sp28.x = 2.0f * var_f30 * (1.0f + (0.007874016f * (frand() & 0x7F))); + sp28.z = 2.0f * var_f29 * (1.0f + (0.007874016f * (frand() & 0x7F))); + sp28.y = 5.0f * (1.0f + (0.7f * (0.007874016f * (frand() & 0x7F)))); + + fn_1_8104(sp34, sp28, 7.5f, lbl_1_data_89F); + } + var_r31 = lbl_1_bss_A0; + if (!arg2) { + for (var_r28 = 0, var_r31 = lbl_1_bss_A0; var_r28 < 64; var_r28++, var_r31++) { + if (!var_r31->unk_00) { + break; + } + } + if (var_r28 >= 64) { + return -1; + } + } else { + for (var_r28 = 0, var_r31 = &lbl_1_bss_A0[64]; var_r28 < 64; var_r28++, var_r31++) { + if (!var_r31->unk_00) { + break; + } + } + if (var_r28 >= 64) { + return -1; + } + } + var_f31 = 1.2f * (2.0f + (0.007874016f * (frand() & 0x7F))); + var_r31->unk_00 = 1; + var_r31->unk_08 = 0; + var_r31->unk_0C = 0.0f; + var_r31->unk_10 = 1.0f; + var_r31->unk_14 = 6.0f; + var_r31->unk_18 = var_f31; + PSMTXCopy(arg0, var_r31->unk_1C); + Hu3DMotionTimeSet(var_r31->unk_04, 0.0f); + Hu3DMotionSpeedSet(var_r31->unk_04, 0.0f); + var_r27 = &Hu3DData[var_r31->unk_04]; + PSMTXScale(sp70, var_f31, var_f31, var_f31); + PSMTXConcat(arg0, sp70, var_r27->unk_F0); + var_r27->unk_F0[0][3] = arg0[0][3]; + var_r27->unk_F0[1][3] = arg0[1][3]; + var_r27->unk_F0[2][3] = arg0[2][3]; + Hu3DModelPosSet(var_r31->unk_04, 0.0f, 0.0f, 0.0f); + Hu3DModelRotSet(var_r31->unk_04, 0.0f, 0.0f, 0.0f); + Hu3DModelScaleSet(var_r31->unk_04, 1.0f, 1.0f, 1.0f); + Hu3DModelAttrReset(var_r31->unk_04, 1); + (void)var_r31; + return var_r28; +} + +void fn_1_9F78(void) +{ + UnkM406Unk120Struct2 *var_r31; + UnkM406Struct8 *var_r30; + ModelData *var_r29; + UnkM406Struct9 *var_r28; + s32 var_r27; + + var_r30 = lbl_1_bss_9C = HuMemDirectMallocNum(HEAP_SYSTEM, sizeof(UnkM406Struct8), MEMORY_DEFAULT_NUM); + memset(var_r30, 0, sizeof(UnkM406Struct8)); + var_r30->unk_00 = HuSprAnimRead(HuDataReadNum(0x250040, MEMORY_DEFAULT_NUM)); + var_r30->unk_04 = HuSprAnimRead(HuDataReadNum(0x250041, MEMORY_DEFAULT_NUM)); + var_r30->unk_08 = HuSprAnimRead(HuDataReadNum(0x250042, MEMORY_DEFAULT_NUM)); + var_r30->unk_0C = HuSprAnimRead(HuDataReadNum(0x250043, MEMORY_DEFAULT_NUM)); + var_r30->unk_24 = 0.0f; + var_r30->unk_28 = 0.0f; + var_r27 = fn_1_B474(var_r30->unk_00, 1); + var_r30->unk_10 = var_r27; + Hu3DModelLayerSet(var_r27, 6); + var_r29 = &Hu3DData[var_r27]; + var_r31 = var_r29->unk_120; + var_r31->unk_20 = 1; + var_r31->unk_22 = 2; + var_r31->unk_4C = fn_1_A2C8; + var_r28 = var_r31->unk_1C = HuMemDirectMallocNum(HEAP_DATA, sizeof(UnkM406Struct9), var_r29->unk_48); + memset(var_r28, 0, 8); + var_r28->unk_02 = 0; + var_r27 = fn_1_B474(var_r30->unk_0C, 0xA); + var_r30->unk_14 = var_r27; + Hu3DModelLayerSet(var_r27, 6); + var_r29 = &Hu3DData[var_r27]; + var_r31 = var_r29->unk_120; + var_r31->unk_20 = 1; + var_r31->unk_22 = 3; + var_r31->unk_4C = fn_1_A2C8; + var_r28 = var_r31->unk_1C = HuMemDirectMallocNum(HEAP_DATA, sizeof(UnkM406Struct9), var_r29->unk_48); + memset(var_r28, 0, 8); + var_r28->unk_02 = 1; + var_r27 = fn_1_B474(var_r30->unk_08, 4); + var_r30->unk_18 = var_r27; + Hu3DModelLayerSet(var_r27, 6); + var_r29 = &Hu3DData[var_r27]; + var_r31 = var_r29->unk_120; + var_r31->unk_20 = 1; + var_r31->unk_22 = 3; + var_r31->unk_4C = fn_1_A2C8; + var_r28 = var_r31->unk_1C = HuMemDirectMallocNum(HEAP_DATA, sizeof(UnkM406Struct9), var_r29->unk_48); + memset(var_r28, 0, 8); + var_r28->unk_02 = 2; + var_r27 = fn_1_B474(var_r30->unk_04, 6); + var_r30->unk_1C = var_r27; + Hu3DModelLayerSet(var_r27, 6); + var_r29 = &Hu3DData[var_r27]; + var_r31 = var_r29->unk_120; + var_r31->unk_20 = 1; + var_r31->unk_22 = 3; + var_r31->unk_4C = fn_1_A2C8; + var_r28 = var_r31->unk_1C = HuMemDirectMallocNum(HEAP_DATA, sizeof(UnkM406Struct9), var_r29->unk_48); + memset(var_r28, 0, 8); + var_r28->unk_02 = 3; + var_r30->unk_20 = Hu3DHookFuncCreate(fn_1_ADB4); + Hu3DModelLayerSet(var_r30->unk_20, 7); +} + +void fn_1_A278(void) +{ + UnkM406Struct8 *var_r31; + + var_r31 = lbl_1_bss_9C; + HuSprAnimKill(var_r31->unk_00); + HuSprAnimKill(var_r31->unk_04); + HuSprAnimKill(var_r31->unk_08); + HuSprAnimKill(var_r31->unk_0C); +} + +void fn_1_A2C8(ModelData *arg0, UnkM406Unk120Struct2 *arg1, Mtx arg2) +{ + Vec sp3C; + Vec sp30; + Vec sp24; + Vec sp18; + void *sp14; + s16 sp8; + + float var_f29; + float var_f28; + float var_f27; + float var_f26; + float var_f25; + float var_f24; + + UnkM406Struct5 *var_r31; + UnkM406Struct9 *var_r29; + s32 var_r28; + + sp8 = 0; + sp14 = lbl_1_bss_9C; + var_r29 = arg1->unk_1C; + switch (var_r29->unk_04) { + case 0: + var_r31 = arg1->unk_3C; + if (var_r29->unk_02) { + sp18.x = 10000.0f; + sp18.y = -20000.0f; + sp18.z = -20000.0f; + var_f28 = (sp18.z * sp18.z) + ((sp18.x * sp18.x) + (sp18.y * sp18.y)); + var_f29 = 1.0f / sqrtf(var_f28); + sp18.x *= var_f29; + sp18.y *= var_f29; + sp18.z *= var_f29; + var_f24 = 6500.0f / arg1->unk_26; + for (var_r28 = 0; var_r28 < arg1->unk_26; var_r28++, var_r31++) { + var_f26 = 500.0 + ((var_f24 * var_r28) + ((0.25f * var_f24) * (1.52587890625e-05 * (frand() & 0xFFFF)))); + var_f25 = var_f26 / 6500.0f; + var_r31->unk_10 = var_f26; + var_r31->unk_30.x = var_f26 * sp18.x; + var_r31->unk_30.y = -27000.0f + (var_f26 * sp18.y); + var_r31->unk_30.z = -63000.0f + (var_f26 * sp18.z); + var_r31->unk_28 = (0.3f + (0.7f * (var_f25 * var_f25))) + * (lbl_1_data_8A4[var_r29->unk_02] * (0.699999988079071 + (0.30000001192092896 * (1.52587890625e-05 * (frand() & 0xFFFF))))); + var_r31->unk_3C.r = (s32)(160.0 * (1.52587890625e-05 * (frand() & 0xFFFF))) + 0x20; + var_r31->unk_3C.g = (s32)(96.0 * (1.52587890625e-05 * (frand() & 0xFFFF))) + 0x20; + var_r31->unk_3C.b = (s32)(128.0 * (1.52587890625e-05 * (frand() & 0xFFFF))) + 0x20; + var_r31->unk_3C.a + = ((1.0 - (0.4 * var_f25)) * (255.0f * lbl_1_data_8B4[var_r29->unk_02])) - (16.0 * (1.52587890625e-05 * (frand() & 0xFFFF))); + } + var_r29->unk_04++; + } else { + var_r31->unk_30.x = 0.0f; + var_r31->unk_30.y = -27000.0f; + var_r31->unk_30.z = -63000.0f; + var_r31->unk_28 = 1000.0f; + } + break; + case 1: + sp3C.x = sind(CRot.y) * cosd(CRot.x); + sp3C.y = -sind(CRot.x); + sp3C.z = cosd(CRot.y) * cosd(CRot.x); + sp30.x = -(Center.x + (1.25f * (sp3C.x * CZoom))); + sp30.y = -27000.0f - (Center.y + (sp3C.y * CZoom)); + sp30.z = -63000.0f - (Center.z + (1.25f * (sp3C.z * CZoom))); + var_f27 = (sp30.z * sp30.z) + ((sp30.x * sp30.x) + (sp30.y * sp30.y)); + var_f29 = 1.0f / sqrtf(var_f27); + sp30.x *= var_f29; + sp30.y *= var_f29; + sp30.z *= var_f29; + var_f29 = -((-sp30.z * -sp3C.z) + ((-sp30.x * -sp3C.x) + (-sp30.y * -sp3C.y))); + sp24.x = -sp3C.x + (-2.0f * sp30.x * var_f29); + sp24.y = -sp3C.y + (-2.0f * sp30.y * var_f29); + sp24.z = -sp3C.z + (-2.0f * sp30.z * var_f29); + var_r31 = arg1->unk_3C; + for (var_r28 = 0; var_r28 < arg1->unk_26; var_r28++, var_r31++) { + var_r31->unk_30.x = sp24.x * var_r31->unk_10; + var_r31->unk_30.y = -27000.0f + (sp24.y * var_r31->unk_10); + var_r31->unk_30.z = -63000.0f + (sp24.z * var_r31->unk_10); + } + break; + default: + break; + } + DCFlushRange(arg1->unk_3C, arg1->unk_26 * sizeof(UnkM406Struct5)); + PPCSync(); +} + +void fn_1_ADB4(ModelData *arg0, float (*arg1)[4]) +{ + Mtx sp50; + Mtx44 sp10; + + CameraData *var_r31; + UnkM406Struct8 *var_r30; + + GXColor spC = { 0xFF, 0xFF, 0xFF, 0xFF }; + var_r31 = &Hu3DCamera[0]; + var_r30 = lbl_1_bss_9C; + if (var_r30->unk_28 <= 0.0f) { + Hu3DModelAttrSet(var_r30->unk_20, 1); + return; + } + GXSetScissor(var_r31->scissor_x, var_r31->scissor_y, var_r31->scissor_w, var_r31->scissor_h); + GXSetViewport(0.0f, 0.0f, 640.0f, 480.0f, 0.0f, 1.0f); + C_MTXOrtho(sp10, 0.0f, 1.0f, 0.0f, 1.0f, 0.0f, 1.0f); + GXSetProjection(sp10, GX_ORTHOGRAPHIC); + spC.a = 255.0f * var_r30->unk_28; + GXSetTevColor(GX_TEVREG0, spC); + GXSetNumTexGens(0); + GXSetNumTevStages(1); + GXSetTevOrder(GX_TEVSTAGE0, GX_TEXCOORD_NULL, GX_TEXMAP_NULL, GX_COLOR0A0); + GXSetTevColorIn(GX_TEVSTAGE0, GX_CC_ZERO, GX_CC_ZERO, GX_CC_ZERO, GX_CC_C0); + GXSetTevColorOp(GX_TEVSTAGE0, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, GX_TRUE, GX_TEVPREV); + GXSetTevAlphaIn(GX_TEVSTAGE0, GX_CA_ZERO, GX_CA_ZERO, GX_CA_ZERO, GX_CA_A0); + GXSetTevAlphaOp(GX_TEVSTAGE0, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, GX_TRUE, GX_TEVPREV); + PSMTXIdentity(sp50); + GXLoadPosMtxImm(sp50, 0); + GXSetZMode(GX_FALSE, GX_ALWAYS, GX_TRUE); + GXSetNumChans(1); + GXSetChanCtrl(GX_COLOR0A0, GX_FALSE, GX_SRC_REG, GX_SRC_REG, 0, GX_DF_CLAMP, GX_AF_NONE); + GXClearVtxDesc(); + GXSetVtxDesc(GX_VA_POS, GX_DIRECT); + GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_POS, GX_POS_XYZ, GX_U8, 0); + GXBegin(GX_QUADS, GX_VTXFMT0, 4); + GXPosition3u8(0, 0, 0); + GXPosition3u8(1, 0, 0); + GXPosition3u8(1, 1, 0); + GXPosition3u8(0, 1, 0); +} + +void fn_1_B104(float arg8) +{ + + UnkM406Struct8 *var_r31; + + var_r31 = lbl_1_bss_9C; + var_r31->unk_24 = arg8; + if (var_r31->unk_24 <= 0.0f) { + Hu3DModelAttrSet(var_r31->unk_10, 1); + Hu3DModelAttrSet(var_r31->unk_14, 1); + Hu3DModelAttrSet(var_r31->unk_18, 1); + Hu3DModelAttrSet(var_r31->unk_1C, 1); + return; + } + Hu3DModelAttrReset(var_r31->unk_10, 1); + Hu3DModelAttrReset(var_r31->unk_14, 1); + Hu3DModelAttrReset(var_r31->unk_18, 1); + Hu3DModelAttrReset(var_r31->unk_1C, 1); +} + +void fn_1_B1E0(float arg8) +{ + UnkM406Struct8 *var_r31; + + var_r31 = lbl_1_bss_9C; + var_r31->unk_28 = arg8; + if (var_r31->unk_28 <= 0.0f) { + Hu3DModelAttrSet(var_r31->unk_20, 1); + return; + } + Hu3DModelAttrReset(var_r31->unk_20, 1); +} + +void fn_1_B25C(void) +{ + s32 var_r31; + s32 var_r30; + + if (lbl_1_bss_98 == -1) { + lbl_1_bss_98 = Hu3DModelCreateFile(DATA_MAKE_NUM(DATADIR_M406, 68)); + Hu3DModelLayerSet(lbl_1_bss_98, 0); + Hu3DModelPosSet(lbl_1_bss_98, 0.0f, -26500.0f, -63000.0f); + Hu3DModelRotSet(lbl_1_bss_98, 0.0f, 0.0f, 0.0f); + Hu3DModelScaleSet(lbl_1_bss_98, 2.75f, 2.75f, 2.75f); + var_r30 = Hu3DModelCreateFile(DATA_MAKE_NUM(DATADIR_M406, 55)); + Hu3DModelLayerSet(var_r30, 0); + var_r31 = Hu3DGLightCreateV(&lbl_1_data_8C4, &lbl_1_data_8D0, &lbl_1_data_8DC); + Hu3DGLightStaticSet(var_r31, 1); + Hu3DGLightPointSet(var_r31, 100.0f, 1.0f, 3); + lbl_1_bss_BC = 0; + fn_1_2C24(lbl_1_bss_CC); + } +} + +void fn_1_B41C(void) +{ + if (lbl_1_bss_98 != -1) { + Hu3DModelKill(lbl_1_bss_98); + } + lbl_1_bss_98 = -1; +} + +void fn_1_B470(void) { } + +s16 fn_1_B474(AnimData *arg0, s16 arg1) +{ + UnkM406Unk120Struct2 *var_r31; + s16 var_r30; + Vec2f *var_r29; + UnkM406Struct5 *var_r28; + ModelData *var_r27; + Vec *var_r25; + void *var_r24; + s16 var_r23; + void *var_r22; + + var_r23 = Hu3DHookFuncCreate(fn_1_BC18); + var_r27 = &Hu3DData[var_r23]; + var_r31 = HuMemDirectMallocNum(HEAP_DATA, sizeof(UnkM406Unk120Struct2), var_r27->unk_48); + var_r27->unk_120 = var_r31; + var_r31->unk_38 = arg0; + var_r31->unk_26 = arg1; + var_r31->unk_20 = 0; + var_r31->unk_22 = 0; + var_r31->unk_4C = 0; + var_r31->unk_50 = 0; + var_r31->unk_28 = 0; + var_r31->unk_21 = 0; + var_r31->unk_30 = 0; + + var_r31->unk_00 = var_r31->unk_02 = 0; + var_r28 = HuMemDirectMallocNum(HEAP_DATA, arg1 * sizeof(UnkM406Struct5), var_r27->unk_48); + var_r31->unk_3C = var_r28; + memset(var_r28, 0, arg1 * sizeof(UnkM406Struct5)); + for (var_r30 = 0; var_r30 < arg1; var_r30++, var_r28++) { + var_r28->unk_28 = 0.0f; + var_r28->unk_2C = 0.0f; + var_r28->unk_30.x = ((frand() & 0x7F) - 0x40) * 0x14; + var_r28->unk_30.y = ((frand() & 0x7F) - 0x40) * 0x1E; + var_r28->unk_30.z = ((frand() & 0x7F) - 0x40) * 0x14; + var_r28->unk_3C.r = var_r28->unk_3C.g = var_r28->unk_3C.b = var_r28->unk_3C.a = 0xFF; + var_r28->unk_40 = 0; + } + var_r25 = HuMemDirectMallocNum(HEAP_DATA, arg1 * sizeof(Vec) * 4, var_r27->unk_48); + var_r31->unk_40 = var_r25; + for (var_r30 = 0; var_r30 < (arg1 * 4); var_r30++, var_r25++) { + var_r25->x = var_r25->y = var_r25->z = 0.0f; + } + var_r29 = HuMemDirectMallocNum(HEAP_DATA, arg1 * sizeof(Vec2f) * 4, var_r27->unk_48); + var_r31->unk_44 = var_r29; + for (var_r30 = 0; var_r30 < arg1; var_r30++) { + var_r29->x = 0.0f; + var_r29->y = 0.0f; + var_r29++; + var_r29->x = 1.0f; + var_r29->y = 0.0f; + var_r29++; + var_r29->x = 1.0f; + var_r29->y = 1.0f; + var_r29++; + var_r29->x = 0.0f; + var_r29->y = 1.0f; + var_r29++; + } + var_r24 = HuMemDirectMallocNum(HEAP_DATA, 0x10000, var_r27->unk_48); + var_r22 = var_r24; + DCFlushRange(var_r24, 0x10000); + GXBeginDisplayList(var_r22, 0x10000); + GXBegin(GX_QUADS, GX_VTXFMT0, arg1 * 4); + for (var_r30 = 0; var_r30 < arg1; var_r30++) { + // TODO + GXUnknownu16(var_r30 * 4); + GXUnknownu16(var_r30); + GXUnknownu16(var_r30 * 4); + + GXUnknownu16(var_r30 * 4 + 1); + GXUnknownu16(var_r30); + GXUnknownu16(var_r30 * 4 + 1); + + GXUnknownu16(var_r30 * 4 + 2); + GXUnknownu16(var_r30); + GXUnknownu16(var_r30 * 4 + 2); + + GXUnknownu16(var_r30 * 4 + 3); + GXUnknownu16(var_r30); + GXUnknownu16(var_r30 * 4 + 3); + } + var_r31->unk_34 = GXEndDisplayList(); + var_r31->unk_48 = HuMemDirectMallocNum(HEAP_DATA, var_r31->unk_34, var_r27->unk_48); + memcpy(var_r31->unk_48, var_r24, var_r31->unk_34); + DCFlushRange(var_r31->unk_48, var_r31->unk_34); + HuMemDirectFree(var_r24); + (void)arg1; + return var_r23; +} + +s16 fn_1_B8FC(s16 arg0) +{ + UnkM406Unk120Struct2 *var_r31; + Vec2f *var_r30; + UnkM406Struct5 *var_r29; + ModelData *var_r27; + s16 var_r28; + UnkM406Unk120Struct2 *var_r26; + Vec *var_r25; + s32 var_r24; + ModelData *var_r23; + s16 var_r22; + + var_r23 = &Hu3DData[arg0]; + var_r26 = var_r23->unk_120; + var_r22 = Hu3DHookFuncCreate(var_r23->hook); + var_r27 = &Hu3DData[var_r22]; + var_r31 = HuMemDirectMallocNum(HEAP_DATA, sizeof(UnkM406Unk120Struct2), var_r27->unk_48); + var_r27->unk_120 = var_r31; + var_r31->unk_38 = var_r26->unk_38; + var_r31->unk_26 = var_r26->unk_26; + var_r24 = var_r31->unk_26; + var_r31->unk_20 = 0; + var_r31->unk_22 = var_r26->unk_22; + var_r31->unk_4C = 0; + var_r31->unk_50 = 0; + var_r31->unk_28 = 0; + var_r31->unk_21 = 0; + var_r31->unk_30 = 0; + + var_r31->unk_00 = var_r31->unk_02 = 0; + var_r29 = HuMemDirectMallocNum(HEAP_DATA, var_r24 * sizeof(UnkM406Struct5), var_r27->unk_48); + var_r31->unk_3C = var_r29; + for (var_r28 = 0; var_r28 < var_r24; var_r28++, var_r29++) { + var_r29->unk_28 = 0.0f; + var_r29->unk_2C = 0.0f; + var_r29->unk_30.x = ((frand() & 0x7F) - 0x40) * 0x14; + var_r29->unk_30.y = ((frand() & 0x7F) - 0x40) * 0x1E; + var_r29->unk_30.z = ((frand() & 0x7F) - 0x40) * 0x14; + var_r29->unk_3C.r = var_r29->unk_3C.g = var_r29->unk_3C.b = var_r29->unk_3C.a = 0xFF; + var_r29->unk_40 = 0; + } + var_r25 = HuMemDirectMallocNum(HEAP_DATA, var_r24 * sizeof(Vec) * 4, var_r27->unk_48); + var_r31->unk_40 = var_r25; + for (var_r28 = 0; var_r28 < (var_r24 * 4); var_r28++, var_r25++) { + var_r25->x = var_r25->y = var_r25->z = 0.0f; + } + var_r30 = HuMemDirectMallocNum(HEAP_DATA, var_r24 * sizeof(Vec2f) * 4, var_r27->unk_48); + var_r31->unk_44 = var_r30; + for (var_r28 = 0; var_r28 < var_r24; var_r28++) { + var_r30->x = 0.0f; + var_r30->y = 0.0f; + var_r30++; + var_r30->x = 1.0f; + var_r30->y = 0.0f; + var_r30++; + var_r30->x = 1.0f; + var_r30->y = 1.0f; + var_r30++; + var_r30->x = 0.0f; + var_r30->y = 1.0f; + var_r30++; + } + var_r31->unk_34 = var_r26->unk_34; + var_r31->unk_48 = var_r26->unk_48; + return var_r22; +} + +void fn_1_BC18(ModelData *arg0, float (*arg1)[4]) +{ + Mtx sp128; + Mtx spF8; + Mtx spC8; + Vec sp98[4]; + Vec sp68[4]; + Vec sp38[4]; + ROMtx sp8; + + UnkM406Unk120Struct2 *var_r31; + Vec *var_r30; + UnkM406Struct5 *var_r29; + Vec2f *var_r28; + Vec *var_r27; + s16 var_r26; + s16 var_r25; + Vec *var_r24; + s16 var_r21; + s16 var_r20; + s16 var_r19; + UnkM406Unk120Struct2Hook var_r18; + + var_r31 = arg0->unk_120; + if (var_r31->unk_2C != GlobalCounter || shadowModelDrawF) { + if (var_r31->unk_50 && var_r31->unk_50 != arg0) { + fn_1_BC18(var_r31->unk_50, arg1); + } + GXLoadPosMtxImm(arg1, 0); + GXSetNumTevStages(1); + GXSetNumTexGens(1); + GXSetTexCoordGen2(GX_TEXCOORD0, GX_TG_MTX2x4, GX_TG_TEX0, 0x3C, GX_FALSE, 0x7D); + GXSetTevOrder(GX_TEVSTAGE0, GX_TEXCOORD0, GX_TEXMAP0, GX_COLOR0A0); + if (shadowModelDrawF) { + GXSetTevColorIn(GX_TEVSTAGE0, GX_CC_ONE, GX_CC_ZERO, GX_CC_ZERO, GX_CC_ZERO); + GXSetZMode(GX_FALSE, GX_LEQUAL, GX_FALSE); + } else { + var_r21 = var_r31->unk_38->bmp->dataFmt & 0xF; + if (var_r21 == 7 || var_r21 == 8) { + GXSetTevColorIn(GX_TEVSTAGE0, GX_CC_ZERO, GX_CC_ONE, GX_CC_RASC, GX_CC_ZERO); + } else { + GXSetTevColorIn(GX_TEVSTAGE0, GX_CC_ZERO, GX_CC_TEXC, GX_CC_RASC, GX_CC_ZERO); + } + if (var_r31->unk_22 & 1) { + GXSetZMode(GX_FALSE, GX_LEQUAL, GX_FALSE); + } else if (arg0->attr & 2) { + GXSetZMode(GX_TRUE, GX_LEQUAL, GX_TRUE); + } else { + GXSetZMode(GX_TRUE, GX_LEQUAL, GX_FALSE); + } + } + GXSetTevColorOp(GX_TEVSTAGE0, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, GX_TRUE, GX_TEVPREV); + GXSetTevAlphaIn(GX_TEVSTAGE0, GX_CA_ZERO, GX_CA_TEXA, GX_CA_RASA, GX_CA_ZERO); + GXSetTevAlphaOp(GX_TEVSTAGE0, GX_TEV_ADD, GX_TB_ZERO, GX_CS_SCALE_1, GX_TRUE, GX_TEVPREV); + GXSetNumChans(1); + GXSetChanCtrl(GX_COLOR0A0, GX_FALSE, GX_SRC_REG, GX_SRC_VTX, 0, GX_DF_CLAMP, GX_AF_NONE); + HuSprTexLoad(var_r31->unk_38, 0, 0, GX_REPEAT, GX_REPEAT, GX_LINEAR); + GXSetAlphaCompare(GX_GEQUAL, 1, GX_AOP_AND, GX_GEQUAL, 1); + GXSetZCompLoc(GX_FALSE); + switch (var_r31->unk_20) { + case 0: + GXSetBlendMode(GX_BM_BLEND, GX_BL_SRCALPHA, GX_BL_INVSRCALPHA, GX_LO_NOOP); + break; + case 1: + GXSetBlendMode(GX_BM_BLEND, GX_BL_SRCALPHA, GX_BL_ONE, GX_LO_NOOP); + break; + case 2: + GXSetBlendMode(GX_BM_BLEND, GX_BL_ZERO, GX_BL_INVDSTCLR, GX_LO_NOOP); + break; + } + GXClearVtxDesc(); + GXSetVtxDesc(GX_VA_POS, GX_INDEX16); + GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_POS, GX_POS_XYZ, GX_F32, 0); + GXSetArray(GX_VA_POS, var_r31->unk_40, 0xC); + GXSetVtxDesc(GX_VA_CLR0, GX_INDEX16); + GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_CLR0, GX_CLR_RGBA, GX_RGBA8, 0); + GXSetArray(GX_VA_CLR0, &var_r31->unk_3C->unk_3C, 0x44); + GXSetVtxDesc(GX_VA_TEX0, GX_INDEX16); + GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_TEX0, GX_TEX_ST, GX_F32, 0); + GXSetArray(GX_VA_TEX0, var_r31->unk_44, 8); + if (HmfInverseMtxF3X3(arg1, sp128) == 0) { + PSMTXIdentity(sp128); + } + PSMTXReorder(sp128, sp8); + if (var_r31->unk_4C) { + var_r18 = var_r31->unk_4C; + var_r18(arg0, var_r31, arg1); + } + var_r29 = var_r31->unk_3C; + var_r30 = var_r31->unk_40; + var_r28 = var_r31->unk_44; + PSMTXROMultVecArray(sp8, lbl_1_data_8E0, &sp38[0], 4); + for (var_r26 = 0; var_r26 < var_r31->unk_26; var_r26++, var_r29++) { + if (!var_r29->unk_28) { + var_r30->x = var_r30->y = var_r30->z = 0.0f; + var_r30++; + var_r30->x = var_r30->y = var_r30->z = 0.0f; + var_r30++; + var_r30->x = var_r30->y = var_r30->z = 0.0f; + var_r30++; + var_r30->x = var_r30->y = var_r30->z = 0.0f; + var_r30++; + } else if (!var_r29->unk_2C) { + var_r27 = &sp98[0]; + var_r24 = &sp38[0]; + PSVECScale(var_r24++, var_r27, var_r29->unk_28); + PSVECAdd(var_r27++, &var_r29->unk_30, var_r30++); + PSVECScale(var_r24++, var_r27, var_r29->unk_28); + PSVECAdd(var_r27++, &var_r29->unk_30, var_r30++); + PSVECScale(var_r24++, var_r27, var_r29->unk_28); + PSVECAdd(var_r27++, &var_r29->unk_30, var_r30++); + PSVECScale(var_r24++, var_r27, var_r29->unk_28); + PSVECAdd(var_r27++, &var_r29->unk_30, var_r30++); + } else { + PSVECScale(lbl_1_data_8E0, &sp98[0], var_r29->unk_28); + PSVECScale(&lbl_1_data_8E0[1], &sp98[1], var_r29->unk_28); + PSVECScale(&lbl_1_data_8E0[2], &sp98[2], var_r29->unk_28); + PSVECScale(&lbl_1_data_8E0[3], &sp98[3], var_r29->unk_28); + PSMTXRotRad(spC8, 90, var_r29->unk_2C); + PSMTXConcat(sp128, spC8, spF8); + PSMTXMultVecArray(spF8, &sp98[0], &sp68[0], 4); + PSVECAdd(&sp68[0], &var_r29->unk_30, var_r30++); + PSVECAdd(&sp68[1], &var_r29->unk_30, var_r30++); + PSVECAdd(&sp68[2], &var_r29->unk_30, var_r30++); + PSVECAdd(&sp68[3], &var_r29->unk_30, var_r30++); + } + } + var_r29 = var_r31->unk_3C; + var_r28 = var_r31->unk_44; + if ((var_r31->unk_22 & 2) == 0) { + for (var_r26 = 0; var_r26 < var_r31->unk_26; var_r26++, var_r29++) { + var_r20 = var_r29->unk_40 & 3; + var_r19 = (var_r29->unk_40 >> 2) & 3; + for (var_r25 = 0; var_r25 < 4; var_r25++, var_r28++) { + var_r28->x = (0.25f * var_r20) + lbl_1_data_910[var_r25].x; + var_r28->y = (0.25f * var_r19) + lbl_1_data_910[var_r25].y; + } + } + } else { + for (var_r26 = 0; var_r26 < var_r31->unk_26; var_r26++, var_r29++) { + for (var_r25 = 0; var_r25 < 4; var_r25++, var_r28++) { + var_r28->x = 4.0f * lbl_1_data_910[var_r25].x; + var_r28->y = 4.0f * lbl_1_data_910[var_r25].y; + } + } + } + DCFlushRangeNoSync(var_r31->unk_40, var_r31->unk_26 * 0xC * 4); + DCFlushRangeNoSync(var_r31->unk_44, var_r31->unk_26 * 8 * 4); + DCFlushRangeNoSync(var_r31->unk_3C, var_r31->unk_26 * 0x44); + PPCSync(); + GXCallDisplayList(var_r31->unk_48, var_r31->unk_34); + if (!shadowModelDrawF) { + if ((var_r31->unk_21 & 2) == 0) { + var_r31->unk_28++; + } + if ((var_r31->unk_30 != 0) && (var_r31->unk_30 <= var_r31->unk_28)) { + if (var_r31->unk_21 & 1) { + var_r31->unk_28 = 0; + } + var_r31->unk_28 = var_r31->unk_30; + } + var_r31->unk_2C = GlobalCounter; + } + } +} + +s16 fn_1_C4F4(s16 arg0) +{ + Vec2f *sp8; + + UnkM406Unk120Struct2 *var_r31; + UnkM406Struct5 *var_r30; + s16 var_r29; + ModelData *var_r28; + Vec *var_r27; + void *var_r25; + s16 var_r24; + void *var_r23; + + var_r24 = Hu3DHookFuncCreate(fn_1_C86C); + var_r28 = &Hu3DData[var_r24]; + var_r31 = HuMemDirectMallocNum(HEAP_DATA, sizeof(UnkM406Unk120Struct2), var_r28->unk_48); + var_r28->unk_120 = var_r31; + var_r31->unk_38 = 0; + var_r31->unk_26 = arg0; + var_r31->unk_20 = 0; + var_r31->unk_22 = 0; + var_r31->unk_4C = 0; + var_r31->unk_50 = 0; + var_r31->unk_28 = 0; + var_r31->unk_21 = 0; + var_r31->unk_30 = 0; + + var_r31->unk_00 = var_r31->unk_02 = 0; + var_r30 = HuMemDirectMallocNum(HEAP_DATA, arg0 * sizeof(UnkM406Struct5), var_r28->unk_48); + var_r31->unk_3C = var_r30; + memset(var_r30, 0, arg0 * sizeof(UnkM406Struct5)); + for (var_r29 = 0; var_r29 < arg0; var_r29++, var_r30++) { + var_r30->unk_28 = 0.0f; + var_r30->unk_2C = 0.0f; + var_r30->unk_30.x = ((frand() & 0x7F) - 0x40) * 0x14; + var_r30->unk_30.y = ((frand() & 0x7F) - 0x40) * 0x1E; + var_r30->unk_30.z = ((frand() & 0x7F) - 0x40) * 0x14; + var_r30->unk_3C.r = var_r30->unk_3C.g = var_r30->unk_3C.b = var_r30->unk_3C.a = 0xFF; + var_r30->unk_40 = 0; + } + var_r27 = HuMemDirectMallocNum(HEAP_DATA, arg0 * sizeof(Vec) * 4, var_r28->unk_48); + var_r31->unk_40 = var_r27; + for (var_r29 = 0; var_r29 < (arg0 * 4); var_r29++, var_r27++) { + var_r27->x = var_r27->y = var_r27->z = 0.0f; + } + var_r31->unk_44 = sp8 = NULL; + var_r25 = HuMemDirectMallocNum(HEAP_DATA, 0x10000, var_r28->unk_48); + var_r23 = var_r25; + DCFlushRange(var_r25, 0x10000); + GXBeginDisplayList(var_r23, 0x10000); + GXBegin(GX_QUADS, GX_VTXFMT0, arg0 * 4); + for (var_r29 = 0; var_r29 < arg0; var_r29++) { + GXUnknownu16(var_r29 * 4); + GXUnknownu16(var_r29); + GXUnknownu16(var_r29 * 4 + 1); + GXUnknownu16(var_r29); + GXUnknownu16(var_r29 * 4 + 2); + GXUnknownu16(var_r29); + GXUnknownu16(var_r29 * 4 + 3); + GXUnknownu16(var_r29); + } + var_r31->unk_34 = GXEndDisplayList(); + var_r31->unk_48 = HuMemDirectMallocNum(HEAP_DATA, var_r31->unk_34, var_r28->unk_48); + memcpy(var_r31->unk_48, var_r25, var_r31->unk_34); + DCFlushRange(var_r31->unk_48, var_r31->unk_34); + HuMemDirectFree(var_r25); + return var_r24; +} + +void fn_1_C86C(ModelData *arg0, Mtx arg1) +{ + Mtx sp9C; + ROMtx sp6C; + ROMtx sp3C; + ROMtx spC; + Vec2f *sp8; + + UnkM406Unk120Struct2 *var_r31; + Vec *var_r30; + UnkM406Struct5 *var_r29; + Vec *var_r28; + Vec *var_r27; + s16 var_r25; + UnkM406Unk120Struct2Hook var_r23; + + var_r31 = arg0->unk_120; + if (var_r31->unk_2C != GlobalCounter || shadowModelDrawF) { + if (var_r31->unk_50 && var_r31->unk_50 != arg0) { + fn_1_C86C(var_r31->unk_50, arg1); + } + GXLoadPosMtxImm(arg1, 0); + GXSetNumTevStages(1); + GXSetNumTexGens(0); + GXSetTexCoordGen2(GX_TEXCOORD0, GX_TG_MTX2x4, GX_TG_TEX0, 0x3C, GX_FALSE, 0x7D); + GXSetTevOrder(GX_TEVSTAGE0, GX_TEXCOORD_NULL, GX_TEXMAP_NULL, GX_COLOR0A0); + GXSetTevOp(GX_TEVSTAGE0, GX_PASSCLR); + GXSetNumChans(1); + GXSetChanCtrl(GX_COLOR0A0, GX_FALSE, GX_SRC_REG, GX_SRC_VTX, 0, GX_DF_CLAMP, GX_AF_NONE); + GXSetAlphaCompare(GX_GEQUAL, 1, GX_AOP_AND, GX_GEQUAL, 1); + GXSetZCompLoc(GX_FALSE); + if (arg0->attr & 2) { + GXSetZMode(GX_TRUE, GX_LEQUAL, GX_TRUE); + } else { + GXSetZMode(GX_TRUE, GX_LEQUAL, GX_FALSE); + } + switch (var_r31->unk_20) { + case 0: + GXSetBlendMode(GX_BM_BLEND, GX_BL_SRCALPHA, GX_BL_INVSRCALPHA, GX_LO_NOOP); + break; + case 1: + GXSetBlendMode(GX_BM_BLEND, GX_BL_SRCALPHA, GX_BL_ONE, GX_LO_NOOP); + break; + case 2: + GXSetBlendMode(GX_BM_BLEND, GX_BL_ZERO, GX_BL_INVDSTCLR, GX_LO_NOOP); + break; + } + GXClearVtxDesc(); + GXSetVtxDesc(GX_VA_POS, GX_INDEX16); + GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_POS, GX_POS_XYZ, GX_F32, 0); + GXSetArray(GX_VA_POS, var_r31->unk_40, sizeof(Vec)); + GXSetVtxDesc(GX_VA_CLR0, GX_INDEX16); + GXSetVtxAttrFmt(GX_VTXFMT0, GX_VA_CLR0, GX_CLR_RGBA, GX_RGBA8, 0); + GXSetArray(GX_VA_CLR0, &var_r31->unk_3C->unk_3C, 0x44); + if (HmfInverseMtxF3X3(arg1, sp9C) == 0) { + PSMTXIdentity(sp9C); + } + PSMTXReorder(sp9C, spC); + if (var_r31->unk_4C) { + var_r23 = var_r31->unk_4C; + var_r23(arg0, var_r31, arg1); + } + var_r29 = var_r31->unk_3C; + var_r30 = var_r31->unk_40; + sp8 = var_r31->unk_44; + PSMTXROMultVecArray(spC, lbl_1_data_930, (Vec *)sp3C, 4); + for (var_r25 = 0; var_r25 < var_r31->unk_26; var_r25++, var_r29++) { + if (!var_r29->unk_28) { + var_r30->x = var_r30->y = var_r30->z = 0.0f; + var_r30++; + var_r30->x = var_r30->y = var_r30->z = 0.0f; + var_r30++; + var_r30->x = var_r30->y = var_r30->z = 0.0f; + var_r30++; + var_r30->x = var_r30->y = var_r30->z = 0.0f; + var_r30++; + } else { + var_r28 = (Vec *)&sp6C; + var_r27 = (Vec *)&sp3C; + PSVECScale(var_r27++, var_r28, var_r29->unk_28); + PSVECAdd(var_r28++, &var_r29->unk_30, var_r30++); + PSVECScale(var_r27++, var_r28, var_r29->unk_28); + PSVECAdd(var_r28++, &var_r29->unk_30, var_r30++); + PSVECScale(var_r27++, var_r28, var_r29->unk_28); + PSVECAdd(var_r28++, &var_r29->unk_30, var_r30++); + PSVECScale(var_r27++, var_r28, var_r29->unk_28); + PSVECAdd(var_r28++, &var_r29->unk_30, var_r30++); + } + } + DCFlushRangeNoSync(var_r31->unk_40, var_r31->unk_26 * 0xC * 4); + DCFlushRangeNoSync(var_r31->unk_3C, var_r31->unk_26 * 0x44); + PPCSync(); + GXCallDisplayList(var_r31->unk_48, var_r31->unk_34); + if (!shadowModelDrawF) { + if ((var_r31->unk_21 & 2) == 0) { + var_r31->unk_28++; + } + if ((var_r31->unk_30 != 0) && (var_r31->unk_30 <= var_r31->unk_28)) { + if (var_r31->unk_21 & 1) { + var_r31->unk_28 = 0; + } + var_r31->unk_28 = var_r31->unk_30; + } + var_r31->unk_2C = GlobalCounter; + } + } +} + +s32 fn_1_CD34(s32 arg0, s32 arg1, s32 arg2) +{ + ModelData *var_r29; + ModelData *var_r30; + s32 var_r31; + + var_r29 = &Hu3DData[arg0]; + var_r30 = &Hu3DData[arg2]; + for (var_r31 = 0; var_r31 < 8; var_r31++) { + if (var_r30->unk_38[var_r31] == -1) { + break; + } + } + if (var_r31 == 8) { + return -1; + } + var_r30->unk_38[var_r31] = var_r29->unk_38[arg1]; + var_r30->attr |= 0x1000; + return var_r31; +} + +void fn_1_CDD8(s32 arg0, float arg8, float arg9, float argA, float argB) +{ + HsfMaterial *var_r31; + s32 var_r30; + HsfData *var_r29; + s32 var_r28; + ModelData *var_r27; + s32 var_r26; + + var_r27 = &Hu3DData[arg0]; + var_r29 = var_r27->hsfData; + var_r31 = var_r29->material; + var_r26 = var_r29->materialCnt; + for (var_r28 = 0; var_r28 < var_r26; var_r28++, var_r31++) { + var_r31->vtxMode = 1; + var_r30 = arg9 * (var_r31->litColor[0] * arg8); + if (var_r30 > 0xFF) { + var_r30 = 0xFF; + } + var_r31->litColor[0] = var_r30; + var_r30 = argA * (var_r31->litColor[1] * arg8); + if (var_r30 > 0xFF) { + var_r30 = 0xFF; + } + var_r31->litColor[1] = var_r30; + var_r30 = argB * (var_r31->litColor[2] * arg8); + if (var_r30 > 0xFF) { + var_r30 = 0xFF; + } + var_r31->litColor[2] = var_r30; + } +} + +void fn_1_CF24(s32 arg0, u8 arg1, u8 arg2, u8 arg3) +{ + HsfMaterial *var_r31; + HsfData *var_r30; + s32 var_r29; + ModelData *var_r28; + s32 var_r27; + + var_r28 = &Hu3DData[arg0]; + var_r30 = var_r28->hsfData; + var_r31 = var_r30->material; + var_r27 = var_r30->materialCnt; + for (var_r29 = 0; var_r29 < var_r27; var_r29++, var_r31++) { + var_r31->vtxMode = 1; + var_r31->litColor[0] = arg1; + var_r31->litColor[1] = arg2; + var_r31->litColor[2] = arg3; + } +} + +void fn_1_CF98(s32 arg0, s32 arg1) +{ + s32 var_r31; + HsfData *var_r30; + HsfData *var_r29; + ModelData *var_r28; + ModelData *var_r27; + + var_r28 = &Hu3DData[arg0]; + var_r27 = &Hu3DData[arg1]; + var_r29 = var_r28->hsfData; + var_r30 = var_r27->hsfData; + for (var_r31 = 0; var_r31 < var_r30->bitmapCnt; var_r31++) { + memcpy(&var_r30->bitmap[var_r31], &var_r29->bitmap[var_r31], 0x20); + } + for (var_r31 = 0; var_r31 < var_r30->attributeCnt; var_r31++) { + memcpy(&var_r30->attribute[var_r31], &var_r29->attribute[var_r31], 0x84); + } +} + +s16 fn_1_D06C(ModelData *arg0, Mtx arg1, Mtx arg2, float arg8) +{ + s16 var_r31; + s16 var_r29; + s16 var_r28; + LightData *var_r27; + + var_r28 = 0; + var_r29 = 1; + if (arg0->attr & 0x1000) { + for (var_r31 = 0; var_r31 < 8; var_r31++) { + if (arg0->unk_38[var_r31] != -1) { + var_r27 = &Hu3DLocalLight[arg0->unk_38[var_r31]]; + fn_1_D13C(var_r27, var_r29, arg2, arg1, arg8); + var_r28 |= var_r29; + var_r29 *= 2; + } + } + } + return var_r28; +} + +void fn_1_D13C(LightData *arg0, s16 arg1, Mtx arg2, Mtx arg3, float arg8) +{ + GXLightObj sp30; + Vec sp24; + Vec sp18; + + switch ((u8)arg0->unk_00) { + case 0: + GXInitLightAttn(&sp30, 1.0f, 0.0f, 0.0f, 1.0f, 0.0f, 0.0f); + GXInitLightSpot(&sp30, arg0->unk_04, arg0->unk_02); + break; + case 1: + GXInitLightAttn(&sp30, 1.0f, 0.0f, 0.0f, 1.0f, 0.0f, 0.0f); + GXInitLightSpot(&sp30, 20.0f, GX_SP_COS); + GXInitLightAttnK(&sp30, 1.0f, 0.0f, 0.0f); + PSVECScale(&arg0->unk_28, &arg0->unk_1C, -1000000.0f); + break; + case 2: + GXInitLightAttn(&sp30, 1.0f, 0.0f, 0.0f, 0.0f, 0.0f, 0.0f); + GXInitLightDistAttn(&sp30, arg0->unk_04, arg0->unk_08, arg0->unk_02); + break; + default: + break; + } + if (arg0->unk_00 & 0x8000) { + PSMTXMultVec(arg2, &arg0->unk_28, &sp24); + PSMTXMultVec(arg3, &arg0->unk_1C, &sp18); + GXInitLightPos(&sp30, sp18.x, sp18.y, sp18.z); + } else { + GXInitLightPos(&sp30, arg0->unk_1C.x, arg0->unk_1C.y, arg0->unk_1C.z); + sp24 = arg0->unk_28; + } + if (arg8 == 0.0f) { + GXInitLightDir(&sp30, sp24.x, sp24.y, sp24.z); + } else { + GXInitSpecularDir(&sp30, sp24.x, sp24.y, sp24.z); + GXInitLightAttn(&sp30, 0.0f, 0.0f, 1.0f, arg8 * 0.5f, 0.0f, 1.0f - (arg8 * 0.5f)); + } + GXInitLightColor(&sp30, arg0->color); + GXLoadLightObjImm(&sp30, arg1); +} + +void fn_1_D488(float arg8, Vec *arg0, Vec *arg1, Vec *arg2) +{ + lbl_1_bss_3C.x = arg0->x + (arg8 * (arg1->x - arg0->x)); + lbl_1_bss_3C.y = arg0->y + (arg8 * (arg1->y - arg0->y)); + lbl_1_bss_3C.z = arg0->z + (arg8 * (arg1->z - arg0->z)); + *arg2 = lbl_1_bss_3C; +} + +void fn_1_D518(Mtx arg0, Vec *arg1) +{ + Vec sp8; + + sp8.x = (arg0[0][2] * arg1->z) + ((arg0[0][0] * arg1->x) + (arg0[0][1] * arg1->y)); + sp8.y = (arg0[1][2] * arg1->z) + ((arg0[1][0] * arg1->x) + (arg0[1][1] * arg1->y)); + sp8.z = (arg0[2][2] * arg1->z) + ((arg0[2][0] * arg1->x) + (arg0[2][1] * arg1->y)); + *arg1 = sp8; +} + +float fn_1_D5CC(Vec *arg0, Vec *arg1, float arg8, float arg9) +{ + float var_f31; + float var_f30; + float var_f29; + float var_f28; + float var_f27; + + var_f31 = arg0->x - arg8; + var_f30 = arg0->z - arg9; + var_f29 = arg1->x - arg8; + var_f28 = arg1->z - arg9; + + var_f27 = -((var_f30 * var_f29) - (var_f31 * var_f28)); + return var_f27; +}