mirror of https://github.com/PCSX2/pcsx2.git
Further fixes for arc the lad, ar tonelico, eternal poison. (I presume so, i ran out of blockdump, thats good, right? :P)
git-svn-id: http://pcsx2.googlecode.com/svn/trunk@2858 96395faa-99c1-11dd-bbfe-3dabce05a288
This commit is contained in:
parent
887a05fa4d
commit
0d1d4d97f2
|
@ -63,9 +63,9 @@ static __forceinline void DmaExec16( void (*func)(), u32 mem, u16 value )
|
||||||
|
|
||||||
//It's invalid for the hardware to write a DMA while it is active, not without Suspending the DMAC
|
//It's invalid for the hardware to write a DMA while it is active, not without Suspending the DMAC
|
||||||
if (chcr.STR && reg->chcr.STR && dmacRegs->ctrl.DMAE) {
|
if (chcr.STR && reg->chcr.STR && dmacRegs->ctrl.DMAE) {
|
||||||
if((reg->chcr._u32 & 0xff) == (chcr._u32 & 0xff)) //Tried to start another DMA in the same mode
|
if((reg->chcr._u32 & 0xff) == (chcr._u32 & 0xff) && psHu8(DMAC_ENABLER+2) == 0) //Tried to start another DMA in the same mode
|
||||||
DevCon.Warning(L"DMAExec32 Attempt to run DMA while one is already active in %s(%x)", ChcrName(mem), mem);
|
DevCon.Warning(L"DMAExec32 Attempt to run DMA while one is already active in %s(%x)", ChcrName(mem), mem);
|
||||||
else if(psHu8(DMAC_ENABLER+2) != 0)//Just trying to change mode without stopping the DMA, so we dont care really :P
|
else //Just trying to change mode without stopping the DMA, so we dont care really :P
|
||||||
{
|
{
|
||||||
HW_LOG("Attempted to change modes while DMA active, ignoring");
|
HW_LOG("Attempted to change modes while DMA active, ignoring");
|
||||||
// When DMA is active only STR field is writable, so we just
|
// When DMA is active only STR field is writable, so we just
|
||||||
|
@ -104,9 +104,9 @@ static void DmaExec( void (*func)(), u32 mem, u32 value )
|
||||||
|
|
||||||
//It's invalid for the hardware to write a DMA while it is active, not without Suspending the DMAC
|
//It's invalid for the hardware to write a DMA while it is active, not without Suspending the DMAC
|
||||||
if (chcr.STR && reg->chcr.STR && dmacRegs->ctrl.DMAE) {
|
if (chcr.STR && reg->chcr.STR && dmacRegs->ctrl.DMAE) {
|
||||||
if((reg->chcr._u32 & 0xff) == (chcr._u32 & 0xff)) //Tried to start another DMA in the same mode
|
if((reg->chcr._u32 & 0xff) == (chcr._u32 & 0xff) && psHu8(DMAC_ENABLER+2) == 0) //Tried to start another DMA in the same mode
|
||||||
DevCon.Warning(L"DMAExec32 Attempt to run DMA while one is already active in %s(%x)", ChcrName(mem), mem);
|
DevCon.Warning(L"DMAExec32 Attempt to run DMA while one is already active in %s(%x)", ChcrName(mem), mem);
|
||||||
else if(psHu8(DMAC_ENABLER+2) != 0)//Just trying to change mode without stopping the DMA, so we dont care really :P
|
else //Just trying to change mode without stopping the DMA, so we dont care really :P
|
||||||
{
|
{
|
||||||
HW_LOG("Attempted to change modes while DMA active, ignoring");
|
HW_LOG("Attempted to change modes while DMA active, ignoring");
|
||||||
// When DMA is active only STR field is writable, so we just
|
// When DMA is active only STR field is writable, so we just
|
||||||
|
|
|
@ -42,7 +42,7 @@
|
||||||
# define IPU_INT_FROM( cycles ) ipu0Interrupt()
|
# define IPU_INT_FROM( cycles ) ipu0Interrupt()
|
||||||
# define IPU_FORCEINLINE
|
# define IPU_FORCEINLINE
|
||||||
#else
|
#else
|
||||||
# define IPU_INT_TO( cycles ) CPU_INT( DMAC_TO_IPU, cycles )
|
# define IPU_INT_TO( cycles ) if(!(cpuRegs.interrupt & (1<<4))) CPU_INT( DMAC_TO_IPU, cycles )
|
||||||
# define IPU_INT_FROM( cycles ) CPU_INT( DMAC_FROM_IPU, cycles )
|
# define IPU_INT_FROM( cycles ) CPU_INT( DMAC_FROM_IPU, cycles )
|
||||||
# define IPU_FORCEINLINE __forceinline
|
# define IPU_FORCEINLINE __forceinline
|
||||||
#endif
|
#endif
|
||||||
|
@ -1372,7 +1372,7 @@ int IPU1dma()
|
||||||
{
|
{
|
||||||
if(!WaitGSPaths())
|
if(!WaitGSPaths())
|
||||||
{ // legacy WaitGSPaths() for now
|
{ // legacy WaitGSPaths() for now
|
||||||
if(totalqwc == 0)IPU_INT_TO(4); //Give it a short wait.
|
IPU_INT_TO(4); //Give it a short wait.
|
||||||
return totalqwc;
|
return totalqwc;
|
||||||
}
|
}
|
||||||
DMA_LOG("Processing Normal QWC left %x Finished %d In Progress %d", ipu1dma->qwc, IPU1Status.DMAFinished, IPU1Status.InProgress);
|
DMA_LOG("Processing Normal QWC left %x Finished %d In Progress %d", ipu1dma->qwc, IPU1Status.DMAFinished, IPU1Status.InProgress);
|
||||||
|
@ -1386,7 +1386,7 @@ int IPU1dma()
|
||||||
{
|
{
|
||||||
if(!WaitGSPaths())
|
if(!WaitGSPaths())
|
||||||
{ // legacy WaitGSPaths() for now
|
{ // legacy WaitGSPaths() for now
|
||||||
if(totalqwc == 0)IPU_INT_TO(4); //Give it a short wait.
|
IPU_INT_TO(4); //Give it a short wait.
|
||||||
return totalqwc;
|
return totalqwc;
|
||||||
}
|
}
|
||||||
DMA_LOG("Processing Chain QWC left %x Finished %d In Progress %d", ipu1dma->qwc, IPU1Status.DMAFinished, IPU1Status.InProgress);
|
DMA_LOG("Processing Chain QWC left %x Finished %d In Progress %d", ipu1dma->qwc, IPU1Status.DMAFinished, IPU1Status.InProgress);
|
||||||
|
@ -1475,7 +1475,7 @@ int IPU1dma()
|
||||||
|
|
||||||
if(!WaitGSPaths() && ipu1dma->qwc > 0)
|
if(!WaitGSPaths() && ipu1dma->qwc > 0)
|
||||||
{ // legacy WaitGSPaths() for now
|
{ // legacy WaitGSPaths() for now
|
||||||
if(totalqwc == 0)IPU_INT_TO(4); //Give it a short wait.
|
IPU_INT_TO(4); //Give it a short wait.
|
||||||
return totalqwc;
|
return totalqwc;
|
||||||
}
|
}
|
||||||
DMA_LOG("Processing Start Chain QWC left %x Finished %d In Progress %d", ipu1dma->qwc, IPU1Status.DMAFinished, IPU1Status.InProgress);
|
DMA_LOG("Processing Start Chain QWC left %x Finished %d In Progress %d", ipu1dma->qwc, IPU1Status.DMAFinished, IPU1Status.InProgress);
|
||||||
|
|
|
@ -455,7 +455,9 @@ __forceinline int GIFPath::ParseTag(GIF_PATH pathidx, const u8* pMem, u32 size)
|
||||||
if (pathidx == GIF_PATH_3) {
|
if (pathidx == GIF_PATH_3) {
|
||||||
gif->madr += size * 16;
|
gif->madr += size * 16;
|
||||||
gif->qwc -= size;
|
gif->qwc -= size;
|
||||||
}
|
} else if (pathidx == GIF_PATH_2 && !nloop) { //Path2 is odd, but always provides the correct size
|
||||||
|
GSTransferStatus.PTH2 = STOPPED_MODE;
|
||||||
|
}
|
||||||
|
|
||||||
return size;
|
return size;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue