Stuff that was changed: - Fixed up pcsx2_2005.sln to not give errors for missing plugin files. - PCSX2 now exits properly with ESC key and GSdx :p - Updated my VU Skip to the latest version I had. - Added/Modified alot of speed hacks. - Added a few SSE and x86 instructions coded by DiablosOf. - Working on VUs: Added some code that fixes SPS in some games, but runs slow. Turn off this code with the speedhack "Disable Extra Overflow Checks" to get back the speed. - Also regarding the VU's, it seems MGS3 doesn't like something I coded. But I'm not sure what it is yet; hopefully I'll figure out the problem ^^ - Some other minor changes I probably forgot to mention :p

git-svn-id: http://pcsx2-playground.googlecode.com/svn/trunk@6 a6443dda-0b58-4228-96e9-037be469359c
This commit is contained in:
cottonvibes 2008-08-12 08:03:07 +00:00 committed by Gregory Hainaut
parent f80441a4f9
commit 4b69e809e5
16 changed files with 1168 additions and 526 deletions

View File

@ -5,15 +5,15 @@
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or * the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version. * (at your option) any later version.
* *
* This program is distributed in the hope that it will be useful, * This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of * but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details. * GNU General Public License for more details.
* *
* You should have received a copy of the GNU General Public License * You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/ */
#include <string.h> #include <string.h>
@ -31,7 +31,9 @@ extern u8 psxhblankgate;
int hblankend = 0; int hblankend = 0;
Counter counters[6]; Counter counters[6];
u32 nextCounter, nextsCounter; u32 nextCounter, nextsCounter;
static void (*s_prevExecuteVU0Block)() = NULL;
static void (*s_prevExecuteVU1Block)() = NULL; static void (*s_prevExecuteVU1Block)() = NULL;
LARGE_INTEGER lfreq; LARGE_INTEGER lfreq;
// its so it doesnt keep triggering an interrupt once its reached its target // its so it doesnt keep triggering an interrupt once its reached its target
@ -126,7 +128,9 @@ void rcntInit() {
rcntSet(); rcntSet();
assert(Cpu != NULL && Cpu->ExecuteVU1Block != NULL ); assert(Cpu != NULL && Cpu->ExecuteVU1Block != NULL );
s_prevExecuteVU0Block = Cpu->ExecuteVU0Block;
s_prevExecuteVU1Block = Cpu->ExecuteVU1Block; s_prevExecuteVU1Block = Cpu->ExecuteVU1Block;
} }
// debug code, used for stats // debug code, used for stats
@ -246,8 +250,11 @@ void VSync()
// swap the vsync field // swap the vsync field
u32 newfield = (*(u32*)(PS2MEM_GS+0x1000)&0x2000) ? 0 : 0x2000; u32 newfield = (*(u32*)(PS2MEM_GS+0x1000)&0x2000) ? 0 : 0x2000;
*(u32*)(PS2MEM_GS+0x1000) = (*(u32*)(PS2MEM_GS+0x1000) & ~(1<<13)) | newfield; *(u32*)(PS2MEM_GS+0x1000) = (*(u32*)(PS2MEM_GS+0x1000) & ~(1<<13)) | newfield;
iFrame++; iFrame++;
// wait until GS stops // wait until GS stops
if( CHECK_MULTIGS ) { if( CHECK_MULTIGS ) {
GSRingBufSimplePacket(GS_RINGTYPE_VSYNC, newfield, 0, 0); GSRingBufSimplePacket(GS_RINGTYPE_VSYNC, newfield, 0, 0);
@ -303,7 +310,10 @@ void VSync()
if( CHECK_MULTIGS ) GSRingBufSimplePacket(GS_RINGTYPE_FRAMESKIP, 1, 0, 0); if( CHECK_MULTIGS ) GSRingBufSimplePacket(GS_RINGTYPE_FRAMESKIP, 1, 0, 0);
else GSsetFrameSkip(1); else GSsetFrameSkip(1);
if( CHECK_FRAMELIMIT == PCSX2_FRAMELIMIT_VUSKIP ) if( CHECK_FRAMELIMIT == PCSX2_FRAMELIMIT_VUSKIP )
{
Cpu->ExecuteVU1Block = DummyExecuteVU1Block; Cpu->ExecuteVU1Block = DummyExecuteVU1Block;
//Cpu->ExecuteVU0Block = NULL;
}
bOkayToSkip = noSkipFrames; bOkayToSkip = noSkipFrames;
bKeepSkipping = yesSkipFrames; bKeepSkipping = yesSkipFrames;
} }
@ -312,8 +322,11 @@ void VSync()
{ {
if (bKeepSkipping <= 1) { if (bKeepSkipping <= 1) {
//first set VU1 to enabled THEN unfreeze GS regs //first set VU1 to enabled THEN unfreeze GS regs
if( CHECK_FRAMELIMIT == PCSX2_FRAMELIMIT_VUSKIP ) if( CHECK_FRAMELIMIT == PCSX2_FRAMELIMIT_VUSKIP )
{
Cpu->ExecuteVU1Block = s_prevExecuteVU1Block; Cpu->ExecuteVU1Block = s_prevExecuteVU1Block;
//Cpu->ExecuteVU0Block = s_prevExecuteVU0Block;
}
if( CHECK_MULTIGS ) GSRingBufSimplePacket(GS_RINGTYPE_FRAMESKIP, 0, 0, 0); if( CHECK_MULTIGS ) GSRingBufSimplePacket(GS_RINGTYPE_FRAMESKIP, 0, 0, 0);
else GSsetFrameSkip(0); else GSsetFrameSkip(0);
bOkayToSkip--; bOkayToSkip--;
@ -614,15 +627,11 @@ void rcntWmode(int index, u32 value)
} }
//if(change != 0) SysPrintf("Weee\n"); //if(change != 0) SysPrintf("Weee\n");
//counters[index].sCycleT = cpuRegs.cycle - ((cpuRegs.cycle - counters[index].sCycleT) % counters[index].rate); //counters[index].sCycleT = cpuRegs.cycle - ((cpuRegs.cycle - counters[index].sCycleT) % counters[index].rate);
#ifdef PCSX2_DEVBUILD
if(!(value & 0x80)) SysPrintf("Stopping\n"); if(!(value & 0x80)) SysPrintf("Stopping\n");
#endif
} }
else { else {
#ifdef PCSX2_DEVBUILD
SysPrintf("Counter %d not running c%x s%x c%x\n", index, counters[index].count, counters[index].sCycleT, cpuRegs.cycle); SysPrintf("Counter %d not running c%x s%x c%x\n", index, counters[index].count, counters[index].sCycleT, cpuRegs.cycle);
if(value & 0x80) SysPrintf("Starting %d, v%x\n", index, value); if(value & 0x80) SysPrintf("Starting %d, v%x\n", index, value);
#endif
counters[index].sCycleT = cpuRegs.cycle; counters[index].sCycleT = cpuRegs.cycle;
} }
//if((value & 0x80) && !(counters[index].mode & 0x80)) rcntUpd(index); //Counter wasnt started, so set the start cycle //if((value & 0x80) && !(counters[index].mode & 0x80)) rcntUpd(index); //Counter wasnt started, so set the start cycle

View File

@ -5,12 +5,12 @@
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or * the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version. * (at your option) any later version.
* *
* This program is distributed in the hope that it will be useful, * This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of * but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details. * GNU General Public License for more details.
* *
* You should have received a copy of the GNU General Public License * You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
@ -23,23 +23,129 @@
// Helper Macros // Helper Macros
//**************************************************************** //****************************************************************
// IEEE 754 Values
#define PosInfinity 0x7f800000
#define NegInfinity 0xff800000
#define posFmax 0x7F7FFFFF
#define negFmax 0xFF7FFFFF
/* Used in compare function to compensate for differences between IEEE 754 and the FPU.
Setting it to ~0x00000000 = Compares Exact Value. (comment out this macro for faster Exact Compare method)
Setting it to ~0x00000001 = Discards the least significant bit when comparing.
Setting it to ~0x00000003 = Discards the least 2 significant bits when comparing... etc.. */
#define comparePrecision ~0x00000001
// Operands
#define _Ft_ ( ( cpuRegs.code >> 16 ) & 0x1F ) #define _Ft_ ( ( cpuRegs.code >> 16 ) & 0x1F )
#define _Fs_ ( ( cpuRegs.code >> 11 ) & 0x1F ) #define _Fs_ ( ( cpuRegs.code >> 11 ) & 0x1F )
#define _Fd_ ( ( cpuRegs.code >> 6 ) & 0x1F ) #define _Fd_ ( ( cpuRegs.code >> 6 ) & 0x1F )
// Floats
#define _FtValf_ fpuRegs.fpr[ _Ft_ ].f #define _FtValf_ fpuRegs.fpr[ _Ft_ ].f
#define _FsValf_ fpuRegs.fpr[ _Fs_ ].f #define _FsValf_ fpuRegs.fpr[ _Fs_ ].f
#define _FdValf_ fpuRegs.fpr[ _Fd_ ].f #define _FdValf_ fpuRegs.fpr[ _Fd_ ].f
#define _FAValf_ fpuRegs.ACC.f #define _FAValf_ fpuRegs.ACC.f
#define _ContVal_ fpuRegs.fprc[ 31 ] // U32's
// Testing
#define _FtValUl_ fpuRegs.fpr[ _Ft_ ].UL #define _FtValUl_ fpuRegs.fpr[ _Ft_ ].UL
#define _FsValUl_ fpuRegs.fpr[ _Fs_ ].UL #define _FsValUl_ fpuRegs.fpr[ _Fs_ ].UL
#define _FdValUl_ fpuRegs.fpr[ _Fd_ ].UL #define _FdValUl_ fpuRegs.fpr[ _Fd_ ].UL
#define _FAValUl_ fpuRegs.ACC.UL #define _FAValUl_ fpuRegs.ACC.UL
// FPU Control Reg (FCR31)
#define _ContVal_ fpuRegs.fprc[ 31 ]
// FCR31 Flags
#define FPUflagC 0X00800000
#define FPUflagI 0X00020000
#define FPUflagD 0X00010000
#define FPUflagO 0X00008000
#define FPUflagU 0X00004000
#define FPUflagSI 0X00000040
#define FPUflagSD 0X00000020
#define FPUflagSO 0X00000010
#define FPUflagSU 0X00000008
//****************************************************************
// If we have an infinity value, then Overflow has occured.
#define checkOverflow(xReg, cFlagsToSet, shouldReturn) { \
if ( ( xReg & ~0x80000000 ) == PosInfinity ) { \
/*SysPrintf( "FPU OVERFLOW!: Changing to +/-Fmax!!!!!!!!!!!!\n" );*/ \
xReg = ( xReg & 0x80000000 ) | posFmax; \
_ContVal_ |= cFlagsToSet; \
if ( shouldReturn ) { return; } \
} \
}
// If we have a denormal value, then Underflow has occured.
#define checkUnderflow(xReg, cFlagsToSet, shouldReturn) { \
if ( ( ( xReg & 0x7F800000 ) == 0 ) && ( ( xReg & 0x007FFFFF ) != 0 ) ) { \
/*SysPrintf( "FPU UNDERFLOW!: Changing to +/-0!!!!!!!!!!!!\n" );*/ \
xReg &= 0x80000000; \
_ContVal_ |= cFlagsToSet; \
if ( shouldReturn ) { return; } \
} \
}
/* Checks if Divide by Zero will occur. (z/y = x)
cFlagsToSet1 = Flags to set if (z != 0)
cFlagsToSet2 = Flags to set if (z == 0)
( Denormals are counted as "0" )
*/
#define checkDivideByZero(xReg, yDivisorReg, zDividendReg, cFlagsToSet1, cFlagsToSet2, shouldReturn) { \
if ( ( yDivisorReg & 0x7F800000 ) == 0 ) { \
_ContVal_ |= ( ( zDividendReg & 0x7F800000 ) == 0 ) ? cFlagsToSet2 : cFlagsToSet1; \
xReg = ( ( yDivisorReg ^ zDividendReg ) & 0x80000000 ) | posFmax; \
if ( shouldReturn ) { return; } \
} \
}
/* Clears the "Cause Flags" of the Control/Status Reg
The "EE Core Users Manual" implies that all the Cause flags are cleared every instruction...
But, the "EE Core Instruction Set Manual" says that only certain Cause Flags are cleared
for specific instructions... I'm just setting them to clear when the Instruction Set Manual
says to... (cottonvibes)
*/
#define clearFPUFlags(cFlags) { \
_ContVal_ &= ~( cFlags ) ; \
}
#ifdef comparePrecision
// This compare discards the least-significant bit(s) in order to solve some rounding issues.
#define C_cond_S(cond) { \
FPRreg tempA, tempB; \
tempA.UL = _FsValUl_ & comparePrecision; \
tempB.UL = _FtValUl_ & comparePrecision; \
_ContVal_ = ( ( tempA.f ) cond ( tempB.f ) ) ? \
( _ContVal_ | FPUflagC ) : \
( _ContVal_ & ~FPUflagC ); \
}
#else
// Used for Comparing; This compares if the floats are exactly the same.
#define C_cond_S(cond) { \
_ContVal_ = ( _FsValf_ cond _FtValf_ ) ? \
( _ContVal_ | FPUflagC ) : \
( _ContVal_ & ~FPUflagC ); \
}
#endif
// Conditional Branch
#define BC1(cond) \
if ( ( _ContVal_ & FPUflagC ) cond 0 ) { \
intDoBranch( _BranchTarget_ ); \
}
// Conditional Branch
#define BC1L(cond) \
if ( ( _ContVal_ & FPUflagC ) cond 0 ) { \
intDoBranch( _BranchTarget_ ); \
} else cpuRegs.pc += 4;
//****************************************************************
// Used to manage FPU Opcodes
//**************************************************************** //****************************************************************
void COP1() { void COP1() {
@ -49,26 +155,6 @@ void COP1() {
Int_COP1PrintTable[_Rs_](); Int_COP1PrintTable[_Rs_]();
} }
/*********************************************************
* Load and store for COP1 *
* Format: OP rt, offset(base) *
*********************************************************/
void LWC1() {
s32 addr;
addr = cpuRegs.GPR.r[_Rs_].UL[0] + (s16)(cpuRegs.code);// ((cpuRegs.code & 0x8000 ? 0xFFFF8000 : 0)| (cpuRegs.code & 0x7fff));
memRead32(addr, &fpuRegs.fpr[_Rt_].UL);
}
void SWC1() {
s32 addr;
addr = cpuRegs.GPR.r[_Rs_].UL[0] + (s16)(cpuRegs.code);//((cpuRegs.code & 0x8000 ? 0xFFFF8000 : 0)| (cpuRegs.code & 0x7fff));
memWrite32(addr, fpuRegs.fpr[_Rt_].UL);
}
void COP1_BC1() { void COP1_BC1() {
Int_COP1BC1PrintTable[_Rt_](); Int_COP1BC1PrintTable[_Rt_]();
} }
@ -87,88 +173,226 @@ void COP1_Unknown() {
#endif #endif
} }
//****************************************************************
// FPU Opcodes
//****************************************************************
float fpuDouble(u32 f)
{
switch(f & 0x7f800000){
case 0x0:
f &= 0x80000000;
return *(float*)&f;
break;
case 0x7f800000:
f = (f & 0x80000000)|0x7f7fffff;
return *(float*)&f;
break;
default:
return *(float*)&f;
break;
}
}
void MFC1() { void ABS_S() {
if ( !_Rt_ ) return; _FdValf_ = fpufabsf( fpuDouble( _FsValUl_ ) );
cpuRegs.GPR.r[_Rt_].UD[0] = (s32)_FsValUl_; clearFPUFlags( FPUflagO | FPUflagU );
}
void ADD_S() {
_FdValf_ = fpuDouble( _FsValUl_ ) + fpuDouble( _FtValUl_ );
checkOverflow( _FdValUl_, FPUflagO | FPUflagSO, 1 );
checkUnderflow( _FdValUl_, FPUflagU | FPUflagSU, 1 );
}
void ADDA_S() {
_FAValf_ = fpuDouble( _FsValUl_ ) + fpuDouble( _FtValUl_ );
checkOverflow( _FAValUl_, FPUflagO | FPUflagSO, 1 );
checkUnderflow( _FAValUl_, FPUflagU | FPUflagSU, 1 );
}
void BC1F() {
BC1(==);
}
void BC1FL() {
BC1L(==); // Equal to 0
}
void BC1T() {
BC1(!=);
}
void BC1TL() {
BC1L(!=); // different from 0
}
void C_EQ() {
C_cond_S(==);
}
void C_F() {
clearFPUFlags( FPUflagC ); //clears C regardless
}
void C_LE() {
C_cond_S(<=);
}
void C_LT() {
C_cond_S(<);
} }
void CFC1() { void CFC1() {
if ( !_Rt_ || ( _Fs_ != 0 && _Fs_ != 31 ) ) return; if ( !_Rt_ || ( (_Fs_ != 0) && (_Fs_ != 31) ) ) return;
cpuRegs.GPR.r[_Rt_].UD[0] = (s32)fpuRegs.fprc[_Fs_]; cpuRegs.GPR.r[_Rt_].UD[0] = (s32)fpuRegs.fprc[_Fs_];
} }
void MTC1() {
_FsValUl_ = cpuRegs.GPR.r[_Rt_].UL[0];
}
void CTC1() { void CTC1() {
if(_Fs_!=31) return; if(_Fs_!=31) return;
fpuRegs.fprc[_Fs_] = cpuRegs.GPR.r[_Rt_].UL[0]; fpuRegs.fprc[_Fs_] = cpuRegs.GPR.r[_Rt_].UL[0];
} }
#define C_cond_S(cond) \ void CVT_S() {
_ContVal_ = ( _FsValf_ cond _FtValf_ ) ? \ _FdValf_ = (float)(s32)_FsValUl_;
( _ContVal_ | 0x00800000 ) : \ _FdValf_ = fpuDouble( _FdValUl_ );
( _ContVal_ & ~0x00800000 );
void C_F() { _ContVal_ &= ~0x00800000;} //clears C regardless
void C_EQ() { C_cond_S(==); }
void C_LT() { C_cond_S(<); }
void C_LE() { C_cond_S(<=); }
#define BC1(cond) \
if ( ( _ContVal_ & 0x00800000 ) cond 0 ) { \
intDoBranch( _BranchTarget_ ); \
}
void BC1F() { BC1(==); }
void BC1T() { BC1(!=); }
#define BC1L(cond) \
if ( ( _ContVal_ & 0x00800000 ) cond 0 ) { \
intDoBranch( _BranchTarget_ ); \
} else cpuRegs.pc += 4;
void BC1FL() { BC1L(==); } // Equal to 0
void BC1TL() { BC1L(!=); } // different from 0
void ADD_S() { _FdValf_ = _FsValf_ + _FtValf_; }
void SUB_S() { _FdValf_ = _FsValf_ - _FtValf_; }
void MUL_S() { _FdValf_ = _FsValf_ * _FtValf_; }
void MOV_S() { _FdValf_ = _FsValf_; }
void NEG_S() { _FdValf_ = -_FsValf_; }
void ADDA_S() { _FAValf_ = _FsValf_ + _FtValf_; }
void SUBA_S() { _FAValf_ = _FsValf_ - _FtValf_; }
void MULA_S() { _FAValf_ = _FsValf_ * _FtValf_; }
void MADD_S() { _FdValf_ = _FAValf_ + ( _FsValf_ * _FtValf_ ); }
void MSUB_S() { _FdValf_ = _FAValf_ - ( _FsValf_ * _FtValf_ ); }
void MADDA_S() { _FAValf_ += _FsValf_ * _FtValf_; }
void MSUBA_S() { _FAValf_ -= _FsValf_ * _FtValf_; }
void ABS_S() { _FdValf_ = fpufabsf(_FsValf_); }
void MAX_S() { _FdValf_ = max( _FsValf_, _FtValf_ ); }
void MIN_S() { _FdValf_ = min( _FsValf_, _FtValf_ ); }
void DIV_S() { if ( _FtValf_ ) { _FdValf_ = _FsValf_ / _FtValf_; } }
void SQRT_S() {
//if ( _FtValf_ >= 0.0f ) { _FdValf_ = fpusqrtf( _FtValf_ ); }
//else {
_FdValf_ = fpusqrtf(fpufabsf(_FtValf_));
//}
}
void CVT_S() { _FdValf_ = (float)(s32)_FsValUl_; }
void CVT_W() {
if ( ( _FsValUl_ & 0x7F800000 ) <= 0x4E800000 ) { _FdValUl_ = (s32)(float)_FsValf_; }
else if ( _FsValUl_ & 0x80000000 ) { _FdValUl_ = 0x80000000; }
else { _FdValUl_ = 0x7fffffff; }
} }
void CVT_W() {
if ( ( _FsValUl_ & 0x7F800000 ) <= 0x4E800000 ) { _FdValUl_ = (s32)(float)_FsValf_; }
else if ( ( _FsValUl_ & 0x80000000 ) == 0 ) { _FdValUl_ = 0x7fffffff; }
else { _FdValUl_ = 0x80000000; }
}
void DIV_S() {
checkDivideByZero( _FdValUl_, _FtValUl_, _FsValUl_, FPUflagD | FPUflagSD, FPUflagI | FPUflagSI, 1 );
_FdValf_ = fpuDouble( _FsValUl_ ) / fpuDouble( _FtValUl_ );
checkOverflow( _FdValUl_, 0, 1);
checkUnderflow( _FdValUl_, 0, 1 );
}
void LWC1() {
u32 addr;
addr = cpuRegs.GPR.r[_Rs_].UL[0] + (s32)(s16)(cpuRegs.code);
if (addr & 0x00000003) { SysPrintf( "FPU (LWC1 Opcode): Invalid Memory Address\n" ); return; } // Should signal an exception?
memRead32(addr, &fpuRegs.fpr[_Rt_].UL);
}
/* The Instruction Set manual has an overly complicated way of
determining the flags that are set. Hopefully this shorter
method provides a similar outcome and is faster. (cottonvibes)
*/
void MADD_S() {
FPRreg temp;
temp.f = fpuDouble( _FsValUl_ ) * fpuDouble( _FtValUl_ );
_FdValf_ = fpuDouble( _FAValUl_ ) + fpuDouble( temp.UL );
checkOverflow( _FdValUl_, FPUflagO | FPUflagSO, 1 );
checkUnderflow( _FdValUl_, FPUflagU | FPUflagSU, 1 );
}
void MADDA_S() {
_FAValf_ += fpuDouble( _FsValUl_ ) * fpuDouble( _FtValUl_ );
checkOverflow( _FAValUl_, FPUflagO | FPUflagSO, 1 );
checkUnderflow( _FAValUl_, FPUflagU | FPUflagSU, 1 );
}
void MAX_S() {
_FdValf_ = max( _FsValf_, _FtValf_ );
clearFPUFlags( FPUflagO | FPUflagU );
}
void MFC1() {
if ( !_Rt_ ) return;
cpuRegs.GPR.r[_Rt_].UD[0] = (s32)_FsValUl_;
}
void MIN_S() {
_FdValf_ = min( _FsValf_, _FtValf_ );
clearFPUFlags( FPUflagO | FPUflagU );
}
void MOV_S() {
_FdValUl_ = _FsValUl_;
}
void MSUB_S() {
FPRreg temp;
temp.f = fpuDouble( _FsValUl_ ) * fpuDouble( _FtValUl_ );
_FdValf_ = fpuDouble( _FAValUl_ ) - fpuDouble( temp.UL );
checkOverflow( _FdValUl_, FPUflagO | FPUflagSO, 1 );
checkUnderflow( _FdValUl_, FPUflagU | FPUflagSU, 1 );
}
void MSUBA_S() {
_FAValf_ -= fpuDouble( _FsValUl_ ) * fpuDouble( _FtValUl_ );
checkOverflow( _FAValUl_, FPUflagO | FPUflagSO, 1 );
checkUnderflow( _FAValUl_, FPUflagU | FPUflagSU, 1 );
}
void MTC1() {
_FsValUl_ = cpuRegs.GPR.r[_Rt_].UL[0];
}
void MUL_S() {
_FdValf_ = fpuDouble( _FsValUl_ ) * fpuDouble( _FtValUl_ );
checkOverflow( _FdValUl_, FPUflagO | FPUflagSO, 1 );
checkUnderflow( _FdValUl_, FPUflagU | FPUflagSU, 1 );
}
void MULA_S() {
_FAValf_ = fpuDouble( _FsValUl_ ) * fpuDouble( _FtValUl_ );
checkOverflow( _FAValUl_, FPUflagO | FPUflagSO, 1 );
checkUnderflow( _FAValUl_, FPUflagU | FPUflagSU, 1 );
}
void NEG_S() {
_FdValUl_ = (_FsValUl_ ^ 0x80000000);
clearFPUFlags( FPUflagO | FPUflagU );
}
void RSQRT_S() { void RSQRT_S() {
if ( _FtValf_ >= 0.0f ) { FPRreg temp;
float tmp = fpusqrtf( _FtValf_ ); if ( ( _FtValUl_ & 0x7F800000 ) == 0 ) { // Ft is zero (Denormals are Zero)
if ( tmp != 0 ) { _FdValf_ = _FsValf_ / tmp; } _ContVal_ |= FPUflagD | FPUflagSD;
_FdValUl_ = ( ( _FsValUl_ ^ _FtValUl_ ) & 0x80000000 ) | posFmax;
return;
} }
else if ( _FtValUl_ & 0x80000000 ) { // Ft is negative
_ContVal_ |= FPUflagI | FPUflagSI;
temp.f = fpusqrtf( fpufabsf( fpuDouble( _FtValUl_ ) ) );
_FdValf_ = fpuDouble( _FsValUl_ ) / fpuDouble( temp.UL );
}
else { _FdValf_ = fpuDouble( _FsValUl_ ) / fpusqrtf( fpuDouble( _FtValUl_ ) ); } // Ft is positive and not zero
checkOverflow( _FdValUl_, 0, 1 );
checkUnderflow( _FdValUl_, 0, 1 );
} }
//3322 2222 2222 1111 1111 1100 0000 0000 void SQRT_S() {
//1098 7654 3210 9876 5432 1098 7654 3210 if ( ( _FtValUl_ & 0xFF800000 ) == 0x80000000 ) { _FdValUl_ = 0x80000000; } // If Ft = -0
//0000 0000 0000 0000 0000 0000 0000 0000 else if ( _FtValUl_ & 0x80000000 ) { // If Ft is Negative
_ContVal_ |= FPUflagI | FPUflagSI;
_FdValf_ = fpusqrtf( fpufabsf( fpuDouble( _FtValUl_ ) ) );
}
else { _FdValf_ = fpusqrtf( fpuDouble( _FtValUl_ ) ); } // If Ft is Positive
clearFPUFlags( FPUflagD );
}
void SUB_S() {
_FdValf_ = fpuDouble( _FsValUl_ ) - fpuDouble( _FtValUl_ );
checkOverflow( _FdValUl_, FPUflagO | FPUflagSO, 1 );
checkUnderflow( _FdValUl_, FPUflagU | FPUflagSU, 1 );
}
void SUBA_S() {
_FAValf_ = fpuDouble( _FsValUl_ ) - fpuDouble( _FtValUl_ );
checkOverflow( _FAValUl_, FPUflagO | FPUflagSO, 1 );
checkUnderflow( _FAValUl_, FPUflagU | FPUflagSU, 1 );
}
void SWC1() {
u32 addr;
addr = cpuRegs.GPR.r[_Rs_].UL[0] + (s32)(s16)(cpuRegs.code);
if (addr & 0x00000003) { SysPrintf( "FPU (SWC1 Opcode): Invalid Memory Address\n" ); return; } // Should signal an exception?
memWrite32(addr, fpuRegs.fpr[_Rt_].UL);
}

View File

@ -1,19 +1,19 @@
/* Pcsx2 - Pc Ps2 Emulator /* Pcsx2 - Pc Ps2 Emulator
* Copyright (C) 2002-2008 Pcsx2 Team * Copyright (C) 2002-2003 Pcsx2 Team
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or * the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version. * (at your option) any later version.
* *
* This program is distributed in the hope that it will be useful, * This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of * but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details. * GNU General Public License for more details.
* *
* You should have received a copy of the GNU General Public License * You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/ */
#include <stdio.h> #include <stdio.h>
@ -40,8 +40,6 @@
#include "Cache.h" #include "Cache.h"
#include "Paths.h"
u32 dwSaveVersion = 0x7a300010; u32 dwSaveVersion = 0x7a300010;
u32 dwCurSaveStateVer = 0; u32 dwCurSaveStateVer = 0;
extern u32 s_iLastCOP0Cycle; extern u32 s_iLastCOP0Cycle;
@ -581,8 +579,8 @@ int SaveState(char *file) {
SysPrintf("Saving GS\n"); SysPrintf("Saving GS\n");
if( CHECK_MULTIGS ) { if( CHECK_MULTIGS ) {
// have to call in thread, otherwise weird stuff will start happening // have to call in thread, otherwise weird stuff will start happening
u64 uf = (uptr)f; uptr uf = (uptr)f;
GSRingBufSimplePacket(GS_RINGTYPE_SAVE, (u32)(uf&0xffffffff), (u32)(uf>>32), 0); GSRingBufSimplePacket(GS_RINGTYPE_SAVE, (int)(uf&0xffffffff), (int)(uf>>32), 0);
gsWaitGS(); gsWaitGS();
} }
else { else {
@ -713,8 +711,8 @@ int LoadState(char *file) {
SysPrintf("Loading GS\n"); SysPrintf("Loading GS\n");
if( CHECK_MULTIGS ) { if( CHECK_MULTIGS ) {
// have to call in thread, otherwise weird stuff will start happening // have to call in thread, otherwise weird stuff will start happening
u64 uf = (uptr)f; uptr uf = (uptr)f;
GSRingBufSimplePacket(GS_RINGTYPE_LOAD, (u32)(uf&0xffffffff), (u32)(uf>>32), 0); GSRingBufSimplePacket(GS_RINGTYPE_LOAD, (int)(uf&0xffffffff), (int)(uf>>32), 0);
gsWaitGS(); gsWaitGS();
} }
else { else {
@ -757,7 +755,7 @@ int SaveGSState(char *file)
return 0; return 0;
} }
extern HWND pDsp; extern long pDsp;
int LoadGSState(char *file) int LoadGSState(char *file)
{ {
int ret; int ret;
@ -768,7 +766,7 @@ int LoadGSState(char *file)
f = gzopen(file, "rb"); f = gzopen(file, "rb");
if (f == NULL) { if (f == NULL) {
sprintf(strfile, SSTATES_DIR "/%s", file); sprintf(strfile, "sstates/%s", file);
// try prefixing with sstates // try prefixing with sstates
f = gzopen(strfile, "rb"); f = gzopen(strfile, "rb");
if( f == NULL ) { if( f == NULL ) {
@ -894,7 +892,7 @@ void ProcessFKeys(int fkey, int shift)
assert(fkey >= 1 && fkey <= 12 ); assert(fkey >= 1 && fkey <= 12 );
switch(fkey) { switch(fkey) {
case 1: case 1:
sprintf(Text, SSTATES_DIR "/%8.8X.%3.3d", ElfCRC, StatesC); sprintf(Text, "sstates/%8.8X.%3.3d", ElfCRC, StatesC);
ret = SaveState(Text); ret = SaveState(Text);
break; break;
case 2: case 2:
@ -904,12 +902,12 @@ void ProcessFKeys(int fkey, int shift)
StatesC = (StatesC+1)%NUM_STATES; StatesC = (StatesC+1)%NUM_STATES;
SysPrintf("*PCSX2*: Selected State %ld\n", StatesC); SysPrintf("*PCSX2*: Selected State %ld\n", StatesC);
if( GSchangeSaveState != NULL ) { if( GSchangeSaveState != NULL ) {
sprintf(Text, SSTATES_DIR "/%8.8X.%3.3d", ElfCRC, StatesC); sprintf(Text, "sstates/%8.8X.%3.3d", ElfCRC, StatesC);
GSchangeSaveState(StatesC, Text); GSchangeSaveState(StatesC, Text);
} }
break; break;
case 3: case 3:
sprintf (Text, SSTATES_DIR "/%8.8X.%3.3d", ElfCRC, StatesC); sprintf (Text, "sstates/%8.8X.%3.3d", ElfCRC, StatesC);
ret = LoadState(Text); ret = LoadState(Text);
break; break;
@ -996,10 +994,10 @@ void ProcessFKeys(int fkey, int shift)
tok = strtok(NULL, " "); tok = strtok(NULL, " ");
if( tok != NULL ) strcat(name, tok); if( tok != NULL ) strcat(name, tok);
sprintf(Text, SSTATES_DIR "/%s.%d.gs", name, StatesC); sprintf(Text, "sstates/%s.%d.gs", name, StatesC);
} }
else else
sprintf(Text, SSTATES_DIR "/%8.8X.%d.gs", ElfCRC, StatesC); sprintf(Text, "sstates/%8.8X.%d.gs", ElfCRC, StatesC);
SaveGSState(Text); SaveGSState(Text);
} }

View File

@ -13,7 +13,7 @@
* *
* You should have received a copy of the GNU General Public License * You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/ */
#ifndef __MISC_H__ #ifndef __MISC_H__
@ -52,7 +52,14 @@
#define CHECK_DUALCORE (Config.Options&PCSX2_DUALCORE) #define CHECK_DUALCORE (Config.Options&PCSX2_DUALCORE)
#define CHECK_EEREC (Config.Options&PCSX2_EEREC) #define CHECK_EEREC (Config.Options&PCSX2_EEREC)
#define CHECK_COP2REC (Config.Options&PCSX2_COP2REC) // goes with ee option #define CHECK_COP2REC (Config.Options&PCSX2_COP2REC) // goes with ee option
#define CHECK_FORCEABS (~(Config.Hacks >> 1) & 1) // always on, (Config.Options&PCSX2_FORCEABS) //------------ SPEED HACKS!!! ---------------
#define CHECK_OVERFLOW (!(Config.Hacks & 0x2))
#define CHECK_EXTRA_OVERFLOW (!(Config.Hacks & 0x40))
#define CHECK_EESYNC_HACK (Config.Hacks & 0x1)
#define CHECK_IOPSYNC_HACK (Config.Hacks & 0x10)
#define CHECK_EE_IOP_EXTRA (Config.Hacks & 0x20)
#define CHECK_DENORMALS ((Config.Hacks & 0x8) ? 0xffc0 : 0xff80) //If enabled, Denormals are Zero for the recs
#define CHECK_FASTBRANCHES (Config.Hacks & 0x80)
#define CHECK_FRAMELIMIT (Config.Options&PCSX2_FRAMELIMIT_MASK) #define CHECK_FRAMELIMIT (Config.Options&PCSX2_FRAMELIMIT_MASK)

View File

@ -1,19 +1,19 @@
/* Pcsx2 - Pc Ps2 Emulator /* Pcsx2 - Pc Ps2 Emulator
* Copyright (C) 2002-2008 Pcsx2 Team * Copyright (C) 2002-2004 Pcsx2 Team
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or * the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version. * (at your option) any later version.
* *
* This program is distributed in the hope that it will be useful, * This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of * but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details. * GNU General Public License for more details.
* *
* You should have received a copy of the GNU General Public License * You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/ */
#include <windows.h> #include <windows.h>

View File

@ -2,18 +2,6 @@ Microsoft Visual Studio Solution File, Format Version 9.00
# Visual Studio 2005 # Visual Studio 2005
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "pcsx2", "pcsx2_2005.vcproj", "{1CEFD830-2B76-4596-A4EE-BCD7280A60BD}" Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "pcsx2", "pcsx2_2005.vcproj", "{1CEFD830-2B76-4596-A4EE-BCD7280A60BD}"
EndProject EndProject
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "spu2PeopsSound", "..\..\..\plugins\spu2\PeopsSPU2\spu2PeopsSound_2005.vcproj", "{F9E64144-301B-48BC-8D35-A2686DBB1982}"
EndProject
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "ZeroSPU2", "..\..\..\plugins\spu2\zerospu2\ZeroSPU2_2005.vcproj", "{7F059854-568D-4E08-9D00-1E78E203E4DC}"
EndProject
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "ZeroPAD", "..\..\..\plugins\pad\zeropad\Windows\ZeroPAD_2005.vcproj", "{CDD9DB83-3BD9-4ED8-BB83-399A2F65F022}"
EndProject
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "SPU2null", "..\..\..\plugins\spu2\SPU2null\Src\SPU2null_2005.vcproj", "{D87F63EC-5CD8-4A41-B416-16C7ABD4E5CB}"
EndProject
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "zerogs", "..\..\..\plugins\gs\zerogs\dx\Win32\zerogs_2005.vcproj", "{5C6B7D28-E73D-4F71-8FC0-17ADA640EBD8}"
EndProject
Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "CDVDiso", "..\..\..\plugins\cdvd\CDVDiso\src\Win32\CDVDiso_2005.vcproj", "{BB27CC2C-28D1-4438-A0DF-3E120D01EDEC}"
EndProject
Global Global
GlobalSection(SolutionConfigurationPlatforms) = preSolution GlobalSection(SolutionConfigurationPlatforms) = preSolution
Debug TLB|Win32 = Debug TLB|Win32 Debug TLB|Win32 = Debug TLB|Win32
@ -33,66 +21,6 @@ Global
{1CEFD830-2B76-4596-A4EE-BCD7280A60BD}.Release TLB|Win32.Build.0 = Release TLB|Win32 {1CEFD830-2B76-4596-A4EE-BCD7280A60BD}.Release TLB|Win32.Build.0 = Release TLB|Win32
{1CEFD830-2B76-4596-A4EE-BCD7280A60BD}.Release|Win32.ActiveCfg = Release|Win32 {1CEFD830-2B76-4596-A4EE-BCD7280A60BD}.Release|Win32.ActiveCfg = Release|Win32
{1CEFD830-2B76-4596-A4EE-BCD7280A60BD}.Release|Win32.Build.0 = Release|Win32 {1CEFD830-2B76-4596-A4EE-BCD7280A60BD}.Release|Win32.Build.0 = Release|Win32
{F9E64144-301B-48BC-8D35-A2686DBB1982}.Debug TLB|Win32.ActiveCfg = Debug|Win32
{F9E64144-301B-48BC-8D35-A2686DBB1982}.Debug TLB|Win32.Build.0 = Debug|Win32
{F9E64144-301B-48BC-8D35-A2686DBB1982}.Debug|Win32.ActiveCfg = Debug|Win32
{F9E64144-301B-48BC-8D35-A2686DBB1982}.Debug|Win32.Build.0 = Debug|Win32
{F9E64144-301B-48BC-8D35-A2686DBB1982}.Release (to Public)|Win32.ActiveCfg = Release|Win32
{F9E64144-301B-48BC-8D35-A2686DBB1982}.Release (to Public)|Win32.Build.0 = Release|Win32
{F9E64144-301B-48BC-8D35-A2686DBB1982}.Release TLB|Win32.ActiveCfg = Release|Win32
{F9E64144-301B-48BC-8D35-A2686DBB1982}.Release TLB|Win32.Build.0 = Release|Win32
{F9E64144-301B-48BC-8D35-A2686DBB1982}.Release|Win32.ActiveCfg = Release|Win32
{F9E64144-301B-48BC-8D35-A2686DBB1982}.Release|Win32.Build.0 = Release|Win32
{7F059854-568D-4E08-9D00-1E78E203E4DC}.Debug TLB|Win32.ActiveCfg = Debug|Win32
{7F059854-568D-4E08-9D00-1E78E203E4DC}.Debug TLB|Win32.Build.0 = Debug|Win32
{7F059854-568D-4E08-9D00-1E78E203E4DC}.Debug|Win32.ActiveCfg = Debug|Win32
{7F059854-568D-4E08-9D00-1E78E203E4DC}.Debug|Win32.Build.0 = Debug|Win32
{7F059854-568D-4E08-9D00-1E78E203E4DC}.Release (to Public)|Win32.ActiveCfg = Release|Win32
{7F059854-568D-4E08-9D00-1E78E203E4DC}.Release (to Public)|Win32.Build.0 = Release|Win32
{7F059854-568D-4E08-9D00-1E78E203E4DC}.Release TLB|Win32.ActiveCfg = Release|Win32
{7F059854-568D-4E08-9D00-1E78E203E4DC}.Release TLB|Win32.Build.0 = Release|Win32
{7F059854-568D-4E08-9D00-1E78E203E4DC}.Release|Win32.ActiveCfg = Release|Win32
{7F059854-568D-4E08-9D00-1E78E203E4DC}.Release|Win32.Build.0 = Release|Win32
{CDD9DB83-3BD9-4ED8-BB83-399A2F65F022}.Debug TLB|Win32.ActiveCfg = Debug|Win32
{CDD9DB83-3BD9-4ED8-BB83-399A2F65F022}.Debug TLB|Win32.Build.0 = Debug|Win32
{CDD9DB83-3BD9-4ED8-BB83-399A2F65F022}.Debug|Win32.ActiveCfg = Debug|Win32
{CDD9DB83-3BD9-4ED8-BB83-399A2F65F022}.Debug|Win32.Build.0 = Debug|Win32
{CDD9DB83-3BD9-4ED8-BB83-399A2F65F022}.Release (to Public)|Win32.ActiveCfg = Release|Win32
{CDD9DB83-3BD9-4ED8-BB83-399A2F65F022}.Release (to Public)|Win32.Build.0 = Release|Win32
{CDD9DB83-3BD9-4ED8-BB83-399A2F65F022}.Release TLB|Win32.ActiveCfg = Release|Win32
{CDD9DB83-3BD9-4ED8-BB83-399A2F65F022}.Release TLB|Win32.Build.0 = Release|Win32
{CDD9DB83-3BD9-4ED8-BB83-399A2F65F022}.Release|Win32.ActiveCfg = Release|Win32
{CDD9DB83-3BD9-4ED8-BB83-399A2F65F022}.Release|Win32.Build.0 = Release|Win32
{D87F63EC-5CD8-4A41-B416-16C7ABD4E5CB}.Debug TLB|Win32.ActiveCfg = Debug|Win32
{D87F63EC-5CD8-4A41-B416-16C7ABD4E5CB}.Debug TLB|Win32.Build.0 = Debug|Win32
{D87F63EC-5CD8-4A41-B416-16C7ABD4E5CB}.Debug|Win32.ActiveCfg = Debug|Win32
{D87F63EC-5CD8-4A41-B416-16C7ABD4E5CB}.Debug|Win32.Build.0 = Debug|Win32
{D87F63EC-5CD8-4A41-B416-16C7ABD4E5CB}.Release (to Public)|Win32.ActiveCfg = Release|Win32
{D87F63EC-5CD8-4A41-B416-16C7ABD4E5CB}.Release (to Public)|Win32.Build.0 = Release|Win32
{D87F63EC-5CD8-4A41-B416-16C7ABD4E5CB}.Release TLB|Win32.ActiveCfg = Release|Win32
{D87F63EC-5CD8-4A41-B416-16C7ABD4E5CB}.Release TLB|Win32.Build.0 = Release|Win32
{D87F63EC-5CD8-4A41-B416-16C7ABD4E5CB}.Release|Win32.ActiveCfg = Release|Win32
{D87F63EC-5CD8-4A41-B416-16C7ABD4E5CB}.Release|Win32.Build.0 = Release|Win32
{5C6B7D28-E73D-4F71-8FC0-17ADA640EBD8}.Debug TLB|Win32.ActiveCfg = Debug|Win32
{5C6B7D28-E73D-4F71-8FC0-17ADA640EBD8}.Debug TLB|Win32.Build.0 = Debug|Win32
{5C6B7D28-E73D-4F71-8FC0-17ADA640EBD8}.Debug|Win32.ActiveCfg = Debug|Win32
{5C6B7D28-E73D-4F71-8FC0-17ADA640EBD8}.Debug|Win32.Build.0 = Debug|Win32
{5C6B7D28-E73D-4F71-8FC0-17ADA640EBD8}.Release (to Public)|Win32.ActiveCfg = Release (to Public)|Win32
{5C6B7D28-E73D-4F71-8FC0-17ADA640EBD8}.Release (to Public)|Win32.Build.0 = Release (to Public)|Win32
{5C6B7D28-E73D-4F71-8FC0-17ADA640EBD8}.Release TLB|Win32.ActiveCfg = Release (to Public)|Win32
{5C6B7D28-E73D-4F71-8FC0-17ADA640EBD8}.Release TLB|Win32.Build.0 = Release (to Public)|Win32
{5C6B7D28-E73D-4F71-8FC0-17ADA640EBD8}.Release|Win32.ActiveCfg = Release|Win32
{5C6B7D28-E73D-4F71-8FC0-17ADA640EBD8}.Release|Win32.Build.0 = Release|Win32
{BB27CC2C-28D1-4438-A0DF-3E120D01EDEC}.Debug TLB|Win32.ActiveCfg = Debug|Win32
{BB27CC2C-28D1-4438-A0DF-3E120D01EDEC}.Debug TLB|Win32.Build.0 = Debug|Win32
{BB27CC2C-28D1-4438-A0DF-3E120D01EDEC}.Debug|Win32.ActiveCfg = Debug|Win32
{BB27CC2C-28D1-4438-A0DF-3E120D01EDEC}.Debug|Win32.Build.0 = Debug|Win32
{BB27CC2C-28D1-4438-A0DF-3E120D01EDEC}.Release (to Public)|Win32.ActiveCfg = Release|Win32
{BB27CC2C-28D1-4438-A0DF-3E120D01EDEC}.Release (to Public)|Win32.Build.0 = Release|Win32
{BB27CC2C-28D1-4438-A0DF-3E120D01EDEC}.Release TLB|Win32.ActiveCfg = Release|Win32
{BB27CC2C-28D1-4438-A0DF-3E120D01EDEC}.Release TLB|Win32.Build.0 = Release|Win32
{BB27CC2C-28D1-4438-A0DF-3E120D01EDEC}.Release|Win32.ActiveCfg = Release|Win32
{BB27CC2C-28D1-4438-A0DF-3E120D01EDEC}.Release|Win32.Build.0 = Release|Win32
EndGlobalSection EndGlobalSection
GlobalSection(SolutionProperties) = preSolution GlobalSection(SolutionProperties) = preSolution
HideSolutionNode = FALSE HideSolutionNode = FALSE

View File

@ -5,15 +5,15 @@
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or * the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version. * (at your option) any later version.
* *
* This program is distributed in the hope that it will be useful, * This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of * but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details. * GNU General Public License for more details.
* *
* You should have received a copy of the GNU General Public License * You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/ */
#define WINVER 0x0500 #define WINVER 0x0500
@ -49,8 +49,6 @@
#include "cheats/cheats.h" #include "cheats/cheats.h"
#include "../Paths.h"
#define COMPILEDATE __DATE__ #define COMPILEDATE __DATE__
static int efile; static int efile;
@ -606,6 +604,10 @@ void CALLBACK KeyEvent(keyEvent* ev)
case VK_F10: ProcessFKeys(10, shiftkey); break; case VK_F10: ProcessFKeys(10, shiftkey); break;
case VK_F11: ProcessFKeys(11, shiftkey); break; case VK_F11: ProcessFKeys(11, shiftkey); break;
case VK_F12: ProcessFKeys(12, shiftkey); break; case VK_F12: ProcessFKeys(12, shiftkey); break;
/*case VK_NUMPAD0:
Config.Hacks ^= 2;
if (Config.Hacks & 2) {SysPrintf( "Overflow Check OFF\n" );} else {SysPrintf( "Overflow Check ON\n" );}
break;*/
case VK_ESCAPE: case VK_ESCAPE:
#ifdef PCSX2_DEVBUILD #ifdef PCSX2_DEVBUILD
@ -616,16 +618,21 @@ void CALLBACK KeyEvent(keyEvent* ev)
} }
#endif #endif
ClosePlugins();
if( !UseGui ) { ClosePlugins();
// not using GUI and user just quit, so exit SysClose();
exit(0); //ReleasePlugins();
} //needReset = 1;
//efile = 0;
//if( !UseGui ) {
//not using GUI and user just quit, so exit
exit(0);
//}
CreateMainWindow(SW_SHOWNORMAL); CreateMainWindow(SW_SHOWNORMAL);
RunGui(); RunGui();
nDisableSC = 0; nDisableSC = 0;
break; break;
default: default:
GSkeyEvent(ev); GSkeyEvent(ev);
@ -707,18 +714,28 @@ BOOL APIENTRY HacksProc(HWND hDlg, UINT message, WPARAM wParam, LPARAM lParam) {
switch (message) { switch (message) {
case WM_INITDIALOG: case WM_INITDIALOG:
if(Config.Hacks & 1) CheckDlgButton(hDlg, IDC_SYNCHACK, TRUE); if(Config.Hacks & 0x1) CheckDlgButton(hDlg, IDC_SYNCHACK, TRUE);
if(Config.Hacks & 2) CheckDlgButton(hDlg, IDC_ABSHACK, TRUE); if(Config.Hacks & 0x2) CheckDlgButton(hDlg, IDC_OVERFLOWHACK, TRUE);
if(Config.Hacks & 4) CheckDlgButton(hDlg, IDC_SOUNDHACK, TRUE); if(Config.Hacks & 0x4) CheckDlgButton(hDlg, IDC_SOUNDHACK, TRUE);
return TRUE; if(Config.Hacks & 0x8) CheckDlgButton(hDlg, IDC_DENORMALS, TRUE);
if(Config.Hacks & 0x10) CheckDlgButton(hDlg, IDC_SYNCHACK2, TRUE);
if(Config.Hacks & 0x20) CheckDlgButton(hDlg, IDC_SYNCHACK3, TRUE);
if(Config.Hacks & 0x40) CheckDlgButton(hDlg, IDC_OVERFLOWHACK_EXTRA, TRUE);
if(Config.Hacks & 0x80) CheckDlgButton(hDlg, IDC_FASTBRANCHES, TRUE);
return TRUE;
case WM_COMMAND: case WM_COMMAND:
if (LOWORD(wParam) == IDOK) { if (LOWORD(wParam) == IDOK) {
Config.Hacks = 0; Config.Hacks = 0;
Config.Hacks |= IsDlgButtonChecked(hDlg, IDC_SYNCHACK) ? 1 : 0; Config.Hacks |= IsDlgButtonChecked(hDlg, IDC_SYNCHACK) ? 0x1 : 0;
Config.Hacks |= IsDlgButtonChecked(hDlg, IDC_ABSHACK) ? 2 : 0; Config.Hacks |= IsDlgButtonChecked(hDlg, IDC_OVERFLOWHACK) ? 0x2 : 0;
Config.Hacks |= IsDlgButtonChecked(hDlg, IDC_SOUNDHACK) ? 4 : 0; Config.Hacks |= IsDlgButtonChecked(hDlg, IDC_SOUNDHACK) ? 0x4 : 0;
Config.Hacks |= IsDlgButtonChecked(hDlg, IDC_DENORMALS) ? 0x8 : 0;
Config.Hacks |= IsDlgButtonChecked(hDlg, IDC_SYNCHACK2) ? 0x10 : 0;
Config.Hacks |= IsDlgButtonChecked(hDlg, IDC_SYNCHACK3) ? 0x20 : 0;
Config.Hacks |= IsDlgButtonChecked(hDlg, IDC_OVERFLOWHACK_EXTRA) ? 0x40 : 0;
Config.Hacks |= IsDlgButtonChecked(hDlg, IDC_FASTBRANCHES) ? 0x80 : 0;
SaveConfig(); SaveConfig();
EndDialog(hDlg, TRUE); EndDialog(hDlg, TRUE);
@ -1350,16 +1367,16 @@ void ChangeLanguage(char *lang) {
static int sinit=0; static int sinit=0;
int SysInit() { int SysInit() {
CreateDirectory(MEMCARDS_DIR, NULL); CreateDirectory("memcards", NULL);
CreateDirectory(SSTATES_DIR, NULL); CreateDirectory("sstates", NULL);
#ifdef EMU_LOG #ifdef EMU_LOG
CreateDirectory(LOGS_DIR, NULL); CreateDirectory("logs", NULL);
#ifdef PCSX2_DEVBUILD #ifdef PCSX2_DEVBUILD
if( g_TestRun.plogname != NULL ) if( g_TestRun.plogname != NULL )
emuLog = fopen(g_TestRun.plogname, "w"); emuLog = fopen(g_TestRun.plogname, "w");
if( emuLog == NULL ) if( emuLog == NULL )
emuLog = fopen(LOGS_DIR "\\emuLog.txt","w"); emuLog = fopen("logs\\emuLog.txt","w");
#endif #endif
if( emuLog != NULL ) if( emuLog != NULL )

View File

@ -1,21 +1,20 @@
/* Pcsx2 - Pc Ps2 Emulator /* Pcsx2 - Pc Ps2 Emulator
* Copyright (C) 2002-2008 Pcsx2 Team * Copyright (C) 2002-2003 Pcsx2 Team
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or * the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version. * (at your option) any later version.
* *
* This program is distributed in the hope that it will be useful, * This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of * but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details. * GNU General Public License for more details.
* *
* You should have received a copy of the GNU General Public License * You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/ */
/* /*
15-09-2004 : file rewriten for work with inis (shadow) 15-09-2004 : file rewriten for work with inis (shadow)
*/ */
@ -27,8 +26,6 @@
#include "win32.h" #include "win32.h"
#include <sys/stat.h> #include <sys/stat.h>
#include "Paths.h"
int LoadConfig() { int LoadConfig() {
FILE *fp; FILE *fp;
@ -44,11 +41,11 @@ int LoadConfig() {
szTemp = strrchr(szIniFile, '\\'); szTemp = strrchr(szIniFile, '\\');
if(!szTemp) return -1; if(!szTemp) return -1;
strcpy(szTemp, "\\" CONFIG_DIR "\\pcsx2.ini"); strcpy(szTemp, "\\inis\\pcsx2.ini");
fp=fopen(CONFIG_DIR "\\pcsx2.ini","rt");//check if pcsx2.ini really exists fp=fopen("inis\\pcsx2.ini","rt");//check if pcsx2.ini really exists
if (!fp) if (!fp)
{ {
CreateDirectory(CONFIG_DIR,NULL); CreateDirectory("inis",NULL);
return -1; return -1;
} }
fclose(fp); fclose(fp);
@ -129,7 +126,7 @@ void SaveConfig() {
szTemp = strrchr(szIniFile, '\\'); szTemp = strrchr(szIniFile, '\\');
if(!szTemp) return; if(!szTemp) return;
strcpy(szTemp, "\\" CONFIG_DIR "\\pcsx2.ini"); strcpy(szTemp, "\\inis\\pcsx2.ini");
//interface //interface
sprintf(szValue,"%s",Conf->Bios); sprintf(szValue,"%s",Conf->Bios);
WritePrivateProfileString("Interface","Bios",szValue,szIniFile); WritePrivateProfileString("Interface","Bios",szValue,szIniFile);

View File

@ -938,19 +938,30 @@ BEGIN
CONTROL 132,IDC_PS2SILVER_RECT,"Static",SS_BITMAP,0,167,70,74 CONTROL 132,IDC_PS2SILVER_RECT,"Static",SS_BITMAP,0,167,70,74
END END
IDD_HACKS DIALOGEX 0, 0, 186, 103 IDD_HACKS DIALOGEX 0, 0, 343, 159
STYLE DS_SETFONT | DS_MODALFRAME | DS_FIXEDSYS | WS_POPUP | WS_CAPTION | WS_SYSMENU STYLE DS_SETFONT | DS_MODALFRAME | DS_FIXEDSYS | WS_POPUP | WS_CAPTION | WS_SYSMENU
CAPTION "PCSX2 Speed Hacks" CAPTION "PCSX2 Speed Hacks"
FONT 8, "MS Shell Dlg", 400, 0, 0x1 FONT 8, "MS Shell Dlg", 400, 0, 0x1
BEGIN BEGIN
DEFPUSHBUTTON "OK",IDOK,41,82,50,14 DEFPUSHBUTTON "OK",IDOK,119,138,50,14
PUSHBUTTON "Cancel",IDCANCEL,96,82,50,14 PUSHBUTTON "Cancel",IDCANCEL,174,138,50,14
CONTROL "EE/IOP Sync Hack - General Speedup",IDC_SYNCHACK,"Button",BS_AUTOCHECKBOX | WS_TABSTOP,7,46,172,10 CONTROL "EE Sync Hack (x2) - Doubles the cycle rate of the EE.",IDC_SYNCHACK,
CONTROL "Disable Forced ABS - Speeds up intense 3D",IDC_ABSHACK, "Button",BS_AUTOCHECKBOX | WS_TABSTOP,7,49,329,10
"Button",BS_AUTOCHECKBOX | WS_TABSTOP,7,34,160,10 CONTROL "Disable All Overflow Checks - Doesn't check for overflow at all in the VU Recs.",IDC_OVERFLOWHACK,
CTEXT "These hacks will effect the speed of PCSX2 but possibly comprimise on compatability",IDC_HACKDESC,7,7,172,17 "Button",BS_AUTOCHECKBOX | WS_TABSTOP,7,37,329,10
CTEXT "These hacks will effect the speed of PCSX2 but possibly comprimise on compatability",IDC_HACKDESC,7,7,329,17
CONTROL "Tighter SPU2 Sync ( FFXII vids) - slower",IDC_SOUNDHACK, CONTROL "Tighter SPU2 Sync ( FFXII vids) - slower",IDC_SOUNDHACK,
"Button",BS_AUTOCHECKBOX | WS_TABSTOP,7,59,154,9 "Button",BS_AUTOCHECKBOX | WS_TABSTOP,7,118,329,9
CONTROL "Denormals are Zero - Makes very small numbers be equal to zero. (Big speedup on Intel CPUs)",IDC_DENORMALS,
"Button",BS_AUTOCHECKBOX | WS_TABSTOP,7,104,329,9
CONTROL "IOP Sync Hack (x2) - Doubles the cycle rate of the IOP.",IDC_SYNCHACK2,
"Button",BS_AUTOCHECKBOX | WS_TABSTOP,7,62,329,10
CONTROL "EE/IOP Sync Hack (x3) - Makes EE and IOP hacks triple the cycle rate instead of doubling it.",IDC_SYNCHACK3,
"Button",BS_AUTOCHECKBOX | WS_TABSTOP,7,75,329,10
CONTROL "Disable Extra Overflow Checks - Disables extra overflow checks used to help stop SPS.",IDC_OVERFLOWHACK_EXTRA,
"Button",BS_AUTOCHECKBOX | WS_TABSTOP,7,24,329,10
CONTROL "EE/IOP Fast Branches - Quick branching (very small speedup)",IDC_FASTBRANCHES,
"Button",BS_AUTOCHECKBOX | WS_TABSTOP,7,89,329,10
END END
@ -971,9 +982,9 @@ BEGIN
IDD_HACKS, DIALOG IDD_HACKS, DIALOG
BEGIN BEGIN
LEFTMARGIN, 7 LEFTMARGIN, 7
RIGHTMARGIN, 179 RIGHTMARGIN, 336
TOPMARGIN, 7 TOPMARGIN, 7
BOTTOMMARGIN, 96 BOTTOMMARGIN, 152
END END
END END
#endif // APSTUDIO_INVOKED #endif // APSTUDIO_INVOKED
@ -1549,7 +1560,7 @@ BEGIN
IDD_CPUDLG, DIALOG IDD_CPUDLG, DIALOG
BEGIN BEGIN
LEFTMARGIN, 7 LEFTMARGIN, 7
RIGHTMARGIN, 551 RIGHTMARGIN, 558
TOPMARGIN, 7 TOPMARGIN, 7
END END
END END

View File

@ -1,21 +1,3 @@
/* Pcsx2 - Pc Ps2 Emulator
* Copyright (C) 2002-2008 Pcsx2 Team
* Original code (2.0 and earlier )copyright (c) 2000-2002 Lee Thomason (www.grinninglizard.com)
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
*/
//{{NO_DEPENDENCIES}} //{{NO_DEPENDENCIES}}
// Microsoft Visual C++ generated include file. // Microsoft Visual C++ generated include file.
// Used by pcsx2.rc // Used by pcsx2.rc
@ -508,8 +490,12 @@
#define IDC_CHECK2 1217 #define IDC_CHECK2 1217
#define IDC_SYNCHACK 1217 #define IDC_SYNCHACK 1217
#define IDC_SPU2HACK 1218 #define IDC_SPU2HACK 1218
#define IDC_SYNCHACK2 1218
#define IDC_VSYNCRATE 1219 #define IDC_VSYNCRATE 1219
#define IDC_SYNCHACK3 1219
#define IDC_IOPGPR0 1220 #define IDC_IOPGPR0 1220
#define IDC_SYNCHACK4 1220
#define IDC_FASTBRANCHES 1220
#define IDC_IOPGPR1 1221 #define IDC_IOPGPR1 1221
#define IDC_IOPGPR2 1222 #define IDC_IOPGPR2 1222
#define IDC_IOPGPR16 1223 #define IDC_IOPGPR16 1223
@ -582,6 +568,7 @@
#define IDC_ADDGS 1278 #define IDC_ADDGS 1278
#define IDC_CONVERTEDCODE 1278 #define IDC_CONVERTEDCODE 1278
#define IDC_CUSTOM_CONSECUTIVE_FRAMES 1278 #define IDC_CUSTOM_CONSECUTIVE_FRAMES 1278
#define IDC_OVERFLOWHACK 1278
#define IDC_HACKDESC 1279 #define IDC_HACKDESC 1279
#define IDC_CONVERT 1279 #define IDC_CONVERT 1279
#define IDC_EDITPATCH 1279 #define IDC_EDITPATCH 1279
@ -589,6 +576,7 @@
#define IDC_READY 1280 #define IDC_READY 1280
#define IDC_ADDPATCH 1280 #define IDC_ADDPATCH 1280
#define IDC_FRAMESKIP_LABEL2 1280 #define IDC_FRAMESKIP_LABEL2 1280
#define IDC_OVERFLOWHACK_EXTRA 1280
#define IDC_GROUP 1281 #define IDC_GROUP 1281
#define IDC_ADDRAW 1281 #define IDC_ADDRAW 1281
#define IDC_FRAMESKIP_LABEL3 1281 #define IDC_FRAMESKIP_LABEL3 1281
@ -617,6 +605,7 @@
#define IDC_ICON2 1300 #define IDC_ICON2 1300
#define IDC_CHECK1 1300 #define IDC_CHECK1 1300
#define IDC_SOUNDHACK 1300 #define IDC_SOUNDHACK 1300
#define IDC_DENORMALS 1301
#define IDC_FRAMELIMIT_OPTIONS 1303 #define IDC_FRAMELIMIT_OPTIONS 1303
#define IDC_LOG 1500 #define IDC_LOG 1500
#define IDC_CPULOG 1500 #define IDC_CPULOG 1500
@ -647,8 +636,8 @@
#define IDC_IOPGPULOG 1527 #define IDC_IOPGPULOG 1527
#define IDC_IOPCNTLOG 1529 #define IDC_IOPCNTLOG 1529
#define IDC_EECNTLOG 1530 #define IDC_EECNTLOG 1530
#define IDC_STDOUTPUTLOG 1531 #define IDC_SYMLOG 1531
#define IDC_SYMLOG 1532 #define IDC_STDOUTPUTLOG 1532
#define IDC_SEARCH 1701 #define IDC_SEARCH 1701
#define IDC_VALUE 1702 #define IDC_VALUE 1702
#define IDC_OLD 1703 #define IDC_OLD 1703
@ -752,7 +741,7 @@
#ifndef APSTUDIO_READONLY_SYMBOLS #ifndef APSTUDIO_READONLY_SYMBOLS
#define _APS_NEXT_RESOURCE_VALUE 136 #define _APS_NEXT_RESOURCE_VALUE 136
#define _APS_NEXT_COMMAND_VALUE 40018 #define _APS_NEXT_COMMAND_VALUE 40018
#define _APS_NEXT_CONTROL_VALUE 1301 #define _APS_NEXT_CONTROL_VALUE 1304
#define _APS_NEXT_SYMED_VALUE 102 #define _APS_NEXT_SYMED_VALUE 102
#endif #endif
#endif #endif

View File

@ -945,7 +945,7 @@ static u32 PCSX2_ALIGNED16(s_pos[4]) = { 0x7fffffff, 0, 0, 0 };
void recSQRT_S_xmm(int info) void recSQRT_S_xmm(int info)
{ {
if( info & PROCESS_EE_T ) { if( info & PROCESS_EE_T ) {
//if( CHECK_FORCEABS ) { //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]);
else { else {
SSE_MOVSS_XMM_to_XMM(EEREC_D, EEREC_T); SSE_MOVSS_XMM_to_XMM(EEREC_D, EEREC_T);
@ -960,7 +960,7 @@ void recSQRT_S_xmm(int info)
}*/ }*/
} }
else { else {
//if( CHECK_FORCEABS ) { //if( CHECK_OVERFLOW ) {
SSE_MOVSS_M32_to_XMM(EEREC_D, (uptr)&fpuRegs.fpr[_Ft_]); SSE_MOVSS_M32_to_XMM(EEREC_D, (uptr)&fpuRegs.fpr[_Ft_]);
SSE_ANDPS_M128_to_XMM(EEREC_D, (uptr)&s_pos[0]); SSE_ANDPS_M128_to_XMM(EEREC_D, (uptr)&s_pos[0]);

View File

@ -1,19 +1,19 @@
/* Pcsx2 - Pc Ps2 Emulator /* Pcsx2 - Pc Ps2 Emulator
* Copyright (C) 2002-2008 Pcsx2 Team * Copyright (C) 2002-2005 Pcsx2 Team
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or * the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version. * (at your option) any later version.
* *
* This program is distributed in the hope that it will be useful, * This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of * but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details. * GNU General Public License for more details.
* *
* You should have received a copy of the GNU General Public License * You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/ */
// recompiler reworked to add dynamic linking Jan06 // recompiler reworked to add dynamic linking Jan06
@ -969,8 +969,8 @@ void psxSetBranchImm( u32 imm )
*ptr = (uptr)JMP32((uptr)psxDispatcher - ( (uptr)x86Ptr + 5 )); *ptr = (uptr)JMP32((uptr)psxDispatcher - ( (uptr)x86Ptr + 5 ));
} }
#define USE_FAST_BRANCHES (Config.Hacks & 1) #define USE_FAST_BRANCHES CHECK_FASTBRANCHES
#define PSXCYCLE_MULT ((Config.Hacks & 1) ? 2.125 : (17/16)) #define PSXCYCLE_MULT (CHECK_IOPSYNC_HACK ? (CHECK_EE_IOP_EXTRA ? 3.1875 : 2.125) : (17/16))
static void iPsxBranchTest(u32 newpc, u32 cpuBranch) static void iPsxBranchTest(u32 newpc, u32 cpuBranch)
{ {

File diff suppressed because it is too large Load Diff

View File

@ -1,19 +1,19 @@
/* Pcsx2 - Pc Ps2 Emulator /* Pcsx2 - Pc Ps2 Emulator
* Copyright (C) 2002-2008 Pcsx2 Team * Copyright (C) 2002-2003 Pcsx2 Team
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or * the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version. * (at your option) any later version.
* *
* This program is distributed in the hope that it will be useful, * This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of * but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details. * GNU General Public License for more details.
* *
* You should have received a copy of the GNU General Public License * You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/ */
#ifndef __IVUMICRO_H__ #ifndef __IVUMICRO_H__
@ -37,8 +37,12 @@
#define RECOMPILE_VUMI_MAX #define RECOMPILE_VUMI_MAX
#define RECOMPILE_VUMI_MINI #define RECOMPILE_VUMI_MINI
#define RECOMPILE_VUMI_FTOI #define RECOMPILE_VUMI_FTOI
#define RECOMPILE_VUMI_OPM
#define RECOMPILE_VUMI_OTHER
#define RECOMPILE_VUMI_MATH #define RECOMPILE_VUMI_MATH
//
#define RECOMPILE_VUMI_MISC #define RECOMPILE_VUMI_MISC
#define RECOMPILE_VUMI_E #define RECOMPILE_VUMI_E
#define RECOMPILE_VUMI_X #define RECOMPILE_VUMI_X
@ -46,6 +50,7 @@
#define RECOMPILE_VUMI_FLAG #define RECOMPILE_VUMI_FLAG
#define RECOMPILE_VUMI_BRANCH #define RECOMPILE_VUMI_BRANCH
#define RECOMPILE_VUMI_ARITHMETIC #define RECOMPILE_VUMI_ARITHMETIC
//
#define RECOMPILE_VUMI_LOADSTORE #define RECOMPILE_VUMI_LOADSTORE
#ifdef __x86_64__ #ifdef __x86_64__

View File

@ -1,19 +1,19 @@
/* Pcsx2 - Pc Ps2 Emulator /* Pcsx2 - Pc Ps2 Emulator
* Copyright (C) 2002-2008 Pcsx2 Team * Copyright (C) 2002-2005 Pcsx2 Team
* *
* This program is free software; you can redistribute it and/or modify * This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by * it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or * the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version. * (at your option) any later version.
* *
* This program is distributed in the hope that it will be useful, * This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of * but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details. * GNU General Public License for more details.
* *
* You should have received a copy of the GNU General Public License * You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software * along with this program; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/ */
// recompiler reworked to add dynamic linking zerofrog(@gmail.com) Jan06 // recompiler reworked to add dynamic linking zerofrog(@gmail.com) Jan06
@ -1450,8 +1450,8 @@ void eeFPURecompileCode(R5900FNPTR_INFO xmmcode, R5900FNPTR_INFO fpucode, int xm
//////////////////////////////////////////////////// ////////////////////////////////////////////////////
extern u8 g_MACFlagTransform[256]; // for vus extern u8 g_MACFlagTransform[256]; // for vus
u32 g_sseMXCSR = 0x9fc0; // disable all exception, round to 0, flush to 0 u32 g_sseMXCSR = 0x9fc0; //0x9fc0 disable all exception, round to 0, flush to 0
u32 g_sseVUMXCSR = 0xff80; // set to 0xffc0 to enable DAZ u32 g_sseVUMXCSR = 0;
void SetCPUState(u32 sseMXCSR, u32 sseVUMXCSR) void SetCPUState(u32 sseMXCSR, u32 sseVUMXCSR)
{ {
@ -1481,7 +1481,7 @@ void SetCPUState(u32 sseMXCSR, u32 sseVUMXCSR)
int recInit( void ) int recInit( void )
{ {
int i; int i;
static const u8 macarr[16] = {0, 8, 4, 12, 2, 10, 6, 14, 1, 9, 5, 13, 3, 11, 7, 15 }; const u8 macarr[16] = {0, 8, 4, 12, 2, 10, 6, 14, 1, 9, 5, 13, 3, 11, 7, 15 };
recLUT = (uptr*) _aligned_malloc( 0x010000 * sizeof(uptr), 16 ); recLUT = (uptr*) _aligned_malloc( 0x010000 * sizeof(uptr), 16 );
memset( recLUT, 0, 0x010000 * sizeof(uptr) ); memset( recLUT, 0, 0x010000 * sizeof(uptr) );
@ -1576,10 +1576,11 @@ int recInit( void )
SuperVUInit(-1); SuperVUInit(-1);
for(i = 0; i < 256; ++i) { for(i = 0; i < 256; ++i) { //x0-xF //0x-Fx
g_MACFlagTransform[i] = macarr[i>>4]|(macarr[i&15]<<4); g_MACFlagTransform[i] = macarr[i>>4]|(macarr[i&15]<<4);
} }
g_sseVUMXCSR = CHECK_DENORMALS;
SetCPUState(g_sseMXCSR, g_sseVUMXCSR); SetCPUState(g_sseMXCSR, g_sseVUMXCSR);
return 0; return 0;
@ -2136,6 +2137,7 @@ void SetBranchReg( u32 reg )
void SetBranchImm( u32 imm ) void SetBranchImm( u32 imm )
{ {
u32* ptr;
branch = 1; branch = 1;
assert( imm ); assert( imm );
@ -2148,10 +2150,8 @@ void SetBranchImm( u32 imm )
if( bExecBIOS ) CheckForBIOSEnd(); if( bExecBIOS ) CheckForBIOSEnd();
MOV32ItoR(EDX, 0); MOV32ItoR(EDX, 0);
{ ptr = (u32*)(x86Ptr-4);
u32* ptr = (u32*)(x86Ptr-4); *ptr = (u32)JMP32((u32)Dispatcher - ( (u32)x86Ptr + 5 ));
*ptr = (u32)JMP32((u32)Dispatcher - ( (u32)x86Ptr + 5 ));
}
} }
void SaveBranchState() void SaveBranchState()
@ -2227,7 +2227,7 @@ void iFlushCall(int flushtype)
} }
} }
#define USE_FAST_BRANCHES (Config.Hacks & 1) #define USE_FAST_BRANCHES CHECK_FASTBRANCHES
//void testfpu() //void testfpu()
//{ //{
@ -2250,7 +2250,7 @@ void iFlushCall(int flushtype)
// assert( !g_globalXMMSaved ); // assert( !g_globalXMMSaved );
//} //}
#define EECYCLE_MULT ((Config.Hacks & 1) ? 2.25 : (9/8)) #define EECYCLE_MULT (CHECK_EESYNC_HACK ? (CHECK_EE_IOP_EXTRA ? 3.375 : 2.25) : (9/8))
static void iBranchTest(u32 newpc, u32 cpuBranch) static void iBranchTest(u32 newpc, u32 cpuBranch)
{ {
@ -2835,9 +2835,9 @@ void recRecompile( u32 startpc )
else { else {
s_pCurBlockEx = NULL; s_pCurBlockEx = NULL;
for(i = 0; i < EE_NUMBLOCKS; ++i) { for(i = 0; i < EE_NUMBLOCKS; ++i) {
if( recBlocks[(i+s_nNextBlock)&(EE_NUMBLOCKS-1)].size == 0 ) { if( recBlocks[(i+s_nNextBlock)%EE_NUMBLOCKS].size == 0 ) {
s_pCurBlockEx = recBlocks+((i+s_nNextBlock)&(EE_NUMBLOCKS-1)); s_pCurBlockEx = recBlocks+(i+s_nNextBlock)%EE_NUMBLOCKS;
s_nNextBlock = (i+s_nNextBlock+1)&(EE_NUMBLOCKS-1); s_nNextBlock = (i+s_nNextBlock+1)%EE_NUMBLOCKS;
break; break;
} }
} }

View File

@ -72,16 +72,16 @@ void WriteRmOffset(x86IntRegType to, int offset)
if( (to&7) == ESP ) { if( (to&7) == ESP ) {
if( offset == 0 ) { if( offset == 0 ) {
ModRM( 0, 0, 4 ); ModRM( 0, 0, 4 );
SibSB( 0, ESP, 4 ); ModRM( 0, ESP, 4 );
} }
else if( offset < 128 && offset >= -128 ) { else if( offset < 128 && offset >= -128 ) {
ModRM( 1, 0, 4 ); ModRM( 1, 0, 4 );
SibSB( 0, ESP, 4 ); ModRM( 0, ESP, 4 );
write8(offset); write8(offset);
} }
else { else {
ModRM( 2, 0, 4 ); ModRM( 2, 0, 4 );
SibSB( 0, ESP, 4 ); ModRM( 0, ESP, 4 );
write32(offset); write32(offset);
} }
} }
@ -1117,56 +1117,32 @@ void ADD64RtoR( x86IntRegType to, x86IntRegType from )
void ADD32ItoR( x86IntRegType to, u32 from ) void ADD32ItoR( x86IntRegType to, u32 from )
{ {
RexB(0, to); RexB(0, to);
if(from < 0x80) if ( to == EAX) {
{ write8( 0x05 );
write8( 0x83 ); }
else {
write8( 0x81 );
ModRM( 3, 0, to ); ModRM( 3, 0, to );
write8( from );
}
else
{
if ( to == EAX) {
write8( 0x05 );
}
else {
write8( 0x81 );
ModRM( 3, 0, to );
}
write32( from );
} }
write32( from );
} }
/* add imm32 to m32 */ /* add imm32 to m32 */
void ADD32ItoM( uptr to, u32 from ) void ADD32ItoM( uptr to, u32 from )
{ {
if(from < 0x80) write8( 0x81 );
{ ModRM( 0, 0, DISP32 );
write8( 0x83 ); write32( MEMADDR(to, 8) );
ModRM( 0, 0, DISP32 ); write32( from );
write32( MEMADDR(to, 8) );
write8( from );
} else {
write8( 0x81 );
ModRM( 0, 0, DISP32 );
write32( MEMADDR(to, 8) );
write32( from );
}
} }
// add imm32 to [r32+off] // add imm32 to [r32+off]
void ADD32ItoRmOffset( x86IntRegType to, u32 from, int offset) void ADD32ItoRmOffset( x86IntRegType to, u32 from, int offset)
{ {
RexB(0,to); RexB(0,to);
if(from < 0x80) write8( 0x81 );
{ WriteRmOffset(to,offset);
write8( 0x83 ); write32(from);
WriteRmOffset(to,offset);
write8(from);
} else {
write8( 0x81 );
WriteRmOffset(to,offset);
write32(from);
}
} }
/* add r32 to r32 */ /* add r32 to r32 */
@ -1207,46 +1183,28 @@ void ADD16RtoR( x86IntRegType to , x86IntRegType from )
/* add imm16 to r16 */ /* add imm16 to r16 */
void ADD16ItoR( x86IntRegType to, u16 from ) void ADD16ItoR( x86IntRegType to, u16 from )
{ {
RexB(0,to);
write8( 0x66 ); write8( 0x66 );
RexB(0,to);
if ( to == EAX) if ( to == EAX)
{ {
write8( 0x05 ); write8( 0x05 );
write16( from );
} }
else if(from < 0x80) else
{ {
write8( 0x83 );
ModRM( 3, 0, to );
write8( from );
}
else
{
write8( 0x81 ); write8( 0x81 );
ModRM( 3, 0, to ); ModRM( 3, 0, to );
write16( from );
} }
write16( from );
} }
/* add imm16 to m16 */ /* add imm16 to m16 */
void ADD16ItoM( uptr to, u16 from ) void ADD16ItoM( uptr to, u16 from )
{ {
write8( 0x66 ); write8( 0x66 );
if(from < 0x80) write8( 0x81 );
{ ModRM( 0, 0, DISP32 );
write8( 0x83 ); write32( MEMADDR(to, 6) );
ModRM( 0, 0, DISP32 ); write16( from );
write32( MEMADDR(to, 6) );
write8( from );
}
else
{
write8( 0x81 );
ModRM( 0, 0, DISP32 );
write32( MEMADDR(to, 6) );
write16( from );
}
} }
/* add r16 to m16 */ /* add r16 to m16 */
@ -2328,20 +2286,13 @@ void AND64I32toM( uptr to, u32 from )
void AND32ItoR( x86IntRegType to, u32 from ) void AND32ItoR( x86IntRegType to, u32 from )
{ {
RexB(0,to); RexB(0,to);
if(from < 0x80) if ( to == EAX ) {
{ write8( 0x25 );
AND32I8toR(to, (u8)from); } else {
} write8( 0x81 );
else ModRM( 3, 0x4, to );
{
if ( to == EAX ) {
write8( 0x25 );
} else {
write8( 0x81 );
ModRM( 3, 0x4, to );
}
write32( from );
} }
write32( from );
} }
/* and sign ext imm8 to r32 */ /* and sign ext imm8 to r32 */
@ -2356,17 +2307,10 @@ void AND32I8toR( x86IntRegType to, u8 from )
/* and imm32 to m32 */ /* and imm32 to m32 */
void AND32ItoM( uptr to, u32 from ) void AND32ItoM( uptr to, u32 from )
{ {
if(from < 0x80) write8( 0x81 );
{ ModRM( 0, 0x4, DISP32 );
AND32I8toM(to, (u8)from); write32( MEMADDR(to, 8) );
} write32( from );
else
{
write8( 0x81 );
ModRM( 0, 0x4, DISP32 );
write32( MEMADDR(to, 8) );
write32( from );
}
} }
/* and sign ext imm8 to m32 */ /* and sign ext imm8 to m32 */
@ -2416,38 +2360,24 @@ void AND16RtoR( x86IntRegType to, x86IntRegType from )
/* and imm16 to r16 */ /* and imm16 to r16 */
void AND16ItoR( x86IntRegType to, u16 from ) void AND16ItoR( x86IntRegType to, u16 from )
{ {
RexB(0,to);
write8(0x66); write8(0x66);
RexB(0,to);
if ( to == EAX ) { if ( to == EAX ) {
write8( 0x25 ); write8( 0x25 );
write16( from );
} else if ( from < 0x80 ) {
write8( 0x83 );
ModRM( 3, 0x4, to );
write8( from );
} else { } else {
write8( 0x81 ); write8( 0x81 );
ModRM( 3, 0x4, to ); ModRM( 3, 0x4, to );
write16( from );
} }
write16( from );
} }
/* and imm16 to m16 */ /* and imm16 to m16 */
void AND16ItoM( uptr to, u16 from ) void AND16ItoM( uptr to, u16 from )
{ {
write8(0x66); write16( 0x8166 );
if ( from < 0x80 ) { ModRM( 0, 0x4, DISP32 );
write8( 0x83 ); write32( MEMADDR(to, 6) );
ModRM( 0, 0x4, DISP32 ); write16( from );
write32( MEMADDR(to, 6) );
write8( from );
} else {
write8( 0x81 );
ModRM( 0, 0x4, DISP32 );
write32( MEMADDR(to, 6) );
write16( from );
}
} }
/* and r16 to m16 */ /* and r16 to m16 */