Diff for /np2/sound/psggeng.c between versions 1.3 and 1.8

version 1.3, 2003/10/22 14:13:25 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;
Line 49  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 58  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 = GETRAND() & (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 66  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 108  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);
 }  }

Removed from v.1.3  
changed lines
  Added in v.1.8


RetroPC.NET-CVS <cvs@retropc.net>