float_dsp_init.c 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. /*
  2. * ARM NEON optimised Float DSP functions
  3. * Copyright (c) 2008 Mans Rullgard <mans@mansr.com>
  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. #include <stdint.h>
  22. #include "libavutil/attributes.h"
  23. #include "libavutil/cpu.h"
  24. #include "libavutil/float_dsp.h"
  25. #include "cpu.h"
  26. void ff_vector_fmul_neon(float *dst, const float *src0, const float *src1,
  27. int len);
  28. void ff_vector_fmac_scalar_neon(float *dst, const float *src, float mul,
  29. int len);
  30. void ff_vector_fmul_scalar_neon(float *dst, const float *src, float mul,
  31. int len);
  32. void ff_vector_dmul_scalar_neon(double *dst, const double *src, double mul,
  33. int len);
  34. void ff_vector_fmul_window_neon(float *dst, const float *src0,
  35. const float *src1, const float *win, int len);
  36. void ff_vector_fmul_add_neon(float *dst, const float *src0, const float *src1,
  37. const float *src2, int len);
  38. void ff_vector_fmul_reverse_neon(float *dst, const float *src0,
  39. const float *src1, int len);
  40. void ff_butterflies_float_neon(float *v1, float *v2, int len);
  41. float ff_scalarproduct_float_neon(const float *v1, const float *v2, int len);
  42. av_cold void ff_float_dsp_init_aarch64(AVFloatDSPContext *fdsp)
  43. {
  44. int cpu_flags = av_get_cpu_flags();
  45. if (have_neon(cpu_flags)) {
  46. fdsp->butterflies_float = ff_butterflies_float_neon;
  47. fdsp->scalarproduct_float = ff_scalarproduct_float_neon;
  48. fdsp->vector_dmul_scalar = ff_vector_dmul_scalar_neon;
  49. fdsp->vector_fmul = ff_vector_fmul_neon;
  50. fdsp->vector_fmac_scalar = ff_vector_fmac_scalar_neon;
  51. fdsp->vector_fmul_add = ff_vector_fmul_add_neon;
  52. fdsp->vector_fmul_reverse = ff_vector_fmul_reverse_neon;
  53. fdsp->vector_fmul_scalar = ff_vector_fmul_scalar_neon;
  54. fdsp->vector_fmul_window = ff_vector_fmul_window_neon;
  55. }
  56. }