minor change, commented out some SysPrintf()'s on some VU Opcodes.

git-svn-id: http://pcsx2-playground.googlecode.com/svn/trunk@57 a6443dda-0b58-4228-96e9-037be469359c
This commit is contained in:
cottonvibes 2008-08-26 19:34:41 +00:00 committed by Gregory Hainaut
parent b6e7ff33fd
commit 8f61f59eba
2 changed files with 15 additions and 13 deletions

View File

@ -951,6 +951,7 @@ static u32 PCSX2_ALIGNED16(s_pos[4]) = { 0x7fffffff, 0, 0, 0 };
void recSQRT_S_xmm(int info) void recSQRT_S_xmm(int info)
{ {
SysPrintf("FPU: SQRT \n");
if( info & PROCESS_EE_T ) { if( info & PROCESS_EE_T ) {
//if( CHECK_OVERFLOW ) { //if( CHECK_OVERFLOW ) {
if( EEREC_D == EEREC_T ) SSE_ANDPS_M128_to_XMM(EEREC_D, (uptr)&s_pos[0]); if( EEREC_D == EEREC_T ) SSE_ANDPS_M128_to_XMM(EEREC_D, (uptr)&s_pos[0]);
@ -1028,6 +1029,7 @@ FPURECOMPILE_CONSTCODE(NEG_S, XMMINFO_WRITED|XMMINFO_READS);
void recRSQRT_S_xmm(int info) void recRSQRT_S_xmm(int info)
{ {
int t0reg = _allocTempXMMreg(XMMT_FPS, -1); int t0reg = _allocTempXMMreg(XMMT_FPS, -1);
SysPrintf("FPU: RSQRT \n");
switch(info & (PROCESS_EE_S|PROCESS_EE_T) ) { switch(info & (PROCESS_EE_S|PROCESS_EE_T) ) {
case PROCESS_EE_S: case PROCESS_EE_S:
if( EEREC_D == EEREC_S ) { if( EEREC_D == EEREC_S ) {

View File

@ -3761,7 +3761,7 @@ void recVUMI_DIV(VURegs *VU, int info)
if( t1reg >= 0 ) // 1/n ---- needs work, ft can also be zero! if( t1reg >= 0 ) // 1/n ---- needs work, ft can also be zero!
{ {
SysPrintf("DIV: Fixed! 1 \n"); //SysPrintf("DIV: Fixed! 1 \n");
_unpackVFSS_xyzw(EEREC_TEMP, EEREC_T, _Ftf_); _unpackVFSS_xyzw(EEREC_TEMP, EEREC_T, _Ftf_);
@ -3800,7 +3800,7 @@ void recVUMI_DIV(VURegs *VU, int info)
} }
else // 1/n ---- needs work, ft can also be zero! else // 1/n ---- needs work, ft can also be zero!
{ {
SysPrintf("DIV: Fixed! 2 \n"); //SysPrintf("DIV: Fixed! 2 \n");
_unpackVFSS_xyzw(EEREC_TEMP, EEREC_T, _Ftf_); _unpackVFSS_xyzw(EEREC_TEMP, EEREC_T, _Ftf_);
if (CHECK_EXTRA_OVERFLOW) if (CHECK_EXTRA_OVERFLOW)
@ -3842,7 +3842,7 @@ void recVUMI_DIV(VURegs *VU, int info)
} }
else else
{ // 1/n ---- (SS) needs work, ft can also be zero! { // 1/n ---- (SS) needs work, ft can also be zero!
SysPrintf("DIV: Fixed! 3 \n"); //SysPrintf("DIV: Fixed! 3 \n");
if (CHECK_EXTRA_OVERFLOW) if (CHECK_EXTRA_OVERFLOW)
vuFloat2(EEREC_T, EEREC_TEMP, 0x8); vuFloat2(EEREC_T, EEREC_TEMP, 0x8);
@ -3878,7 +3878,7 @@ void recVUMI_DIV(VURegs *VU, int info)
} }
} }
else { // 1/n ---- (SS) needs work, ft can also be zero! else { // 1/n ---- (SS) needs work, ft can also be zero!
SysPrintf("DIV: Fixed! 4 \n"); //SysPrintf("DIV: Fixed! 4 \n");
t1reg = (EEREC_TEMP == 0) ? (EEREC_TEMP + 1) : (EEREC_TEMP - 1); // find a xmm reg thats not EEREC_TEMP t1reg = (EEREC_TEMP == 0) ? (EEREC_TEMP + 1) : (EEREC_TEMP - 1); // find a xmm reg thats not EEREC_TEMP
SSE_MOVAPS_XMM_to_M128( (uptr)&DIV_TEMP_XMM[0], t1reg ); // backup data in t1reg to a temp address SSE_MOVAPS_XMM_to_M128( (uptr)&DIV_TEMP_XMM[0], t1reg ); // backup data in t1reg to a temp address
@ -3920,7 +3920,7 @@ void recVUMI_DIV(VURegs *VU, int info)
} }
} }
else { // 0/n ---- So result is +/- 0, or +/- Fmax if (FT == 0) else { // 0/n ---- So result is +/- 0, or +/- Fmax if (FT == 0)
SysPrintf("FS = 0, FT = n \n"); //SysPrintf("FS = 0, FT = n \n");
if( _Ftf_ == 0 ) SSE_MOVAPS_XMM_to_XMM(EEREC_TEMP, EEREC_T); if( _Ftf_ == 0 ) SSE_MOVAPS_XMM_to_XMM(EEREC_TEMP, EEREC_T);
else _unpackVFSS_xyzw(EEREC_TEMP, EEREC_T, _Ftf_); // EEREC_TEMP.x <- EEREC_T.ftf else _unpackVFSS_xyzw(EEREC_TEMP, EEREC_T, _Ftf_); // EEREC_TEMP.x <- EEREC_T.ftf
@ -3961,7 +3961,7 @@ void recVUMI_DIV(VURegs *VU, int info)
else { // _Fs_ != 0 else { // _Fs_ != 0
if( _Ft_ == 0 ) { if( _Ft_ == 0 ) {
if( _Ftf_ < 3 ) { // needs extra work, fs can also be zero! if( _Ftf_ < 3 ) { // needs extra work, fs can also be zero!
SysPrintf("DIV: FS = n, FT == 0 ---- Finished! \n"); //SysPrintf("DIV: FS = n, FT == 0 ---- Finished! \n");
_unpackVFSS_xyzw(EEREC_TEMP, EEREC_S, _Fsf_); // EEREC_TEMP.x <- EEREC_S.fsf _unpackVFSS_xyzw(EEREC_TEMP, EEREC_S, _Fsf_); // EEREC_TEMP.x <- EEREC_S.fsf
@ -3990,7 +3990,7 @@ void recVUMI_DIV(VURegs *VU, int info)
SSE_MOVAPS_M128_to_XMM( t1reg, (uptr)&DIV_TEMP_XMM[0] ); // restore data to t1reg SSE_MOVAPS_M128_to_XMM( t1reg, (uptr)&DIV_TEMP_XMM[0] ); // restore data to t1reg
} }
else { else {
SysPrintf("DIV: FS = n, FT == 1 \n"); //SysPrintf("DIV: FS = n, FT == 1 \n");
if( _Fsf_ == 0 ) SSE_MOVAPS_XMM_to_XMM(EEREC_TEMP, EEREC_S); if( _Fsf_ == 0 ) SSE_MOVAPS_XMM_to_XMM(EEREC_TEMP, EEREC_S);
else _unpackVF_xyzw(EEREC_TEMP, EEREC_S, _Fsf_); else _unpackVF_xyzw(EEREC_TEMP, EEREC_S, _Fsf_);
if (CHECK_EXTRA_OVERFLOW) if (CHECK_EXTRA_OVERFLOW)
@ -4010,7 +4010,7 @@ void recVUMI_DIV(VURegs *VU, int info)
if( t1reg >= 0 ) if( t1reg >= 0 )
{ {
SysPrintf("Second Half of DIV Opcode: Fixed 1 \n"); //SysPrintf("Second Half of DIV Opcode: Fixed 1 \n");
_unpackVFSS_xyzw(t1reg, EEREC_T, _Ftf_); _unpackVFSS_xyzw(t1reg, EEREC_T, _Ftf_);
if (CHECK_EXTRA_OVERFLOW) { if (CHECK_EXTRA_OVERFLOW) {
@ -4068,7 +4068,7 @@ void recVUMI_DIV(VURegs *VU, int info)
} }
else else
{ {
SysPrintf("Second Half of DIV Opcode: Fixed 2 \n"); //SysPrintf("Second Half of DIV Opcode: Fixed 2 \n");
t1reg = EEREC_T; t1reg = EEREC_T;
SSE_MOVAPS_XMM_to_M128( (uptr)&DIV_TEMP_XMM[0], t1reg ); // backup data in t1reg to a temp address SSE_MOVAPS_XMM_to_M128( (uptr)&DIV_TEMP_XMM[0], t1reg ); // backup data in t1reg to a temp address
_unpackVFSS_xyzw(t1reg, EEREC_T, _Ftf_); _unpackVFSS_xyzw(t1reg, EEREC_T, _Ftf_);
@ -4129,7 +4129,7 @@ void recVUMI_DIV(VURegs *VU, int info)
} }
else else
{ {
SysPrintf("Second Half of DIV Opcode: Fixed 3 \n"); //SysPrintf("Second Half of DIV Opcode: Fixed 3 \n");
if (CHECK_EXTRA_OVERFLOW) { if (CHECK_EXTRA_OVERFLOW) {
vuFloat2(EEREC_TEMP, EEREC_TEMP, 0x8); vuFloat2(EEREC_TEMP, EEREC_TEMP, 0x8);
@ -4194,7 +4194,7 @@ void recVUMI_SQRT( VURegs *VU, int info )
int vftemp = ALLOCTEMPX86(MODE_8BITREG); int vftemp = ALLOCTEMPX86(MODE_8BITREG);
u8* pjmp; u8* pjmp;
SysPrintf("SQRT Opcode \n"); //SysPrintf("SQRT Opcode \n");
AND32ItoM(VU_VI_ADDR(REG_STATUS_FLAG, 2), 0xFCF); // Clear D/I flags AND32ItoM(VU_VI_ADDR(REG_STATUS_FLAG, 2), 0xFCF); // Clear D/I flags
if( xmmregs[EEREC_T].mode & MODE_WRITE ) if( xmmregs[EEREC_T].mode & MODE_WRITE )
@ -4255,7 +4255,7 @@ void recVUMI_RSQRT(VURegs *VU, int info)
if( t1reg >= 0 ) if( t1reg >= 0 )
{ {
SysPrintf("RSQRT Opcode Part 1 \n"); //SysPrintf("RSQRT Opcode Part 1 \n");
// Ft can still be zero here! so we need to check if its zero and set the correct flag. // Ft can still be zero here! so we need to check if its zero and set the correct flag.
SSE_XORPS_XMM_to_XMM(t1reg, t1reg); // Clear t1reg SSE_XORPS_XMM_to_XMM(t1reg, t1reg); // Clear t1reg
XOR32RtoR(vftemp, vftemp); XOR32RtoR(vftemp, vftemp);
@ -4289,7 +4289,7 @@ void recVUMI_RSQRT(VURegs *VU, int info)
} }
else else
{ {
SysPrintf("RSQRT Opcode Part 2 \n"); //SysPrintf("RSQRT Opcode Part 2 \n");
for (t1reg = 0; ( (t1reg == EEREC_TEMP) || (t1reg == EEREC_S) ); t1reg++) for (t1reg = 0; ( (t1reg == EEREC_TEMP) || (t1reg == EEREC_S) ); t1reg++)
; // Makes t1reg not be EEREC_TEMP or EEREC_S. ; // Makes t1reg not be EEREC_TEMP or EEREC_S.
SSE_MOVAPS_XMM_to_M128( (uptr)&RSQRT_TEMP_XMM[0], t1reg ); // backup data in t1reg to a temp address SSE_MOVAPS_XMM_to_M128( (uptr)&RSQRT_TEMP_XMM[0], t1reg ); // backup data in t1reg to a temp address