mirror of https://github.com/PCSX2/pcsx2.git
Updated the FFX Video Fix, should work again now. Added DMA End log messages to DMA logging. Hopefully one day someone will reverse engineer the FFX video code so we can see if we are really doing something really wrong or if the code is just dire >.<
git-svn-id: http://pcsx2.googlecode.com/svn/trunk@4354 96395faa-99c1-11dd-bbfe-3dabce05a288
This commit is contained in:
parent
6af6a424ba
commit
c368a6a422
|
@ -166,7 +166,7 @@ __fi void gsInterrupt()
|
|||
gifRegs.stat.clear_flags(GIF_STAT_FQC);
|
||||
clearFIFOstuff(false);
|
||||
hwDmacIrq(DMAC_GIF);
|
||||
//DevCon.Warning("GIF DMA end");
|
||||
DMA_LOG("GIF DMA End");
|
||||
}
|
||||
|
||||
static u32 WRITERING_DMA(u32 *pMem, u32 qwc)
|
||||
|
@ -683,7 +683,7 @@ void gifMFIFOInterrupt()
|
|||
gifch.chcr.STR = false;
|
||||
gifstate = GIF_STATE_READY;
|
||||
hwDmacIrq(DMAC_GIF);
|
||||
GIF_LOG("gifMFIFO End");
|
||||
DMA_LOG("GIF MFIFO DMA End");
|
||||
clearFIFOstuff(false);
|
||||
}
|
||||
|
||||
|
|
|
@ -152,7 +152,6 @@ int IPU1dma()
|
|||
int totalqwc = 0;
|
||||
|
||||
//We need to make sure GIF has flushed before sending IPU data, it seems to REALLY screw FFX videos
|
||||
//if(!WaitGSPaths()) return totalqwc;
|
||||
|
||||
if(ipu1dma.chcr.STR == false || IPU1Status.DMAMode == 2)
|
||||
{
|
||||
|
@ -169,11 +168,6 @@ int IPU1dma()
|
|||
{
|
||||
case DMA_MODE_NORMAL:
|
||||
{
|
||||
if(!WaitGSPaths())
|
||||
{ // legacy WaitGSPaths() for now
|
||||
IPU_INT_TO(32); //Give it a short wait.
|
||||
return totalqwc;
|
||||
}
|
||||
IPU_LOG("Processing Normal QWC left %x Finished %d In Progress %d", ipu1dma.qwc, IPU1Status.DMAFinished, IPU1Status.InProgress);
|
||||
if(IPU1Status.InProgress == true) totalqwc += IPU1chain();
|
||||
}
|
||||
|
@ -183,11 +177,6 @@ int IPU1dma()
|
|||
{
|
||||
if(IPU1Status.InProgress == true) //No transfer is ready to go so we need to set one up
|
||||
{
|
||||
if(!WaitGSPaths())
|
||||
{ // legacy WaitGSPaths() for now
|
||||
IPU_INT_TO(32); //Give it a short wait.
|
||||
return totalqwc;
|
||||
}
|
||||
IPU_LOG("Processing Chain QWC left %x Finished %d In Progress %d", ipu1dma.qwc, IPU1Status.DMAFinished, IPU1Status.InProgress);
|
||||
totalqwc += IPU1chain();
|
||||
//Set the TADR forward
|
||||
|
@ -263,12 +252,6 @@ int IPU1dma()
|
|||
if (ipu1dma.chcr.TIE && ptag->IRQ) //Tag Interrupt is set, so schedule the end/interrupt
|
||||
IPU1Status.DMAFinished = true;
|
||||
|
||||
|
||||
if(!WaitGSPaths() && ipu1dma.qwc > 0)
|
||||
{ // legacy WaitGSPaths() for now
|
||||
IPU_INT_TO(32); //Give it a short wait.
|
||||
return totalqwc;
|
||||
}
|
||||
IPU_LOG("Processing Start Chain QWC left %x Finished %d In Progress %d", ipu1dma.qwc, IPU1Status.DMAFinished, IPU1Status.InProgress);
|
||||
totalqwc += IPU1chain();
|
||||
//Set the TADR forward
|
||||
|
@ -490,6 +473,7 @@ void ipu0Interrupt()
|
|||
|
||||
ipu0dma.chcr.STR = false;
|
||||
hwDmacIrq(DMAC_FROM_IPU);
|
||||
DMA_LOG("IPU0 DMA End");
|
||||
}
|
||||
|
||||
IPU_FORCEINLINE void ipu1Interrupt()
|
||||
|
@ -502,7 +486,7 @@ IPU_FORCEINLINE void ipu1Interrupt()
|
|||
return;
|
||||
}
|
||||
|
||||
IPU_LOG("ipu1 finish %x:", cpuRegs.cycle);
|
||||
DMA_LOG("IPU1 DMA End");
|
||||
ipu1dma.chcr.STR = false;
|
||||
IPU1Status.DMAMode = 2;
|
||||
hwDmacIrq(DMAC_TO_IPU);
|
||||
|
|
|
@ -264,6 +264,7 @@ void SPRFROMinterrupt()
|
|||
|
||||
spr0ch.chcr.STR = false;
|
||||
hwDmacIrq(DMAC_FROM_SPR);
|
||||
DMA_LOG("SPR0 DMA End");
|
||||
}
|
||||
|
||||
void dmaSPR0() // fromSPR
|
||||
|
@ -316,9 +317,17 @@ int _SPR1chain()
|
|||
}
|
||||
|
||||
__fi void SPR1chain()
|
||||
{
|
||||
if(!CHECK_IPUWAITHACK)
|
||||
{
|
||||
CPU_INT(DMAC_TO_SPR, _SPR1chain() * BIAS);
|
||||
}
|
||||
else
|
||||
{
|
||||
_SPR1chain();
|
||||
CPU_INT(DMAC_TO_SPR, 8);
|
||||
}
|
||||
}
|
||||
|
||||
void _SPR1interleave()
|
||||
{
|
||||
|
@ -444,7 +453,7 @@ void SPRTOinterrupt()
|
|||
return;
|
||||
}
|
||||
|
||||
SPR_LOG("SPR1 End");
|
||||
DMA_LOG("SPR1 DMA End");
|
||||
spr1ch.chcr.STR = false;
|
||||
hwDmacIrq(DMAC_TO_SPR);
|
||||
}
|
||||
|
|
|
@ -288,7 +288,7 @@ static __fi void Sif0End()
|
|||
psHu32(SBUS_F240) &= ~0x20;
|
||||
psHu32(SBUS_F240) &= ~0x2000;
|
||||
|
||||
SIF_LOG("SIF0 DMA end...");
|
||||
DMA_LOG("SIF0 DMA End");
|
||||
}
|
||||
|
||||
// Transfer IOP to EE, putting data in the fifo as an intermediate step.
|
||||
|
|
|
@ -281,7 +281,7 @@ static __fi void Sif1End()
|
|||
psHu32(SBUS_F240) &= ~0x40;
|
||||
psHu32(SBUS_F240) &= ~0x4000;
|
||||
|
||||
SIF_LOG("SIF1 DMA end...");
|
||||
DMA_LOG("SIF1 DMA End");
|
||||
}
|
||||
|
||||
// Transfer EE to IOP, putting data in the fifo as an intermediate step.
|
||||
|
|
|
@ -236,6 +236,7 @@ __fi void vif0Interrupt()
|
|||
g_vifCycles = 0;
|
||||
hwDmacIrq(DMAC_VIF0);
|
||||
vif0Regs.stat.FQC = 0;
|
||||
DMA_LOG("VIF0 DMA End");
|
||||
}
|
||||
|
||||
void dmaVIF0()
|
||||
|
|
|
@ -457,7 +457,7 @@ __fi void vif1Interrupt()
|
|||
vif1.vifstalled = false;
|
||||
g_vifCycles = 0;
|
||||
g_vu1Cycles = 0;
|
||||
VIF_LOG("VIF1 End");
|
||||
DMA_LOG("VIF1 DMA End");
|
||||
hwDmacIrq(DMAC_VIF1);
|
||||
|
||||
}
|
||||
|
|
|
@ -356,7 +356,7 @@ void vifMFIFOInterrupt()
|
|||
vif1Regs.stat.FQC = min((u16)0x10, vif1ch.qwc);
|
||||
vif1ch.chcr.STR = false;
|
||||
hwDmacIrq(DMAC_VIF1);
|
||||
VIF_LOG("vif mfifo dma end");
|
||||
DMA_LOG("VIF1 MFIFO DMA End");
|
||||
|
||||
vif1Regs.stat.FQC = 0;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue