mirror of https://github.com/PCSX2/pcsx2.git
Sif: Check if there is anything in the fifo before reading from it, and if there is any free space in it before writing to it. Tweak logging a bit.
git-svn-id: http://pcsx2.googlecode.com/svn/trunk@2704 96395faa-99c1-11dd-bbfe-3dabce05a288
This commit is contained in:
parent
3f45a3b8b1
commit
02497e0d41
|
@ -36,7 +36,7 @@ static _BaseStateThread* current_state_thread = NULL;
|
||||||
static NonblockingMutex state_buffer_lock;
|
static NonblockingMutex state_buffer_lock;
|
||||||
|
|
||||||
// This boolean tracks if a savestate is actively saving. When a state is saving we
|
// This boolean tracks if a savestate is actively saving. When a state is saving we
|
||||||
// typically delay program termination to allow th state time to finish it's work.
|
// typically delay program termination to allow the state time to finish its work.
|
||||||
static bool state_is_saving = false;
|
static bool state_is_saving = false;
|
||||||
|
|
||||||
// This boolean is to keep the system from resuming emulation until the current state has completely
|
// This boolean is to keep the system from resuming emulation until the current state has completely
|
||||||
|
|
|
@ -18,11 +18,6 @@
|
||||||
|
|
||||||
#define FIFO_SIF_W 128
|
#define FIFO_SIF_W 128
|
||||||
|
|
||||||
// I'm not sure if removing the top 8 bits is correct or not, so this define lets me test it a bit.
|
|
||||||
// It doesn't seem like word has anything in the first 8 bits anyways, but data does (IRQ and tag id),
|
|
||||||
// so I'll have to play with it.
|
|
||||||
#define CHOP_OFF_DATA
|
|
||||||
|
|
||||||
struct sifData
|
struct sifData
|
||||||
{
|
{
|
||||||
s32 data;
|
s32 data;
|
||||||
|
|
|
@ -26,6 +26,7 @@ static bool done = false;
|
||||||
|
|
||||||
static __forceinline void Sif0Init()
|
static __forceinline void Sif0Init()
|
||||||
{
|
{
|
||||||
|
SIF_LOG("SIF0 DMA start...");
|
||||||
done = false;
|
done = false;
|
||||||
sif0.ee.cycles = 0;
|
sif0.ee.cycles = 0;
|
||||||
sif0.iop.cycles = 0;
|
sif0.iop.cycles = 0;
|
||||||
|
@ -35,8 +36,7 @@ static __forceinline void Sif0Init()
|
||||||
static __forceinline bool WriteFifoToEE()
|
static __forceinline bool WriteFifoToEE()
|
||||||
{
|
{
|
||||||
const int readSize = min((s32)sif0dma->qwc, sif0.fifo.size >> 2);
|
const int readSize = min((s32)sif0dma->qwc, sif0.fifo.size >> 2);
|
||||||
//if (readSize > 0)
|
|
||||||
//{
|
|
||||||
tDMA_TAG *ptag;
|
tDMA_TAG *ptag;
|
||||||
|
|
||||||
//SIF_LOG(" EE SIF doing transfer %04Xqw to %08X", readSize, sif0dma->madr);
|
//SIF_LOG(" EE SIF doing transfer %04Xqw to %08X", readSize, sif0dma->madr);
|
||||||
|
@ -57,12 +57,7 @@ static __forceinline bool WriteFifoToEE()
|
||||||
sif0dma->madr += readSize << 4;
|
sif0dma->madr += readSize << 4;
|
||||||
sif0.ee.cycles += readSize; // fixme : BIAS is factored in above
|
sif0.ee.cycles += readSize; // fixme : BIAS is factored in above
|
||||||
sif0dma->qwc -= readSize;
|
sif0dma->qwc -= readSize;
|
||||||
//}
|
|
||||||
//else
|
|
||||||
//{
|
|
||||||
//DevCon.Warning("Write Fifo to EE: readSize is 0");
|
|
||||||
// return false;
|
|
||||||
//}
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -72,13 +67,6 @@ static __forceinline bool WriteIOPtoFifo()
|
||||||
// There's some data ready to transfer into the fifo..
|
// There's some data ready to transfer into the fifo..
|
||||||
const int writeSize = min(sif0.iop.counter, sif0.fifo.free());
|
const int writeSize = min(sif0.iop.counter, sif0.fifo.free());
|
||||||
|
|
||||||
//if (writeSize <= 0)
|
|
||||||
//{
|
|
||||||
//DevCon.Warning("Write IOP to Fifo: writeSize is 0");
|
|
||||||
// return false;
|
|
||||||
//}
|
|
||||||
//else
|
|
||||||
//{
|
|
||||||
SIF_LOG("Write IOP to Fifo: +++++++++++ %lX of %lX", writeSize, sif0.iop.counter);
|
SIF_LOG("Write IOP to Fifo: +++++++++++ %lX of %lX", writeSize, sif0.iop.counter);
|
||||||
|
|
||||||
sif0.fifo.write((u32*)iopPhysMem(hw_dma(9).madr), writeSize);
|
sif0.fifo.write((u32*)iopPhysMem(hw_dma(9).madr), writeSize);
|
||||||
|
@ -87,7 +75,7 @@ static __forceinline bool WriteIOPtoFifo()
|
||||||
// iop is 1/8th the clock rate of the EE and psxcycles is in words (not quadwords).
|
// iop is 1/8th the clock rate of the EE and psxcycles is in words (not quadwords).
|
||||||
sif0.iop.cycles += (writeSize >> 2) * BIAS; // fixme : should be >> 4
|
sif0.iop.cycles += (writeSize >> 2) * BIAS; // fixme : should be >> 4
|
||||||
sif0.iop.counter -= writeSize;
|
sif0.iop.counter -= writeSize;
|
||||||
//}
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -142,17 +130,13 @@ static __forceinline bool ProcessIOPTag()
|
||||||
|
|
||||||
hw_dma(9).tadr += 16; ///hw_dma(9).madr + 16 + sif0.sifData.words << 2;
|
hw_dma(9).tadr += 16; ///hw_dma(9).madr + 16 + sif0.sifData.words << 2;
|
||||||
|
|
||||||
// Looks like we are only copying the first 24 bits.
|
// We're only copying the first 24 bits.
|
||||||
#ifdef CHOP_OFF_DATA
|
|
||||||
hw_dma(9).madr = sif0data & 0xFFFFFF;
|
hw_dma(9).madr = sif0data & 0xFFFFFF;
|
||||||
#else
|
|
||||||
hw_dma(9).madr = sif0data;
|
|
||||||
#endif
|
|
||||||
sif0.iop.counter = sif0words;
|
sif0.iop.counter = sif0words;
|
||||||
//if (sif0words != ( sif0words & 0xFFFFFF)) DevCon.WriteLn("sif0words more then 24 bit.");
|
|
||||||
|
|
||||||
if (sif0tag.IRQ || (sif0tag.ID & 4)) sif0.iop.end = true;
|
if (sif0tag.IRQ || (sif0tag.ID & 4)) sif0.iop.end = true;
|
||||||
SIF_LOG("SIF0 IOP Tag: madr=%lx, tadr=%lx, counter=%lx (%08X_%08X)", hw_dma(9).madr, hw_dma(9).tadr, sif0.iop.counter, sif0words, sif0data);
|
SIF_LOG("SIF0 IOP Tag: madr=%lx, tadr=%lx, counter=%lx (%08X_%08X)", hw_dma(9).madr, hw_dma(9).tadr, sif0.iop.counter, sif0words, sif0data);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -164,7 +148,7 @@ static __forceinline void EndEE()
|
||||||
sif0.ee.busy = false;
|
sif0.ee.busy = false;
|
||||||
if (sif0.ee.cycles == 0)
|
if (sif0.ee.cycles == 0)
|
||||||
{
|
{
|
||||||
DevCon.Warning("SIF0 EE: cycles = 0");
|
SIF_LOG("SIF0 EE: cycles = 0");
|
||||||
sif0.ee.cycles = 1;
|
sif0.ee.cycles = 1;
|
||||||
}
|
}
|
||||||
CPU_INT(DMAC_SIF0, sif0.ee.cycles*BIAS);
|
CPU_INT(DMAC_SIF0, sif0.ee.cycles*BIAS);
|
||||||
|
@ -180,7 +164,7 @@ static __forceinline void EndIOP()
|
||||||
|
|
||||||
if (sif0.iop.cycles == 0)
|
if (sif0.iop.cycles == 0)
|
||||||
{
|
{
|
||||||
DevCon.Warning("SIF0 IOP: cycles = 0");
|
SIF_LOG("SIF0 IOP: cycles = 0");
|
||||||
sif0.iop.cycles = 1;
|
sif0.iop.cycles = 1;
|
||||||
}
|
}
|
||||||
// iop is 1/8th the clock rate of the EE and psxcycles is in words (not quadwords)
|
// iop is 1/8th the clock rate of the EE and psxcycles is in words (not quadwords)
|
||||||
|
@ -218,9 +202,12 @@ static __forceinline void HandleEETransfer()
|
||||||
if (sif0dma->qwc > 0) // If we're writing something, continue to do so.
|
if (sif0dma->qwc > 0) // If we're writing something, continue to do so.
|
||||||
{
|
{
|
||||||
// Write from Fifo to EE.
|
// Write from Fifo to EE.
|
||||||
|
if (sif0.fifo.size > 0)
|
||||||
|
{
|
||||||
WriteFifoToEE();
|
WriteFifoToEE();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Handle the IOP transfer.
|
// Handle the IOP transfer.
|
||||||
// Note: Test any changes in this function against Grandia III.
|
// Note: Test any changes in this function against Grandia III.
|
||||||
|
@ -271,18 +258,21 @@ static __forceinline void HandleIOPTransfer()
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// Write IOP to Fifo.
|
// Write IOP to Fifo.
|
||||||
|
if (sif0.fifo.free() > 0)
|
||||||
|
{
|
||||||
WriteIOPtoFifo();
|
WriteIOPtoFifo();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static __forceinline void Sif0End()
|
static __forceinline void Sif0End()
|
||||||
{
|
{
|
||||||
|
SIF_LOG("SIF0 DMA end...");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Transfer IOP to EE, putting data in the fifo as an intermediate step.
|
// Transfer IOP to EE, putting data in the fifo as an intermediate step.
|
||||||
__forceinline void SIF0Dma()
|
__forceinline void SIF0Dma()
|
||||||
{
|
{
|
||||||
SIF_LOG("SIF0 DMA start...");
|
|
||||||
Sif0Init();
|
Sif0Init();
|
||||||
|
|
||||||
do
|
do
|
||||||
|
@ -291,7 +281,6 @@ __forceinline void SIF0Dma()
|
||||||
if (sif0.ee.busy) HandleEETransfer();
|
if (sif0.ee.busy) HandleEETransfer();
|
||||||
} while (!done); // Substituting (sif0.ee.busy || sif0.iop.busy) breaks things.
|
} while (!done); // Substituting (sif0.ee.busy || sif0.iop.busy) breaks things.
|
||||||
|
|
||||||
SIF_LOG("SIF0 DMA end...");
|
|
||||||
Sif0End();
|
Sif0End();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -26,6 +26,7 @@ static bool done = false;
|
||||||
|
|
||||||
static __forceinline void Sif1Init()
|
static __forceinline void Sif1Init()
|
||||||
{
|
{
|
||||||
|
SIF_LOG("SIF1 DMA start...");
|
||||||
done = false;
|
done = false;
|
||||||
sif1.ee.cycles = 0;
|
sif1.ee.cycles = 0;
|
||||||
sif1.iop.cycles = 0;
|
sif1.iop.cycles = 0;
|
||||||
|
@ -38,13 +39,7 @@ static __forceinline bool WriteEEtoFifo()
|
||||||
|
|
||||||
SIF_LOG("Sif 1: Write EE to Fifo");
|
SIF_LOG("Sif 1: Write EE to Fifo");
|
||||||
const int writeSize = min((s32)sif1dma->qwc, sif1.fifo.free() >> 2);
|
const int writeSize = min((s32)sif1dma->qwc, sif1.fifo.free() >> 2);
|
||||||
//if (writeSize <= 0)
|
|
||||||
//{
|
|
||||||
//DevCon.Warning("WriteEEtoFifo: writeSize is 0");
|
|
||||||
// return false;
|
|
||||||
//}
|
|
||||||
//else
|
|
||||||
//{
|
|
||||||
tDMA_TAG *ptag;
|
tDMA_TAG *ptag;
|
||||||
|
|
||||||
ptag = sif1dma->getAddr(sif1dma->madr, DMAC_SIF1);
|
ptag = sif1dma->getAddr(sif1dma->madr, DMAC_SIF1);
|
||||||
|
@ -59,7 +54,7 @@ static __forceinline bool WriteEEtoFifo()
|
||||||
sif1dma->madr += writeSize << 4;
|
sif1dma->madr += writeSize << 4;
|
||||||
sif1.ee.cycles += writeSize; // fixme : BIAS is factored in above
|
sif1.ee.cycles += writeSize; // fixme : BIAS is factored in above
|
||||||
sif1dma->qwc -= writeSize;
|
sif1dma->qwc -= writeSize;
|
||||||
//}
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -70,13 +65,7 @@ static __forceinline bool WriteFifoToIOP()
|
||||||
|
|
||||||
SIF_LOG("Sif1: Write Fifo to IOP");
|
SIF_LOG("Sif1: Write Fifo to IOP");
|
||||||
const int readSize = min (sif1.iop.counter, sif1.fifo.size);
|
const int readSize = min (sif1.iop.counter, sif1.fifo.size);
|
||||||
//if (readSize <= 0)
|
|
||||||
//{
|
|
||||||
//DevCon.Warning("WriteFifoToIOP: readSize is 0");
|
|
||||||
// return false;
|
|
||||||
//}
|
|
||||||
//else
|
|
||||||
//{
|
|
||||||
SIF_LOG("Sif 1 IOP doing transfer %04X to %08X", readSize, HW_DMA10_MADR);
|
SIF_LOG("Sif 1 IOP doing transfer %04X to %08X", readSize, HW_DMA10_MADR);
|
||||||
|
|
||||||
sif1.fifo.read((u32*)iopPhysMem(hw_dma(10).madr), readSize);
|
sif1.fifo.read((u32*)iopPhysMem(hw_dma(10).madr), readSize);
|
||||||
|
@ -84,7 +73,7 @@ static __forceinline bool WriteFifoToIOP()
|
||||||
hw_dma(10).madr += readSize << 2;
|
hw_dma(10).madr += readSize << 2;
|
||||||
sif1.iop.cycles += readSize >> 2; // fixme: should be >> 4
|
sif1.iop.cycles += readSize >> 2; // fixme: should be >> 4
|
||||||
sif1.iop.counter -= readSize;
|
sif1.iop.counter -= readSize;
|
||||||
//}
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -161,15 +150,12 @@ static __forceinline bool SIFIOPReadTag()
|
||||||
SIF_LOG("SIF 1 IOP: dest chain tag madr:%08X wc:%04X id:%X irq:%d",
|
SIF_LOG("SIF 1 IOP: dest chain tag madr:%08X wc:%04X id:%X irq:%d",
|
||||||
sif1data & 0xffffff, sif1words, sif1tag.ID, sif1tag.IRQ);
|
sif1data & 0xffffff, sif1words, sif1tag.ID, sif1tag.IRQ);
|
||||||
|
|
||||||
#ifdef CHOP_OFF_DATA
|
// Only use the first 24 bits.
|
||||||
hw_dma(10).madr = sif1data & 0xffffff;
|
hw_dma(10).madr = sif1data & 0xffffff;
|
||||||
#else
|
|
||||||
hw_dma(10).madr = sif1data;
|
|
||||||
#endif
|
|
||||||
sif1.iop.counter = sif1words;
|
|
||||||
//if (sif1words != ( sif1words & 0xFFFFFF)) DevCon.WriteLn("sif1words more then 24 bit.");
|
|
||||||
|
|
||||||
|
sif1.iop.counter = sif1words;
|
||||||
if (sif1tag.IRQ || (sif1tag.ID & 4)) sif1.iop.end = true;
|
if (sif1tag.IRQ || (sif1tag.ID & 4)) sif1.iop.end = true;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -185,7 +171,7 @@ static __forceinline void EndEE()
|
||||||
// (Cause of double interrupts on the EE)
|
// (Cause of double interrupts on the EE)
|
||||||
if (sif1.ee.cycles == 0)
|
if (sif1.ee.cycles == 0)
|
||||||
{
|
{
|
||||||
DevCon.Warning("SIF1 EE: cycles = 0");
|
SIF_LOG("SIF1 EE: cycles = 0");
|
||||||
sif1.ee.cycles = 1;
|
sif1.ee.cycles = 1;
|
||||||
}
|
}
|
||||||
CPU_INT(DMAC_SIF1, min((int)(sif1.ee.cycles*BIAS), 384));
|
CPU_INT(DMAC_SIF1, min((int)(sif1.ee.cycles*BIAS), 384));
|
||||||
|
@ -205,7 +191,7 @@ static __forceinline void EndIOP()
|
||||||
//Total cycles over 1024 makes SIF too slow to keep up the sound stream in so3...
|
//Total cycles over 1024 makes SIF too slow to keep up the sound stream in so3...
|
||||||
if (sif1.iop.cycles == 0)
|
if (sif1.iop.cycles == 0)
|
||||||
{
|
{
|
||||||
DevCon.Warning("SIF1 IOP: cycles = 0");
|
SIF_LOG("SIF1 IOP: cycles = 0");
|
||||||
sif1.iop.cycles = 1;
|
sif1.iop.cycles = 1;
|
||||||
}
|
}
|
||||||
// iop is 1/8th the clock rate of the EE and psxcycles is in words (not quadwords)
|
// iop is 1/8th the clock rate of the EE and psxcycles is in words (not quadwords)
|
||||||
|
@ -238,18 +224,24 @@ static __forceinline void HandleEETransfer()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
|
{
|
||||||
|
if (sif1.fifo.free() > 0)
|
||||||
{
|
{
|
||||||
WriteEEtoFifo();
|
WriteEEtoFifo();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Handle the IOP transfer.
|
// Handle the IOP transfer.
|
||||||
static __forceinline void HandleIOPTransfer()
|
static __forceinline void HandleIOPTransfer()
|
||||||
{
|
{
|
||||||
if (sif1.iop.counter > 0)
|
if (sif1.iop.counter > 0)
|
||||||
|
{
|
||||||
|
if (sif1.fifo.size > 0)
|
||||||
{
|
{
|
||||||
WriteFifoToIOP();
|
WriteFifoToIOP();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (sif1.iop.counter <= 0)
|
if (sif1.iop.counter <= 0)
|
||||||
{
|
{
|
||||||
|
@ -269,12 +261,12 @@ static __forceinline void HandleIOPTransfer()
|
||||||
|
|
||||||
static __forceinline void Sif1End()
|
static __forceinline void Sif1End()
|
||||||
{
|
{
|
||||||
|
SIF_LOG("SIF1 DMA end...");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Transfer EE to IOP, putting data in the fifo as an intermediate step.
|
// Transfer EE to IOP, putting data in the fifo as an intermediate step.
|
||||||
__forceinline void SIF1Dma()
|
__forceinline void SIF1Dma()
|
||||||
{
|
{
|
||||||
SIF_LOG("SIF1 DMA start...");
|
|
||||||
Sif1Init();
|
Sif1Init();
|
||||||
|
|
||||||
do
|
do
|
||||||
|
@ -283,7 +275,6 @@ __forceinline void SIF1Dma()
|
||||||
if (sif1.iop.busy) HandleIOPTransfer();
|
if (sif1.iop.busy) HandleIOPTransfer();
|
||||||
} while (!done);
|
} while (!done);
|
||||||
|
|
||||||
SIF_LOG("SIF1 DMA end...");
|
|
||||||
Sif1End();
|
Sif1End();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue