diff options
author | notaz | 2012-11-22 02:48:19 +0200 |
---|---|---|
committer | notaz | 2012-11-24 04:25:25 +0200 |
commit | 6f6fe96900374d8744473ce240279e66d1260191 (patch) | |
tree | 71516fd69225765af0c523963a14e76f93e4ce57 /plugins/dfsound | |
parent | c668f24877c063db881fa8d1eeb8a6fbc649d5a0 (diff) | |
download | pcsx_rearmed-6f6fe96900374d8744473ce240279e66d1260191.tar.gz pcsx_rearmed-6f6fe96900374d8744473ce240279e66d1260191.tar.bz2 pcsx_rearmed-6f6fe96900374d8744473ce240279e66d1260191.zip |
spu: fix saving bug
fixup on load too
Diffstat (limited to 'plugins/dfsound')
-rw-r--r-- | plugins/dfsound/freeze.c | 6 |
1 files changed, 2 insertions, 4 deletions
diff --git a/plugins/dfsound/freeze.c b/plugins/dfsound/freeze.c index 8787db0..0601bf5 100644 --- a/plugins/dfsound/freeze.c +++ b/plugins/dfsound/freeze.c @@ -188,7 +188,6 @@ static void load_channel(SPUCHAN *d, const SPUCHAN_orig *s, int ch) memcpy(d->SB, s->SB, sizeof(d->SB));
d->pCurr = (void *)((long)s->iCurr & 0x7fff0);
d->pLoop = (void *)((long)s->iLoop & 0x7fff0);
- if (s->bOn) dwChannelOn |= 1<<ch;
d->bStop = s->bStop;
d->bReverb = s->bReverb;
d->iLeftVolume = s->iLeftVolume;
@@ -209,6 +208,8 @@ static void load_channel(SPUCHAN *d, const SPUCHAN_orig *s, int ch) d->ADSRX.ReleaseModeExp = s->ADSRX.ReleaseModeExp;
d->ADSRX.ReleaseRate = s->ADSRX.ReleaseRate;
d->ADSRX.EnvelopeVol = s->ADSRX.EnvelopeVol;
+ if (s->bOn) dwChannelOn |= 1<<ch;
+ else d->ADSRX.EnvelopeVol = 0;
}
////////////////////////////////////////////////////////////////////////
@@ -252,9 +253,6 @@ long CALLBACK SPUfreeze(uint32_t ulFreezeMode,SPUFreeze_t * pF) for(i=0;i<MAXCHAN;i++)
{
- if(!(s_chan[i].prevflags&2))
- dwChannelOn&=~(1<<i);
-
save_channel(&pFO->s_chan[i],&s_chan[i],i);
if(s_chan[i].pCurr)
pFO->s_chan[i].iCurr=s_chan[i].pCurr-spuMemC;
|