You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

79 lines
3.3KB

  1. /*
  2. * audio resampling
  3. * Copyright (c) 2004-2012 Michael Niedermayer <michaelni@gmx.at>
  4. *
  5. * This file is part of FFmpeg.
  6. *
  7. * FFmpeg is free software; you can redistribute it and/or
  8. * modify it under the terms of the GNU Lesser General Public
  9. * License as published by the Free Software Foundation; either
  10. * version 2.1 of the License, or (at your option) any later version.
  11. *
  12. * FFmpeg is distributed in the hope that it will be useful,
  13. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  15. * Lesser General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU Lesser General Public
  18. * License along with FFmpeg; if not, write to the Free Software
  19. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  20. */
  21. /**
  22. * @file
  23. * audio resampling
  24. * @author Michael Niedermayer <michaelni@gmx.at>
  25. */
  26. #include "resample.h"
  27. int swri_resample_common_int16 (ResampleContext *c, int16_t *dst, const int16_t *src, int n, int update_ctx);
  28. int swri_resample_common_int32 (ResampleContext *c, int32_t *dst, const int32_t *src, int n, int update_ctx);
  29. int swri_resample_common_float (ResampleContext *c, float *dst, const float *src, int n, int update_ctx);
  30. int swri_resample_common_double(ResampleContext *c, double *dst, const double *src, int n, int update_ctx);
  31. int swri_resample_linear_int16 (ResampleContext *c, int16_t *dst, const int16_t *src, int n, int update_ctx);
  32. int swri_resample_linear_int32 (ResampleContext *c, int32_t *dst, const int32_t *src, int n, int update_ctx);
  33. int swri_resample_linear_float (ResampleContext *c, float *dst, const float *src, int n, int update_ctx);
  34. int swri_resample_linear_double(ResampleContext *c, double *dst, const double *src, int n, int update_ctx);
  35. #define DO_RESAMPLE_ONE 1
  36. #define TEMPLATE_RESAMPLE_S16
  37. #include "resample_template.c"
  38. #undef TEMPLATE_RESAMPLE_S16
  39. #define TEMPLATE_RESAMPLE_S32
  40. #include "resample_template.c"
  41. #undef TEMPLATE_RESAMPLE_S32
  42. #define TEMPLATE_RESAMPLE_FLT
  43. #include "resample_template.c"
  44. #undef TEMPLATE_RESAMPLE_FLT
  45. #define TEMPLATE_RESAMPLE_DBL
  46. #include "resample_template.c"
  47. #undef TEMPLATE_RESAMPLE_DBL
  48. #undef DO_RESAMPLE_ONE
  49. void swresample_dsp_init(ResampleContext *c)
  50. {
  51. #define FNIDX(fmt) (AV_SAMPLE_FMT_##fmt - AV_SAMPLE_FMT_S16P)
  52. c->dsp.resample_one[FNIDX(S16P)] = (resample_one_fn) resample_one_int16;
  53. c->dsp.resample_one[FNIDX(S32P)] = (resample_one_fn) resample_one_int32;
  54. c->dsp.resample_one[FNIDX(FLTP)] = (resample_one_fn) resample_one_float;
  55. c->dsp.resample_one[FNIDX(DBLP)] = (resample_one_fn) resample_one_double;
  56. c->dsp.resample_common[FNIDX(S16P)] = (resample_fn) swri_resample_common_int16;
  57. c->dsp.resample_common[FNIDX(S32P)] = (resample_fn) swri_resample_common_int32;
  58. c->dsp.resample_common[FNIDX(FLTP)] = (resample_fn) swri_resample_common_float;
  59. c->dsp.resample_common[FNIDX(DBLP)] = (resample_fn) swri_resample_common_double;
  60. c->dsp.resample_linear[FNIDX(S16P)] = (resample_fn) swri_resample_linear_int16;
  61. c->dsp.resample_linear[FNIDX(S32P)] = (resample_fn) swri_resample_linear_int32;
  62. c->dsp.resample_linear[FNIDX(FLTP)] = (resample_fn) swri_resample_linear_float;
  63. c->dsp.resample_linear[FNIDX(DBLP)] = (resample_fn) swri_resample_linear_double;
  64. if (ARCH_X86) swresample_dsp_x86_init(c);
  65. }