mirror of https://github.com/PCSX2/pcsx2.git
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:
parent
f80441a4f9
commit
4b69e809e5
|
@ -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
|
||||||
|
|
406
pcsx2/FPU.c
406
pcsx2/FPU.c
|
@ -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);
|
||||||
|
}
|
32
pcsx2/Misc.c
32
pcsx2/Misc.c
|
@ -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);
|
||||||
}
|
}
|
||||||
|
|
11
pcsx2/Misc.h
11
pcsx2/Misc.h
|
@ -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)
|
||||||
|
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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 )
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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]);
|
||||||
|
|
||||||
|
|
|
@ -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
|
@ -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__
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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 */
|
||||||
|
|
Loading…
Reference in New Issue