aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--plugins/dfsound/registers.c2
-rw-r--r--plugins/dfsound/spu.c10
2 files changed, 9 insertions, 3 deletions
diff --git a/plugins/dfsound/registers.c b/plugins/dfsound/registers.c
index 19a0a46..c790525 100644
--- a/plugins/dfsound/registers.c
+++ b/plugins/dfsound/registers.c
@@ -168,7 +168,7 @@ void CALLBACK SPUwriteRegister(unsigned long reg, unsigned short val)
case 14: // loop?
//WaitForSingleObject(s_chan[ch].hMutex,2000); // -> no multithread fuckups
s_chan[ch].pLoop=spuMemC+((unsigned long)((val<<3)&~0xf));
- s_chan[ch].bIgnoreLoop=1;
+ //s_chan[ch].bIgnoreLoop=1;
//ReleaseMutex(s_chan[ch].hMutex); // -> oki, on with the thread
break;
//------------------------------------------------//
diff --git a/plugins/dfsound/spu.c b/plugins/dfsound/spu.c
index 8558e48..0f952fb 100644
--- a/plugins/dfsound/spu.c
+++ b/plugins/dfsound/spu.c
@@ -586,9 +586,12 @@ static void *MAINThread(void *arg)
{
// We play this block out first...
//if(!(flags&2)) // 1+2: do loop... otherwise: stop
- if(flags!=3 || s_chan[ch].pLoop==NULL) // PETE: if we don't check exactly for 3, loop hang ups will happen (DQ4, for example)
- { // and checking if pLoop is set avoids crashes, yeah
+ if((flags!=3 && flags!=7) // PETE: if we don't check exactly for 3, loop hang ups will happen (DQ4, for example)
+ || s_chan[ch].pLoop==NULL) // and checking if pLoop is set avoids crashes, yeah
+ {
start = (unsigned char*)-1;
+ // Actua Soccer 2, Jungle Book, other games that check for this condition
+ s_chan[ch].ADSRX.EnvelopeVol = 0;
}
else
{
@@ -596,6 +599,9 @@ static void *MAINThread(void *arg)
}
}
+ if (start - spuMemC >= 0x80000)
+ start = (unsigned char*)-1;
+
s_chan[ch].pCurr=start; // store values for next cycle
s_chan[ch].s_1=s_1;
s_chan[ch].s_2=s_2;