mirror of https://github.com/PCSX2/pcsx2.git
Remove some obsolete code relating to VIF/GIF FIFOs (hwRead/Write handlers always intercept them now, so saving values back to the eeHw register mirror is ineffective).
git-svn-id: http://pcsx2.googlecode.com/svn/trunk@3741 96395faa-99c1-11dd-bbfe-3dabce05a288
This commit is contained in:
parent
e246d617ef
commit
372478c0ec
|
@ -53,7 +53,7 @@ void __fastcall ReadFIFO_VIF1(mem128_t* out)
|
||||||
if (vif1Regs.stat.FQC > 0)
|
if (vif1Regs.stat.FQC > 0)
|
||||||
{
|
{
|
||||||
GetMTGS().WaitGS();
|
GetMTGS().WaitGS();
|
||||||
GSreadFIFO(&psHu64(VIF1_FIFO));
|
GSreadFIFO(out);
|
||||||
vif1.GSLastDownloadSize--;
|
vif1.GSLastDownloadSize--;
|
||||||
if (vif1.GSLastDownloadSize <= 16)
|
if (vif1.GSLastDownloadSize <= 16)
|
||||||
gifRegs.stat.OPH = false;
|
gifRegs.stat.OPH = false;
|
||||||
|
@ -61,7 +61,6 @@ void __fastcall ReadFIFO_VIF1(mem128_t* out)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
CopyQWC( out, &psHu128(VIF1_FIFO) );
|
|
||||||
VIF_LOG("ReadFIFO/VIF1 -> %ls", out->ToString().c_str());
|
VIF_LOG("ReadFIFO/VIF1 -> %ls", out->ToString().c_str());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -72,8 +71,6 @@ void __fastcall WriteFIFO_VIF0(const mem128_t *value)
|
||||||
{
|
{
|
||||||
VIF_LOG("WriteFIFO/VIF0 <- %ls", value->ToString().c_str());
|
VIF_LOG("WriteFIFO/VIF0 <- %ls", value->ToString().c_str());
|
||||||
|
|
||||||
CopyQWC(&psHu128(VIF0_FIFO), value);
|
|
||||||
|
|
||||||
vif0ch.qwc += 1;
|
vif0ch.qwc += 1;
|
||||||
if(vif0.irqoffset != 0 && vif0.vifstalled == true) DevCon.Warning("Offset on VIF0 FIFO start!");
|
if(vif0.irqoffset != 0 && vif0.vifstalled == true) DevCon.Warning("Offset on VIF0 FIFO start!");
|
||||||
bool ret = VIF0transfer((u32*)value, 4);
|
bool ret = VIF0transfer((u32*)value, 4);
|
||||||
|
@ -94,8 +91,6 @@ void __fastcall WriteFIFO_VIF1(const mem128_t *value)
|
||||||
{
|
{
|
||||||
VIF_LOG("WriteFIFO/VIF1 <- %ls", value->ToString().c_str());
|
VIF_LOG("WriteFIFO/VIF1 <- %ls", value->ToString().c_str());
|
||||||
|
|
||||||
CopyQWC(&psHu128(VIF1_FIFO), value);
|
|
||||||
|
|
||||||
if (vif1Regs.stat.FDR)
|
if (vif1Regs.stat.FDR)
|
||||||
DevCon.Warning("writing to fifo when fdr is set!");
|
DevCon.Warning("writing to fifo when fdr is set!");
|
||||||
if (vif1Regs.stat.test(VIF1_STAT_INT | VIF1_STAT_VSS | VIF1_STAT_VIS | VIF1_STAT_VFS) )
|
if (vif1Regs.stat.test(VIF1_STAT_INT | VIF1_STAT_VSS | VIF1_STAT_VIS | VIF1_STAT_VFS) )
|
||||||
|
@ -123,18 +118,15 @@ void __fastcall WriteFIFO_VIF1(const mem128_t *value)
|
||||||
pxAssertDev( ret, "vif stall code not implemented" );
|
pxAssertDev( ret, "vif stall code not implemented" );
|
||||||
}
|
}
|
||||||
|
|
||||||
// Dummy GIF-TAG Packet to Guarantee Count = 1
|
|
||||||
__aligned16 u128 nloop0_packet;
|
|
||||||
|
|
||||||
void __fastcall WriteFIFO_GIF(const mem128_t *value)
|
void __fastcall WriteFIFO_GIF(const mem128_t *value)
|
||||||
{
|
{
|
||||||
GIF_LOG("WriteFIFO/GIF <- %ls", value->ToString().c_str());
|
GIF_LOG("WriteFIFO/GIF <- %ls", value->ToString().c_str());
|
||||||
|
|
||||||
CopyQWC(&psHu128(GIF_FIFO), value);
|
//CopyQWC(&psHu128(GIF_FIFO), value);
|
||||||
CopyQWC(&nloop0_packet, value);
|
//CopyQWC(&nloop0_packet, value);
|
||||||
|
|
||||||
GetMTGS().PrepDataPacket(GIF_PATH_3, 1);
|
GetMTGS().PrepDataPacket(GIF_PATH_3, 1);
|
||||||
GIFPath_CopyTag( GIF_PATH_3, &nloop0_packet, 1 );
|
GIFPath_CopyTag( GIF_PATH_3, value, 1 );
|
||||||
GetMTGS().SendDataPacket();
|
GetMTGS().SendDataPacket();
|
||||||
if(GSTransferStatus.PTH3 == STOPPED_MODE && gifRegs.stat.APATH == GIF_APATH3 )
|
if(GSTransferStatus.PTH3 == STOPPED_MODE && gifRegs.stat.APATH == GIF_APATH3 )
|
||||||
{
|
{
|
||||||
|
|
|
@ -31,9 +31,6 @@ void vif0Reset()
|
||||||
memzero(vif0);
|
memzero(vif0);
|
||||||
memzero(vif0Regs);
|
memzero(vif0Regs);
|
||||||
|
|
||||||
psHu64(VIF0_FIFO) = 0;
|
|
||||||
psHu64(VIF0_FIFO + 8) = 0;
|
|
||||||
|
|
||||||
vif0Regs.stat.VPS = VPS_IDLE;
|
vif0Regs.stat.VPS = VPS_IDLE;
|
||||||
vif0Regs.stat.FQC = 0;
|
vif0Regs.stat.FQC = 0;
|
||||||
|
|
||||||
|
@ -48,9 +45,6 @@ void vif1Reset()
|
||||||
memzero(vif1);
|
memzero(vif1);
|
||||||
memzero(vif1Regs);
|
memzero(vif1Regs);
|
||||||
|
|
||||||
psHu64(VIF1_FIFO) = 0;
|
|
||||||
psHu64(VIF1_FIFO + 8) = 0;
|
|
||||||
|
|
||||||
vif1Regs.stat.VPS = VPS_IDLE;
|
vif1Regs.stat.VPS = VPS_IDLE;
|
||||||
vif1Regs.stat.FQC = 0; // FQC=0
|
vif1Regs.stat.FQC = 0; // FQC=0
|
||||||
|
|
||||||
|
|
|
@ -58,7 +58,7 @@ __fi void vif1FLUSH()
|
||||||
void vif1TransferToMemory()
|
void vif1TransferToMemory()
|
||||||
{
|
{
|
||||||
u32 size;
|
u32 size;
|
||||||
u64* pMem = (u64*)dmaGetAddr(vif1ch.madr, false);
|
u128* pMem = (u128*)dmaGetAddr(vif1ch.madr, false);
|
||||||
|
|
||||||
// VIF from gsMemory
|
// VIF from gsMemory
|
||||||
if (pMem == NULL) //Is vif0ptag empty?
|
if (pMem == NULL) //Is vif0ptag empty?
|
||||||
|
@ -78,54 +78,34 @@ void vif1TransferToMemory()
|
||||||
// completely and execute the transfer there-after.
|
// completely and execute the transfer there-after.
|
||||||
//Console.Warning("Real QWC %x", vif1ch.qwc);
|
//Console.Warning("Real QWC %x", vif1ch.qwc);
|
||||||
size = min((u32)vif1ch.qwc, vif1.GSLastDownloadSize);
|
size = min((u32)vif1ch.qwc, vif1.GSLastDownloadSize);
|
||||||
|
const u128* pMemEnd = pMem + vif1.GSLastDownloadSize;
|
||||||
|
|
||||||
if (GSreadFIFO2 == NULL)
|
if (GSreadFIFO2 == NULL)
|
||||||
{
|
{
|
||||||
for (;size > 0; --size)
|
for (;size > 0; --size)
|
||||||
{
|
{
|
||||||
GetMTGS().WaitGS();
|
GetMTGS().WaitGS();
|
||||||
GSreadFIFO(&psHu64(VIF1_FIFO));
|
GSreadFIFO((u64*)pMem);
|
||||||
|
++pMem;
|
||||||
pMem[0] = psHu64(VIF1_FIFO);
|
|
||||||
pMem[1] = psHu64(VIF1_FIFO + 8);
|
|
||||||
pMem += 2;
|
|
||||||
}
|
|
||||||
if(vif1ch.qwc > vif1.GSLastDownloadSize)
|
|
||||||
{
|
|
||||||
DevCon.Warning("GS Transfer < VIF QWC, Clearing end of space");
|
|
||||||
for (size = vif1ch.qwc - vif1.GSLastDownloadSize; size > 0; --size)
|
|
||||||
{
|
|
||||||
psHu64(VIF1_FIFO) = 0;
|
|
||||||
psHu64(VIF1_FIFO + 8) = 0;
|
|
||||||
pMem[0] = psHu64(VIF1_FIFO);
|
|
||||||
pMem[1] = psHu64(VIF1_FIFO + 8);
|
|
||||||
pMem += 2;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
GetMTGS().WaitGS();
|
GetMTGS().WaitGS();
|
||||||
GSreadFIFO2(pMem, size);
|
GSreadFIFO2((u64*)pMem, size);
|
||||||
|
pMem += size;
|
||||||
// set incase read
|
|
||||||
psHu64(VIF1_FIFO) = pMem[2*size-2];
|
|
||||||
psHu64(VIF1_FIFO + 8) = pMem[2*size-1];
|
|
||||||
pMem += size * 2;
|
|
||||||
if(vif1ch.qwc > vif1.GSLastDownloadSize)
|
|
||||||
{
|
|
||||||
DevCon.Warning("GS Transfer < VIF QWC, Clearing end of space");
|
|
||||||
for (size = vif1ch.qwc - vif1.GSLastDownloadSize; size > 0; --size)
|
|
||||||
{
|
|
||||||
psHu64(VIF1_FIFO) = 0;
|
|
||||||
psHu64(VIF1_FIFO + 8) = 0;
|
|
||||||
pMem[0] = psHu64(VIF1_FIFO);
|
|
||||||
pMem[1] = psHu64(VIF1_FIFO + 8);
|
|
||||||
pMem += 2;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(pMem < pMemEnd)
|
||||||
|
{
|
||||||
|
DevCon.Warning("GS Transfer < VIF QWC, Clearing end of space");
|
||||||
|
|
||||||
|
__m128 zeroreg = _mm_setzero_ps();
|
||||||
|
do {
|
||||||
|
_mm_store_ps((float*)pMem, zeroreg);
|
||||||
|
++pMem;
|
||||||
|
} while (pMem < pMemEnd);
|
||||||
|
}
|
||||||
|
|
||||||
g_vifCycles += vif1ch.qwc * 2;
|
g_vifCycles += vif1ch.qwc * 2;
|
||||||
vif1ch.madr += vif1ch.qwc * 16; // mgs3 scene changes
|
vif1ch.madr += vif1ch.qwc * 16; // mgs3 scene changes
|
||||||
|
|
|
@ -58,10 +58,15 @@ enum GIF_REG
|
||||||
// are modified during the GIFtag unpacking process.
|
// are modified during the GIFtag unpacking process.
|
||||||
struct GIFTAG
|
struct GIFTAG
|
||||||
{
|
{
|
||||||
u32 NLOOP : 15;
|
u16 NLOOP : 15;
|
||||||
u32 EOP : 1;
|
u16 EOP : 1;
|
||||||
u32 _dummy0 : 16;
|
|
||||||
|
// Note that contents of the Dummy bits on real hardware is likely used to maintain state
|
||||||
|
// information regarding tag processing (namely nllop and curreg info, so to resume partial
|
||||||
|
// transfers later).
|
||||||
|
u16 _dummy0 : 16;
|
||||||
u32 _dummy1 : 14;
|
u32 _dummy1 : 14;
|
||||||
|
|
||||||
u32 PRE : 1;
|
u32 PRE : 1;
|
||||||
u32 PRIM : 11;
|
u32 PRIM : 11;
|
||||||
u32 FLG : 2;
|
u32 FLG : 2;
|
||||||
|
|
Loading…
Reference in New Issue