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.

78 lines
3.0KB

  1. /*
  2. * MMX optimized DSP utils
  3. * Copyright (c) 2007 Aurelien Jacobs <aurel@gnuage.org>
  4. *
  5. * This file is part of Libav.
  6. *
  7. * Libav 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. * Libav 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 Libav; if not, write to the Free Software
  19. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  20. */
  21. #ifndef AVCODEC_X86_DSPUTIL_X86_H
  22. #define AVCODEC_X86_DSPUTIL_X86_H
  23. #include <stddef.h>
  24. #include <stdint.h>
  25. #include "libavcodec/avcodec.h"
  26. #include "libavcodec/dsputil.h"
  27. void ff_dsputilenc_init_mmx(DSPContext *c, AVCodecContext *avctx,
  28. unsigned high_bit_depth);
  29. void ff_dsputil_init_pix_mmx(DSPContext *c, AVCodecContext *avctx);
  30. void ff_add_pixels_clamped_mmx(const int16_t *block, uint8_t *pixels,
  31. int line_size);
  32. void ff_put_pixels_clamped_mmx(const int16_t *block, uint8_t *pixels,
  33. int line_size);
  34. void ff_put_signed_pixels_clamped_mmx(const int16_t *block, uint8_t *pixels,
  35. int line_size);
  36. void ff_clear_block_mmx(int16_t *block);
  37. void ff_clear_block_sse(int16_t *block);
  38. void ff_clear_blocks_mmx(int16_t *blocks);
  39. void ff_clear_blocks_sse(int16_t *blocks);
  40. void ff_add_bytes_mmx(uint8_t *dst, uint8_t *src, int w);
  41. void ff_add_hfyu_median_prediction_cmov(uint8_t *dst, const uint8_t *top,
  42. const uint8_t *diff, int w,
  43. int *left, int *left_top);
  44. void ff_draw_edges_mmx(uint8_t *buf, int wrap, int width, int height,
  45. int w, int h, int sides);
  46. void ff_gmc_mmx(uint8_t *dst, uint8_t *src,
  47. int stride, int h, int ox, int oy,
  48. int dxx, int dxy, int dyx, int dyy,
  49. int shift, int r, int width, int height);
  50. void ff_vector_clipf_sse(float *dst, const float *src,
  51. float min, float max, int len);
  52. void ff_avg_pixels8_x2_mmx(uint8_t *block, const uint8_t *pixels,
  53. ptrdiff_t line_size, int h);
  54. void ff_avg_pixels8_xy2_mmx(uint8_t *block, const uint8_t *pixels,
  55. ptrdiff_t line_size, int h);
  56. void ff_avg_pixels16_xy2_mmx(uint8_t *block, const uint8_t *pixels,
  57. ptrdiff_t line_size, int h);
  58. void ff_put_pixels8_xy2_mmx(uint8_t *block, const uint8_t *pixels,
  59. ptrdiff_t line_size, int h);
  60. void ff_put_pixels16_xy2_mmx(uint8_t *block, const uint8_t *pixels,
  61. ptrdiff_t line_size, int h);
  62. #endif /* AVCODEC_X86_DSPUTIL_X86_H */