X-Git-Url: https://notaz.gp2x.de/cgi-bin/gitweb.cgi?p=pcsx_rearmed.git;a=blobdiff_plain;f=libpcsxcore%2Fpsxdma.c;h=6d7981f0c243f44d69cc8a7b49c150d1c16e0fac;hp=b7d6d6a07c6634eb5189dc30983f3834a6ea2abc;hb=caeefe315aeb0c86e7c9135fac7d79d8e4e4ebd4;hpb=57a757cedcc7928894aaf957565adfa95f1caab5 diff --git a/libpcsxcore/psxdma.c b/libpcsxcore/psxdma.c index b7d6d6a0..6d7981f0 100644 --- a/libpcsxcore/psxdma.c +++ b/libpcsxcore/psxdma.c @@ -27,8 +27,11 @@ // Dma3 in CdRom.c void spuInterrupt() { - HW_DMA4_CHCR &= SWAP32(~0x01000000); - DMA_INTERRUPT(4); + if (HW_DMA4_CHCR & SWAP32(0x01000000)) + { + HW_DMA4_CHCR &= SWAP32(~0x01000000); + DMA_INTERRUPT(4); + } } void psxDma4(u32 madr, u32 bcr, u32 chcr) { // SPU @@ -140,7 +143,7 @@ void psxDma2(u32 madr, u32 bcr, u32 chcr) { // GPU psxCpu->Clear(madr, size); // already 32-bit word size ((size * 4) / 4) - GPUDMA_INT(size); + GPUDMA_INT(size / 4); return; case 0x01000201: // mem2vram @@ -159,7 +162,7 @@ void psxDma2(u32 madr, u32 bcr, u32 chcr) { // GPU GPU_writeDataMem(ptr, size); // already 32-bit word size ((size * 4) / 4) - GPUDMA_INT(size); + GPUDMA_INT(size / 4); return; case 0x01000401: // dma chain @@ -167,8 +170,9 @@ void psxDma2(u32 madr, u32 bcr, u32 chcr) { // GPU PSXDMA_LOG("*** DMA 2 - GPU dma chain *** %lx addr = %lx size = %lx\n", chcr, madr, bcr); #endif - size = gpuDmaChainSize(madr); - GPU_dmaChain((u32 *)psxM, madr & 0x1fffff); + size = GPU_dmaChain((u32 *)psxM, madr & 0x1fffff); + if ((int)size <= 0) + size = gpuDmaChainSize(madr); // Tekken 3 = use 1.0 only (not 1.5x) @@ -191,8 +195,11 @@ void psxDma2(u32 madr, u32 bcr, u32 chcr) { // GPU } void gpuInterrupt() { - HW_DMA2_CHCR &= SWAP32(~0x01000000); - DMA_INTERRUPT(2); + if (HW_DMA2_CHCR & SWAP32(0x01000000)) + { + HW_DMA2_CHCR &= SWAP32(~0x01000000); + DMA_INTERRUPT(2); + } } void psxDma6(u32 madr, u32 bcr, u32 chcr) { @@ -238,6 +245,9 @@ void psxDma6(u32 madr, u32 bcr, u32 chcr) { void gpuotcInterrupt() { - HW_DMA6_CHCR &= SWAP32(~0x01000000); - DMA_INTERRUPT(6); + if (HW_DMA6_CHCR & SWAP32(0x01000000)) + { + HW_DMA6_CHCR &= SWAP32(~0x01000000); + DMA_INTERRUPT(6); + } }