Skip to content

Commit

Permalink
pcsx2: call GSReadFIFO from GS thread (was EE)
Browse files Browse the repository at this point in the history
  • Loading branch information
gregory38 committed Mar 25, 2014
1 parent 39a9b7b commit f78c39c
Show file tree
Hide file tree
Showing 4 changed files with 12 additions and 2 deletions.
2 changes: 1 addition & 1 deletion pcsx2/FiFo.cpp
Expand Up @@ -50,8 +50,8 @@ void __fastcall ReadFIFO_VIF1(mem128_t* out)
DevCon.Warning("Warning! GS Download size < FIFO count!");
}
if (vif1Regs.stat.FQC > 0) {
GetMTGS().SendPointerPacket(GS_RINGTYPE_READ_FIFO1, 0, out);
GetMTGS().WaitGS();
GSreadFIFO((u64*)out);
vif1.GSLastDownloadSize--;
GUNIT_LOG("ReadFIFO_VIF1");
if (vif1.GSLastDownloadSize <= 16)
Expand Down
2 changes: 2 additions & 0 deletions pcsx2/GS.h
Expand Up @@ -247,6 +247,8 @@ enum MTGS_RingCommand
, GS_RINGTYPE_CRC
, GS_RINGTYPE_GSPACKET
, GS_RINGTYPE_MTVU_GSPACKET
, GS_RINGTYPE_READ_FIFO1
, GS_RINGTYPE_READ_FIFO2
};


Expand Down
8 changes: 8 additions & 0 deletions pcsx2/MTGS.cpp
Expand Up @@ -495,6 +495,14 @@ void SysMtgsThread::ExecuteTaskInThread()
GSsetGameCRC( tag.data[0], 0 );
break;

case GS_RINGTYPE_READ_FIFO1:
GSreadFIFO( (u64*)tag.data[1]);
break;

case GS_RINGTYPE_READ_FIFO2:
GSreadFIFO2( (u64*)tag.data[1], tag.data[0]);
break;

#ifdef PCSX2_DEVBUILD
default:
Console.Error("GSThreadProc, bad packet (%x) at m_ReadPos: %x, m_WritePos: %x", tag.command, m_ReadPos, m_WritePos);
Expand Down
2 changes: 1 addition & 1 deletion pcsx2/Vif1_Dma.cpp
Expand Up @@ -67,8 +67,8 @@ void vif1TransferToMemory()
pxAssert(p3.isDone() || !p3.gifTag.isValid);
}

GetMTGS().SendPointerPacket(GS_RINGTYPE_READ_FIFO2, size, pMem);
GetMTGS().WaitGS();
GSreadFIFO2((u64*)pMem, size);
pMem += size;

if(pMem < pMemEnd) {
Expand Down

0 comments on commit f78c39c

Please sign in to comment.