mirror of https://github.com/PCSX2/pcsx2.git
Revised Ipu1Chain, and tweaked Ipu1Dma.
git-svn-id: http://pcsx2.googlecode.com/svn/trunk@1329 96395faa-99c1-11dd-bbfe-3dabce05a288
This commit is contained in:
parent
a134dd6110
commit
c668c7c351
|
@ -1373,7 +1373,7 @@ int FIFOto_write(u32* pMem, int size)
|
||||||
return firsttrans;
|
return firsttrans;
|
||||||
}
|
}
|
||||||
|
|
||||||
static __forceinline s32 IPU1chain(u32* &pMem, int &totalqwc)
|
static __forceinline bool IPU1chain(u32* &pMem, int &totalqwc)
|
||||||
{
|
{
|
||||||
if (ipu1dma->qwc > 0)
|
if (ipu1dma->qwc > 0)
|
||||||
{
|
{
|
||||||
|
@ -1384,7 +1384,7 @@ static __forceinline s32 IPU1chain(u32* &pMem, int &totalqwc)
|
||||||
if (pMem == NULL)
|
if (pMem == NULL)
|
||||||
{
|
{
|
||||||
Console::Error("ipu1dma NULL!");
|
Console::Error("ipu1dma NULL!");
|
||||||
return totalqwc;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
qwc = FIFOto_write(pMem, qwc);
|
qwc = FIFOto_write(pMem, qwc);
|
||||||
|
@ -1395,11 +1395,25 @@ static __forceinline s32 IPU1chain(u32* &pMem, int &totalqwc)
|
||||||
if (ipu1dma->qwc > 0)
|
if (ipu1dma->qwc > 0)
|
||||||
{
|
{
|
||||||
g_nDMATransfer |= IPU_DMA_ACTV1;
|
g_nDMATransfer |= IPU_DMA_ACTV1;
|
||||||
return totalqwc;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
return -1;
|
static __forceinline bool IncreaseTadr(u32 tag)
|
||||||
|
{
|
||||||
|
switch (tag & 0x70000000)
|
||||||
|
{
|
||||||
|
case 0x00000000:
|
||||||
|
ipu1dma->tadr += 16;
|
||||||
|
return true;
|
||||||
|
|
||||||
|
case 0x70000000:
|
||||||
|
ipu1dma->tadr = ipu1dma->madr;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
extern void gsInterrupt();
|
extern void gsInterrupt();
|
||||||
|
@ -1427,95 +1441,76 @@ int IPU1dma()
|
||||||
// in kh, qwc == 0 when dma_actv1 is set
|
// in kh, qwc == 0 when dma_actv1 is set
|
||||||
if ((g_nDMATransfer & IPU_DMA_ACTV1) && ipu1dma->qwc > 0)
|
if ((g_nDMATransfer & IPU_DMA_ACTV1) && ipu1dma->qwc > 0)
|
||||||
{
|
{
|
||||||
int temp = IPU1chain(pMem, totalqwc);
|
if (IPU1chain(pMem, totalqwc)) return totalqwc;
|
||||||
if (temp != -1) return temp;
|
|
||||||
|
|
||||||
//Check TIE bit of CHCR and IRQ bit of tag
|
//Check TIE bit of CHCR and IRQ bit of tag
|
||||||
if ((ipu1dma->chcr & 0x80) && (g_nDMATransfer&IPU_DMA_DOTIE1))
|
if ((ipu1dma->chcr & 0x80) && (g_nDMATransfer & IPU_DMA_DOTIE1))
|
||||||
{
|
{
|
||||||
Console::WriteLn("IPU1 TIE");
|
Console::WriteLn("IPU1 TIE");
|
||||||
|
|
||||||
IPU_INT_TO(totalqwc*BIAS);
|
IPU_INT_TO(totalqwc * BIAS);
|
||||||
g_nDMATransfer &= ~(IPU_DMA_ACTV1 | IPU_DMA_DOTIE1);
|
g_nDMATransfer &= ~(IPU_DMA_ACTV1 | IPU_DMA_DOTIE1);
|
||||||
g_nDMATransfer |= IPU_DMA_TIE1;
|
g_nDMATransfer |= IPU_DMA_TIE1;
|
||||||
return totalqwc;
|
return totalqwc;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((ipu1dma->chcr&0xc) == 0)
|
if (!(ipu1dma->chcr & 0xc))
|
||||||
{
|
{
|
||||||
IPU_INT_TO(totalqwc*BIAS);
|
IPU_INT_TO(totalqwc * BIAS);
|
||||||
return totalqwc;
|
return totalqwc;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
u32 tag = ipu1dma->chcr; // upper bits describe current tag
|
u32 tag = ipu1dma->chcr; // upper bits describe current tag
|
||||||
|
|
||||||
if ((ipu1dma->chcr & 0x80) && (tag&0x80000000))
|
if ((ipu1dma->chcr & 0x80) && (tag & 0x80000000))
|
||||||
{
|
{
|
||||||
ptag = (u32*)dmaGetAddr(ipu1dma->tadr);
|
ptag = (u32*)dmaGetAddr(ipu1dma->tadr);
|
||||||
|
|
||||||
switch (tag&0x70000000)
|
IncreaseTadr(tag);
|
||||||
{
|
|
||||||
case 0x00000000:
|
|
||||||
ipu1dma->tadr += 16;
|
|
||||||
break;
|
|
||||||
case 0x70000000:
|
|
||||||
ipu1dma->tadr = ipu1dma->madr;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
ipu1dma->chcr = (ipu1dma->chcr & 0xFFFF) | ((*ptag) & 0xFFFF0000);
|
ipu1dma->chcr = (ipu1dma->chcr & 0xFFFF) | ((*ptag) & 0xFFFF0000);
|
||||||
IPU_LOG("IPU dmaIrq Set");
|
IPU_LOG("IPU dmaIrq Set");
|
||||||
IPU_INT_TO(totalqwc*BIAS);
|
IPU_INT_TO(totalqwc * BIAS);
|
||||||
g_nDMATransfer |= IPU_DMA_TIE1;
|
g_nDMATransfer |= IPU_DMA_TIE1;
|
||||||
return totalqwc;
|
return totalqwc;
|
||||||
}
|
}
|
||||||
|
|
||||||
switch (tag&0x70000000)
|
if (IncreaseTadr(tag))
|
||||||
{
|
{
|
||||||
case 0x00000000:
|
IPU_INT_TO((1 + totalqwc)*BIAS);
|
||||||
ipu1dma->tadr += 16;
|
return totalqwc;
|
||||||
IPU_INT_TO((1 + totalqwc)*BIAS);
|
|
||||||
return totalqwc;
|
|
||||||
|
|
||||||
case 0x70000000:
|
|
||||||
ipu1dma->tadr = ipu1dma->madr;
|
|
||||||
IPU_INT_TO((1 + totalqwc)*BIAS);
|
|
||||||
return totalqwc;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
g_nDMATransfer &= ~(IPU_DMA_ACTV1 | IPU_DMA_DOTIE1);
|
g_nDMATransfer &= ~(IPU_DMA_ACTV1 | IPU_DMA_DOTIE1);
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((ipu1dma->chcr & 0xc) == 0 && ipu1dma->qwc == 0) // Normal Mode
|
if (((ipu1dma->chcr & 0xc) == 0) && (ipu1dma->qwc == 0)) // Normal Mode
|
||||||
{
|
{
|
||||||
//Console::WriteLn("ipu1 normal empty qwc?");
|
//Console::WriteLn("ipu1 normal empty qwc?");
|
||||||
return totalqwc;
|
return totalqwc;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Transfer Dn_QWC from Dn_MADR to GIF
|
// Transfer Dn_QWC from Dn_MADR to GIF
|
||||||
|
if (ipu1dma->qwc > 0)
|
||||||
if ((ipu1dma->chcr & 0xc) == 0 || ipu1dma->qwc > 0) // Normal Mode
|
|
||||||
{
|
{
|
||||||
IPU_LOG("dmaIPU1 Normal size=%d, addr=%lx, fifosize=%x",
|
IPU_LOG("dmaIPU1 Normal size=%d, addr=%lx, fifosize=%x",
|
||||||
ipu1dma->qwc, ipu1dma->madr, 8 - g_BP.IFC);
|
ipu1dma->qwc, ipu1dma->madr, 8 - g_BP.IFC);
|
||||||
|
|
||||||
int temp = IPU1chain(pMem, totalqwc);
|
if (!IPU1chain(pMem, totalqwc)) IPU_INT_TO((ipu1cycles + totalqwc) * BIAS);
|
||||||
if (temp != -1) return temp;
|
|
||||||
|
|
||||||
IPU_INT_TO((ipu1cycles + totalqwc)*BIAS);
|
|
||||||
return totalqwc;
|
return totalqwc;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// Chain Mode
|
// Chain Mode & ipu1dma->qwc is 0
|
||||||
ptag = (u32*)dmaGetAddr(ipu1dma->tadr); //Set memory pointer to TADR
|
ptag = (u32*)dmaGetAddr(ipu1dma->tadr); //Set memory pointer to TADR
|
||||||
if (ptag == NULL) //Is ptag empty?
|
if (ptag == NULL) //Is ptag empty?
|
||||||
{
|
{
|
||||||
Console::Error("IPU1 BUSERR");
|
Console::Error("IPU1 BUSERR");
|
||||||
ipu1dma->chcr = (ipu1dma->chcr & 0xFFFF) | ((*ptag) & 0xFFFF0000); //Transfer upper part of tag to CHCR bits 31-15
|
ipu1dma->chcr = (ipu1dma->chcr & 0xFFFF) | ((*ptag) & 0xFFFF0000); //Transfer upper part of tag to CHCR bits 31-15
|
||||||
psHu32(DMAC_STAT) |= 1 << 15; //If yes, set BEIS (BUSERR) in DMAC_STAT register
|
psHu32(DMAC_STAT) |= DMAC_STAT_BEIS; //If yes, set BEIS (BUSERR) in DMAC_STAT register
|
||||||
return totalqwc;
|
return totalqwc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1567,54 +1562,44 @@ int IPU1dma()
|
||||||
else
|
else
|
||||||
g_nDMATransfer &= ~IPU_DMA_DOTIE1;
|
g_nDMATransfer &= ~IPU_DMA_DOTIE1;
|
||||||
|
|
||||||
//Britney Dance beat does a blank NEXT tag, for some odd reason the fix doesnt work if after IPU1Chain O_o
|
|
||||||
if ((ipu1dma->qwc == 0) && (!done) && !(g_nDMATransfer & IPU_DMA_DOTIE1)) IPU1dma();
|
|
||||||
|
|
||||||
int temp = IPU1chain(pMem, totalqwc);
|
|
||||||
if (temp != -1) return temp;
|
|
||||||
|
|
||||||
if ((ipu1dma->chcr & 0x80) && (ptag[0]&0x80000000) && ipu1dma->qwc == 0) //Check TIE bit of CHCR and IRQ bit of tag
|
|
||||||
{
|
|
||||||
Console::WriteLn("IPU1 TIE");
|
|
||||||
|
|
||||||
if (done)
|
|
||||||
{
|
|
||||||
ptag = (u32*)dmaGetAddr(ipu1dma->tadr);
|
|
||||||
|
|
||||||
switch (ptag[0]&0x70000000)
|
|
||||||
{
|
|
||||||
case 0x00000000:
|
|
||||||
ipu1dma->tadr += 16;
|
|
||||||
break;
|
|
||||||
case 0x70000000:
|
|
||||||
ipu1dma->tadr = ipu1dma->madr;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
ipu1dma->chcr = (ipu1dma->chcr & 0xFFFF) | ((*ptag) & 0xFFFF0000);
|
|
||||||
}
|
|
||||||
|
|
||||||
IPU_INT_TO(ipu1cycles + totalqwc*BIAS);
|
|
||||||
g_nDMATransfer |= IPU_DMA_TIE1;
|
|
||||||
return totalqwc;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (ipu1dma->qwc == 0)
|
if (ipu1dma->qwc == 0)
|
||||||
{
|
{
|
||||||
switch (ptag[0]&0x70000000)
|
//if ((ipu1dma->chcr & 0x80) && (ptag[0] & 0x80000000)) //Check TIE bit of CHCR and IRQ bit of tag
|
||||||
|
if (g_nDMATransfer & IPU_DMA_DOTIE1)
|
||||||
{
|
{
|
||||||
case 0x00000000:
|
Console::WriteLn("IPU1 TIE");
|
||||||
ipu1dma->tadr += 16;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case 0x70000000:
|
if (IPU1chain(pMem, totalqwc)) return totalqwc;
|
||||||
ipu1dma->tadr = ipu1dma->madr;
|
|
||||||
break;
|
if (done)
|
||||||
|
{
|
||||||
|
ptag = (u32*)dmaGetAddr(ipu1dma->tadr);
|
||||||
|
|
||||||
|
IncreaseTadr(ptag[0]);
|
||||||
|
|
||||||
|
ipu1dma->chcr = (ipu1dma->chcr & 0xFFFF) | ((*ptag) & 0xFFFF0000);
|
||||||
|
}
|
||||||
|
|
||||||
|
IPU_INT_TO(ipu1cycles + totalqwc * BIAS); // Should it be (ipu1cycles + totalqwc) * BIAS?
|
||||||
|
g_nDMATransfer |= IPU_DMA_TIE1;
|
||||||
|
return totalqwc;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
//Britney Dance beat does a blank NEXT tag, for some odd reason the fix doesnt work if after IPU1Chain O_o
|
||||||
|
if (!done) IPU1dma();
|
||||||
|
if (IPU1chain(pMem, totalqwc)) return totalqwc;
|
||||||
|
}
|
||||||
|
|
||||||
|
IncreaseTadr(ptag[0]);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
if (IPU1chain(pMem, totalqwc)) return totalqwc;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
IPU_INT_TO((ipu1cycles + totalqwc)*BIAS);
|
IPU_INT_TO((ipu1cycles + totalqwc) * BIAS);
|
||||||
return totalqwc;
|
return totalqwc;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue