|
|
| version 1.5, 2003/10/26 08:59:53 | version 1.7, 2003/12/24 14:01:56 |
|---|---|
| Line 15 void SOUNDCALL psggen_getpcm(PSGGEN psg, | Line 15 void SOUNDCALL psggen_getpcm(PSGGEN psg, |
| 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; |
| Line 50 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 68 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 110 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); | } while(--count); |
| } | } |