X-Git-Url: https://notaz.gp2x.de/cgi-bin/gitweb.cgi?p=pcsx_rearmed.git;a=blobdiff_plain;f=plugins%2Fdfsound%2Ffreeze.c;h=d38faa65bfc370cf27f9b611ac644f7a27fe095d;hp=b865b84837ca6b81339b29be0453f21ac80893d0;hb=c4c66b22ae607aa8dc5e6983f7ab030ead01faae;hpb=fb01e82a3453b4b068fde274a42df336e778d8d3 diff --git a/plugins/dfsound/freeze.c b/plugins/dfsound/freeze.c index b865b848..d38faa65 100644 --- a/plugins/dfsound/freeze.c +++ b/plugins/dfsound/freeze.c @@ -307,6 +307,9 @@ long CALLBACK SPUfreeze(uint32_t ulFreezeMode, SPUFreeze_t * pF, ClearWorkingState(); spu.cycles_played = cycles; + if (spu.spuCtrl & CTRL_IRQ) + schedule_next_irq(); + return 1; } @@ -318,7 +321,7 @@ void LoadStateV5(SPUFreeze_t * pF) pFO=(SPUOSSFreeze_t *)(pF+1); - if(pFO->pSpuIrq) spu.pSpuIrq = spu.spuMemC+((long)pFO->pSpuIrq&0x7fff0); else spu.pSpuIrq=NULL; + spu.pSpuIrq = spu.spuMemC + ((spu.regArea[(H_SPUirqAddr - 0x0c00) / 2] << 3) & ~0xf); if(pFO->spuAddr) { @@ -353,7 +356,7 @@ void LoadStateUnknown(SPUFreeze_t * pF, uint32_t cycles) spu.dwNewChannel=0; spu.dwChannelOn=0; spu.dwChannelDead=0; - spu.pSpuIrq=0; + spu.pSpuIrq=spu.spuMemC; for(i=0;i<0xc0;i++) {