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.

68 lines
2.1KB

  1. /*
  2. * Monkey's Audio lossless audio decoder
  3. * Copyright (c) 2007 Benjamin Zores <ben@geexbox.org>
  4. * based upon libdemac from Dave Chapman.
  5. *
  6. * This file is part of FFmpeg.
  7. *
  8. * FFmpeg is free software; you can redistribute it and/or
  9. * modify it under the terms of the GNU Lesser General Public
  10. * License as published by the Free Software Foundation; either
  11. * version 2.1 of the License, or (at your option) any later version.
  12. *
  13. * FFmpeg is distributed in the hope that it will be useful,
  14. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  16. * Lesser General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU Lesser General Public
  19. * License along with FFmpeg; if not, write to the Free Software
  20. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  21. */
  22. #include "avcodec.h"
  23. #include "lossless_audiodsp.h"
  24. static int32_t scalarproduct_and_madd_int16_c(int16_t *v1, const int16_t *v2,
  25. const int16_t *v3,
  26. int order, int mul)
  27. {
  28. int res = 0;
  29. do {
  30. res += *v1 * *v2++;
  31. *v1++ += mul * *v3++;
  32. res += *v1 * *v2++;
  33. *v1++ += mul * *v3++;
  34. } while (order-=2);
  35. return res;
  36. }
  37. static int32_t scalarproduct_and_madd_int32_c(int16_t *v1, const int32_t *v2,
  38. const int16_t *v3,
  39. int order, int mul)
  40. {
  41. int res = 0;
  42. do {
  43. res += *v1 * (uint32_t)*v2++;
  44. *v1++ += mul * *v3++;
  45. res += *v1 * (uint32_t)*v2++;
  46. *v1++ += mul * *v3++;
  47. } while (order-=2);
  48. return res;
  49. }
  50. av_cold void ff_llauddsp_init(LLAudDSPContext *c)
  51. {
  52. c->scalarproduct_and_madd_int16 = scalarproduct_and_madd_int16_c;
  53. c->scalarproduct_and_madd_int32 = scalarproduct_and_madd_int32_c;
  54. if (ARCH_ARM)
  55. ff_llauddsp_init_arm(c);
  56. if (ARCH_PPC)
  57. ff_llauddsp_init_ppc(c);
  58. if (ARCH_X86)
  59. ff_llauddsp_init_x86(c);
  60. }