mirror of https://github.com/PCSX2/pcsx2.git
- renamed pcsx2pg.ini to pcsx2.ini
- made pcsx2 to default to MTGS mode "on" instead of "off" - renamed "Mega VU" recs to "Micro VU" recs since the team thought "Mega" sounded lame ;p git-svn-id: http://pcsx2.googlecode.com/svn/trunk@439 96395faa-99c1-11dd-bbfe-3dabce05a288
This commit is contained in:
parent
f70ce7be01
commit
73d6a8aca0
|
@ -68,7 +68,7 @@ extern SessionOverrideFlags g_Session;
|
||||||
//////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////
|
||||||
// Pcsx2 User Configuration Options!
|
// Pcsx2 User Configuration Options!
|
||||||
|
|
||||||
//#define PCSX2_MEGAVU // Use Mega VU recs instead of Zero VU Recs
|
//#define PCSX2_MICROVU // Use Micro VU recs instead of Zero VU Recs
|
||||||
#define PCSX2_GSMULTITHREAD 1 // uses multi-threaded gs
|
#define PCSX2_GSMULTITHREAD 1 // uses multi-threaded gs
|
||||||
#define PCSX2_EEREC 0x10
|
#define PCSX2_EEREC 0x10
|
||||||
#define PCSX2_VU0REC 0x20
|
#define PCSX2_VU0REC 0x20
|
||||||
|
|
|
@ -2325,30 +2325,30 @@
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<Filter
|
<Filter
|
||||||
Name="megaVU"
|
Name="microVU"
|
||||||
>
|
>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\x86\megaVU.cpp"
|
RelativePath="..\..\x86\microVU.cpp"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\x86\megaVU.h"
|
RelativePath="..\..\x86\microVU.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\x86\megaVU_Lower.cpp"
|
RelativePath="..\..\x86\microVU_Lower.cpp"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\x86\megaVU_Tables.cpp"
|
RelativePath="..\..\x86\microVU_Tables.cpp"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\x86\megaVU_Tables.h"
|
RelativePath="..\..\x86\microVU_Tables.h"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
<File
|
<File
|
||||||
RelativePath="..\..\x86\megaVU_Upper.cpp"
|
RelativePath="..\..\x86\microVU_Upper.cpp"
|
||||||
>
|
>
|
||||||
</File>
|
</File>
|
||||||
</Filter>
|
</Filter>
|
||||||
|
|
|
@ -49,7 +49,7 @@ static void GetConfigFilename( string& dest )
|
||||||
// Our current working directory can change, so we use the one we detected
|
// Our current working directory can change, so we use the one we detected
|
||||||
// at startup:
|
// at startup:
|
||||||
|
|
||||||
Path::Combine( dest, g_WorkingFolder, CONFIG_DIR "\\pcsx2pg.ini" );
|
Path::Combine( dest, g_WorkingFolder, CONFIG_DIR "\\pcsx2.ini" );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -128,7 +128,7 @@ public:
|
||||||
|
|
||||||
//cpu
|
//cpu
|
||||||
SetCurrentSection( "Cpu" );
|
SetCurrentSection( "Cpu" );
|
||||||
Entry( "Options", Conf.Options, PCSX2_EEREC|PCSX2_VU0REC|PCSX2_VU1REC );
|
Entry( "Options", Conf.Options, PCSX2_EEREC|PCSX2_VU0REC|PCSX2_VU1REC|PCSX2_GSMULTITHREAD );
|
||||||
Entry( "sseMXCSR", Conf.sseMXCSR, DEFAULT_sseMXCSR );
|
Entry( "sseMXCSR", Conf.sseMXCSR, DEFAULT_sseMXCSR );
|
||||||
Entry( "sseVUMXCSR", Conf.sseVUMXCSR, DEFAULT_sseVUMXCSR );
|
Entry( "sseVUMXCSR", Conf.sseVUMXCSR, DEFAULT_sseVUMXCSR );
|
||||||
Entry( "eeOptions", Conf.eeOptions, DEFAULT_eeOptions );
|
Entry( "eeOptions", Conf.eeOptions, DEFAULT_eeOptions );
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
/* Pcsx2-Playground - Pc Ps2 Emulator
|
/* Pcsx2 - Pc Ps2 Emulator
|
||||||
* Copyright (C) 2009 Pcsx2-Playground Team
|
* Copyright (C) 2009 Pcsx2-Playground 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
|
||||||
|
@ -16,25 +16,24 @@
|
||||||
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
|
||||||
*/
|
*/
|
||||||
|
|
||||||
// Mega VU(micro) recompiler! - author: cottonvibes(@gmail.com)
|
// Micro VU recompiler! - author: cottonvibes(@gmail.com)
|
||||||
|
|
||||||
#include "PrecompiledHeader.h"
|
#include "microVU.h"
|
||||||
#include "megaVU.h"
|
#ifdef PCSX2_MICROVU
|
||||||
#ifdef PCSX2_MEGAVU
|
|
||||||
|
|
||||||
//------------------------------------------------------------------
|
//------------------------------------------------------------------
|
||||||
// Mega VU - Global Variables
|
// VU Micro - Global Variables
|
||||||
//------------------------------------------------------------------
|
//------------------------------------------------------------------
|
||||||
|
|
||||||
megaVU megaVU0;
|
microVU microVU0;
|
||||||
megaVU megaVU1;
|
microVU microVU1;
|
||||||
|
|
||||||
//------------------------------------------------------------------
|
//------------------------------------------------------------------
|
||||||
// Mega VU - Main Functions
|
// Micro VU - Main Functions
|
||||||
//------------------------------------------------------------------
|
//------------------------------------------------------------------
|
||||||
|
|
||||||
// Only run this once! ;)
|
// Only run this once! ;)
|
||||||
__forceinline void mVUinit(megaVU* mVU, VURegs* vuRegsPtr, const int vuIndex) {
|
__forceinline void mVUinit(microVU* mVU, VURegs* vuRegsPtr, const int vuIndex) {
|
||||||
|
|
||||||
mVU->regs = vuRegsPtr;
|
mVU->regs = vuRegsPtr;
|
||||||
mVU->index = vuIndex;
|
mVU->index = vuIndex;
|
||||||
|
@ -45,7 +44,7 @@ __forceinline void mVUinit(megaVU* mVU, VURegs* vuRegsPtr, const int vuIndex) {
|
||||||
|
|
||||||
for (int i; i <= mVU->prog.max; i++) {
|
for (int i; i <= mVU->prog.max; i++) {
|
||||||
for (u32 j; j < mVU->progSize; j++) {
|
for (u32 j; j < mVU->progSize; j++) {
|
||||||
mVU->prog.prog[i].block[j] = new megaBlockManager();
|
mVU->prog.prog[i].block[j] = new microBlockManager();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -53,13 +52,13 @@ __forceinline void mVUinit(megaVU* mVU, VURegs* vuRegsPtr, const int vuIndex) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Will Optimize later
|
// Will Optimize later
|
||||||
__forceinline void mVUreset(megaVU* mVU) {
|
__forceinline void mVUreset(microVU* mVU) {
|
||||||
|
|
||||||
mVUclose(mVU); // Close
|
mVUclose(mVU); // Close
|
||||||
|
|
||||||
// Dynarec Cache
|
// Dynarec Cache
|
||||||
mVU->cache = SysMmap(mVU->cacheAddr, mVU->cacheSize, 0x10000000, "Mega VU");
|
mVU->cache = SysMmapEx(mVU->cacheAddr, mVU->cacheSize, 0x10000000, "Mega VU");
|
||||||
if ( mVU->cache == NULL ) throw Exception::OutOfMemory(fmt_string( "megaVU Error: failed to allocate recompiler memory! (addr: 0x%x)", params (u32)mVU->cache));
|
if ( mVU->cache == NULL ) throw Exception::OutOfMemory(fmt_string( "microVU Error: failed to allocate recompiler memory! (addr: 0x%x)", params (u32)mVU->cache));
|
||||||
|
|
||||||
// Other Variables
|
// Other Variables
|
||||||
ZeroMemory(&mVU->prog, sizeof(mVU->prog));
|
ZeroMemory(&mVU->prog, sizeof(mVU->prog));
|
||||||
|
@ -70,7 +69,7 @@ __forceinline void mVUreset(megaVU* mVU) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Free Allocated Resources
|
// Free Allocated Resources
|
||||||
__forceinline void mVUclose(megaVU* mVU) {
|
__forceinline void mVUclose(microVU* mVU) {
|
||||||
|
|
||||||
if ( mVU->cache ) { SysMunmap( mVU->cache, mVU->cacheSize ); mVU->cache = NULL; }
|
if ( mVU->cache ) { SysMunmap( mVU->cache, mVU->cacheSize ); mVU->cache = NULL; }
|
||||||
|
|
||||||
|
@ -82,7 +81,7 @@ __forceinline void mVUclose(megaVU* mVU) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Clears Block Data in specified range (Caches current microProgram if a difference has been found)
|
// Clears Block Data in specified range (Caches current microProgram if a difference has been found)
|
||||||
__forceinline void mVUclear(megaVU* mVU, u32 addr, u32 size) {
|
__forceinline void mVUclear(microVU* mVU, u32 addr, u32 size) {
|
||||||
|
|
||||||
int i = addr/8;
|
int i = addr/8;
|
||||||
int end = i+((size+(8-(size&7)))/8); // ToDo: Can be simplified to addr+size if Size is always a multiple of 8
|
int end = i+((size+(8-(size&7)))/8); // ToDo: Can be simplified to addr+size if Size is always a multiple of 8
|
||||||
|
@ -103,12 +102,12 @@ __forceinline void mVUclear(megaVU* mVU, u32 addr, u32 size) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Executes for number of cycles
|
// Executes for number of cycles
|
||||||
void* mVUexecute(megaVU* mVU, u32 startPC, u32 cycles) {
|
void* mVUexecute(microVU* mVU, u32 startPC, u32 cycles) {
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Executes till finished
|
// Executes till finished
|
||||||
void* mVUexecuteF(megaVU* mVU, u32 startPC) {
|
void* mVUexecuteF(microVU* mVU, u32 startPC) {
|
||||||
//if (!mProg.finished) {
|
//if (!mProg.finished) {
|
||||||
// runMicroProgram(startPC);
|
// runMicroProgram(startPC);
|
||||||
//}
|
//}
|
||||||
|
@ -119,11 +118,11 @@ void* mVUexecuteF(megaVU* mVU, u32 startPC) {
|
||||||
}
|
}
|
||||||
|
|
||||||
//------------------------------------------------------------------
|
//------------------------------------------------------------------
|
||||||
// Mega VU - Private Functions
|
// Micro VU - Private Functions
|
||||||
//------------------------------------------------------------------
|
//------------------------------------------------------------------
|
||||||
|
|
||||||
// Finds the least used program
|
// Finds the least used program
|
||||||
__forceinline int mVUfindLeastUsedProg(megaVU* mVU) {
|
__forceinline int mVUfindLeastUsedProg(microVU* mVU) {
|
||||||
if (mVU->prog.total < mVU->prog.max) {
|
if (mVU->prog.total < mVU->prog.max) {
|
||||||
mVU->prog.total++;
|
mVU->prog.total++;
|
||||||
return mVU->prog.total;
|
return mVU->prog.total;
|
||||||
|
@ -142,14 +141,14 @@ __forceinline int mVUfindLeastUsedProg(megaVU* mVU) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Caches Micro Program if appropriate
|
// Caches Micro Program if appropriate
|
||||||
__forceinline void mVUcacheProg(megaVU* mVU) {
|
__forceinline void mVUcacheProg(microVU* mVU) {
|
||||||
if (!mVU->prog.prog[mVU->prog.cur].cached) { // If uncached, then cache
|
if (!mVU->prog.prog[mVU->prog.cur].cached) { // If uncached, then cache
|
||||||
memcpy_fast(mVU->prog.prog[mVU->prog.cur].data, mVU->regs->Micro, mVU->microSize);
|
memcpy_fast(mVU->prog.prog[mVU->prog.cur].data, mVU->regs->Micro, mVU->microSize);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Searches for Cached Micro Program and sets prog.cur (returns -1 if no program found)
|
// Searches for Cached Micro Program and sets prog.cur (returns -1 if no program found)
|
||||||
__forceinline int mVUsearchProg(megaVU* mVU) {
|
__forceinline int mVUsearchProg(microVU* mVU) {
|
||||||
if (mVU->prog.cleared) { // If cleared, we need to search for new program
|
if (mVU->prog.cleared) { // If cleared, we need to search for new program
|
||||||
for (int i = 0; i <= mVU->prog.total; i++) {
|
for (int i = 0; i <= mVU->prog.total; i++) {
|
||||||
if (!memcmp_mmx(mVU->prog.prog[i].data, mVU->regs->Micro, mVU->microSize)) {
|
if (!memcmp_mmx(mVU->prog.prog[i].data, mVU->regs->Micro, mVU->microSize)) {
|
||||||
|
@ -167,38 +166,38 @@ __forceinline int mVUsearchProg(megaVU* mVU) {
|
||||||
//------------------------------------------------------------------
|
//------------------------------------------------------------------
|
||||||
|
|
||||||
// Runs till finished
|
// Runs till finished
|
||||||
__declspec(naked) void runVU0(megaVU* mVU, u32 startPC) {
|
__declspec(naked) void runVU0(microVU* mVU, u32 startPC) {
|
||||||
__asm {
|
__asm {
|
||||||
mov eax, dword ptr [esp]
|
mov eax, dword ptr [esp]
|
||||||
mov megaVU0.x86callstack, eax
|
mov microVU0.x86callstack, eax
|
||||||
add esp, 4
|
add esp, 4
|
||||||
call mVUexecuteF
|
call mVUexecuteF
|
||||||
|
|
||||||
/*backup cpu state*/
|
/*backup cpu state*/
|
||||||
mov megaVU0.x86ebp, ebp
|
mov microVU0.x86ebp, ebp
|
||||||
mov megaVU0.x86esi, esi
|
mov microVU0.x86esi, esi
|
||||||
mov megaVU0.x86edi, edi
|
mov microVU0.x86edi, edi
|
||||||
mov megaVU0.x86ebx, ebx
|
mov microVU0.x86ebx, ebx
|
||||||
/*mov megaVU0.x86esp, esp*/
|
/*mov microVU0.x86esp, esp*/
|
||||||
|
|
||||||
ldmxcsr g_sseVUMXCSR
|
ldmxcsr g_sseVUMXCSR
|
||||||
|
|
||||||
jmp eax
|
jmp eax
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
__declspec(naked) void runVU1(megaVU* mVU, u32 startPC) {
|
__declspec(naked) void runVU1(microVU* mVU, u32 startPC) {
|
||||||
__asm {
|
__asm {
|
||||||
mov eax, dword ptr [esp]
|
mov eax, dword ptr [esp]
|
||||||
mov megaVU1.x86callstack, eax
|
mov microVU1.x86callstack, eax
|
||||||
add esp, 4
|
add esp, 4
|
||||||
call mVUexecuteF
|
call mVUexecuteF
|
||||||
|
|
||||||
/*backup cpu state*/
|
/*backup cpu state*/
|
||||||
mov megaVU1.x86ebp, ebp
|
mov microVU1.x86ebp, ebp
|
||||||
mov megaVU1.x86esi, esi
|
mov microVU1.x86esi, esi
|
||||||
mov megaVU1.x86edi, edi
|
mov microVU1.x86edi, edi
|
||||||
mov megaVU1.x86ebx, ebx
|
mov microVU1.x86ebx, ebx
|
||||||
/*mov megaVU1.x86esp, esp*/
|
/*mov microVU1.x86esp, esp*/
|
||||||
|
|
||||||
ldmxcsr g_sseVUMXCSR
|
ldmxcsr g_sseVUMXCSR
|
||||||
|
|
||||||
|
@ -207,38 +206,38 @@ __declspec(naked) void runVU1(megaVU* mVU, u32 startPC) {
|
||||||
}
|
}
|
||||||
|
|
||||||
// Runs for number of cycles
|
// Runs for number of cycles
|
||||||
__declspec(naked) void runVU0(megaVU* mVU, u32 startPC, u32 cycles) {
|
__declspec(naked) void runVU0(microVU* mVU, u32 startPC, u32 cycles) {
|
||||||
__asm {
|
__asm {
|
||||||
mov eax, dword ptr [esp]
|
mov eax, dword ptr [esp]
|
||||||
mov megaVU0.x86callstack, eax
|
mov microVU0.x86callstack, eax
|
||||||
add esp, 4
|
add esp, 4
|
||||||
call mVUexecute
|
call mVUexecute
|
||||||
|
|
||||||
/*backup cpu state*/
|
/*backup cpu state*/
|
||||||
mov megaVU0.x86ebp, ebp
|
mov microVU0.x86ebp, ebp
|
||||||
mov megaVU0.x86esi, esi
|
mov microVU0.x86esi, esi
|
||||||
mov megaVU0.x86edi, edi
|
mov microVU0.x86edi, edi
|
||||||
mov megaVU0.x86ebx, ebx
|
mov microVU0.x86ebx, ebx
|
||||||
/*mov megaVU0.x86esp, esp*/
|
/*mov microVU0.x86esp, esp*/
|
||||||
|
|
||||||
ldmxcsr g_sseVUMXCSR
|
ldmxcsr g_sseVUMXCSR
|
||||||
|
|
||||||
jmp eax
|
jmp eax
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
__declspec(naked) void runVU1(megaVU* mVU, u32 startPC, u32 cycles) {
|
__declspec(naked) void runVU1(microVU* mVU, u32 startPC, u32 cycles) {
|
||||||
__asm {
|
__asm {
|
||||||
mov eax, dword ptr [esp]
|
mov eax, dword ptr [esp]
|
||||||
mov megaVU1.x86callstack, eax
|
mov microVU1.x86callstack, eax
|
||||||
add esp, 4
|
add esp, 4
|
||||||
call mVUexecute
|
call mVUexecute
|
||||||
|
|
||||||
/*backup cpu state*/
|
/*backup cpu state*/
|
||||||
mov megaVU1.x86ebp, ebp
|
mov microVU1.x86ebp, ebp
|
||||||
mov megaVU1.x86esi, esi
|
mov microVU1.x86esi, esi
|
||||||
mov megaVU1.x86edi, edi
|
mov microVU1.x86edi, edi
|
||||||
mov megaVU1.x86ebx, ebx
|
mov microVU1.x86ebx, ebx
|
||||||
/*mov megaVU1.x86esp, esp*/
|
/*mov microVU1.x86esp, esp*/
|
||||||
|
|
||||||
ldmxcsr g_sseVUMXCSR
|
ldmxcsr g_sseVUMXCSR
|
||||||
|
|
||||||
|
@ -250,33 +249,33 @@ __declspec(naked) void runVU1(megaVU* mVU, u32 startPC, u32 cycles) {
|
||||||
//------------------------------------------------------------------
|
//------------------------------------------------------------------
|
||||||
|
|
||||||
__forceinline void initVUrec(VURegs* vuRegs, int vuIndex) {
|
__forceinline void initVUrec(VURegs* vuRegs, int vuIndex) {
|
||||||
if (!vuIndex) mVUinit(&megaVU0, vuRegs, 0);
|
if (!vuIndex) mVUinit(µVU0, vuRegs, 0);
|
||||||
else mVUinit(&megaVU1, vuRegs, 1);
|
else mVUinit(µVU1, vuRegs, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
__forceinline void closeVUrec(int vuIndex) {
|
__forceinline void closeVUrec(int vuIndex) {
|
||||||
if (!vuIndex) mVUclose(&megaVU0);
|
if (!vuIndex) mVUclose(µVU0);
|
||||||
else mVUclose(&megaVU1);
|
else mVUclose(µVU1);
|
||||||
}
|
}
|
||||||
|
|
||||||
__forceinline void resetVUrec(int vuIndex) {
|
__forceinline void resetVUrec(int vuIndex) {
|
||||||
if (!vuIndex) mVUreset(&megaVU0);
|
if (!vuIndex) mVUreset(µVU0);
|
||||||
else mVUreset(&megaVU1);
|
else mVUreset(µVU1);
|
||||||
}
|
}
|
||||||
|
|
||||||
__forceinline void clearVUrec(u32 addr, u32 size, int vuIndex) {
|
__forceinline void clearVUrec(u32 addr, u32 size, int vuIndex) {
|
||||||
if (!vuIndex) mVUclear(&megaVU0, addr, size);
|
if (!vuIndex) mVUclear(µVU0, addr, size);
|
||||||
else mVUclear(&megaVU1, addr, size);
|
else mVUclear(µVU1, addr, size);
|
||||||
}
|
}
|
||||||
|
|
||||||
__forceinline void runVUrec(u32 startPC, int vuIndex) {
|
__forceinline void runVUrec(u32 startPC, int vuIndex) {
|
||||||
if (!vuIndex) runVU0(&megaVU0, startPC);
|
if (!vuIndex) runVU0(µVU0, startPC);
|
||||||
else runVU1(&megaVU1, startPC);
|
else runVU1(µVU1, startPC);
|
||||||
}
|
}
|
||||||
|
|
||||||
__forceinline void runVUrec(u32 startPC, u32 cycles, int vuIndex) {
|
__forceinline void runVUrec(u32 startPC, u32 cycles, int vuIndex) {
|
||||||
if (!vuIndex) runVU0(&megaVU0, startPC, cycles);
|
if (!vuIndex) runVU0(µVU0, startPC, cycles);
|
||||||
else runVU1(&megaVU1, startPC, cycles);
|
else runVU1(µVU1, startPC, cycles);
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // PCSX2_MEGAVU
|
#endif // PCSX2_MEGAVU
|
|
@ -1,4 +1,4 @@
|
||||||
/* Pcsx2-Playground - Pc Ps2 Emulator
|
/* Pcsx2 - Pc Ps2 Emulator
|
||||||
* Copyright (C) 2009 Pcsx2-Playground Team
|
* Copyright (C) 2009 Pcsx2-Playground 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
|
||||||
|
@ -17,12 +17,13 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#pragma once
|
#pragma once
|
||||||
|
#include "PrecompiledHeader.h"
|
||||||
#include "Common.h"
|
#include "Common.h"
|
||||||
#include "VU.h"
|
#include "VU.h"
|
||||||
#include "megaVU_Tables.h"
|
#include "microVU_Tables.h"
|
||||||
//#include <vector>
|
//#include <vector>
|
||||||
|
|
||||||
struct megaBlock {
|
struct microBlock {
|
||||||
u32 pipelineState; // FMACx|y|z|w | FDiv | EFU | IALU | BRANCH // Still thinking of how I'm going to do this
|
u32 pipelineState; // FMACx|y|z|w | FDiv | EFU | IALU | BRANCH // Still thinking of how I'm going to do this
|
||||||
u32 x86ptrStart;
|
u32 x86ptrStart;
|
||||||
u32 x86ptrEnd;
|
u32 x86ptrEnd;
|
||||||
|
@ -31,19 +32,19 @@ struct megaBlock {
|
||||||
};
|
};
|
||||||
|
|
||||||
#define mMaxBlocks 32 // Max Blocks With Different Pipeline States (For n = 1, 2, 4, 8, 16, etc...)
|
#define mMaxBlocks 32 // Max Blocks With Different Pipeline States (For n = 1, 2, 4, 8, 16, etc...)
|
||||||
class megaBlockManager {
|
class microBlockManager {
|
||||||
private:
|
private:
|
||||||
static const int MaxBlocks = mMaxBlocks - 1;
|
static const int MaxBlocks = mMaxBlocks - 1;
|
||||||
u32 startPC;
|
u32 startPC;
|
||||||
u32 endPC;
|
u32 endPC;
|
||||||
int listSize; // Total Items - 1
|
int listSize; // Total Items - 1
|
||||||
int callerSize; // Total Callers - 1
|
int callerSize; // Total Callers - 1
|
||||||
megaBlock blockList[mMaxBlocks];
|
microBlock blockList[mMaxBlocks];
|
||||||
megaBlock callersList[mMaxBlocks]; // Foreign Blocks that call Local Blocks
|
microBlock callersList[mMaxBlocks]; // Foreign Blocks that call Local Blocks
|
||||||
|
|
||||||
public:
|
public:
|
||||||
megaBlockManager() { init(); }
|
microBlockManager() { init(); }
|
||||||
~megaBlockManager() { close(); }
|
~microBlockManager() { close(); }
|
||||||
void init() {
|
void init() {
|
||||||
listSize = -1;
|
listSize = -1;
|
||||||
callerSize = -1;
|
callerSize = -1;
|
||||||
|
@ -58,7 +59,7 @@ public:
|
||||||
blockList[listSize].x86ptrStart = x86ptrStart;
|
blockList[listSize].x86ptrStart = x86ptrStart;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
megaBlock* search(u32 pipelineState) {
|
microBlock* search(u32 pipelineState) {
|
||||||
for (int i = 0; i < listSize; i++) {
|
for (int i = 0; i < listSize; i++) {
|
||||||
if (blockList[i].pipelineState == pipelineState) return &blockList[i];
|
if (blockList[i].pipelineState == pipelineState) return &blockList[i];
|
||||||
}
|
}
|
||||||
|
@ -80,7 +81,7 @@ struct microProgram {
|
||||||
u8 data[progSize];
|
u8 data[progSize];
|
||||||
u32 used; // Number of times its been used
|
u32 used; // Number of times its been used
|
||||||
int cached; // Has been Cached?
|
int cached; // Has been Cached?
|
||||||
megaBlockManager* block[progSize];
|
microBlockManager* block[progSize];
|
||||||
};
|
};
|
||||||
|
|
||||||
#define mMaxProg 16 // The amount of Micro Programs Recs will 'remember' (For n = 1, 2, 4, 8, 16, etc...)
|
#define mMaxProg 16 // The amount of Micro Programs Recs will 'remember' (For n = 1, 2, 4, 8, 16, etc...)
|
||||||
|
@ -94,7 +95,7 @@ struct microProgManager {
|
||||||
int finished; // Completed MicroProgram to E-bit Termination
|
int finished; // Completed MicroProgram to E-bit Termination
|
||||||
};
|
};
|
||||||
|
|
||||||
struct megaVU {
|
struct microVU {
|
||||||
int index; // VU Index (VU0 or VU1)
|
int index; // VU Index (VU0 or VU1)
|
||||||
u32 microSize; // VU Micro Memory Size
|
u32 microSize; // VU Micro Memory Size
|
||||||
u32 progSize; // VU Micro Program Size (microSize/8)
|
u32 progSize; // VU Micro Program Size (microSize/8)
|
||||||
|
@ -120,13 +121,13 @@ extern void (*mVU_UPPER_OPCODE[64])( VURegs* VU, s32 info );
|
||||||
extern void (*mVU_LOWER_OPCODE[128])( VURegs* VU, s32 info );
|
extern void (*mVU_LOWER_OPCODE[128])( VURegs* VU, s32 info );
|
||||||
|
|
||||||
//void invalidateBlocks(u32 addr, u32 size); // Invalidates Blocks in the range [addr, addr+size)
|
//void invalidateBlocks(u32 addr, u32 size); // Invalidates Blocks in the range [addr, addr+size)
|
||||||
__forceinline void mVUinit(megaVU* mVU, VURegs* vuRegsPtr, const int vuIndex);
|
__forceinline void mVUinit(microVU* mVU, VURegs* vuRegsPtr, const int vuIndex);
|
||||||
__forceinline void mVUreset(megaVU* mVU);
|
__forceinline void mVUreset(microVU* mVU);
|
||||||
__forceinline void mVUclose(megaVU* mVU);
|
__forceinline void mVUclose(microVU* mVU);
|
||||||
__forceinline void mVUclear(megaVU* mVU, u32 addr, u32 size); // Clears part of a Micro Program (must use before modifying micro program!)
|
__forceinline void mVUclear(microVU* mVU, u32 addr, u32 size); // Clears part of a Micro Program (must use before modifying micro program!)
|
||||||
void* mVUexecute(megaVU* mVU, u32 startPC, u32 cycles); // Recompiles/Executes code for the number of cycles indicated (will always run for >= 'cycles' amount unless 'finished')
|
void* mVUexecute(microVU* mVU, u32 startPC, u32 cycles); // Recompiles/Executes code for the number of cycles indicated (will always run for >= 'cycles' amount unless 'finished')
|
||||||
void* mVUexecuteF(megaVU* mVU, u32 startPC); // Recompiles/Executes code till finished
|
void* mVUexecuteF(microVU* mVU, u32 startPC); // Recompiles/Executes code till finished
|
||||||
|
|
||||||
__forceinline int mVUfindLeastUsedProg(megaVU* mVU);
|
__forceinline int mVUfindLeastUsedProg(microVU* mVU);
|
||||||
__forceinline int mVUsearchProg(megaVU* mVU);
|
__forceinline int mVUsearchProg(microVU* mVU);
|
||||||
__forceinline void mVUcacheProg(megaVU* mVU);
|
__forceinline void mVUcacheProg(microVU* mVU);
|
|
@ -1,4 +1,4 @@
|
||||||
/* Pcsx2-Playground - Pc Ps2 Emulator
|
/* Pcsx2 - Pc Ps2 Emulator
|
||||||
* Copyright (C) 2009 Pcsx2-Playground Team
|
* Copyright (C) 2009 Pcsx2-Playground 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
|
|
@ -1,4 +1,4 @@
|
||||||
/* Pcsx2-Playground - Pc Ps2 Emulator
|
/* Pcsx2 - Pc Ps2 Emulator
|
||||||
* Copyright (C) 2009 Pcsx2-Playground Team
|
* Copyright (C) 2009 Pcsx2-Playground 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
|
||||||
|
@ -16,10 +16,9 @@
|
||||||
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#include "PrecompiledHeader.h"
|
#include "microVU.h"
|
||||||
#include "megaVU.h"
|
|
||||||
|
|
||||||
#ifdef PCSX2_MEGAVU_lulz
|
#ifdef PCSX2_MICROVU_lulz
|
||||||
|
|
||||||
void mVU_UPPER_FD_00(VURegs* VU, s32 info);
|
void mVU_UPPER_FD_00(VURegs* VU, s32 info);
|
||||||
void mVU_UPPER_FD_01(VURegs* VU, s32 info);
|
void mVU_UPPER_FD_01(VURegs* VU, s32 info);
|
|
@ -1,4 +1,4 @@
|
||||||
/* Pcsx2-Playground - Pc Ps2 Emulator
|
/* Pcsx2 - Pc Ps2 Emulator
|
||||||
* Copyright (C) 2009 Pcsx2-Playground Team
|
* Copyright (C) 2009 Pcsx2-Playground 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
|
||||||
|
@ -99,12 +99,12 @@ void mVU_MAXx(VURegs *vuRegs, int info);
|
||||||
void mVU_MAXy(VURegs *vuRegs, int info);
|
void mVU_MAXy(VURegs *vuRegs, int info);
|
||||||
void mVU_MAXz(VURegs *vuRegs, int info);
|
void mVU_MAXz(VURegs *vuRegs, int info);
|
||||||
void mVU_MAXw(VURegs *vuRegs, int info);
|
void mVU_MAXw(VURegs *vuRegs, int info);
|
||||||
void mVU_MIN(VURegs *vuRegs, int info);
|
void mVU_MINI(VURegs *vuRegs, int info);
|
||||||
void mVU_MINi(VURegs *vuRegs, int info);
|
void mVU_MINIi(VURegs *vuRegs, int info);
|
||||||
void mVU_MINx(VURegs *vuRegs, int info);
|
void mVU_MINIx(VURegs *vuRegs, int info);
|
||||||
void mVU_MINy(VURegs *vuRegs, int info);
|
void mVU_MINIy(VURegs *vuRegs, int info);
|
||||||
void mVU_MINz(VURegs *vuRegs, int info);
|
void mVU_MINIz(VURegs *vuRegs, int info);
|
||||||
void mVU_MINw(VURegs *vuRegs, int info);
|
void mVU_MINIw(VURegs *vuRegs, int info);
|
||||||
void mVU_OPMULA(VURegs *vuRegs, int info);
|
void mVU_OPMULA(VURegs *vuRegs, int info);
|
||||||
void mVU_OPMSUB(VURegs *vuRegs, int info);
|
void mVU_OPMSUB(VURegs *vuRegs, int info);
|
||||||
void mVU_NOP(VURegs *vuRegs, int info);
|
void mVU_NOP(VURegs *vuRegs, int info);
|
|
@ -1,4 +1,4 @@
|
||||||
/* Pcsx2-Playground - Pc Ps2 Emulator
|
/* Pcsx2 - Pc Ps2 Emulator
|
||||||
* Copyright (C) 2009 Pcsx2-Playground Team
|
* Copyright (C) 2009 Pcsx2-Playground 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
|
Loading…
Reference in New Issue