|
|
| version 1.2, 2003/10/19 16:54:51 | version 1.8, 2005/02/07 14:46:12 |
|---|---|
| Line 1 | Line 1 |
| #include "compiler.h" | #include "compiler.h" |
| #include "parts.h" | |
| #include "sound.h" | #include "sound.h" |
| #include "psggen.h" | #include "psggen.h" |
| Line 9 extern PSGGENCFG psggencfg; | Line 10 extern PSGGENCFG psggencfg; |
| void SOUNDCALL psggen_getpcm(PSGGEN psg, SINT32 *pcm, UINT count) { | void SOUNDCALL psggen_getpcm(PSGGEN psg, SINT32 *pcm, UINT count) { |
| SINT32 noisevol; | SINT32 noisevol; |
| BYTE mixer; | UINT8 mixer; |
| UINT noisetbl = 0; | UINT noisetbl = 0; |
| PSGTONE *tone; | PSGTONE *tone; |
| PSGTONE *toneterm; | PSGTONE *toneterm; |
| SINT32 samp; | SINT32 samp; |
| UINT psgvol; | // UINT psgvol; |
| SINT32 vol; | SINT32 vol; |
| UINT i; | UINT i; |
| UINT noise; | UINT noise; |
| while(count--) { | if ((psg->mixer & 0x3f) == 0) { |
| count = min(count, psg->puchicount); | |
| psg->puchicount -= count; | |
| } | |
| if (count == 0) { | |
| return; | |
| } | |
| do { | |
| noisevol = 0; | noisevol = 0; |
| if (psg->envcnt) { | if (psg->envcnt) { |
| psg->envcnt--; | psg->envcnt--; |
| Line 42 void SOUNDCALL psggen_getpcm(PSGGEN psg, | Line 50 void SOUNDCALL psggen_getpcm(PSGGEN psg, |
| psg->envcnt = psg->envmax; | psg->envcnt = psg->envmax; |
| psg->envvol = (psg->envvolcnt ^ psg->envmode) & 0x0f; | psg->envvol = (psg->envvolcnt ^ psg->envmode) & 0x0f; |
| } | } |
| psg->evol = psggencfg.volume[psg->envvol]; | |
| } | } |
| } | } |
| mixer = psg->mixer; | mixer = psg->mixer; |
| Line 51 void SOUNDCALL psggen_getpcm(PSGGEN psg, | Line 60 void SOUNDCALL psggen_getpcm(PSGGEN psg, |
| countbak = psg->noise.count; | countbak = psg->noise.count; |
| psg->noise.count -= psg->noise.freq; | psg->noise.count -= psg->noise.freq; |
| if (psg->noise.count > countbak) { | if (psg->noise.count > countbak) { |
| psg->noise.base = rand() & (1 << (1 << PSGADDEDBIT)); | // psg->noise.base = GETRAND() & (1 << (1 << PSGADDEDBIT)); |
| psg->noise.base = rand_get() & (1 << (1 << PSGADDEDBIT)); | |
| } | } |
| noisetbl += psg->noise.base; | noisetbl += psg->noise.base; |
| noisetbl >>= 1; | noisetbl >>= 1; |
| Line 59 void SOUNDCALL psggen_getpcm(PSGGEN psg, | Line 69 void SOUNDCALL psggen_getpcm(PSGGEN psg, |
| } | } |
| tone = psg->tone; | tone = psg->tone; |
| toneterm = tone + 3; | toneterm = tone + 3; |
| samp = 0; | |
| do { | do { |
| psgvol = (*(tone->pvol)) & 15; | vol = *(tone->pvol); |
| if (psgvol) { | if (vol) { |
| vol = psggencfg.volume[psgvol]; | samp = 0; |
| switch(mixer & 9) { | switch(mixer & 9) { |
| case 0: // no mix | case 0: // no mix |
| if (tone->puchi) { | if (tone->puchi) { |
| Line 101 void SOUNDCALL psggen_getpcm(PSGGEN psg, | Line 110 void SOUNDCALL psggen_getpcm(PSGGEN psg, |
| } | } |
| break; | break; |
| } | } |
| if (!(tone->pan & 1)) { | |
| pcm[0] += samp; | |
| } | |
| if (!(tone->pan & 2)) { | |
| pcm[1] += samp; | |
| } | |
| } | } |
| mixer >>= 1; | mixer >>= 1; |
| } while(++tone < toneterm); | } while(++tone < toneterm); |
| pcm[0] += samp; | |
| pcm[1] += samp; | |
| pcm += 2; | pcm += 2; |
| } | } while(--count); |
| } | } |