X-Git-Url: https://notaz.gp2x.de/cgi-bin/gitweb.cgi?p=pcsx_rearmed.git;a=blobdiff_plain;f=libpcsxcore%2Fpsxhw.c;h=54e03f6420e058dc09c8a1540982e3231d258b5b;hp=8069c07ae9fd7f0ce329dd3e9a0e11357452382c;hb=1f77c86322bf6567909da192fdbf6c28c0596a13;hpb=ad418c19cd4ca9a80820593609b786c6993b2eda diff --git a/libpcsxcore/psxhw.c b/libpcsxcore/psxhw.c index 8069c07a..54e03f64 100644 --- a/libpcsxcore/psxhw.c +++ b/libpcsxcore/psxhw.c @@ -25,6 +25,9 @@ #include "mdec.h" #include "cdrom.h" +//#undef PSXHW_LOG +//#define PSXHW_LOG printf + void psxHwReset() { if (Config.Sio) psxHu32ref(0x1070) |= SWAP32(0x80); if (Config.SpuIrq) psxHu32ref(0x1070) |= SWAP32(0x200); @@ -658,8 +661,15 @@ void psxHwWrite32(u32 add, u32 value) { PSXHW_LOG("DMA ICR 32bit write %x\n", value); #endif { - u32 tmp = (~value) & SWAPu32(HW_DMA_ICR); - HW_DMA_ICR = SWAPu32(((tmp ^ value) & 0xffffff) ^ tmp); + u32 tmp = value & 0x00ff803f; + tmp |= (SWAPu32(HW_DMA_ICR) & ~value) & 0x7f000000; + if ((tmp & HW_DMA_ICR_GLOBAL_ENABLE && tmp & 0x7f000000) + || tmp & HW_DMA_ICR_BUS_ERROR) { + if (!(SWAPu32(HW_DMA_ICR) & HW_DMA_ICR_IRQ_SENT)) + psxHu32ref(0x1070) |= SWAP32(8); + tmp |= HW_DMA_ICR_IRQ_SENT; + } + HW_DMA_ICR = SWAPu32(tmp); return; }