mirror of https://github.com/PCSX2/pcsx2.git
GIF: Correct GIF FIFO timing logic
This commit is contained in:
parent
97b94acd86
commit
2af8cde40d
|
@ -108,8 +108,6 @@ int GIF_Fifo::write_fifo(u32* pMem, int size)
|
||||||
|
|
||||||
int writePos = fifoSize * 4;
|
int writePos = fifoSize * 4;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
memcpy(&data[writePos], pMem, transferSize * 16);
|
memcpy(&data[writePos], pMem, transferSize * 16);
|
||||||
|
|
||||||
fifoSize += transferSize;
|
fifoSize += transferSize;
|
||||||
|
@ -292,7 +290,7 @@ __fi void gifInterrupt()
|
||||||
}
|
}
|
||||||
// If the dma has data waiting and there's something in the fifo, drain the fifo
|
// If the dma has data waiting and there's something in the fifo, drain the fifo
|
||||||
// If the GIF is currently paused, check if the FIFO is full, otherwise fill it
|
// If the GIF is currently paused, check if the FIFO is full, otherwise fill it
|
||||||
if ((!CheckPaths() && gif_fifo.fifoSize == 16) || (readSize && gif_fifo.fifoSize > 0))
|
if ((!CheckPaths() && gif_fifo.fifoSize == 16) || (readSize && gif_fifo.fifoSize < 16))
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -804,7 +802,7 @@ void gifMFIFOInterrupt()
|
||||||
|
|
||||||
// If the dma has data waiting and there's something in the fifo, drain the fifo
|
// If the dma has data waiting and there's something in the fifo, drain the fifo
|
||||||
// If the GIF is currently paused, check if the FIFO is full, otherwise fill it
|
// If the GIF is currently paused, check if the FIFO is full, otherwise fill it
|
||||||
if ((!CheckPaths() && gif_fifo.fifoSize == 16) || (readSize && gif_fifo.fifoSize > 0))
|
if ((!CheckPaths() && gif_fifo.fifoSize == 16) || (readSize && gif_fifo.fifoSize < 16))
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue