X-Git-Url: https://notaz.gp2x.de/cgi-bin/gitweb.cgi?p=pcsx_rearmed.git;a=blobdiff_plain;f=plugins%2Fdfsound%2Fxa.c;h=1c5425eaf78112698dae1313946d136b7513af67;hp=b45aef2743631d265b47b5bb38e8c663290053fe;hb=fa56d36096cd4ab2b227ce2aa61c8404b8874689;hpb=381ea10346ab85b2f2d46f33d28461211e239c0a diff --git a/plugins/dfsound/xa.c b/plugins/dfsound/xa.c index b45aef27..1c5425ea 100644 --- a/plugins/dfsound/xa.c +++ b/plugins/dfsound/xa.c @@ -22,8 +22,6 @@ // will be included from spu.c #ifdef _IN_SPU -#define XA_HACK - //////////////////////////////////////////////////////////////////////// // XA GLOBALS //////////////////////////////////////////////////////////////////////// @@ -61,42 +59,44 @@ static int gauss_window[8] = {0, 0, 0, 0, 0, 0, 0, 0}; INLINE void MixXA(void) { int ns; - uint32_t l; - - for(ns=0;ns>16)&0xffff)) * iRightXAVol)/32768; -#else - SSumLR[ns++]+=(((short)(XALastVal&0xffff)) * iLeftXAVol)/32767; - SSumLR[ns++]+=(((short)((XALastVal>>16)&0xffff)) * iRightXAVol)/32767; -#endif - } + short l, r; + uint32_t v; + int cursor = decode_pos; - if(XAPlay==XAFeed && XARepeat) - { + if(XAPlay != XAFeed || XARepeat > 0) + { + if(XAPlay == XAFeed) XARepeat--; - for(;ns>16)&0xffff)) * iRightXAVol)/32768; -#else - SSumLR[ns++]+=(((short)(XALastVal&0xffff)) * iLeftXAVol)/32767; - SSumLR[ns++]+=(((short)((XALastVal>>16)&0xffff)) * iRightXAVol)/32767; -#endif - } - } + + v = XALastVal; + for(ns=0;ns> 15; + r = ((int)(short)(v >> 16) * iLeftXAVol) >> 15; + SSumLR[ns++] += l; + SSumLR[ns++] += r; + spuMem[cursor] = l; + spuMem[cursor + 0x400/2] = r; + cursor = (cursor + 1) & 0x1ff; + } + XALastVal = v; + } for(ns=0;ns> 15; - SSumLR[ns++]+=(((short)((l>>16)&0xffff)) * iRightXAVol) >> 15; + + l = ((int)(short)v * iLeftXAVol) >> 15; + r = ((int)(short)(v >> 16) * iLeftXAVol) >> 15; + SSumLR[ns++] += l; + SSumLR[ns++] += r; + spuMem[cursor] = l; + spuMem[cursor + 0x400/2] = r; + cursor = (cursor + 1) & 0x1ff; } } @@ -104,7 +104,7 @@ INLINE void MixXA(void) // small linux time helper... only used for watchdog //////////////////////////////////////////////////////////////////////// -unsigned long timeGetTime_spu() +static unsigned long timeGetTime_spu() { struct timeval tv; gettimeofday(&tv, 0); // well, maybe there are better ways @@ -389,21 +389,29 @@ INLINE void FeedXA(xa_decode_t *xap) // FEED CDDA //////////////////////////////////////////////////////////////////////// -INLINE void FeedCDDA(unsigned char *pcm, int nBytes) +INLINE int FeedCDDA(unsigned char *pcm, int nBytes) { + int space; + space=(CDDAPlay-CDDAFeed-1)*4 & (CDDA_BUFFER_SIZE - 1); + if(space0) { if(CDDAFeed==CDDAEnd) CDDAFeed=CDDAStart; - while(CDDAFeed==CDDAPlay-1|| - (CDDAFeed==CDDAEnd-1&&CDDAPlay==CDDAStart)) - { - if (!iUseTimer) usleep(1000); - else return; - } - *CDDAFeed++=(*pcm | (*(pcm+1)<<8) | (*(pcm+2)<<16) | (*(pcm+3)<<24)); - nBytes-=4; - pcm+=4; + space=(CDDAPlay-CDDAFeed-1)*4 & (CDDA_BUFFER_SIZE - 1); + if(CDDAFeed+space/4>CDDAEnd) + space=(CDDAEnd-CDDAFeed)*4; + if(space>nBytes) + space=nBytes; + + memcpy(CDDAFeed,pcm,space); + CDDAFeed+=space/4; + nBytes-=space; + pcm+=space; } + + return 0x676f; // rearmed_go } #endif