videodsp.h 3.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. /*
  2. * Copyright (C) 2012 Ronald S. Bultje
  3. *
  4. * This file is part of FFmpeg.
  5. *
  6. * FFmpeg is free software; you can redistribute it and/or
  7. * modify it under the terms of the GNU Lesser General Public
  8. * License as published by the Free Software Foundation; either
  9. * version 2.1 of the License, or (at your option) any later version.
  10. *
  11. * FFmpeg is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  14. * Lesser General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU Lesser General Public
  17. * License along with FFmpeg; if not, write to the Free Software
  18. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  19. */
  20. /**
  21. * @file
  22. * Core video DSP helper functions
  23. */
  24. #ifndef AVCODEC_VIDEODSP_H
  25. #define AVCODEC_VIDEODSP_H
  26. #include <stddef.h>
  27. #include <stdint.h>
  28. #define EMULATED_EDGE(depth) \
  29. void ff_emulated_edge_mc_ ## depth(uint8_t *dst, const uint8_t *src, \
  30. ptrdiff_t dst_stride, ptrdiff_t src_stride, \
  31. int block_w, int block_h,\
  32. int src_x, int src_y, int w, int h);
  33. EMULATED_EDGE(8)
  34. EMULATED_EDGE(16)
  35. typedef struct VideoDSPContext {
  36. /**
  37. * Copy a rectangular area of samples to a temporary buffer and replicate
  38. * the border samples.
  39. *
  40. * @param dst destination buffer
  41. * @param dst_stride number of bytes between 2 vertically adjacent samples
  42. * in destination buffer
  43. * @param src source buffer
  44. * @param dst_linesize number of bytes between 2 vertically adjacent
  45. * samples in the destination buffer
  46. * @param src_linesize number of bytes between 2 vertically adjacent
  47. * samples in both the source buffer
  48. * @param block_w width of block
  49. * @param block_h height of block
  50. * @param src_x x coordinate of the top left sample of the block in the
  51. * source buffer
  52. * @param src_y y coordinate of the top left sample of the block in the
  53. * source buffer
  54. * @param w width of the source buffer
  55. * @param h height of the source buffer
  56. */
  57. void (*emulated_edge_mc)(uint8_t *dst, const uint8_t *src,
  58. ptrdiff_t dst_linesize,
  59. ptrdiff_t src_linesize,
  60. int block_w, int block_h,
  61. int src_x, int src_y, int w, int h);
  62. /**
  63. * Prefetch memory into cache (if supported by hardware).
  64. *
  65. * @param buf pointer to buffer to prefetch memory from
  66. * @param stride distance between two lines of buf (in bytes)
  67. * @param h number of lines to prefetch
  68. */
  69. void (*prefetch)(uint8_t *buf, ptrdiff_t stride, int h);
  70. } VideoDSPContext;
  71. void ff_videodsp_init(VideoDSPContext *ctx, int bpc);
  72. /* for internal use only (i.e. called by ff_videodsp_init() */
  73. void ff_videodsp_init_aarch64(VideoDSPContext *ctx, int bpc);
  74. void ff_videodsp_init_arm(VideoDSPContext *ctx, int bpc);
  75. void ff_videodsp_init_ppc(VideoDSPContext *ctx, int bpc);
  76. void ff_videodsp_init_x86(VideoDSPContext *ctx, int bpc);
  77. void ff_videodsp_init_mips(VideoDSPContext *ctx, int bpc);
  78. #endif /* AVCODEC_VIDEODSP_H */