mirror of https://github.com/PrimeDecomp/prime.git
Match and link vi.c and THPDec.c, minor CPhysicsActor and GBA.c fixes
This commit is contained in:
parent
0b74ded7ba
commit
6a3e0c0728
|
@ -19029,10 +19029,18 @@ LeapYearDays = .data:0x803F2320; // type:object size:0x30 scope:local
|
||||||
...data.0 = .data:0x803F2350; // type:label scope:local
|
...data.0 = .data:0x803F2350; // type:label scope:local
|
||||||
ResetFunctionInfo = .data:0x803F2398; // type:object size:0x10 scope:local
|
ResetFunctionInfo = .data:0x803F2398; // type:object size:0x10 scope:local
|
||||||
...data.0 = .data:0x803F23A8; // type:label scope:local
|
...data.0 = .data:0x803F23A8; // type:label scope:local
|
||||||
lbl_803F23A8 = .data:0x803F23A8; // type:object size:0x1F4
|
@3 = .data:0x803F23A8; // type:object size:0x44 scope:local data:string
|
||||||
jumptable_803F259C = .data:0x803F259C; // type:object size:0x6C scope:local
|
timing = .data:0x803F23EC; // type:object size:0x17C scope:local
|
||||||
lbl_803F2608 = .data:0x803F2608; // type:object size:0x154 scope:local
|
taps = .data:0x803F2568; // type:object size:0x34 scope:local
|
||||||
@724 = .data:0x803F275C; // type:object size:0x1C scope:local
|
@90 = .data:0x803F259C; // type:object size:0x6C scope:local
|
||||||
|
@333 = .data:0x803F2608; // type:object size:0x29 scope:local data:string
|
||||||
|
@334 = .data:0x803F2634; // type:object size:0x29 scope:local data:string
|
||||||
|
@335 = .data:0x803F2660; // type:object size:0x29 scope:local data:string
|
||||||
|
@336 = .data:0x803F268C; // type:object size:0x29 scope:local data:string
|
||||||
|
@337 = .data:0x803F26B8; // type:object size:0x29 scope:local data:string
|
||||||
|
@338 = .data:0x803F26E4; // type:object size:0x29 scope:local data:string
|
||||||
|
@521 = .data:0x803F2710; // type:object size:0x4B scope:local data:string
|
||||||
|
@694 = .data:0x803F275C; // type:object size:0x1C scope:local
|
||||||
__files = .data:0x803F2778; // type:object size:0x140 scope:global
|
__files = .data:0x803F2778; // type:object size:0x140 scope:global
|
||||||
lbl_803F28B8 = .data:0x803F28B8; // type:object size:0x40
|
lbl_803F28B8 = .data:0x803F28B8; // type:object size:0x40
|
||||||
jumptable_803F28F8 = .data:0x803F28F8; // type:object size:0x124 scope:local
|
jumptable_803F28F8 = .data:0x803F28F8; // type:object size:0x124 scope:local
|
||||||
|
@ -19304,8 +19312,10 @@ Type = .bss:0x80541FF0; // type:object size:0x10 scope:local
|
||||||
...bss.0 = .bss:0x80541FF0; // type:label scope:local
|
...bss.0 = .bss:0x80541FF0; // type:label scope:local
|
||||||
Origin = .bss:0x80542000; // type:object size:0x30 scope:local
|
Origin = .bss:0x80542000; // type:object size:0x30 scope:local
|
||||||
CmdProbeDevice = .bss:0x80542030; // type:object size:0x10 scope:local
|
CmdProbeDevice = .bss:0x80542030; // type:object size:0x10 scope:local
|
||||||
lbl_80542040 = .bss:0x80542040; // type:object size:0xF0 data:2byte
|
...bss.0 = .bss:0x80542040; // type:label scope:local
|
||||||
lbl_80542130 = .bss:0x80542130; // type:object size:0x58 data:2byte
|
regs = .bss:0x80542040; // type:object size:0x76 scope:local data:2byte
|
||||||
|
shdwRegs = .bss:0x805420B8; // type:object size:0x76 scope:local
|
||||||
|
HorVer = .bss:0x80542130; // type:object size:0x58 scope:local data:2byte
|
||||||
fragmentinfo = .bss:0x80542188; // type:object size:0xC scope:local data:4byte
|
fragmentinfo = .bss:0x80542188; // type:object size:0xC scope:local data:4byte
|
||||||
__atexit_funcs = .bss:0x80542198; // type:object size:0x100 scope:local
|
__atexit_funcs = .bss:0x80542198; // type:object size:0x100 scope:local
|
||||||
protopool$192 = .bss:0x80542298; // type:object size:0x38 scope:local data:4byte
|
protopool$192 = .bss:0x80542298; // type:object size:0x38 scope:local data:4byte
|
||||||
|
@ -19394,9 +19404,9 @@ Ecb = .bss:0x80569E98; // type:object size:0xC0 scope:local data:4byte
|
||||||
__THPIDCTWorkspace = .bss:0x80569F60; // type:object size:0x100 scope:local align:32
|
__THPIDCTWorkspace = .bss:0x80569F60; // type:object size:0x100 scope:local align:32
|
||||||
__THPLCWork512 = .bss:0x8056A060; // type:object size:0xC scope:local
|
__THPLCWork512 = .bss:0x8056A060; // type:object size:0xC scope:local
|
||||||
__THPLCWork640 = .bss:0x8056A06C; // type:object size:0xC scope:local
|
__THPLCWork640 = .bss:0x8056A06C; // type:object size:0xC scope:local
|
||||||
__THPMCUBuffer = .bss:0x8056A078; // type:object size:0x28 scope:global data:4byte
|
__THPMCUBuffer = .bss:0x8056A078; // type:object size:0x18 scope:global data:4byte
|
||||||
SecParams = .bss:0x8056A0A0; // type:object size:0x100 scope:local
|
SecParams = .bss:0x8056A0A0; // type:object size:0x100 scope:local align:32
|
||||||
__GBA = .bss:0x8056A1A0; // type:object size:0x400 scope:global
|
__GBA = .bss:0x8056A1A0; // type:object size:0x400 scope:global align:8
|
||||||
gCommandFilterFlag__13ControlMapper = .bss:0x8056A5A0; // type:object size:0x48 scope:global data:4byte
|
gCommandFilterFlag__13ControlMapper = .bss:0x8056A5A0; // type:object size:0x48 scope:global data:4byte
|
||||||
sIdentity__10CAxisAngle = .bss:0x8056A5E8; // type:object size:0xC scope:global data:float
|
sIdentity__10CAxisAngle = .bss:0x8056A5E8; // type:object size:0xC scope:global data:float
|
||||||
lbl_8056A5F4 = .bss:0x8056A5F4; // type:object size:0xC data:float
|
lbl_8056A5F4 = .bss:0x8056A5F4; // type:object size:0xC data:float
|
||||||
|
@ -21453,8 +21463,8 @@ Spec = .sdata:0x805A8B68; // type:object size:0x4 scope:local data:4byte
|
||||||
MakeStatus = .sdata:0x805A8B6C; // type:object size:0x4 scope:local data:4byte
|
MakeStatus = .sdata:0x805A8B6C; // type:object size:0x4 scope:local data:4byte
|
||||||
CmdReadOrigin = .sdata:0x805A8B70; // type:object size:0x4 scope:local
|
CmdReadOrigin = .sdata:0x805A8B70; // type:object size:0x4 scope:local
|
||||||
CmdCalibrate = .sdata:0x805A8B74; // type:object size:0x4 scope:local
|
CmdCalibrate = .sdata:0x805A8B74; // type:object size:0x4 scope:local
|
||||||
lbl_805A8B78 = .sdata:0x805A8B78; // type:object size:0x4 data:4byte
|
__VIVersion = .sdata:0x805A8B78; // type:object size:0x4 data:4byte
|
||||||
lbl_805A8B7C = .sdata:0x805A8B7C; // type:object size:0xC
|
@520 = .sdata:0x805A8B7C; // type:object size:0x5 scope:local data:string
|
||||||
fragmentID = .sdata:0x805A8B88; // type:object size:0x4 scope:local data:4byte
|
fragmentID = .sdata:0x805A8B88; // type:object size:0x4 scope:local data:4byte
|
||||||
@wstringBase0 = .sdata:0x805A8B90; // type:object size:0x2 scope:local
|
@wstringBase0 = .sdata:0x805A8B90; // type:object size:0x2 scope:local
|
||||||
next = .sdata:0x805A8B98; // type:object size:0x4 scope:local data:4byte
|
next = .sdata:0x805A8B98; // type:object size:0x4 scope:local data:4byte
|
||||||
|
@ -22235,27 +22245,25 @@ PendingBits = .sbss:0x805A9948; // type:object size:0x4 scope:local data:4byte
|
||||||
SamplingCallback = .sbss:0x805A994C; // type:object size:0x4 scope:local data:4byte
|
SamplingCallback = .sbss:0x805A994C; // type:object size:0x4 scope:local data:4byte
|
||||||
recalibrated$396 = .sbss:0x805A9950; // type:object size:0x4 scope:local data:4byte
|
recalibrated$396 = .sbss:0x805A9950; // type:object size:0x4 scope:local data:4byte
|
||||||
__PADSpec = .sbss:0x805A9954; // type:object size:0x4 scope:global data:4byte
|
__PADSpec = .sbss:0x805A9954; // type:object size:0x4 scope:global data:4byte
|
||||||
lbl_805A9958 = .sbss:0x805A9958; // type:object size:0x4 data:4byte
|
IsInitialized = .sbss:0x805A9958; // type:object size:0x4 scope:local data:4byte
|
||||||
lbl_805A995C = .sbss:0x805A995C; // type:object size:0x4 data:4byte
|
retraceCount = .sbss:0x805A995C; // type:object size:0x4 scope:local data:4byte
|
||||||
lbl_805A9960 = .sbss:0x805A9960; // type:object size:0x4 data:4byte
|
flushFlag = .sbss:0x805A9960; // type:object size:0x4 scope:local data:4byte
|
||||||
lbl_805A9964 = .sbss:0x805A9964; // type:object size:0x8
|
retraceQueue = .sbss:0x805A9964; // type:object size:0x8 scope:local
|
||||||
lbl_805A996C = .sbss:0x805A996C; // type:object size:0x4 data:4byte
|
PreCB = .sbss:0x805A996C; // type:object size:0x4 scope:local data:4byte
|
||||||
lbl_805A9970 = .sbss:0x805A9970; // type:object size:0x4 data:4byte
|
PostCB = .sbss:0x805A9970; // type:object size:0x4 scope:local data:4byte
|
||||||
lbl_805A9974 = .sbss:0x805A9974; // type:object size:0x4 data:4byte
|
encoderType = .sbss:0x805A9974; // type:object size:0x4 scope:local data:4byte
|
||||||
lbl_805A9978 = .sbss:0x805A9978; // type:object size:0x2 data:2byte
|
displayOffsetH = .sbss:0x805A9978; // type:object size:0x2 scope:local data:2byte
|
||||||
lbl_805A997A = .sbss:0x805A997A; // type:object size:0x2 data:2byte
|
displayOffsetV = .sbss:0x805A997A; // type:object size:0x2 scope:local data:2byte
|
||||||
lbl_805A997C = .sbss:0x805A997C; // type:object size:0x4 data:4byte
|
changeMode = .sbss:0x805A997C; // type:object size:0x4 scope:local data:4byte
|
||||||
lbl_805A9980 = .sbss:0x805A9980; // type:object size:0x4 data:4byte
|
changed = .sbss:0x805A9980; // type:object size:0x8 scope:local data:8byte
|
||||||
lbl_805A9984 = .sbss:0x805A9984; // type:object size:0x4 data:4byte
|
shdwChangeMode = .sbss:0x805A9988; // type:object size:0x4 scope:local data:4byte
|
||||||
lbl_805A9988 = .sbss:0x805A9988; // type:object size:0x8 data:4byte
|
shdwChanged = .sbss:0x805A9990; // type:object size:0x8 scope:local data:8byte
|
||||||
lbl_805A9990 = .sbss:0x805A9990; // type:object size:0x4 data:4byte
|
CurrTiming = .sbss:0x805A9998; // type:object size:0x4 scope:local data:4byte
|
||||||
lbl_805A9994 = .sbss:0x805A9994; // type:object size:0x4 data:4byte
|
|
||||||
lbl_805A9998 = .sbss:0x805A9998; // type:object size:0x4 data:4byte
|
|
||||||
CurrTvMode = .sbss:0x805A999C; // type:object size:0x4 scope:local data:4byte
|
CurrTvMode = .sbss:0x805A999C; // type:object size:0x4 scope:local data:4byte
|
||||||
lbl_805A99A0 = .sbss:0x805A99A0; // type:object size:0x4 data:4byte
|
NextBufAddr = .sbss:0x805A99A0; // type:object size:0x4 scope:local data:4byte
|
||||||
lbl_805A99A4 = .sbss:0x805A99A4; // type:object size:0x4 data:4byte
|
CurrBufAddr = .sbss:0x805A99A4; // type:object size:0x4 scope:local data:4byte
|
||||||
lbl_805A99A8 = .sbss:0x805A99A8; // type:object size:0x4 data:4byte
|
FBSet = .sbss:0x805A99A8; // type:object size:0x4 scope:local data:4byte
|
||||||
lbl_805A99AC = .sbss:0x805A99AC; // type:object size:0x4 data:4byte
|
message$329 = .sbss:0x805A99AC; // type:object size:0x4 scope:local data:4byte
|
||||||
__global_destructor_chain = .sbss:0x805A99B0; // type:object size:0x4 scope:global data:4byte
|
__global_destructor_chain = .sbss:0x805A99B0; // type:object size:0x4 scope:global data:4byte
|
||||||
__aborting = .sbss:0x805A99B8; // type:object size:0x4 scope:global data:4byte
|
__aborting = .sbss:0x805A99B8; // type:object size:0x4 scope:global data:4byte
|
||||||
__atexit_curr_func = .sbss:0x805A99BC; // type:object size:0x4 scope:local data:4byte
|
__atexit_curr_func = .sbss:0x805A99BC; // type:object size:0x4 scope:local data:4byte
|
||||||
|
|
|
@ -1186,7 +1186,7 @@ config.libs = [
|
||||||
DolphinLib(
|
DolphinLib(
|
||||||
"vi",
|
"vi",
|
||||||
[
|
[
|
||||||
Object(NonMatching, "Dolphin/vi.c"),
|
Object(Matching, "Dolphin/vi.c"),
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
{
|
{
|
||||||
|
@ -1349,7 +1349,7 @@ config.libs = [
|
||||||
DolphinLib(
|
DolphinLib(
|
||||||
"thp",
|
"thp",
|
||||||
[
|
[
|
||||||
Object(NonMatching, "Dolphin/thp/THPDec.c"),
|
Object(Matching, "Dolphin/thp/THPDec.c"),
|
||||||
Object(NonMatching, "Dolphin/thp/THPAudio.c"),
|
Object(NonMatching, "Dolphin/thp/THPAudio.c"),
|
||||||
],
|
],
|
||||||
),
|
),
|
||||||
|
|
|
@ -39,6 +39,7 @@ public:
|
||||||
}
|
}
|
||||||
|
|
||||||
CGuiObject* Parent();
|
CGuiObject* Parent();
|
||||||
|
const CGuiObject* GetParent() const { return x64_parent; }
|
||||||
const CGuiObject* GetChildObject() const;
|
const CGuiObject* GetChildObject() const;
|
||||||
CGuiObject* ChildObject();
|
CGuiObject* ChildObject();
|
||||||
const CGuiObject* GetNextSibling() const;
|
const CGuiObject* GetNextSibling() const;
|
||||||
|
|
|
@ -20,7 +20,7 @@ public:
|
||||||
// CAnimRes()
|
// CAnimRes()
|
||||||
// : x4_charIdx(-1), x14_canLoop(false), x8_scale(????), x18_defaultAnim(-1) {}
|
// : x4_charIdx(-1), x14_canLoop(false), x8_scale(????), x18_defaultAnim(-1) {}
|
||||||
|
|
||||||
CAnimRes(CAssetId ancs, int charIdx, const CVector3f& scale, int defaultAnim, bool loop)
|
CAnimRes(CAssetId ancs, const int charIdx, const CVector3f& scale, int defaultAnim, bool loop)
|
||||||
: x0_ancsId(ancs)
|
: x0_ancsId(ancs)
|
||||||
, x4_charIdx(charIdx)
|
, x4_charIdx(charIdx)
|
||||||
, x8_scale(scale)
|
, x8_scale(scale)
|
||||||
|
|
|
@ -111,8 +111,8 @@ public:
|
||||||
void Stop();
|
void Stop();
|
||||||
|
|
||||||
CVector3f GetPrimitiveOffset() const;
|
CVector3f GetPrimitiveOffset() const;
|
||||||
uchar IsStandardCollider() const { return xf9_standardCollider; } // name and type?
|
const bool IsStandardCollider() const { return xf9_standardCollider; } // name and type?
|
||||||
void SetStandardCollider(uchar v) { xf9_standardCollider = v; } // name and type?
|
void SetStandardCollider(const bool v) { xf9_standardCollider = v; } // name and type?
|
||||||
const CVector3f& GetConstantForceWR() const { return xfc_constantForce; }
|
const CVector3f& GetConstantForceWR() const { return xfc_constantForce; }
|
||||||
void SetConstantForceWR(const CVector3f& force) { xfc_constantForce = force; }
|
void SetConstantForceWR(const CVector3f& force) { xfc_constantForce = force; }
|
||||||
const CAxisAngle& GetAngularMomentumWR() const { return x108_angularMomentum; }
|
const CAxisAngle& GetAngularMomentumWR() const { return x108_angularMomentum; }
|
||||||
|
@ -167,6 +167,7 @@ public:
|
||||||
void RotateToOR(const CQuaternion&, float);
|
void RotateToOR(const CQuaternion&, float);
|
||||||
|
|
||||||
CVector3f GetTotalForceWR() const;
|
CVector3f GetTotalForceWR() const;
|
||||||
|
CVector3f GetConstantTotalForceWR() const { return x15c_force + x150_momentum; }
|
||||||
|
|
||||||
static float GravityConstant() { return kGravityAccel; }
|
static float GravityConstant() { return kGravityAccel; }
|
||||||
|
|
||||||
|
|
|
@ -14,7 +14,7 @@ public:
|
||||||
const CAxisAngle& torque, const CAxisAngle& angularImpulse);
|
const CAxisAngle& torque, const CAxisAngle& angularImpulse);
|
||||||
|
|
||||||
CVector3f GetTranslation() const { return x0_translation; }
|
CVector3f GetTranslation() const { return x0_translation; }
|
||||||
CQuaternion GetOrientationWR() const { return xc_orientation; }
|
CQuaternion GetOrientation() const { return xc_orientation; }
|
||||||
CVector3f GetConstantForceWR() const { return x1c_constantForce; }
|
CVector3f GetConstantForceWR() const { return x1c_constantForce; }
|
||||||
CAxisAngle GetAngularMomentumWR() const { return x28_angularMomentum; }
|
CAxisAngle GetAngularMomentumWR() const { return x28_angularMomentum; }
|
||||||
CVector3f GetMomentumWR() const { return x34_momentum; }
|
CVector3f GetMomentumWR() const { return x34_momentum; }
|
||||||
|
|
|
@ -40,7 +40,7 @@
|
||||||
*/
|
*/
|
||||||
#include "dolphin/GBAPriv.h"
|
#include "dolphin/GBAPriv.h"
|
||||||
|
|
||||||
static GBASecParam SecParams[4];
|
static GBASecParam SecParams[4] ATTRIBUTE_ALIGN(32);
|
||||||
GBAControl __GBA[4];
|
GBAControl __GBA[4];
|
||||||
BOOL __GBAReset = FALSE;
|
BOOL __GBAReset = FALSE;
|
||||||
|
|
||||||
|
|
|
@ -16,7 +16,7 @@ static THPSample* Gbase ATTRIBUTE_ALIGN(32);
|
||||||
static u32 Gwid ATTRIBUTE_ALIGN(32);
|
static u32 Gwid ATTRIBUTE_ALIGN(32);
|
||||||
static f32* Gq ATTRIBUTE_ALIGN(32);
|
static f32* Gq ATTRIBUTE_ALIGN(32);
|
||||||
static u8* __THPLCWork512[3];
|
static u8* __THPLCWork512[3];
|
||||||
static u8* __THPLCWork672[3];
|
static u8* __THPLCWork640[3];
|
||||||
static u32 __THPOldGQR5;
|
static u32 __THPOldGQR5;
|
||||||
static u32 __THPOldGQR6;
|
static u32 __THPOldGQR6;
|
||||||
static u8* __THPWorkArea;
|
static u8* __THPWorkArea;
|
||||||
|
@ -1545,7 +1545,7 @@ static void __THPDecompressiMCURow640x480(void)
|
||||||
__THPHuffDecodeDCTCompV(__THPInfo, __THPMCUBuffer[5]);
|
__THPHuffDecodeDCTCompV(__THPInfo, __THPMCUBuffer[5]);
|
||||||
|
|
||||||
comp = &__THPInfo->components[0];
|
comp = &__THPInfo->components[0];
|
||||||
Gbase = __THPLCWork672[0];
|
Gbase = __THPLCWork640[0];
|
||||||
Gwid = 640;
|
Gwid = 640;
|
||||||
Gq = __THPInfo->quantTabs[comp->quantizationTableSelector];
|
Gq = __THPInfo->quantTabs[comp->quantizationTableSelector];
|
||||||
x_pos = (u32)(cl_num * 16);
|
x_pos = (u32)(cl_num * 16);
|
||||||
|
@ -1555,14 +1555,14 @@ static void __THPDecompressiMCURow640x480(void)
|
||||||
__THPInverseDCTY8(__THPMCUBuffer[3], x_pos + 8);
|
__THPInverseDCTY8(__THPMCUBuffer[3], x_pos + 8);
|
||||||
|
|
||||||
comp = &__THPInfo->components[1];
|
comp = &__THPInfo->components[1];
|
||||||
Gbase = __THPLCWork672[1];
|
Gbase = __THPLCWork640[1];
|
||||||
Gwid = 320;
|
Gwid = 320;
|
||||||
Gq = __THPInfo->quantTabs[comp->quantizationTableSelector];
|
Gq = __THPInfo->quantTabs[comp->quantizationTableSelector];
|
||||||
x_pos /= 2;
|
x_pos /= 2;
|
||||||
__THPInverseDCTNoYPos(__THPMCUBuffer[4], x_pos);
|
__THPInverseDCTNoYPos(__THPMCUBuffer[4], x_pos);
|
||||||
|
|
||||||
comp = &__THPInfo->components[2];
|
comp = &__THPInfo->components[2];
|
||||||
Gbase = __THPLCWork672[2];
|
Gbase = __THPLCWork640[2];
|
||||||
Gq = __THPInfo->quantTabs[comp->quantizationTableSelector];
|
Gq = __THPInfo->quantTabs[comp->quantizationTableSelector];
|
||||||
__THPInverseDCTNoYPos(__THPMCUBuffer[5], x_pos);
|
__THPInverseDCTNoYPos(__THPMCUBuffer[5], x_pos);
|
||||||
|
|
||||||
|
@ -1585,9 +1585,9 @@ static void __THPDecompressiMCURow640x480(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
LCStoreData(__THPInfo->dLC[0], __THPLCWork672[0], 0x2800);
|
LCStoreData(__THPInfo->dLC[0], __THPLCWork640[0], 0x2800);
|
||||||
LCStoreData(__THPInfo->dLC[1], __THPLCWork672[1], 0xA00);
|
LCStoreData(__THPInfo->dLC[1], __THPLCWork640[1], 0xA00);
|
||||||
LCStoreData(__THPInfo->dLC[2], __THPLCWork672[2], 0xA00);
|
LCStoreData(__THPInfo->dLC[2], __THPLCWork640[2], 0xA00);
|
||||||
|
|
||||||
__THPInfo->dLC[0] += 0x2800;
|
__THPInfo->dLC[0] += 0x2800;
|
||||||
__THPInfo->dLC[1] += 0xA00;
|
__THPInfo->dLC[1] += 0xA00;
|
||||||
|
@ -1618,7 +1618,7 @@ static void __THPDecompressiMCURowNxN(void)
|
||||||
__THPHuffDecodeDCTCompV(__THPInfo, __THPMCUBuffer[5]);
|
__THPHuffDecodeDCTCompV(__THPInfo, __THPMCUBuffer[5]);
|
||||||
|
|
||||||
comp = &__THPInfo->components[0];
|
comp = &__THPInfo->components[0];
|
||||||
Gbase = __THPLCWork672[0];
|
Gbase = __THPLCWork640[0];
|
||||||
Gwid = x;
|
Gwid = x;
|
||||||
Gq = __THPInfo->quantTabs[comp->quantizationTableSelector];
|
Gq = __THPInfo->quantTabs[comp->quantizationTableSelector];
|
||||||
x_pos = (u32)(cl_num * 16);
|
x_pos = (u32)(cl_num * 16);
|
||||||
|
@ -1628,14 +1628,14 @@ static void __THPDecompressiMCURowNxN(void)
|
||||||
__THPInverseDCTY8(__THPMCUBuffer[3], x_pos + 8);
|
__THPInverseDCTY8(__THPMCUBuffer[3], x_pos + 8);
|
||||||
|
|
||||||
comp = &__THPInfo->components[1];
|
comp = &__THPInfo->components[1];
|
||||||
Gbase = __THPLCWork672[1];
|
Gbase = __THPLCWork640[1];
|
||||||
Gwid = x / 2;
|
Gwid = x / 2;
|
||||||
Gq = __THPInfo->quantTabs[comp->quantizationTableSelector];
|
Gq = __THPInfo->quantTabs[comp->quantizationTableSelector];
|
||||||
x_pos /= 2;
|
x_pos /= 2;
|
||||||
__THPInverseDCTNoYPos(__THPMCUBuffer[4], x_pos);
|
__THPInverseDCTNoYPos(__THPMCUBuffer[4], x_pos);
|
||||||
|
|
||||||
comp = &__THPInfo->components[2];
|
comp = &__THPInfo->components[2];
|
||||||
Gbase = __THPLCWork672[2];
|
Gbase = __THPLCWork640[2];
|
||||||
Gq = __THPInfo->quantTabs[comp->quantizationTableSelector];
|
Gq = __THPInfo->quantTabs[comp->quantizationTableSelector];
|
||||||
__THPInverseDCTNoYPos(__THPMCUBuffer[5], x_pos);
|
__THPInverseDCTNoYPos(__THPMCUBuffer[5], x_pos);
|
||||||
|
|
||||||
|
@ -1656,9 +1656,9 @@ static void __THPDecompressiMCURowNxN(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
LCStoreData(__THPInfo->dLC[0], __THPLCWork672[0], ((4 * sizeof(u8) * 64) * (x / 16)));
|
LCStoreData(__THPInfo->dLC[0], __THPLCWork640[0], ((4 * sizeof(u8) * 64) * (x / 16)));
|
||||||
LCStoreData(__THPInfo->dLC[1], __THPLCWork672[1], ((sizeof(u8) * 64) * (x / 16)));
|
LCStoreData(__THPInfo->dLC[1], __THPLCWork640[1], ((sizeof(u8) * 64) * (x / 16)));
|
||||||
LCStoreData(__THPInfo->dLC[2], __THPLCWork672[2], ((sizeof(u8) * 64) * (x / 16)));
|
LCStoreData(__THPInfo->dLC[2], __THPLCWork640[2], ((sizeof(u8) * 64) * (x / 16)));
|
||||||
__THPInfo->dLC[0] += ((4 * sizeof(u8) * 64) * (x / 16));
|
__THPInfo->dLC[0] += ((4 * sizeof(u8) * 64) * (x / 16));
|
||||||
__THPInfo->dLC[1] += ((sizeof(u8) * 64) * (x / 16));
|
__THPInfo->dLC[1] += ((sizeof(u8) * 64) * (x / 16));
|
||||||
__THPInfo->dLC[2] += ((sizeof(u8) * 64) * (x / 16));
|
__THPInfo->dLC[2] += ((sizeof(u8) * 64) * (x / 16));
|
||||||
|
@ -2356,11 +2356,11 @@ BOOL THPInit(void)
|
||||||
base += 0x200;
|
base += 0x200;
|
||||||
|
|
||||||
base = (u8*)(0xE000 << 16);
|
base = (u8*)(0xE000 << 16);
|
||||||
__THPLCWork672[0] = base;
|
__THPLCWork640[0] = base;
|
||||||
base += 0x2800;
|
base += 0x2800;
|
||||||
__THPLCWork672[1] = base;
|
__THPLCWork640[1] = base;
|
||||||
base += 0xA00;
|
base += 0xA00;
|
||||||
__THPLCWork672[2] = base;
|
__THPLCWork640[2] = base;
|
||||||
base += 0xA00;
|
base += 0xA00;
|
||||||
|
|
||||||
OSInitFastCast();
|
OSInitFastCast();
|
||||||
|
|
856
src/Dolphin/vi.c
856
src/Dolphin/vi.c
|
@ -20,7 +20,6 @@ static u32 flushFlag;
|
||||||
static OSThreadQueue retraceQueue;
|
static OSThreadQueue retraceQueue;
|
||||||
static VIRetraceCallback PreCB;
|
static VIRetraceCallback PreCB;
|
||||||
static VIRetraceCallback PostCB;
|
static VIRetraceCallback PostCB;
|
||||||
static VIPositionCallback PositionCallback;
|
|
||||||
static u32 encoderType;
|
static u32 encoderType;
|
||||||
|
|
||||||
static s16 displayOffsetH;
|
static s16 displayOffsetH;
|
||||||
|
@ -808,15 +807,6 @@ void VIConfigure(const GXRenderModeObj* obj) {
|
||||||
"VIConfigure(): Tried to change mode from (%d) to (%d), which is forbidden\n",
|
"VIConfigure(): Tried to change mode from (%d) to (%d), which is forbidden\n",
|
||||||
tvInBootrom, tvInGame);
|
tvInBootrom, tvInGame);
|
||||||
}
|
}
|
||||||
// if (((tvInBootrom != VI_PAL && tvInBootrom != VI_EURGB60) && (tvInGame == VI_PAL || tvInGame ==
|
|
||||||
// VI_EURGB60))
|
|
||||||
// || ((tvInBootrom == VI_PAL || tvInBootrom == VI_EURGB60) && (tvInGame != VI_PAL && tvInGame
|
|
||||||
// != VI_EURGB60))) {
|
|
||||||
|
|
||||||
// OSErrorLine(1908, "VIConfigure(): Tried to change mode from (%d) to (%d), which is
|
|
||||||
// forbidden\n", tvInBootrom, tvInGame);
|
|
||||||
// }
|
|
||||||
|
|
||||||
if ((tvInGame == VI_NTSC) || (tvInGame == VI_MPAL)) {
|
if ((tvInGame == VI_NTSC) || (tvInGame == VI_MPAL)) {
|
||||||
HorVer.tv = tvInBootrom;
|
HorVer.tv = tvInBootrom;
|
||||||
} else {
|
} else {
|
||||||
|
@ -895,655 +885,42 @@ void VIConfigure(const GXRenderModeObj* obj) {
|
||||||
setVerticalRegs(HorVer.adjDispPosY, HorVer.adjDispSizeY, tm->equ, tm->acv, tm->prbOdd,
|
setVerticalRegs(HorVer.adjDispPosY, HorVer.adjDispSizeY, tm->equ, tm->acv, tm->prbOdd,
|
||||||
tm->prbEven, tm->psbOdd, tm->psbEven, HorVer.isBlack);
|
tm->prbEven, tm->psbOdd, tm->psbEven, HorVer.isBlack);
|
||||||
OSRestoreInterrupts(enabled);
|
OSRestoreInterrupts(enabled);
|
||||||
/*
|
|
||||||
.loc_0x0:
|
|
||||||
mflr r0
|
|
||||||
lis r5, 0x804A
|
|
||||||
stw r0, 0x4(r1)
|
|
||||||
lis r4, 0x804F
|
|
||||||
stwu r1, -0x78(r1)
|
|
||||||
stmw r14, 0x30(r1)
|
|
||||||
addi r31, r3, 0
|
|
||||||
addi r15, r5, 0x72B0
|
|
||||||
addi r29, r4, 0x59A8
|
|
||||||
bl 0x1D518
|
|
||||||
lwz r4, 0x0(r31)
|
|
||||||
addi r28, r29, 0x114
|
|
||||||
lwz r0, 0x114(r29)
|
|
||||||
addi r14, r3, 0
|
|
||||||
rlwinm r4,r4,0,30,31
|
|
||||||
cmplw r0, r4
|
|
||||||
beq- .loc_0x50
|
|
||||||
li r0, 0x1
|
|
||||||
stw r0, -0x72E0(r13)
|
|
||||||
stw r4, 0x0(r28)
|
|
||||||
|
|
||||||
.loc_0x50:
|
|
||||||
lwz r0, 0x0(r31)
|
|
||||||
lis r3, 0x8000
|
|
||||||
lwz r16, 0xCC(r3)
|
|
||||||
rlwinm r0,r0,30,2,31
|
|
||||||
cmplwi r0, 0x4
|
|
||||||
mr r17, r0
|
|
||||||
bne- .loc_0xD4
|
|
||||||
lwz r0, -0x72AC(r13)
|
|
||||||
cmplwi r0, 0
|
|
||||||
bne- .loc_0xD4
|
|
||||||
li r0, 0x1
|
|
||||||
crclr 6, 0x6
|
|
||||||
stw r0, -0x72AC(r13)
|
|
||||||
addi r3, r15, 0x260
|
|
||||||
bl 0x1BF68
|
|
||||||
addi r3, r15, 0x28C
|
|
||||||
crclr 6, 0x6
|
|
||||||
bl 0x1BF5C
|
|
||||||
addi r3, r15, 0x2B8
|
|
||||||
crclr 6, 0x6
|
|
||||||
bl 0x1BF50
|
|
||||||
addi r3, r15, 0x2E4
|
|
||||||
crclr 6, 0x6
|
|
||||||
bl 0x1BF44
|
|
||||||
addi r3, r15, 0x310
|
|
||||||
crclr 6, 0x6
|
|
||||||
bl 0x1BF38
|
|
||||||
addi r3, r15, 0x33C
|
|
||||||
crclr 6, 0x6
|
|
||||||
bl 0x1BF2C
|
|
||||||
addi r3, r15, 0x260
|
|
||||||
crclr 6, 0x6
|
|
||||||
bl 0x1BF20
|
|
||||||
|
|
||||||
.loc_0xD4:
|
|
||||||
cmpwi r16, 0x2
|
|
||||||
beq- .loc_0x108
|
|
||||||
bge- .loc_0xF0
|
|
||||||
cmpwi r16, 0
|
|
||||||
beq- .loc_0x108
|
|
||||||
bge- .loc_0x124
|
|
||||||
b .loc_0x134
|
|
||||||
|
|
||||||
.loc_0xF0:
|
|
||||||
cmpwi r16, 0x6
|
|
||||||
beq- .loc_0x108
|
|
||||||
bge- .loc_0x134
|
|
||||||
cmpwi r16, 0x5
|
|
||||||
bge- .loc_0x124
|
|
||||||
b .loc_0x134
|
|
||||||
|
|
||||||
.loc_0x108:
|
|
||||||
cmplwi r17, 0
|
|
||||||
beq- .loc_0x150
|
|
||||||
cmplwi r17, 0x2
|
|
||||||
beq- .loc_0x150
|
|
||||||
cmplwi r17, 0x6
|
|
||||||
bne- .loc_0x134
|
|
||||||
b .loc_0x150
|
|
||||||
|
|
||||||
.loc_0x124:
|
|
||||||
cmplwi r17, 0x1
|
|
||||||
beq- .loc_0x150
|
|
||||||
cmplwi r17, 0x5
|
|
||||||
beq- .loc_0x150
|
|
||||||
|
|
||||||
.loc_0x134:
|
|
||||||
addi r6, r16, 0
|
|
||||||
crclr 6, 0x6
|
|
||||||
addi r7, r17, 0
|
|
||||||
addi r5, r15, 0x368
|
|
||||||
subi r3, r13, 0x7D94
|
|
||||||
li r4, 0x774
|
|
||||||
bl 0x1BF24
|
|
||||||
|
|
||||||
.loc_0x150:
|
|
||||||
cmplwi r17, 0
|
|
||||||
beq- .loc_0x160
|
|
||||||
cmplwi r17, 0x2
|
|
||||||
bne- .loc_0x168
|
|
||||||
|
|
||||||
.loc_0x160:
|
|
||||||
stw r16, 0x118(r29)
|
|
||||||
b .loc_0x16C
|
|
||||||
|
|
||||||
.loc_0x168:
|
|
||||||
stw r17, 0x118(r29)
|
|
||||||
|
|
||||||
.loc_0x16C:
|
|
||||||
lhz r0, 0xA(r31)
|
|
||||||
sth r0, 0xF0(r29)
|
|
||||||
lwz r0, 0x0(r28)
|
|
||||||
cmplwi r0, 0x1
|
|
||||||
bne- .loc_0x18C
|
|
||||||
lhz r0, 0xC(r31)
|
|
||||||
rlwinm r0,r0,1,16,30
|
|
||||||
b .loc_0x190
|
|
||||||
|
|
||||||
.loc_0x18C:
|
|
||||||
lhz r0, 0xC(r31)
|
|
||||||
|
|
||||||
.loc_0x190:
|
|
||||||
sth r0, 0xF2(r29)
|
|
||||||
addi r23, r29, 0xF2
|
|
||||||
addi r24, r29, 0xF4
|
|
||||||
lhz r0, 0xE(r31)
|
|
||||||
addi r27, r29, 0x102
|
|
||||||
addi r25, r29, 0x110
|
|
||||||
sth r0, 0xF4(r29)
|
|
||||||
li r0, 0
|
|
||||||
addi r16, r29, 0x10A
|
|
||||||
lhz r3, 0x4(r31)
|
|
||||||
addi r26, r29, 0x10C
|
|
||||||
addi r15, r29, 0x106
|
|
||||||
sth r3, 0x102(r29)
|
|
||||||
addi r17, r29, 0x108
|
|
||||||
lhz r3, 0x8(r31)
|
|
||||||
sth r3, 0x104(r29)
|
|
||||||
lwz r3, 0x14(r31)
|
|
||||||
stw r3, 0x110(r29)
|
|
||||||
lhz r3, 0x102(r29)
|
|
||||||
sth r3, 0x10A(r29)
|
|
||||||
lhz r3, 0x104(r29)
|
|
||||||
sth r3, 0x10C(r29)
|
|
||||||
sth r0, 0x106(r29)
|
|
||||||
sth r0, 0x108(r29)
|
|
||||||
lwz r0, 0x0(r28)
|
|
||||||
cmplwi r0, 0x2
|
|
||||||
bne- .loc_0x204
|
|
||||||
lhz r0, 0x0(r26)
|
|
||||||
b .loc_0x230
|
|
||||||
|
|
||||||
.loc_0x204:
|
|
||||||
cmplwi r0, 0x3
|
|
||||||
bne- .loc_0x214
|
|
||||||
lhz r0, 0x0(r26)
|
|
||||||
b .loc_0x230
|
|
||||||
|
|
||||||
.loc_0x214:
|
|
||||||
lwz r0, 0x0(r25)
|
|
||||||
cmpwi r0, 0
|
|
||||||
bne- .loc_0x22C
|
|
||||||
lhz r0, 0x0(r26)
|
|
||||||
rlwinm r0,r0,1,16,30
|
|
||||||
b .loc_0x230
|
|
||||||
|
|
||||||
.loc_0x22C:
|
|
||||||
lhz r0, 0x0(r26)
|
|
||||||
|
|
||||||
.loc_0x230:
|
|
||||||
addi r22, r29, 0xF6
|
|
||||||
sth r0, 0xF6(r29)
|
|
||||||
lwz r0, 0x0(r28)
|
|
||||||
cmplwi r0, 0x3
|
|
||||||
bne- .loc_0x24C
|
|
||||||
li r0, 0x1
|
|
||||||
b .loc_0x250
|
|
||||||
|
|
||||||
.loc_0x24C:
|
|
||||||
li r0, 0
|
|
||||||
|
|
||||||
.loc_0x250:
|
|
||||||
addi r18, r29, 0x134
|
|
||||||
stw r0, 0x134(r29)
|
|
||||||
addi r21, r29, 0x118
|
|
||||||
lwz r3, 0x118(r29)
|
|
||||||
lwz r0, 0x0(r28)
|
|
||||||
rlwinm r3,r3,2,0,29
|
|
||||||
add r3, r3, r0
|
|
||||||
bl -0xE84
|
|
||||||
mr r30, r3
|
|
||||||
stw r30, 0x144(r29)
|
|
||||||
lhz r0, 0x0(r24)
|
|
||||||
lha r4, 0xF0(r29)
|
|
||||||
lha r3, -0x72E4(r13)
|
|
||||||
subfic r5, r0, 0x2D0
|
|
||||||
lhz r0, 0x2(r30)
|
|
||||||
add r3, r4, r3
|
|
||||||
cmpw r3, r5
|
|
||||||
ble- .loc_0x29C
|
|
||||||
b .loc_0x2AC
|
|
||||||
|
|
||||||
.loc_0x29C:
|
|
||||||
cmpwi r3, 0
|
|
||||||
bge- .loc_0x2A8
|
|
||||||
li r3, 0
|
|
||||||
|
|
||||||
.loc_0x2A8:
|
|
||||||
mr r5, r3
|
|
||||||
|
|
||||||
.loc_0x2AC:
|
|
||||||
sth r5, 0xF8(r29)
|
|
||||||
addi r3, r29, 0xF8
|
|
||||||
lwz r4, 0x0(r25)
|
|
||||||
cmpwi r4, 0
|
|
||||||
bne- .loc_0x2C8
|
|
||||||
li r4, 0x2
|
|
||||||
b .loc_0x2CC
|
|
||||||
|
|
||||||
.loc_0x2C8:
|
|
||||||
li r4, 0x1
|
|
||||||
|
|
||||||
.loc_0x2CC:
|
|
||||||
lhz r5, 0x0(r23)
|
|
||||||
lha r6, -0x72E2(r13)
|
|
||||||
extsh r7, r5
|
|
||||||
rlwinm r5,r5,0,31,31
|
|
||||||
add r7, r7, r6
|
|
||||||
cmpw r7, r5
|
|
||||||
ble- .loc_0x2EC
|
|
||||||
b .loc_0x2F0
|
|
||||||
|
|
||||||
.loc_0x2EC:
|
|
||||||
mr r7, r5
|
|
||||||
|
|
||||||
.loc_0x2F0:
|
|
||||||
sth r7, 0xFA(r29)
|
|
||||||
extsh r0, r0
|
|
||||||
rlwinm r0,r0,1,0,30
|
|
||||||
lhz r8, 0x0(r22)
|
|
||||||
sub r0, r0, r5
|
|
||||||
lha r7, 0x0(r23)
|
|
||||||
addi r19, r29, 0xFA
|
|
||||||
extsh r9, r8
|
|
||||||
add r10, r9, r6
|
|
||||||
add r10, r7, r10
|
|
||||||
sub. r9, r10, r0
|
|
||||||
ble- .loc_0x328
|
|
||||||
sub r9, r10, r0
|
|
||||||
b .loc_0x32C
|
|
||||||
|
|
||||||
.loc_0x328:
|
|
||||||
li r9, 0
|
|
||||||
|
|
||||||
.loc_0x32C:
|
|
||||||
add r10, r7, r6
|
|
||||||
sub. r7, r10, r5
|
|
||||||
bge- .loc_0x340
|
|
||||||
sub r7, r10, r5
|
|
||||||
b .loc_0x344
|
|
||||||
|
|
||||||
.loc_0x340:
|
|
||||||
li r7, 0
|
|
||||||
|
|
||||||
.loc_0x344:
|
|
||||||
add r7, r8, r7
|
|
||||||
sub r7, r7, r9
|
|
||||||
addi r20, r29, 0xFC
|
|
||||||
sth r7, 0xFC(r29)
|
|
||||||
lha r7, 0x0(r23)
|
|
||||||
add r8, r7, r6
|
|
||||||
sub. r7, r8, r5
|
|
||||||
bge- .loc_0x36C
|
|
||||||
sub r7, r8, r5
|
|
||||||
b .loc_0x370
|
|
||||||
|
|
||||||
.loc_0x36C:
|
|
||||||
li r7, 0
|
|
||||||
|
|
||||||
.loc_0x370:
|
|
||||||
divw r8, r7, r4
|
|
||||||
lhz r7, 0x0(r17)
|
|
||||||
sub r7, r7, r8
|
|
||||||
sth r7, 0xFE(r29)
|
|
||||||
lha r7, 0x0(r22)
|
|
||||||
lha r9, 0x0(r23)
|
|
||||||
add r8, r7, r6
|
|
||||||
add r8, r9, r8
|
|
||||||
sub. r7, r8, r0
|
|
||||||
ble- .loc_0x3A0
|
|
||||||
sub r7, r8, r0
|
|
||||||
b .loc_0x3A4
|
|
||||||
|
|
||||||
.loc_0x3A0:
|
|
||||||
li r7, 0
|
|
||||||
|
|
||||||
.loc_0x3A4:
|
|
||||||
add r6, r9, r6
|
|
||||||
sub. r0, r6, r5
|
|
||||||
bge- .loc_0x3B8
|
|
||||||
sub r0, r6, r5
|
|
||||||
b .loc_0x3BC
|
|
||||||
|
|
||||||
.loc_0x3B8:
|
|
||||||
li r0, 0
|
|
||||||
|
|
||||||
.loc_0x3BC:
|
|
||||||
divw r0, r0, r4
|
|
||||||
lhz r5, 0x0(r26)
|
|
||||||
divw r4, r7, r4
|
|
||||||
add r0, r5, r0
|
|
||||||
sub r0, r0, r4
|
|
||||||
sth r0, 0x100(r29)
|
|
||||||
lwz r0, -0x72E8(r13)
|
|
||||||
cmplwi r0, 0
|
|
||||||
bne- .loc_0x3E8
|
|
||||||
li r0, 0x3
|
|
||||||
stw r0, 0x0(r21)
|
|
||||||
|
|
||||||
.loc_0x3E8:
|
|
||||||
lhz r5, 0x18(r30)
|
|
||||||
srawi r4, r5, 0x1
|
|
||||||
addze r4, r4
|
|
||||||
srawi r0, r5, 0x1
|
|
||||||
addze r0, r0
|
|
||||||
rlwinm r0,r0,1,0,30
|
|
||||||
subc r0, r5, r0
|
|
||||||
rlwinm. r0,r0,0,16,31
|
|
||||||
rlwinm r4,r4,0,16,31
|
|
||||||
beq- .loc_0x418
|
|
||||||
lhz r5, 0x1A(r30)
|
|
||||||
b .loc_0x41C
|
|
||||||
|
|
||||||
.loc_0x418:
|
|
||||||
li r5, 0
|
|
||||||
|
|
||||||
.loc_0x41C:
|
|
||||||
addi r0, r5, 0x1
|
|
||||||
sth r0, 0x32(r29)
|
|
||||||
addi r0, r4, 0x1
|
|
||||||
ori r0, r0, 0x1000
|
|
||||||
lwz r5, -0x72D8(r13)
|
|
||||||
addi r4, r29, 0x2
|
|
||||||
lwz r6, -0x72D4(r13)
|
|
||||||
ori r5, r5, 0x40
|
|
||||||
stw r6, -0x72D4(r13)
|
|
||||||
stw r5, -0x72D8(r13)
|
|
||||||
sth r0, 0x30(r29)
|
|
||||||
lwz r0, -0x72D8(r13)
|
|
||||||
lwz r5, -0x72D4(r13)
|
|
||||||
ori r0, r0, 0x80
|
|
||||||
stw r5, -0x72D4(r13)
|
|
||||||
stw r0, -0x72D8(r13)
|
|
||||||
lwz r0, 0x0(r28)
|
|
||||||
lhz r5, 0x2(r29)
|
|
||||||
cmplwi r0, 0x2
|
|
||||||
beq- .loc_0x474
|
|
||||||
cmplwi r0, 0x3
|
|
||||||
bne- .loc_0x480
|
|
||||||
|
|
||||||
.loc_0x474:
|
|
||||||
rlwinm r0,r5,0,30,28
|
|
||||||
ori r5, r0, 0x4
|
|
||||||
b .loc_0x488
|
|
||||||
|
|
||||||
.loc_0x480:
|
|
||||||
rlwinm r5,r5,0,30,28
|
|
||||||
rlwimi r5,r0,2,29,29
|
|
||||||
|
|
||||||
.loc_0x488:
|
|
||||||
lwz r6, 0x0(r21)
|
|
||||||
rlwinm r5,r5,0,29,27
|
|
||||||
lwz r7, 0x0(r18)
|
|
||||||
cmplwi r6, 0x4
|
|
||||||
rlwinm r0,r7,3,0,28
|
|
||||||
or r5, r5, r0
|
|
||||||
beq- .loc_0x4B0
|
|
||||||
subi r0, r6, 0x5
|
|
||||||
cmplwi r0, 0x1
|
|
||||||
bgt- .loc_0x4B8
|
|
||||||
|
|
||||||
.loc_0x4B0:
|
|
||||||
rlwinm r0,r5,0,24,21
|
|
||||||
b .loc_0x4C4
|
|
||||||
|
|
||||||
.loc_0x4B8:
|
|
||||||
rlwinm r5,r5,0,24,21
|
|
||||||
rlwinm r0,r6,8,0,23
|
|
||||||
or r0, r5, r0
|
|
||||||
|
|
||||||
.loc_0x4C4:
|
|
||||||
sth r0, 0x0(r4)
|
|
||||||
lis r0, 0x4000
|
|
||||||
addi r6, r29, 0x6C
|
|
||||||
lwz r4, -0x72D8(r13)
|
|
||||||
lwz r5, -0x72D4(r13)
|
|
||||||
or r0, r4, r0
|
|
||||||
stw r5, -0x72D4(r13)
|
|
||||||
stw r0, -0x72D8(r13)
|
|
||||||
lwz r0, 0x0(r31)
|
|
||||||
lhz r4, 0x6C(r29)
|
|
||||||
cmpwi r0, 0x2
|
|
||||||
beq- .loc_0x504
|
|
||||||
cmpwi r0, 0x3
|
|
||||||
beq- .loc_0x504
|
|
||||||
cmpwi r0, 0x1A
|
|
||||||
bne- .loc_0x510
|
|
||||||
|
|
||||||
.loc_0x504:
|
|
||||||
rlwinm r0,r4,0,0,30
|
|
||||||
ori r0, r0, 0x1
|
|
||||||
b .loc_0x514
|
|
||||||
|
|
||||||
.loc_0x510:
|
|
||||||
rlwinm r0,r4,0,0,30
|
|
||||||
|
|
||||||
.loc_0x514:
|
|
||||||
sth r0, 0x0(r6)
|
|
||||||
cmpwi r7, 0
|
|
||||||
lwz r4, -0x72D8(r13)
|
|
||||||
lwz r0, -0x72D4(r13)
|
|
||||||
ori r0, r0, 0x200
|
|
||||||
stw r0, -0x72D4(r13)
|
|
||||||
stw r4, -0x72D8(r13)
|
|
||||||
lhz r4, 0x0(r24)
|
|
||||||
lhz r5, 0x0(r16)
|
|
||||||
beq- .loc_0x544
|
|
||||||
rlwinm r0,r5,1,0,30
|
|
||||||
b .loc_0x548
|
|
||||||
|
|
||||||
.loc_0x544:
|
|
||||||
mr r0, r5
|
|
||||||
|
|
||||||
.loc_0x548:
|
|
||||||
rlwinm r8,r0,0,16,31
|
|
||||||
cmplw r8, r4
|
|
||||||
bge- .loc_0x5A0
|
|
||||||
rlwinm r6,r8,8,0,23
|
|
||||||
subi r0, r6, 0x1
|
|
||||||
add r0, r4, r0
|
|
||||||
divwu r0, r0, r4
|
|
||||||
ori r0, r0, 0x1000
|
|
||||||
sth r0, 0x4A(r29)
|
|
||||||
lis r0, 0x400
|
|
||||||
lwz r6, -0x72D8(r13)
|
|
||||||
lwz r7, -0x72D4(r13)
|
|
||||||
or r0, r7, r0
|
|
||||||
stw r0, -0x72D4(r13)
|
|
||||||
stw r6, -0x72D8(r13)
|
|
||||||
sth r8, 0x70(r29)
|
|
||||||
lwz r6, -0x72D8(r13)
|
|
||||||
lwz r0, -0x72D4(r13)
|
|
||||||
ori r0, r0, 0x80
|
|
||||||
stw r0, -0x72D4(r13)
|
|
||||||
stw r6, -0x72D8(r13)
|
|
||||||
b .loc_0x5C0
|
|
||||||
|
|
||||||
.loc_0x5A0:
|
|
||||||
li r0, 0x100
|
|
||||||
sth r0, 0x4A(r29)
|
|
||||||
lis r0, 0x400
|
|
||||||
lwz r6, -0x72D8(r13)
|
|
||||||
lwz r7, -0x72D4(r13)
|
|
||||||
or r0, r7, r0
|
|
||||||
stw r0, -0x72D4(r13)
|
|
||||||
stw r6, -0x72D8(r13)
|
|
||||||
|
|
||||||
.loc_0x5C0:
|
|
||||||
lhz r0, 0x0(r3)
|
|
||||||
subfic r12, r4, 0x2D0
|
|
||||||
lhz r6, 0x1A(r30)
|
|
||||||
lis r3, 0x1000
|
|
||||||
lis r8, 0x2000
|
|
||||||
sth r6, 0x6(r29)
|
|
||||||
lis r9, 0x400
|
|
||||||
lis r7, 0x800
|
|
||||||
lwz r10, -0x72D8(r13)
|
|
||||||
lis r6, 0x10
|
|
||||||
lis r4, 0x20
|
|
||||||
lwz r11, -0x72D4(r13)
|
|
||||||
or r10, r10, r3
|
|
||||||
lis r3, 0x4
|
|
||||||
stw r11, -0x72D4(r13)
|
|
||||||
stw r10, -0x72D8(r13)
|
|
||||||
lbz r10, 0x1D(r30)
|
|
||||||
lbz r11, 0x1E(r30)
|
|
||||||
rlwimi r11,r10,8,16,23
|
|
||||||
sth r11, 0x4(r29)
|
|
||||||
lwz r10, -0x72D8(r13)
|
|
||||||
lwz r11, -0x72D4(r13)
|
|
||||||
or r8, r10, r8
|
|
||||||
stw r11, -0x72D4(r13)
|
|
||||||
stw r8, -0x72D8(r13)
|
|
||||||
lbz r8, 0x1F(r30)
|
|
||||||
lbz r10, 0x1C(r30)
|
|
||||||
add r16, r8, r0
|
|
||||||
lhz r11, 0x20(r30)
|
|
||||||
subi r16, r16, 0x28
|
|
||||||
rlwinm r8,r16,7,16,24
|
|
||||||
or r8, r10, r8
|
|
||||||
sth r8, 0xA(r29)
|
|
||||||
add r8, r11, r0
|
|
||||||
addi r0, r8, 0x28
|
|
||||||
lwz r10, -0x72D8(r13)
|
|
||||||
sub r0, r0, r12
|
|
||||||
rlwinm r8,r16,23,9,31
|
|
||||||
lwz r11, -0x72D4(r13)
|
|
||||||
rlwinm r0,r0,1,0,30
|
|
||||||
or r9, r10, r9
|
|
||||||
stw r11, -0x72D4(r13)
|
|
||||||
or r0, r8, r0
|
|
||||||
stw r9, -0x72D8(r13)
|
|
||||||
sth r0, 0x8(r29)
|
|
||||||
lwz r0, -0x72D8(r13)
|
|
||||||
lwz r8, -0x72D4(r13)
|
|
||||||
or r0, r0, r7
|
|
||||||
stw r8, -0x72D4(r13)
|
|
||||||
stw r0, -0x72D8(r13)
|
|
||||||
lhz r0, 0x10(r30)
|
|
||||||
lbz r7, 0xC(r30)
|
|
||||||
rlwinm r0,r0,5,0,26
|
|
||||||
or r0, r7, r0
|
|
||||||
sth r0, 0x16(r29)
|
|
||||||
lwz r0, -0x72D8(r13)
|
|
||||||
lwz r7, -0x72D4(r13)
|
|
||||||
or r0, r0, r6
|
|
||||||
stw r7, -0x72D4(r13)
|
|
||||||
stw r0, -0x72D8(r13)
|
|
||||||
lhz r0, 0x14(r30)
|
|
||||||
lbz r6, 0xE(r30)
|
|
||||||
rlwinm r0,r0,5,0,26
|
|
||||||
or r0, r6, r0
|
|
||||||
sth r0, 0x14(r29)
|
|
||||||
lwz r0, -0x72D8(r13)
|
|
||||||
lwz r6, -0x72D4(r13)
|
|
||||||
or r0, r0, r4
|
|
||||||
stw r6, -0x72D4(r13)
|
|
||||||
stw r0, -0x72D8(r13)
|
|
||||||
lhz r0, 0x12(r30)
|
|
||||||
lbz r4, 0xD(r30)
|
|
||||||
rlwinm r0,r0,5,0,26
|
|
||||||
or r0, r4, r0
|
|
||||||
sth r0, 0x1A(r29)
|
|
||||||
lwz r0, -0x72D8(r13)
|
|
||||||
lwz r4, -0x72D4(r13)
|
|
||||||
or r0, r0, r3
|
|
||||||
stw r4, -0x72D4(r13)
|
|
||||||
stw r0, -0x72D8(r13)
|
|
||||||
lhz r0, 0x16(r30)
|
|
||||||
lbz r3, 0xF(r30)
|
|
||||||
rlwinm r0,r0,5,0,26
|
|
||||||
or r0, r3, r0
|
|
||||||
sth r0, 0x18(r29)
|
|
||||||
lwz r3, -0x72D8(r13)
|
|
||||||
lis r0, 0x8
|
|
||||||
addi r6, r29, 0x11C
|
|
||||||
lwz r4, -0x72D4(r13)
|
|
||||||
or r0, r3, r0
|
|
||||||
stw r4, -0x72D4(r13)
|
|
||||||
stw r0, -0x72D8(r13)
|
|
||||||
lhz r3, 0x0(r27)
|
|
||||||
lwz r4, 0x0(r25)
|
|
||||||
addi r0, r3, 0xF
|
|
||||||
lhz r3, 0x0(r15)
|
|
||||||
srawi r0, r0, 0x4
|
|
||||||
addze r0, r0
|
|
||||||
cmpwi r4, 0
|
|
||||||
stb r0, 0x11C(r29)
|
|
||||||
bne- .loc_0x75C
|
|
||||||
lbz r4, 0x0(r6)
|
|
||||||
b .loc_0x764
|
|
||||||
|
|
||||||
.loc_0x75C:
|
|
||||||
lbz r0, 0x0(r6)
|
|
||||||
rlwinm r4,r0,1,24,30
|
|
||||||
|
|
||||||
.loc_0x764:
|
|
||||||
srawi r0, r3, 0x4
|
|
||||||
stb r4, 0x11D(r29)
|
|
||||||
addze r0, r0
|
|
||||||
rlwinm r0,r0,4,0,27
|
|
||||||
subc r0, r3, r0
|
|
||||||
stb r0, 0x12C(r29)
|
|
||||||
addi r0, r5, 0xF
|
|
||||||
lis r3, 0x800
|
|
||||||
lbz r4, 0x12C(r29)
|
|
||||||
add r0, r4, r0
|
|
||||||
srawi r0, r0, 0x4
|
|
||||||
addze r0, r0
|
|
||||||
stb r0, 0x11E(r29)
|
|
||||||
lbz r0, 0x11E(r29)
|
|
||||||
lbz r4, 0x11D(r29)
|
|
||||||
rlwimi r4,r0,8,16,23
|
|
||||||
sth r4, 0x48(r29)
|
|
||||||
lwz r4, -0x72D8(r13)
|
|
||||||
lwz r0, -0x72B0(r13)
|
|
||||||
lwz r5, -0x72D4(r13)
|
|
||||||
cmplwi r0, 0
|
|
||||||
or r0, r5, r3
|
|
||||||
stw r0, -0x72D4(r13)
|
|
||||||
stw r4, -0x72D8(r13)
|
|
||||||
beq- .loc_0x7E0
|
|
||||||
addi r3, r29, 0xF0
|
|
||||||
addi r4, r29, 0x124
|
|
||||||
addi r5, r29, 0x128
|
|
||||||
addi r6, r29, 0x13C
|
|
||||||
addi r7, r29, 0x140
|
|
||||||
bl -0xC50
|
|
||||||
|
|
||||||
.loc_0x7E0:
|
|
||||||
lwz r0, 0x130(r29)
|
|
||||||
stw r0, 0x8(r1)
|
|
||||||
lhz r3, 0x0(r19)
|
|
||||||
lhz r4, 0x0(r20)
|
|
||||||
lbz r5, 0x0(r30)
|
|
||||||
lhz r6, 0x2(r30)
|
|
||||||
lhz r7, 0x4(r30)
|
|
||||||
lhz r8, 0x6(r30)
|
|
||||||
lhz r9, 0x8(r30)
|
|
||||||
lhz r10, 0xA(r30)
|
|
||||||
bl -0x9A8
|
|
||||||
mr r3, r14
|
|
||||||
bl 0x1CD54
|
|
||||||
lmw r14, 0x30(r1)
|
|
||||||
lwz r0, 0x7C(r1)
|
|
||||||
addi r1, r1, 0x78
|
|
||||||
mtlr r0
|
|
||||||
blr
|
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
void VIConfigurePan(u16 xOrg, u16 yOrg, u16 width, u16 height)
|
||||||
* --INFO--
|
{
|
||||||
* Address: ........
|
BOOL enabled;
|
||||||
* Size: 000394
|
VITimingInfo *tm;
|
||||||
*/
|
|
||||||
void VIConfigurePan(u16 panPosX, u16 panPosY, u16 panSizeX, u16 panSizeY) {
|
// #if DEBUG
|
||||||
// UNUSED FUNCTION
|
// ASSERTMSGLINEV(0x69C, (xOrg & 1) == 0,
|
||||||
|
// "VIConfigurePan(): Odd number(%d) is specified to xOrg\n",
|
||||||
|
// xOrg);
|
||||||
|
// if (HorVer.FBMode == VI_XFBMODE_DF) {
|
||||||
|
// ASSERTMSGLINEV(0x6A1, (height & 1) == 0,
|
||||||
|
// "VIConfigurePan(): Odd number(%d) is specified to height when DF XFB mode\n",
|
||||||
|
// height);
|
||||||
|
// }
|
||||||
|
// #endif
|
||||||
|
enabled = OSDisableInterrupts();
|
||||||
|
HorVer.panPosX = xOrg;
|
||||||
|
HorVer.panPosY = yOrg;
|
||||||
|
HorVer.panSizeX = width;
|
||||||
|
HorVer.panSizeY = height;
|
||||||
|
HorVer.dispSizeY = (HorVer.nonInter == 2) ? HorVer.panSizeY
|
||||||
|
: (HorVer.nonInter == 3) ? HorVer.panSizeY : (HorVer.xfbMode == VI_XFBMODE_SF) ? (u16)(HorVer.panSizeY * 2)
|
||||||
|
: HorVer.panSizeY;
|
||||||
|
tm = HorVer.timing;
|
||||||
|
AdjustPosition(tm->acv);
|
||||||
|
setScalingRegs(HorVer.panSizeX, HorVer.dispSizeX, HorVer.is3D);
|
||||||
|
setPicConfig(HorVer.fbSizeX, HorVer.xfbMode, HorVer.panPosX, HorVer.panSizeX, &HorVer.wordPerLine, &HorVer.std, &HorVer.wpl, &HorVer.xof);
|
||||||
|
if (FBSet != 0) {
|
||||||
|
setFbbRegs(&HorVer, &HorVer.tfbb, &HorVer.bfbb, &HorVer.rtfbb, &HorVer.rbfbb);
|
||||||
|
}
|
||||||
|
setVerticalRegs(HorVer.adjDispPosY, HorVer.dispSizeY, tm->equ, tm->acv, tm->prbOdd, tm->prbEven, tm->psbOdd, tm->psbEven, HorVer.isBlack);
|
||||||
|
OSRestoreInterrupts(enabled);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* --INFO--
|
|
||||||
* Address: 800D1F24
|
|
||||||
* Size: 000130
|
|
||||||
*/
|
|
||||||
void VIFlush(void) {
|
void VIFlush(void) {
|
||||||
BOOL enabled;
|
BOOL enabled;
|
||||||
s32 regIndex;
|
s32 regIndex;
|
||||||
|
@ -1565,11 +942,6 @@ void VIFlush(void) {
|
||||||
OSRestoreInterrupts(enabled);
|
OSRestoreInterrupts(enabled);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* --INFO--
|
|
||||||
* Address: 800D2054
|
|
||||||
* Size: 00006C
|
|
||||||
*/
|
|
||||||
void VISetNextFrameBuffer(void* fb) {
|
void VISetNextFrameBuffer(void* fb) {
|
||||||
BOOL enabled = OSDisableInterrupts();
|
BOOL enabled = OSDisableInterrupts();
|
||||||
HorVer.bufAddr = (u32)fb;
|
HorVer.bufAddr = (u32)fb;
|
||||||
|
@ -1578,36 +950,16 @@ void VISetNextFrameBuffer(void* fb) {
|
||||||
OSRestoreInterrupts(enabled);
|
OSRestoreInterrupts(enabled);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* --INFO--
|
|
||||||
* Address: ........
|
|
||||||
* Size: 000008
|
|
||||||
*/
|
|
||||||
void* VIGetNextFrameBuffer() {
|
void* VIGetNextFrameBuffer() {
|
||||||
// UNUSED FUNCTION
|
// UNUSED FUNCTION
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* --INFO--
|
|
||||||
* Address: 800D20C0
|
|
||||||
* Size: 000008
|
|
||||||
*/
|
|
||||||
void* VIGetCurrentFrameBuffer(void) { return (void*)CurrBufAddr; }
|
void* VIGetCurrentFrameBuffer(void) { return (void*)CurrBufAddr; }
|
||||||
|
|
||||||
/*
|
|
||||||
* --INFO--
|
|
||||||
* Address: ........
|
|
||||||
* Size: 00006C
|
|
||||||
*/
|
|
||||||
void VISetNextRightFrameBuffer(void* fb) {
|
void VISetNextRightFrameBuffer(void* fb) {
|
||||||
// UNUSED FUNCTION
|
// UNUSED FUNCTION
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* --INFO--
|
|
||||||
* Address: 800D20C8
|
|
||||||
* Size: 00007C
|
|
||||||
*/
|
|
||||||
void VISetBlack(BOOL isBlack) {
|
void VISetBlack(BOOL isBlack) {
|
||||||
int interrupt;
|
int interrupt;
|
||||||
VITimingInfo* tm;
|
VITimingInfo* tm;
|
||||||
|
@ -1620,67 +972,31 @@ void VISetBlack(BOOL isBlack) {
|
||||||
OSRestoreInterrupts(interrupt);
|
OSRestoreInterrupts(interrupt);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* --INFO--
|
|
||||||
* Address: ........
|
|
||||||
* Size: 000100
|
|
||||||
*/
|
|
||||||
void VISet3D(void) {
|
void VISet3D(void) {
|
||||||
// UNUSED FUNCTION
|
// UNUSED FUNCTION
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* --INFO--
|
|
||||||
* Address: 800D2144
|
|
||||||
* Size: 000008
|
|
||||||
*/
|
|
||||||
u32 VIGetRetraceCount(void) { return retraceCount; }
|
u32 VIGetRetraceCount(void) { return retraceCount; }
|
||||||
|
|
||||||
/*
|
static u32 getCurrentHalfLine(void)
|
||||||
* --INFO--
|
{
|
||||||
* Address: 800D214C
|
u32 hcount;
|
||||||
* Size: 00003C
|
u32 vcount0;
|
||||||
*/
|
u32 vcount;
|
||||||
static void GetCurrentDisplayPosition(u32* hct, u32* vct) {
|
|
||||||
u32 hcount, vcount0, vcount;
|
|
||||||
vcount = __VIRegs[VI_VERT_COUNT] & 0x7FF;
|
|
||||||
|
|
||||||
|
vcount = __VIRegs[22] & 0x7FF;
|
||||||
do {
|
do {
|
||||||
vcount0 = vcount;
|
vcount0 = vcount;
|
||||||
hcount = __VIRegs[VI_HORIZ_COUNT] & 0x7FF;
|
hcount = __VIRegs[23] & 0x7FF;
|
||||||
vcount = __VIRegs[VI_VERT_COUNT] & 0x7FF;
|
vcount = __VIRegs[22] & 0x7FF;
|
||||||
} while (vcount0 != vcount);
|
} while (vcount0 != vcount);
|
||||||
|
return ((vcount - 1) * 2) + ((hcount - 1) / CurrTiming->hlw);
|
||||||
*hct = hcount;
|
|
||||||
*vct = vcount;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* --INFO--
|
|
||||||
* Address: ........
|
|
||||||
* Size: 000050
|
|
||||||
*/
|
|
||||||
static u32 getCurrentHalfLine(void) {
|
|
||||||
u32 hcount, vcount;
|
|
||||||
GetCurrentDisplayPosition(&hcount, &vcount);
|
|
||||||
|
|
||||||
return ((vcount - 1) << 1) + ((hcount - 1) / CurrTiming->hlw);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* --INFO--
|
|
||||||
* Address: 800D2188
|
|
||||||
* Size: 000068
|
|
||||||
*/
|
|
||||||
static u32 getCurrentFieldEvenOdd() {
|
static u32 getCurrentFieldEvenOdd() {
|
||||||
return (getCurrentHalfLine() < CurrTiming->numHalfLines) ? 1 : 0;
|
return (getCurrentHalfLine() < CurrTiming->numHalfLines) ? 1 : 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* --INFO--
|
|
||||||
* Address: 800D21F0
|
|
||||||
* Size: 00009C
|
|
||||||
*/
|
|
||||||
u32 VIGetNextField(void) {
|
u32 VIGetNextField(void) {
|
||||||
u32 nextField;
|
u32 nextField;
|
||||||
int interrupt;
|
int interrupt;
|
||||||
|
@ -1691,11 +1007,6 @@ u32 VIGetNextField(void) {
|
||||||
return nextField ^ (HorVer.adjDispPosY & 1);
|
return nextField ^ (HorVer.adjDispPosY & 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* --INFO--
|
|
||||||
* Address: 800D228C
|
|
||||||
* Size: 000098
|
|
||||||
*/
|
|
||||||
u32 VIGetCurrentLine(void) {
|
u32 VIGetCurrentLine(void) {
|
||||||
u32 line;
|
u32 line;
|
||||||
VITimingInfo* tm;
|
VITimingInfo* tm;
|
||||||
|
@ -1713,11 +1024,6 @@ u32 VIGetCurrentLine(void) {
|
||||||
return (line >> 1);
|
return (line >> 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* --INFO--
|
|
||||||
* Address: 800D2324
|
|
||||||
* Size: 000068
|
|
||||||
*/
|
|
||||||
u32 VIGetTvFormat(void) {
|
u32 VIGetTvFormat(void) {
|
||||||
u32 fmt;
|
u32 fmt;
|
||||||
int interrupt;
|
int interrupt;
|
||||||
|
@ -1744,11 +1050,6 @@ u32 VIGetTvFormat(void) {
|
||||||
return fmt;
|
return fmt;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* --INFO--
|
|
||||||
* Address: 800D238C
|
|
||||||
* Size: 00003C
|
|
||||||
*/
|
|
||||||
u32 VIGetDTVStatus(void) {
|
u32 VIGetDTVStatus(void) {
|
||||||
u32 stat;
|
u32 stat;
|
||||||
int interrupt;
|
int interrupt;
|
||||||
|
@ -1758,78 +1059,3 @@ u32 VIGetDTVStatus(void) {
|
||||||
OSRestoreInterrupts(interrupt);
|
OSRestoreInterrupts(interrupt);
|
||||||
return (stat & 1);
|
return (stat & 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* --INFO--
|
|
||||||
* Address: 800D23C8
|
|
||||||
* Size: 00021C
|
|
||||||
*/
|
|
||||||
void __VIDisplayPositionToXY(u32 hcount, u32 vcount, s16* x, s16* y) {
|
|
||||||
u32 halfLine = ((vcount - 1) << 1) + ((hcount - 1) / CurrTiming->hlw);
|
|
||||||
|
|
||||||
if (HorVer.nonInter == VI_INTERLACE) {
|
|
||||||
if (halfLine < CurrTiming->numHalfLines) {
|
|
||||||
if (halfLine < CurrTiming->equ * 3 + CurrTiming->prbOdd) {
|
|
||||||
*y = -1;
|
|
||||||
} else if (halfLine >= CurrTiming->numHalfLines - CurrTiming->psbOdd) {
|
|
||||||
*y = -1;
|
|
||||||
} else {
|
|
||||||
*y = (s16)((halfLine - CurrTiming->equ * 3 - CurrTiming->prbOdd) & ~1);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
halfLine -= CurrTiming->numHalfLines;
|
|
||||||
|
|
||||||
if (halfLine < CurrTiming->equ * 3 + CurrTiming->prbEven) {
|
|
||||||
*y = -1;
|
|
||||||
} else if (halfLine >= CurrTiming->numHalfLines - CurrTiming->psbEven) {
|
|
||||||
*y = -1;
|
|
||||||
} else {
|
|
||||||
*y = (s16)(((halfLine - CurrTiming->equ * 3 - CurrTiming->prbEven) & ~1) + 1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else if (HorVer.nonInter == VI_NON_INTERLACE) {
|
|
||||||
if (halfLine >= CurrTiming->numHalfLines) {
|
|
||||||
halfLine -= CurrTiming->numHalfLines;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (halfLine < CurrTiming->equ * 3 + CurrTiming->prbOdd) {
|
|
||||||
*y = -1;
|
|
||||||
} else if (halfLine >= CurrTiming->numHalfLines - CurrTiming->psbOdd) {
|
|
||||||
*y = -1;
|
|
||||||
} else {
|
|
||||||
*y = (s16)((halfLine - CurrTiming->equ * 3 - CurrTiming->prbOdd) & ~1);
|
|
||||||
}
|
|
||||||
} else if (HorVer.nonInter == VI_PROGRESSIVE) {
|
|
||||||
if (halfLine < CurrTiming->numHalfLines) {
|
|
||||||
if (halfLine < CurrTiming->equ * 3 + CurrTiming->prbOdd) {
|
|
||||||
*y = -1;
|
|
||||||
} else if (halfLine >= CurrTiming->numHalfLines - CurrTiming->psbOdd) {
|
|
||||||
*y = -1;
|
|
||||||
} else {
|
|
||||||
*y = (s16)(halfLine - CurrTiming->equ * 3 - CurrTiming->prbOdd);
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
halfLine -= CurrTiming->numHalfLines;
|
|
||||||
|
|
||||||
if (halfLine < CurrTiming->equ * 3 + CurrTiming->prbEven) {
|
|
||||||
*y = -1;
|
|
||||||
} else if (halfLine >= CurrTiming->numHalfLines - CurrTiming->psbEven) {
|
|
||||||
*y = -1;
|
|
||||||
} else
|
|
||||||
*y = (s16)((halfLine - CurrTiming->equ * 3 - CurrTiming->prbEven) & ~1);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
*x = (s16)(hcount - 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* --INFO--
|
|
||||||
* Address: 800D25E4
|
|
||||||
* Size: 000060
|
|
||||||
*/
|
|
||||||
void __VIGetCurrentPosition(s16* x, s16* y) {
|
|
||||||
u32 h, v;
|
|
||||||
GetCurrentDisplayPosition(&h, &v);
|
|
||||||
__VIDisplayPositionToXY(h, v, x, y);
|
|
||||||
}
|
|
||||||
|
|
|
@ -234,12 +234,12 @@ void CPhysicsActor::UseCollisionImpulses() {
|
||||||
}
|
}
|
||||||
|
|
||||||
void CPhysicsActor::MoveToWR(const CVector3f& trans, float d) {
|
void CPhysicsActor::MoveToWR(const CVector3f& trans, float d) {
|
||||||
xfc_constantForce = (trans - GetTransform().GetTranslation()) * GetMass() / d;
|
xfc_constantForce = (trans - GetTranslation()) * GetMass() * (1.f / d);
|
||||||
ComputeDerivedQuantities();
|
ComputeDerivedQuantities();
|
||||||
}
|
}
|
||||||
|
|
||||||
void CPhysicsActor::MoveToInOneFrameWR(const CVector3f& trans, float d) {
|
void CPhysicsActor::MoveToInOneFrameWR(const CVector3f& trans, float d) {
|
||||||
x18c_moveImpulse += (trans - GetTranslation()) * GetMass() / d;
|
x18c_moveImpulse += (trans - GetTranslation()) * GetMass() * (1.f / d);
|
||||||
}
|
}
|
||||||
|
|
||||||
CVector3f CPhysicsActor::GetMoveToORImpulseWR(const CVector3f& trans, float d) const {
|
CVector3f CPhysicsActor::GetMoveToORImpulseWR(const CVector3f& trans, float d) const {
|
||||||
|
|
Loading…
Reference in New Issue