mirror of https://github.com/PCSX2/pcsx2.git
microVU: Setting VU clamp mode to "normal" should fix sps/problems in alot of games now.
I'll list what I think should be fixed: Dawn of Mana SPS <- Should be fixed, untested ToTa Characters <- Should be fixed, untested FFXII SPS in Barheim Passage <- Should be fixed, untested KH1 floor bug <- Fixed for me, but theres still other sps on characters caused by something else Most-likely SPS in some other games is fixed as well... If anyone can confirm the games I listed are fixed, please leave a comment :D git-svn-id: http://pcsx2.googlecode.com/svn/trunk@1568 96395faa-99c1-11dd-bbfe-3dabce05a288
This commit is contained in:
parent
829efedfb5
commit
aedf28726c
|
@ -68,7 +68,7 @@ mVUop(mVU_DIV) {
|
||||||
x86SetJ8(cjmp);
|
x86SetJ8(cjmp);
|
||||||
MOV32ItoM((uptr)&mVU->divFlag, 0); // Clear I/D flags
|
MOV32ItoM((uptr)&mVU->divFlag, 0); // Clear I/D flags
|
||||||
SSE_DIVSS_XMM_to_XMM(xmmFs, xmmFt);
|
SSE_DIVSS_XMM_to_XMM(xmmFs, xmmFt);
|
||||||
if (CHECK_VU_OVERFLOW) mVUclamp1(xmmFs, xmmFt, 8);
|
mVUclamp1(xmmFs, xmmFt, 8);
|
||||||
x86SetJ8(djmp);
|
x86SetJ8(djmp);
|
||||||
|
|
||||||
if (mVUinfo.writeQ) SSE2_PSHUFD_XMM_to_XMM(xmmPQ, xmmPQ, 0xe1);
|
if (mVUinfo.writeQ) SSE2_PSHUFD_XMM_to_XMM(xmmPQ, xmmPQ, 0xe1);
|
||||||
|
@ -124,7 +124,7 @@ mVUop(mVU_RSQRT) {
|
||||||
djmp = JMP8(0);
|
djmp = JMP8(0);
|
||||||
x86SetJ8(ajmp);
|
x86SetJ8(ajmp);
|
||||||
SSE_DIVSS_XMM_to_XMM(xmmFs, xmmFt);
|
SSE_DIVSS_XMM_to_XMM(xmmFs, xmmFt);
|
||||||
if (CHECK_VU_OVERFLOW) mVUclamp1(xmmFs, xmmFt, 8);
|
mVUclamp1(xmmFs, xmmFt, 8);
|
||||||
x86SetJ8(djmp);
|
x86SetJ8(djmp);
|
||||||
|
|
||||||
if (mVUinfo.writeQ) SSE2_PSHUFD_XMM_to_XMM(xmmPQ, xmmPQ, 0xe1);
|
if (mVUinfo.writeQ) SSE2_PSHUFD_XMM_to_XMM(xmmPQ, xmmPQ, 0xe1);
|
||||||
|
|
|
@ -24,15 +24,17 @@
|
||||||
|
|
||||||
// Used for Result Clamping
|
// Used for Result Clamping
|
||||||
void mVUclamp1(int reg, int regT1, int xyzw) {
|
void mVUclamp1(int reg, int regT1, int xyzw) {
|
||||||
switch (xyzw) {
|
if (CHECK_VU_OVERFLOW) {
|
||||||
case 1: case 2: case 4: case 8:
|
switch (xyzw) {
|
||||||
SSE_MINSS_M32_to_XMM(reg, (uptr)mVU_maxvals);
|
case 1: case 2: case 4: case 8:
|
||||||
SSE_MAXSS_M32_to_XMM(reg, (uptr)mVU_minvals);
|
SSE_MINSS_M32_to_XMM(reg, (uptr)mVU_maxvals);
|
||||||
break;
|
SSE_MAXSS_M32_to_XMM(reg, (uptr)mVU_minvals);
|
||||||
default:
|
break;
|
||||||
SSE_MINPS_M128_to_XMM(reg, (uptr)mVU_maxvals);
|
default:
|
||||||
SSE_MAXPS_M128_to_XMM(reg, (uptr)mVU_minvals);
|
SSE_MINPS_M128_to_XMM(reg, (uptr)mVU_maxvals);
|
||||||
break;
|
SSE_MAXPS_M128_to_XMM(reg, (uptr)mVU_minvals);
|
||||||
|
break;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -41,18 +43,18 @@ void mVUclamp2(int reg, int regT1, int xyzw) {
|
||||||
if (CHECK_VU_SIGN_OVERFLOW) {
|
if (CHECK_VU_SIGN_OVERFLOW) {
|
||||||
switch (xyzw) {
|
switch (xyzw) {
|
||||||
case 1: case 2: case 4: case 8:
|
case 1: case 2: case 4: case 8:
|
||||||
SSE_MOVSS_XMM_to_XMM(regT1, reg);
|
SSE_MOVSS_XMM_to_XMM (regT1, reg);
|
||||||
SSE_ANDPS_M128_to_XMM(regT1, (uptr)mVU_signbit);
|
SSE_ANDPS_M128_to_XMM(regT1, (uptr)mVU_signbit);
|
||||||
SSE_MINSS_M32_to_XMM(reg, (uptr)mVU_maxvals);
|
SSE_MINSS_M32_to_XMM (reg, (uptr)mVU_maxvals);
|
||||||
SSE_MAXSS_M32_to_XMM(reg, (uptr)mVU_minvals);
|
SSE_MAXSS_M32_to_XMM (reg, (uptr)mVU_minvals);
|
||||||
SSE_ORPS_XMM_to_XMM(reg, regT1);
|
SSE_ORPS_XMM_to_XMM (reg, regT1);
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
SSE_MOVAPS_XMM_to_XMM(regT1, reg);
|
SSE_MOVAPS_XMM_to_XMM(regT1, reg);
|
||||||
SSE_ANDPS_M128_to_XMM(regT1, (uptr)mVU_signbit);
|
SSE_ANDPS_M128_to_XMM(regT1, (uptr)mVU_signbit);
|
||||||
SSE_MINPS_M128_to_XMM(reg, (uptr)mVU_maxvals);
|
SSE_MINPS_M128_to_XMM(reg, (uptr)mVU_maxvals);
|
||||||
SSE_MAXPS_M128_to_XMM(reg, (uptr)mVU_minvals);
|
SSE_MAXPS_M128_to_XMM(reg, (uptr)mVU_minvals);
|
||||||
SSE_ORPS_XMM_to_XMM(reg, regT1);
|
SSE_ORPS_XMM_to_XMM (reg, regT1);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -148,6 +148,7 @@ void mVU_FMACa(microVU* mVU, int recPass, int opCase, int opType, bool isACC, co
|
||||||
|
|
||||||
opCase1 { if (_XYZW_SS && _X_Y_Z_W != 8) { SSE2_PSHUFD_XMM_to_XMM(Ft, Ft, shuffleSS(_X_Y_Z_W)); } }
|
opCase1 { if (_XYZW_SS && _X_Y_Z_W != 8) { SSE2_PSHUFD_XMM_to_XMM(Ft, Ft, shuffleSS(_X_Y_Z_W)); } }
|
||||||
opCase2 { if (_XYZW_SS && (!_bc_x)) { SSE2_PSHUFD_XMM_to_XMM(Ft, Ft, shuffleSS((1 << (3 - _bc_)))); } }
|
opCase2 { if (_XYZW_SS && (!_bc_x)) { SSE2_PSHUFD_XMM_to_XMM(Ft, Ft, shuffleSS((1 << (3 - _bc_)))); } }
|
||||||
|
opCase2 { if (opType == 2) { mVUclamp1(Fs, -1, _X_Y_Z_W); } } // Clamp Needed for alot of games (TOTA, DoM, etc...)
|
||||||
|
|
||||||
if (_XYZW_SS) SSE_SS[opType](mVU, Fs, Ft, -1, -1);
|
if (_XYZW_SS) SSE_SS[opType](mVU, Fs, Ft, -1, -1);
|
||||||
else SSE_PS[opType](mVU, Fs, Ft, -1, -1);
|
else SSE_PS[opType](mVU, Fs, Ft, -1, -1);
|
||||||
|
@ -186,6 +187,7 @@ void mVU_FMACb(microVU* mVU, int recPass, int opCase, int opType, const char* op
|
||||||
if (_XYZW_SS && _X_Y_Z_W != 8) { SSE2_PSHUFD_XMM_to_XMM(ACC, ACC, shuffleSS(_X_Y_Z_W)); }
|
if (_XYZW_SS && _X_Y_Z_W != 8) { SSE2_PSHUFD_XMM_to_XMM(ACC, ACC, shuffleSS(_X_Y_Z_W)); }
|
||||||
opCase1 { if (_XYZW_SS && _X_Y_Z_W != 8) { SSE2_PSHUFD_XMM_to_XMM(Ft, Ft, shuffleSS(_X_Y_Z_W)); } }
|
opCase1 { if (_XYZW_SS && _X_Y_Z_W != 8) { SSE2_PSHUFD_XMM_to_XMM(Ft, Ft, shuffleSS(_X_Y_Z_W)); } }
|
||||||
opCase2 { if (_XYZW_SS && (!_bc_x)) { SSE2_PSHUFD_XMM_to_XMM(Ft, Ft, shuffleSS((1 << (3 - _bc_)))); } }
|
opCase2 { if (_XYZW_SS && (!_bc_x)) { SSE2_PSHUFD_XMM_to_XMM(Ft, Ft, shuffleSS((1 << (3 - _bc_)))); } }
|
||||||
|
opCase2 { if (opType == 2) { mVUclamp1(Fs, -1, _X_Y_Z_W); } } // Clamp Needed for alot of games (TOTA, DoM, etc...)
|
||||||
|
|
||||||
if (_XYZW_SS) SSE_SS[2](mVU, Fs, Ft, -1, -1);
|
if (_XYZW_SS) SSE_SS[2](mVU, Fs, Ft, -1, -1);
|
||||||
else SSE_PS[2](mVU, Fs, Ft, -1, -1);
|
else SSE_PS[2](mVU, Fs, Ft, -1, -1);
|
||||||
|
@ -230,6 +232,7 @@ void mVU_FMACc(microVU* mVU, int recPass, int opCase, const char* opName) {
|
||||||
if (_XYZW_SS && _X_Y_Z_W != 8) { SSE2_PSHUFD_XMM_to_XMM(ACC, ACC, shuffleSS(_X_Y_Z_W)); }
|
if (_XYZW_SS && _X_Y_Z_W != 8) { SSE2_PSHUFD_XMM_to_XMM(ACC, ACC, shuffleSS(_X_Y_Z_W)); }
|
||||||
opCase1 { if (_XYZW_SS && _X_Y_Z_W != 8) { SSE2_PSHUFD_XMM_to_XMM(Ft, Ft, shuffleSS(_X_Y_Z_W)); } }
|
opCase1 { if (_XYZW_SS && _X_Y_Z_W != 8) { SSE2_PSHUFD_XMM_to_XMM(Ft, Ft, shuffleSS(_X_Y_Z_W)); } }
|
||||||
opCase2 { if (_XYZW_SS && (!_bc_x)) { SSE2_PSHUFD_XMM_to_XMM(Ft, Ft, shuffleSS((1 << (3 - _bc_)))); } }
|
opCase2 { if (_XYZW_SS && (!_bc_x)) { SSE2_PSHUFD_XMM_to_XMM(Ft, Ft, shuffleSS((1 << (3 - _bc_)))); } }
|
||||||
|
opCase2 { mVUclamp1(Fs, -1, _X_Y_Z_W); } // Clamp Needed for alot of games (TOTA, DoM, etc...)
|
||||||
|
|
||||||
if (_XYZW_SS) { SSE_SS[2](mVU, Fs, Ft, -1, -1); SSE_SS[0](mVU, Fs, ACC, -1, -1); }
|
if (_XYZW_SS) { SSE_SS[2](mVU, Fs, Ft, -1, -1); SSE_SS[0](mVU, Fs, ACC, -1, -1); }
|
||||||
else { SSE_PS[2](mVU, Fs, Ft, -1, -1); SSE_PS[0](mVU, Fs, ACC, -1, -1); }
|
else { SSE_PS[2](mVU, Fs, Ft, -1, -1); SSE_PS[0](mVU, Fs, ACC, -1, -1); }
|
||||||
|
|
Loading…
Reference in New Issue