/[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 1282 by stargo, Sun Oct 1 15:07:55 2006 UTC revision 1291 by stargo, Sun Oct 1 23:42:14 2006 UTC
# Line 18  Line 18 
18     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.     Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
19  */  */
20    
21    #include <strings.h>
22    
23  #include "rdesktop.h"  #include "rdesktop.h"
24  #include "rdpsnd.h"  #include "rdpsnd.h"
25  #include "rdpsnd_dsp.h"  #include "rdpsnd_dsp.h"
# Line 132  rdpsnd_dsp_resample_set(uint32 device_sr Line 134  rdpsnd_dsp_resample_set(uint32 device_sr
134          int err;          int err;
135  #endif  #endif
136    
 #ifndef HAVE_LIBSAMPLERATE  
         if (device_srate != 44100 && device_srate != 22050)  
                 return False;  
 #endif  
   
137          if (device_bitspersample != 16 && device_bitspersample != 8)          if (device_bitspersample != 16 && device_bitspersample != 8)
138                  return False;                  return False;
139    
# Line 170  rdpsnd_dsp_resample_supported(WAVEFORMAT Line 167  rdpsnd_dsp_resample_supported(WAVEFORMAT
167                  return False;                  return False;
168          if ((format->wBitsPerSample != 8) && (format->wBitsPerSample != 16))          if ((format->wBitsPerSample != 8) && (format->wBitsPerSample != 16))
169                  return False;                  return False;
 #ifndef HAVE_LIBSAMPLERATE  
         if ((format->nSamplesPerSec != 44100) && (format->nSamplesPerSec != 22050))  
                 return False;  
 #endif  
170    
171          return True;          return True;
172  }  }
# Line 185  rdpsnd_dsp_resample(unsigned char **out, Line 178  rdpsnd_dsp_resample(unsigned char **out,
178  #ifdef HAVE_LIBSAMPLERATE  #ifdef HAVE_LIBSAMPLERATE
179          SRC_DATA resample_data;          SRC_DATA resample_data;
180          float *infloat, *outfloat;          float *infloat, *outfloat;
         int innum, outnum;  
181          int err;          int err;
182  #else  #else
183          int offset;          int ratio1k = (resample_to_srate * 1000) / format->nSamplesPerSec;
184  #endif  #endif
185          static BOOL warned = False;          int innum, outnum;
186          unsigned char *tmpdata = NULL;          unsigned char *tmpdata = NULL, *tmp = 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 206  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 214  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 223  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 (tmp != NULL)
246                                    xfree(tmp);
247                  }                  }
248          }          }
249    
250          if (resample_to_channels != format->nChannels)          innum = size / samplewidth;
         {  
                 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;  
         }  
251    
252          /* Do the resampling */          /* Do the resampling */
253  #ifdef HAVE_LIBSAMPLERATE  #ifdef HAVE_LIBSAMPLERATE
# Line 240  rdpsnd_dsp_resample(unsigned char **out, Line 257  rdpsnd_dsp_resample(unsigned char **out,
257                  return 0;                  return 0;
258          }          }
259    
260          innum = size / samplewidth;          outnum = ((float) innum * ((float) resample_to_srate / (float) format->nSamplesPerSec)) + 1;
         outnum = ((float)innum * ((float)resample_to_srate / (float)format->nSamplesPerSec)) + 1;  
261    
262          infloat = xmalloc(sizeof(float) * innum);          infloat = xmalloc(sizeof(float) * innum);
263          outfloat = xmalloc(sizeof(float) * outnum);          outfloat = xmalloc(sizeof(float) * outnum);
# Line 263  rdpsnd_dsp_resample(unsigned char **out, Line 279  rdpsnd_dsp_resample(unsigned char **out,
279    
280          outsize = resample_data.output_frames_gen * resample_to_channels * samplewidth;          outsize = resample_data.output_frames_gen * resample_to_channels * samplewidth;
281          *out = xmalloc(outsize);          *out = xmalloc(outsize);
282          src_float_to_short_array(outfloat, (short *) *out, resample_data.output_frames_gen * resample_to_channels);          src_float_to_short_array(outfloat, (short *) *out,
283                                     resample_data.output_frames_gen * resample_to_channels);
284          xfree(outfloat);          xfree(outfloat);
285    
286  #else  #else
287          if (format->nSamplesPerSec != 22050)          /* Michaels simple linear resampler */
288            if (resample_to_srate < format->nSamplesPerSec)
289          {          {
290                  if (!warned)                  warning("downsampling currently not supported!\n");
                 {  
                         warning("unsupported source samplerate (%u), not resampling!\n",  
                                 format->nSamplesPerSec);  
                         warned = True;  
                 }  
291                  return 0;                  return 0;
292          }          }
293    
294          outsize = size * 2;          outnum = (innum * ratio1k) / 1000;
295    
296            outsize = outnum * samplewidth;
297          *out = xmalloc(outsize);          *out = xmalloc(outsize);
298            bzero(*out, outsize);
299    
300          /* Resample from 22050 to 44100 */          for (i = 0; i < outsize / (resample_to_channels * samplewidth); i++)
         for (i = 0; i < (size / samplewidth); i++)  
301          {          {
302                  /* On a stereo-channel we must make sure that left and right                  int source = (i * 1000) / ratio1k;
303                     does not get mixed up, so we need to expand the sample-                  int j;
                    data with channels in mind: 1234 -> 12123434  
                    If we have a mono-channel, we can expand the data by simply  
                    doubling the sample-data: 1234 -> 11223344 */  
                 if (resample_to_channels == 2)  
                         offset = ((i * 2) - (i & 1)) * samplewidth;  
                 else  
                         offset = (i * 2) * samplewidth;  
   
                 memcpy(*out + offset, in + (i * samplewidth), samplewidth);  
                 memcpy(*out + (resample_to_channels * samplewidth + offset),  
                        in + (i * samplewidth), samplewidth);  
304    
305                    if (source * resample_to_channels + samplewidth > size)
306                            break;
307    
308                    for (j = 0; j < resample_to_channels; j++)
309                    {
310                            memcpy(*out + (i * resample_to_channels * samplewidth) + (samplewidth * j),
311                                   in + (source * resample_to_channels * samplewidth) +
312                                   (samplewidth * j), samplewidth);
313                    }
314          }          }
315            outsize = i * resample_to_channels * samplewidth;
316  #endif  #endif
317    
318          if (tmpdata != NULL)          if (tmpdata != NULL)

Legend:
Removed from v.1282  
changed lines
  Added in v.1291

  ViewVC Help
Powered by ViewVC 1.1.26