idctdsp_init_arm.c 3.2 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. /*
  2. * ARM-optimized IDCT functions
  3. * Copyright (c) 2001 Lionel Ulmer
  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 <stddef.h>
  22. #include <stdint.h>
  23. #include "libavutil/attributes.h"
  24. #include "libavutil/cpu.h"
  25. #include "libavutil/arm/cpu.h"
  26. #include "libavcodec/avcodec.h"
  27. #include "libavcodec/idctdsp.h"
  28. #include "idct.h"
  29. #include "idctdsp_arm.h"
  30. void ff_add_pixels_clamped_arm(const int16_t *block, uint8_t *dest,
  31. ptrdiff_t line_size);
  32. /* XXX: those functions should be suppressed ASAP when all IDCTs are
  33. * converted */
  34. static void j_rev_dct_arm_put(uint8_t *dest, ptrdiff_t line_size,
  35. int16_t *block)
  36. {
  37. ff_j_rev_dct_arm(block);
  38. ff_put_pixels_clamped_c(block, dest, line_size);
  39. }
  40. static void j_rev_dct_arm_add(uint8_t *dest, ptrdiff_t line_size,
  41. int16_t *block)
  42. {
  43. ff_j_rev_dct_arm(block);
  44. ff_add_pixels_clamped_arm(block, dest, line_size);
  45. }
  46. static void simple_idct_arm_put(uint8_t *dest, ptrdiff_t line_size,
  47. int16_t *block)
  48. {
  49. ff_simple_idct_arm(block);
  50. ff_put_pixels_clamped_c(block, dest, line_size);
  51. }
  52. static void simple_idct_arm_add(uint8_t *dest, ptrdiff_t line_size,
  53. int16_t *block)
  54. {
  55. ff_simple_idct_arm(block);
  56. ff_add_pixels_clamped_arm(block, dest, line_size);
  57. }
  58. av_cold void ff_idctdsp_init_arm(IDCTDSPContext *c, AVCodecContext *avctx,
  59. unsigned high_bit_depth)
  60. {
  61. int cpu_flags = av_get_cpu_flags();
  62. if (!avctx->lowres && !high_bit_depth) {
  63. if ((avctx->idct_algo == FF_IDCT_AUTO && !(avctx->flags & AV_CODEC_FLAG_BITEXACT)) ||
  64. avctx->idct_algo == FF_IDCT_ARM) {
  65. c->idct_put = j_rev_dct_arm_put;
  66. c->idct_add = j_rev_dct_arm_add;
  67. c->idct = ff_j_rev_dct_arm;
  68. c->perm_type = FF_IDCT_PERM_LIBMPEG2;
  69. } else if (avctx->idct_algo == FF_IDCT_SIMPLEARM) {
  70. c->idct_put = simple_idct_arm_put;
  71. c->idct_add = simple_idct_arm_add;
  72. c->idct = ff_simple_idct_arm;
  73. c->perm_type = FF_IDCT_PERM_NONE;
  74. }
  75. }
  76. c->add_pixels_clamped = ff_add_pixels_clamped_arm;
  77. if (have_armv5te(cpu_flags))
  78. ff_idctdsp_init_armv5te(c, avctx, high_bit_depth);
  79. if (have_armv6(cpu_flags))
  80. ff_idctdsp_init_armv6(c, avctx, high_bit_depth);
  81. if (have_neon(cpu_flags))
  82. ff_idctdsp_init_neon(c, avctx, high_bit_depth);
  83. }