/[rdesktop]/sourceforge.net/trunk/rdesktop/rdpsnd_dsp.c
This is repository of my old source code which isn't updated any more. Go to git.rot13.org for current projects!
ViewVC logotype

Diff of /sourceforge.net/trunk/rdesktop/rdpsnd_dsp.c

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 1285 by stargo, Sun Oct 1 18:22:05 2006 UTC revision 1365 by jsorg71, Thu Jan 4 05:39:39 2007 UTC
# Line 1  Line 1 
1  /*  /*
2     rdesktop: A Remote Desktop Protocol client.     rdesktop: A Remote Desktop Protocol client.
3     Sound DSP routines     Sound DSP routines
4     Copyright (C) Michael Gernoth 2006     Copyright (C) Michael Gernoth 2006-2007
5    
6     This program is free software; you can redistribute it and/or modify     This program is free software; you can redistribute it and/or modify
7     it under the terms of the GNU General Public License as published by     it under the terms of the GNU General Public License as published by
# Line 50  rdpsnd_dsp_softvol_set(uint16 left, uint Line 50  rdpsnd_dsp_softvol_set(uint16 left, uint
50  }  }
51    
52  void  void
53  rdpsnd_dsp_softvol(unsigned char *buffer, unsigned int size, WAVEFORMATEX * format)  rdpsnd_dsp_softvol(unsigned char *buffer, unsigned int size, RD_WAVEFORMATEX * format)
54  {  {
55          unsigned int factor_left, factor_right;          unsigned int factor_left, factor_right;
56          unsigned char *posin = buffer;          unsigned char *posin = buffer;
# Line 111  rdpsnd_dsp_softvol(unsigned char *buffer Line 111  rdpsnd_dsp_softvol(unsigned char *buffer
111  }  }
112    
113  void  void
114  rdpsnd_dsp_swapbytes(unsigned char *buffer, unsigned int size, WAVEFORMATEX * format)  rdpsnd_dsp_swapbytes(unsigned char *buffer, unsigned int size, RD_WAVEFORMATEX * format)
115  {  {
116          int i;          int i;
117          uint8 swap;          uint8 swap;
# Line 159  rdpsnd_dsp_resample_set(uint32 device_sr Line 159  rdpsnd_dsp_resample_set(uint32 device_sr
159  }  }
160    
161  BOOL  BOOL
162  rdpsnd_dsp_resample_supported(WAVEFORMATEX * format)  rdpsnd_dsp_resample_supported(RD_WAVEFORMATEX * format)
163  {  {
164          if (format->wFormatTag != WAVE_FORMAT_PCM)          if (format->wFormatTag != WAVE_FORMAT_PCM)
165                  return False;                  return False;
# Line 173  rdpsnd_dsp_resample_supported(WAVEFORMAT Line 173  rdpsnd_dsp_resample_supported(WAVEFORMAT
173    
174  uint32  uint32
175  rdpsnd_dsp_resample(unsigned char **out, unsigned char *in, unsigned int size,  rdpsnd_dsp_resample(unsigned char **out, unsigned char *in, unsigned int size,
176                      WAVEFORMATEX * format, BOOL stream_be)                      RD_WAVEFORMATEX * format, BOOL stream_be)
177  {  {
178  #ifdef HAVE_LIBSAMPLERATE  #ifdef HAVE_LIBSAMPLERATE
179          SRC_DATA resample_data;          SRC_DATA resample_data;
# Line 183  rdpsnd_dsp_resample(unsigned char **out, Line 183  rdpsnd_dsp_resample(unsigned char **out,
183          int ratio1k = (resample_to_srate * 1000) / format->nSamplesPerSec;          int ratio1k = (resample_to_srate * 1000) / format->nSamplesPerSec;
184  #endif  #endif
185          int innum, outnum;          int innum, outnum;
186          static BOOL warned = False;          unsigned char *tmpdata = NULL, *tmp = NULL;
         unsigned char *tmpdata = NULL;  
187          int samplewidth = format->wBitsPerSample / 8;          int samplewidth = format->wBitsPerSample / 8;
188          int outsize = 0;          int outsize = 0;
189          int i;          int i;
# Line 199  rdpsnd_dsp_resample(unsigned char **out, Line 198  rdpsnd_dsp_resample(unsigned char **out,
198                  rdpsnd_dsp_swapbytes(in, size, format);                  rdpsnd_dsp_swapbytes(in, size, format);
199  #endif  #endif
200    
201            if (resample_to_channels != format->nChannels)
202            {
203                    int newsize = (size / format->nChannels) * resample_to_channels;
204                    tmpdata = xmalloc(newsize);
205    
206                    for (i = 0; i < newsize / samplewidth; i++)
207                    {
208                            if (format->nChannels > resample_to_channels)
209                                    memcpy(tmpdata + (i * samplewidth),
210                                           in +
211                                           (((i * format->nChannels) / resample_to_channels) *
212                                            samplewidth), samplewidth);
213                            else
214                                    memcpy(tmpdata + (i * samplewidth),
215                                           in +
216                                           (((i / resample_to_channels) * format->nChannels +
217                                             (i % format->nChannels)) * samplewidth), samplewidth);
218    
219                    }
220    
221                    in = tmpdata;
222                    size = newsize;
223            }
224    
225    
226          /* Expand 8bit input-samples to 16bit */          /* Expand 8bit input-samples to 16bit */
227  #ifndef HAVE_LIBSAMPLERATE      /* libsamplerate needs 16bit samples */  #ifndef HAVE_LIBSAMPLERATE      /* libsamplerate needs 16bit samples */
228          if (format->wBitsPerSample != resample_to_bitspersample)          if (format->wBitsPerSample != resample_to_bitspersample)
# Line 207  rdpsnd_dsp_resample(unsigned char **out, Line 231  rdpsnd_dsp_resample(unsigned char **out,
231                  /* source: 8 bit, dest: 16bit */                  /* source: 8 bit, dest: 16bit */
232                  if (format->wBitsPerSample == 8)                  if (format->wBitsPerSample == 8)
233                  {                  {
234                            tmp = tmpdata;
235                          tmpdata = xmalloc(size * 2);                          tmpdata = xmalloc(size * 2);
236                          for (i = 0; i < size; i++)                          for (i = 0; i < size; i++)
237                          {                          {
# Line 216  rdpsnd_dsp_resample(unsigned char **out, Line 241  rdpsnd_dsp_resample(unsigned char **out,
241                          in = tmpdata;                          in = tmpdata;
242                          samplewidth = 16 / 2;                          samplewidth = 16 / 2;
243                          size *= 2;                          size *= 2;
                 }  
         }  
244    
245          if (resample_to_channels != format->nChannels)                          if (tmp != NULL)
246          {                                  xfree(tmp);
247                  warning("unsupported resample-settings (%u -> %u/%u -> %u/%u -> %u), not resampling!\n", format->nSamplesPerSec, resample_to_srate, format->wBitsPerSample, resample_to_bitspersample, format->nChannels, resample_to_channels);                  }
                 warned = True;  
248          }          }
249    
250          innum = size / samplewidth;          innum = size / samplewidth;
# Line 277  rdpsnd_dsp_resample(unsigned char **out, Line 299  rdpsnd_dsp_resample(unsigned char **out,
299    
300          for (i = 0; i < outsize / (resample_to_channels * samplewidth); i++)          for (i = 0; i < outsize / (resample_to_channels * samplewidth); i++)
301          {          {
302                  int source = ((i * 1000) + ratio1k - 1000) / (ratio1k + 1);                  int source = (i * 1000) / ratio1k;
303    #if 0                           /* Partial for linear resampler */
304                    int part = (i * 100000) / ratio1k - source * 100;
305    #endif
306                    int j;
307    
308                  if (source * resample_to_channels + samplewidth > size)                  if (source * resample_to_channels + samplewidth > size)
309                          break;                          break;
310    
311                  if (resample_to_channels == 2)  #if 0                           /* Linear resampling, TODO: soundquality fixes (LP filter) */
312                    if (samplewidth == 1)
313                  {                  {
314                          memcpy(*out + (i * resample_to_channels * samplewidth),                          sint8 cval1, cval2;
315                                 in + (source * resample_to_channels * samplewidth), samplewidth);                          for (j = 0; j < resample_to_channels; j++)
316                          memcpy(*out + (i * resample_to_channels * samplewidth) + samplewidth,                          {
317                                 in + (source * resample_to_channels * samplewidth) + samplewidth,                                  memcpy(&cval1,
318                                 samplewidth);                                         in + (source * resample_to_channels * samplewidth) +
319                                           (samplewidth * j), samplewidth);
320                                    memcpy(&cval2,
321                                           in + ((source + 1) * resample_to_channels * samplewidth) +
322                                           (samplewidth * j), samplewidth);
323    
324                                    cval1 += (sint8) (cval2 * part) / 100;
325    
326                                    memcpy(*out + (i * resample_to_channels * samplewidth) +
327                                           (samplewidth * j), &cval1, samplewidth);
328                            }
329                  }                  }
330                  else                  else
331                  {                  {
332                          memcpy(*out + (i * samplewidth), in + (source * samplewidth), samplewidth);                          sint16 sval1, sval2;
333                            for (j = 0; j < resample_to_channels; j++)
334                            {
335                                    memcpy(&sval1,
336                                           in + (source * resample_to_channels * samplewidth) +
337                                           (samplewidth * j), samplewidth);
338                                    memcpy(&sval2,
339                                           in + ((source + 1) * resample_to_channels * samplewidth) +
340                                           (samplewidth * j), samplewidth);
341    
342                                    sval1 += (sint16) (sval2 * part) / 100;
343    
344                                    memcpy(*out + (i * resample_to_channels * samplewidth) +
345                                           (samplewidth * j), &sval1, samplewidth);
346                            }
347                  }                  }
348    #else /* Nearest neighbor search */
349                    for (j = 0; j < resample_to_channels; j++)
350                    {
351                            memcpy(*out + (i * resample_to_channels * samplewidth) + (samplewidth * j),
352                                   in + (source * resample_to_channels * samplewidth) +
353                                   (samplewidth * j), samplewidth);
354                    }
355    #endif
356          }          }
357          outsize = i * resample_to_channels * samplewidth;          outsize = i * resample_to_channels * samplewidth;
358  #endif  #endif
# Line 325  rdpsnd_dsp_resample(unsigned char **out, Line 384  rdpsnd_dsp_resample(unsigned char **out,
384  }  }
385    
386  STREAM  STREAM
387  rdpsnd_dsp_process(STREAM s, struct audio_driver * current_driver, WAVEFORMATEX * format)  rdpsnd_dsp_process(unsigned char *data, unsigned int size, struct audio_driver * current_driver,
388                       RD_WAVEFORMATEX * format)
389  {  {
390          static struct stream out;          static struct stream out;
391          BOOL stream_be = False;          BOOL stream_be = False;
# Line 333  rdpsnd_dsp_process(STREAM s, struct audi Line 393  rdpsnd_dsp_process(STREAM s, struct audi
393          /* softvol and byteswap do not change the amount of data they          /* softvol and byteswap do not change the amount of data they
394             return, so they can operate on the input-stream */             return, so they can operate on the input-stream */
395          if (current_driver->wave_out_volume == rdpsnd_dsp_softvol_set)          if (current_driver->wave_out_volume == rdpsnd_dsp_softvol_set)
396                  rdpsnd_dsp_softvol(s->data, s->size, format);                  rdpsnd_dsp_softvol(data, size, format);
397    
398  #ifdef B_ENDIAN  #ifdef B_ENDIAN
399          if (current_driver->need_byteswap_on_be)          if (current_driver->need_byteswap_on_be)
400          {          {
401                  rdpsnd_dsp_swapbytes(s->data, s->size, format);                  rdpsnd_dsp_swapbytes(data, size, format);
402                  stream_be = True;                  stream_be = True;
403          }          }
404  #endif  #endif
# Line 346  rdpsnd_dsp_process(STREAM s, struct audi Line 406  rdpsnd_dsp_process(STREAM s, struct audi
406          out.data = NULL;          out.data = NULL;
407    
408          if (current_driver->need_resampling)          if (current_driver->need_resampling)
409                  out.size = rdpsnd_dsp_resample(&out.data, s->data, s->size, format, stream_be);                  out.size = rdpsnd_dsp_resample(&out.data, data, size, format, stream_be);
410    
411          if (out.data == NULL)          if (out.data == NULL)
412          {          {
413                  out.data = xmalloc(s->size);                  out.data = xmalloc(size);
414                  memcpy(out.data, s->data, s->size);                  memcpy(out.data, data, size);
415                  out.size = s->size;                  out.size = size;
416          }          }
417    
418          out.p = out.data;          out.p = out.data;

Legend:
Removed from v.1285  
changed lines
  Added in v.1365

  ViewVC Help
Powered by ViewVC 1.1.26