pcsx2: got rid of the compile warning.

microVU: minor changes/cleanup.

git-svn-id: http://pcsx2.googlecode.com/svn/trunk@811 96395faa-99c1-11dd-bbfe-3dabce05a288
This commit is contained in:
cottonvibes 2009-03-18 08:22:01 +00:00
parent d1ae92e203
commit 996f229cbf
5 changed files with 60 additions and 78 deletions

View File

@ -109,7 +109,7 @@ namespace Threading
__forceinline long pcsx2_InterlockedExchangeAdd( volatile long* target, long srcval ) __forceinline long pcsx2_InterlockedExchangeAdd( volatile long* target, long srcval )
{ {
long result; //long result;
// Use our own implementation... // Use our own implementation...
// Pcsx2 won't use threads unless it's a multicore cpu, so no need to use // Pcsx2 won't use threads unless it's a multicore cpu, so no need to use

View File

@ -29,37 +29,7 @@
PCSX2_ALIGNED16(microVU microVU0); PCSX2_ALIGNED16(microVU microVU0);
PCSX2_ALIGNED16(microVU microVU1); PCSX2_ALIGNED16(microVU microVU1);
PCSX2_ALIGNED16(const u32 mVU_absclip[4]) = {0x7fffffff, 0x7fffffff, 0x7fffffff, 0x7fffffff}; declareAllVariables // Declares All Global Variables :D
PCSX2_ALIGNED16(const u32 mVU_signbit[4]) = {0x80000000, 0x80000000, 0x80000000, 0x80000000};
PCSX2_ALIGNED16(const u32 mVU_minvals[4]) = {0xff7fffff, 0xff7fffff, 0xff7fffff, 0xff7fffff};
PCSX2_ALIGNED16(const u32 mVU_maxvals[4]) = {0x7f7fffff, 0x7f7fffff, 0x7f7fffff, 0x7f7fffff};
PCSX2_ALIGNED16(const u32 mVU_one[4]) = {0x3f800000, 0x3f800000, 0x3f800000, 0x3f800000};
PCSX2_ALIGNED16(const u32 mVU_T1[4]) = {0x3f7ffff5, 0x3f7ffff5, 0x3f7ffff5, 0x3f7ffff5};
PCSX2_ALIGNED16(const u32 mVU_T2[4]) = {0xbeaaa61c, 0xbeaaa61c, 0xbeaaa61c, 0xbeaaa61c};
PCSX2_ALIGNED16(const u32 mVU_T3[4]) = {0x3e4c40a6, 0x3e4c40a6, 0x3e4c40a6, 0x3e4c40a6};
PCSX2_ALIGNED16(const u32 mVU_T4[4]) = {0xbe0e6c63, 0xbe0e6c63, 0xbe0e6c63, 0xbe0e6c63};
PCSX2_ALIGNED16(const u32 mVU_T5[4]) = {0x3dc577df, 0x3dc577df, 0x3dc577df, 0x3dc577df};
PCSX2_ALIGNED16(const u32 mVU_T6[4]) = {0xbd6501c4, 0xbd6501c4, 0xbd6501c4, 0xbd6501c4};
PCSX2_ALIGNED16(const u32 mVU_T7[4]) = {0x3cb31652, 0x3cb31652, 0x3cb31652, 0x3cb31652};
PCSX2_ALIGNED16(const u32 mVU_T8[4]) = {0xbb84d7e7, 0xbb84d7e7, 0xbb84d7e7, 0xbb84d7e7};
PCSX2_ALIGNED16(const u32 mVU_Pi4[4]) = {0x3f490fdb, 0x3f490fdb, 0x3f490fdb, 0x3f490fdb};
PCSX2_ALIGNED16(const u32 mVU_S2[4]) = {0xbe2aaaa4, 0xbe2aaaa4, 0xbe2aaaa4, 0xbe2aaaa4};
PCSX2_ALIGNED16(const u32 mVU_S3[4]) = {0x3c08873e, 0x3c08873e, 0x3c08873e, 0x3c08873e};
PCSX2_ALIGNED16(const u32 mVU_S4[4]) = {0xb94fb21f, 0xb94fb21f, 0xb94fb21f, 0xb94fb21f};
PCSX2_ALIGNED16(const u32 mVU_S5[4]) = {0x362e9c14, 0x362e9c14, 0x362e9c14, 0x362e9c14};
PCSX2_ALIGNED16(const u32 mVU_E1[4]) = {0x3e7fffa8, 0x3e7fffa8, 0x3e7fffa8, 0x3e7fffa8};
PCSX2_ALIGNED16(const u32 mVU_E2[4]) = {0x3d0007f4, 0x3d0007f4, 0x3d0007f4, 0x3d0007f4};
PCSX2_ALIGNED16(const u32 mVU_E3[4]) = {0x3b29d3ff, 0x3b29d3ff, 0x3b29d3ff, 0x3b29d3ff};
PCSX2_ALIGNED16(const u32 mVU_E4[4]) = {0x3933e553, 0x3933e553, 0x3933e553, 0x3933e553};
PCSX2_ALIGNED16(const u32 mVU_E5[4]) = {0x36b63510, 0x36b63510, 0x36b63510, 0x36b63510};
PCSX2_ALIGNED16(const u32 mVU_E6[4]) = {0x353961ac, 0x353961ac, 0x353961ac, 0x353961ac};
PCSX2_ALIGNED16(const float mVU_FTOI_4[4]) = {16.0, 16.0, 16.0, 16.0};
PCSX2_ALIGNED16(const float mVU_FTOI_12[4]) = {4096.0, 4096.0, 4096.0, 4096.0};
PCSX2_ALIGNED16(const float mVU_FTOI_15[4]) = {32768.0, 32768.0, 32768.0, 32768.0};
PCSX2_ALIGNED16(const float mVU_ITOF_4[4]) = {0.0625f, 0.0625f, 0.0625f, 0.0625f};
PCSX2_ALIGNED16(const float mVU_ITOF_12[4]) = {0.000244140625, 0.000244140625, 0.000244140625, 0.000244140625};
PCSX2_ALIGNED16(const float mVU_ITOF_15[4]) = {0.000030517578125, 0.000030517578125, 0.000030517578125, 0.000030517578125};
//------------------------------------------------------------------ //------------------------------------------------------------------
// Micro VU - Main Functions // Micro VU - Main Functions
//------------------------------------------------------------------ //------------------------------------------------------------------

View File

@ -31,7 +31,7 @@ struct microBlock {
u8* x86ptrStart; // Start of code u8* x86ptrStart; // Start of code
u8* x86ptrEnd; // End of code (first byte outside of block) u8* x86ptrEnd; // End of code (first byte outside of block)
u8* x86ptrBranch; // u8* x86ptrBranch; //
//u32 size; u32 size; // Number of 64bit VU Instructions in Block
}; };
#define mMaxBlocks 32 // Max Blocks With Different Pipeline States (For n = 1, 2, 4, 8, 16, etc...) #define mMaxBlocks 32 // Max Blocks With Different Pipeline States (For n = 1, 2, 4, 8, 16, etc...)

View File

@ -56,7 +56,7 @@ microVUf(void) mVU_DIV() {
SSE_XORPS_XMM_to_XMM(xmmFs, xmmFt); SSE_XORPS_XMM_to_XMM(xmmFs, xmmFt);
SSE_ANDPS_M128_to_XMM(xmmFs, (uptr)mVU_signbit); SSE_ANDPS_M128_to_XMM(xmmFs, (uptr)mVU_signbit);
SSE_ORPS_M128_to_XMM(xmmFs, (uptr)mVU_maxvals); // If division by zero, then xmmFs = +/- fmax SSE_ORPS_XMM_to_XMM(xmmFs, xmmMax); // If division by zero, then xmmFs = +/- fmax
bjmp32 = JMP32(0); bjmp32 = JMP32(0);
x86SetJ32(ajmp32); x86SetJ32(ajmp32);
@ -86,7 +86,7 @@ microVUf(void) mVU_SQRT() {
//x86SetJ8(pjmp); //x86SetJ8(pjmp);
SSE_ANDPS_M128_to_XMM(xmmFt, (uptr)mVU_absclip); // Do a cardinal sqrt SSE_ANDPS_M128_to_XMM(xmmFt, (uptr)mVU_absclip); // Do a cardinal sqrt
if (CHECK_VU_OVERFLOW) SSE_MINSS_M32_to_XMM(xmmFt, (uptr)mVU_maxvals); // Clamp infinities (only need to do positive clamp since xmmFt is positive) if (CHECK_VU_OVERFLOW) SSE_MINSS_XMM_to_XMM(xmmFt, xmmMax); // Clamp infinities (only need to do positive clamp since xmmFt is positive)
SSE_SQRTSS_XMM_to_XMM(xmmFt, xmmFt); SSE_SQRTSS_XMM_to_XMM(xmmFt, xmmFt);
mVUunpack_xyzw<vuIndex>(xmmFt, xmmFt, 0); mVUunpack_xyzw<vuIndex>(xmmFt, xmmFt, 0);
mVUmergeRegs<vuIndex>(xmmPQ, xmmFt, writeQ ? 4 : 8); mVUmergeRegs<vuIndex>(xmmPQ, xmmFt, writeQ ? 4 : 8);
@ -122,7 +122,7 @@ microVUf(void) mVU_RSQRT() {
ajmp8 = JZ8(0); // Skip if none are ajmp8 = JZ8(0); // Skip if none are
//OR32ItoM(VU_VI_ADDR(REG_STATUS_FLAG, 2), 0x820); // Zero divide flag //OR32ItoM(VU_VI_ADDR(REG_STATUS_FLAG, 2), 0x820); // Zero divide flag
SSE_ANDPS_M128_to_XMM(xmmFs, (uptr)mVU_signbit); SSE_ANDPS_M128_to_XMM(xmmFs, (uptr)mVU_signbit);
SSE_ORPS_M128_to_XMM(xmmFs, (uptr)mVU_maxvals); // EEREC_TEMP = +/-Max SSE_ORPS_XMM_to_XMM(xmmFs, xmmMax); // EEREC_TEMP = +/-Max
bjmp8 = JMP8(0); bjmp8 = JMP8(0);
x86SetJ8(ajmp8); x86SetJ8(ajmp8);
SSE_DIVSS_XMM_to_XMM(xmmFs, xmmFt); SSE_DIVSS_XMM_to_XMM(xmmFs, xmmFt);

View File

@ -22,35 +22,46 @@
// Global Variables // Global Variables
//------------------------------------------------------------------ //------------------------------------------------------------------
PCSX2_ALIGNED16_EXTERN(const u32 mVU_absclip[4]); #define declareAllVariables \
PCSX2_ALIGNED16_EXTERN(const u32 mVU_signbit[4]); initVariable( _somePrefix_, u32, mVU_absclip, 0x7fffffff ); \
PCSX2_ALIGNED16_EXTERN(const u32 mVU_minvals[4]); initVariable( _somePrefix_, u32, mVU_signbit, 0x80000000 ); \
PCSX2_ALIGNED16_EXTERN(const u32 mVU_maxvals[4]); initVariable( _somePrefix_, u32, mVU_minvals, 0xff7fffff ); \
PCSX2_ALIGNED16_EXTERN(const u32 mVU_T1[4]); initVariable( _somePrefix_, u32, mVU_maxvals, 0x7f7fffff ); \
PCSX2_ALIGNED16_EXTERN(const u32 mVU_T2[4]); initVariable( _somePrefix_, u32, mVU_one, 0x3f800000 ); \
PCSX2_ALIGNED16_EXTERN(const u32 mVU_T3[4]); initVariable( _somePrefix_, u32, mVU_T1, 0x3f7ffff5 ); \
PCSX2_ALIGNED16_EXTERN(const u32 mVU_T4[4]); initVariable( _somePrefix_, u32, mVU_T2, 0xbeaaa61c ); \
PCSX2_ALIGNED16_EXTERN(const u32 mVU_T5[4]); initVariable( _somePrefix_, u32, mVU_T3, 0x3e4c40a6 ); \
PCSX2_ALIGNED16_EXTERN(const u32 mVU_T6[4]); initVariable( _somePrefix_, u32, mVU_T4, 0xbe0e6c63 ); \
PCSX2_ALIGNED16_EXTERN(const u32 mVU_T7[4]); initVariable( _somePrefix_, u32, mVU_T5, 0x3dc577df ); \
PCSX2_ALIGNED16_EXTERN(const u32 mVU_T8[4]); initVariable( _somePrefix_, u32, mVU_T6, 0xbd6501c4 ); \
PCSX2_ALIGNED16_EXTERN(const u32 mVU_Pi4[4]); initVariable( _somePrefix_, u32, mVU_T7, 0x3cb31652 ); \
PCSX2_ALIGNED16_EXTERN(const u32 mVU_S2[4]); initVariable( _somePrefix_, u32, mVU_T8, 0xbb84d7e7 ); \
PCSX2_ALIGNED16_EXTERN(const u32 mVU_S3[4]); initVariable( _somePrefix_, u32, mVU_Pi4, 0x3f490fdb ); \
PCSX2_ALIGNED16_EXTERN(const u32 mVU_S4[4]); initVariable( _somePrefix_, u32, mVU_S2, 0xbe2aaaa4 ); \
PCSX2_ALIGNED16_EXTERN(const u32 mVU_S5[4]); initVariable( _somePrefix_, u32, mVU_S3, 0x3c08873e ); \
PCSX2_ALIGNED16_EXTERN(const u32 mVU_E1[4]); initVariable( _somePrefix_, u32, mVU_S4, 0xb94fb21f ); \
PCSX2_ALIGNED16_EXTERN(const u32 mVU_E2[4]); initVariable( _somePrefix_, u32, mVU_S5, 0x362e9c14 ); \
PCSX2_ALIGNED16_EXTERN(const u32 mVU_E3[4]); initVariable( _somePrefix_, u32, mVU_E1, 0x3e7fffa8 ); \
PCSX2_ALIGNED16_EXTERN(const u32 mVU_E4[4]); initVariable( _somePrefix_, u32, mVU_E2, 0x3d0007f4 ); \
PCSX2_ALIGNED16_EXTERN(const u32 mVU_E5[4]); initVariable( _somePrefix_, u32, mVU_E3, 0x3b29d3ff ); \
PCSX2_ALIGNED16_EXTERN(const u32 mVU_E6[4]); initVariable( _somePrefix_, u32, mVU_E4, 0x3933e553 ); \
PCSX2_ALIGNED16_EXTERN(const float mVU_FTOI_4[4]); initVariable( _somePrefix_, u32, mVU_E5, 0x36b63510 ); \
PCSX2_ALIGNED16_EXTERN(const float mVU_FTOI_12[4]); initVariable( _somePrefix_, u32, mVU_E6, 0x353961ac ); \
PCSX2_ALIGNED16_EXTERN(const float mVU_FTOI_15[4]); initVariable( _somePrefix_, float, mVU_FTOI_4, 16.0 ); \
PCSX2_ALIGNED16_EXTERN(const float mVU_ITOF_4[4]); initVariable( _somePrefix_, float, mVU_FTOI_12, 4096.0 ); \
PCSX2_ALIGNED16_EXTERN(const float mVU_ITOF_12[4]); initVariable( _somePrefix_, float, mVU_FTOI_15, 32768.0 ); \
PCSX2_ALIGNED16_EXTERN(const float mVU_ITOF_15[4]); initVariable( _somePrefix_, float, mVU_ITOF_4, 0.0625f ); \
initVariable( _somePrefix_, float, mVU_ITOF_12, 0.000244140625 ); \
initVariable( _somePrefix_, float, mVU_ITOF_15, 0.000030517578125 );
#define _somePrefix_ PCSX2_ALIGNED16_EXTERN
#define initVariable(aprefix, atype, aname, avalue) aprefix (const atype aname [4]);
declareAllVariables
#undef _somePrefix_
#undef initVariable
#define _somePrefix_ PCSX2_ALIGNED16
#define initVariable(aprefix, atype, aname, avalue) aprefix (const atype aname [4]) = {avalue, avalue, avalue, avalue};
//------------------------------------------------------------------ //------------------------------------------------------------------
// Helper Macros // Helper Macros
@ -142,7 +153,7 @@ PCSX2_ALIGNED16_EXTERN(const float mVU_ITOF_15[4]);
#define _writeQ (1<<5) #define _writeQ (1<<5)
#define _readQ (1<<6) #define _readQ (1<<6)
#define _writeP (1<<7) #define _writeP (1<<7)
#define _readP (1<<7) #define _readP (1<<7) // same as writeP
#define _doFlags (3<<8) #define _doFlags (3<<8)
#define _doMac (1<<8) #define _doMac (1<<8)
#define _doStatus (1<<9) #define _doStatus (1<<9)
@ -159,23 +170,24 @@ PCSX2_ALIGNED16_EXTERN(const float mVU_ITOF_15[4]);
#define isBranch (mVUinfo & (1<<1)) #define isBranch (mVUinfo & (1<<1))
#define isEOB (mVUinfo & (1<<2)) #define isEOB (mVUinfo & (1<<2))
#define isBdelay (mVUinfo & (1<<3)) #define isBdelay (mVUinfo & (1<<3))
#define writeQ ((mVUinfo & (1<<5)) >> 5) #define writeQ ((mVUinfo >> 5) & 1)
#define readQ ((mVUinfo & (1<<6)) >> 6) #define readQ ((mVUinfo >> 6) & 1)
#define writeP ((mVUinfo & (1<<7)) >> 7) #define writeP ((mVUinfo >> 7) & 1)
#define readP ((mVUinfo & (1<<7)) >> 7) // same as write #define readP ((mVUinfo >> 7) & 1) // same as writeP
#define doFlags (mVUinfo & (3<<8)) #define doFlags (mVUinfo & (3<<8))
#define doMac (mVUinfo & (1<<8)) #define doMac (mVUinfo & (1<<8))
#define doStatus (mVUinfo & (1<<9)) #define doStatus (mVUinfo & (1<<9))
#define fmInstance ((mVUinfo & (3<<10)) >> 10) #define fmInstance ((mVUinfo >> 10) & 3)
#define fsInstance ((mVUinfo & (3<<12)) >> 12) #define fsInstance ((mVUinfo >> 12) & 3)
#define fcInstance ((mVUinfo & (3<<14)) >> 14) #define fpsInstance ((((mVUinfo>>12) & 3) - 1) & 0x3)
#define fpmInstance (((u8)((mVUinfo & (3<<10)) >> 10) - 1) & 0x3) #define fcInstance ((mVUinfo >> 14) & 3)
#define fpsInstance (((u8)((mVUinfo & (3<<12)) >> 12) - 1) & 0x3) #define fvcInstance ((mVUinfo >> 14) & 3)
#define fvmInstance ((mVUinfo & (3<<16)) >> 16) #define fvmInstance ((mVUinfo >> 16) & 3)
#define fvsInstance ((mVUinfo & (3<<18)) >> 18) #define fvsInstance ((mVUinfo >> 18) & 3)
#define fvcInstance ((mVUinfo & (3<<14)) >> 14)
//#define getFs (mVUinfo & (1<<13)) //#define getFs (mVUinfo & (1<<13))
//#define getFt (mVUinfo & (1<<14)) //#define getFt (mVUinfo & (1<<14))
//#define fpmInstance (((u8)((mVUinfo & (3<<10)) >> 10) - 1) & 0x3)
#define isMMX(_VIreg_) (_VIreg_ >= 1 && _VIreg_ <=9) #define isMMX(_VIreg_) (_VIreg_ >= 1 && _VIreg_ <=9)
#define mmVI(_VIreg_) (_VIreg_ - 1) #define mmVI(_VIreg_) (_VIreg_ - 1)