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.

163 lines
8.0KB

  1. /*
  2. * software RGB to RGB converter
  3. * pluralize by Software PAL8 to RGB converter
  4. * Software YUV to YUV converter
  5. * Software YUV to RGB converter
  6. * Written by Nick Kurshev.
  7. * YUV & runtime CPU stuff by Michael (michaelni@gmx.at)
  8. *
  9. * This file is part of FFmpeg.
  10. *
  11. * FFmpeg is free software; you can redistribute it and/or
  12. * modify it under the terms of the GNU Lesser General Public
  13. * License as published by the Free Software Foundation; either
  14. * version 2.1 of the License, or (at your option) any later version.
  15. *
  16. * FFmpeg is distributed in the hope that it will be useful,
  17. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  18. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  19. * Lesser General Public License for more details.
  20. *
  21. * You should have received a copy of the GNU Lesser General Public
  22. * License along with FFmpeg; if not, write to the Free Software
  23. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
  24. */
  25. #ifndef SWSCALE_RGB2RGB_H
  26. #define SWSCALE_RGB2RGB_H
  27. #include <inttypes.h>
  28. #include "libswscale/swscale.h"
  29. #include "libavutil/avutil.h"
  30. /* A full collection of RGB to RGB(BGR) converters */
  31. extern void (*rgb24tobgr32)(const uint8_t *src, uint8_t *dst, int src_size);
  32. extern void (*rgb24tobgr16)(const uint8_t *src, uint8_t *dst, int src_size);
  33. extern void (*rgb24tobgr15)(const uint8_t *src, uint8_t *dst, int src_size);
  34. extern void (*rgb32tobgr24)(const uint8_t *src, uint8_t *dst, int src_size);
  35. extern void (*rgb32to16)(const uint8_t *src, uint8_t *dst, int src_size);
  36. extern void (*rgb32to15)(const uint8_t *src, uint8_t *dst, int src_size);
  37. extern void (*rgb15to16)(const uint8_t *src, uint8_t *dst, int src_size);
  38. extern void (*rgb15tobgr24)(const uint8_t *src, uint8_t *dst, int src_size);
  39. extern void (*rgb15to32)(const uint8_t *src, uint8_t *dst, int src_size);
  40. extern void (*rgb16to15)(const uint8_t *src, uint8_t *dst, int src_size);
  41. extern void (*rgb16tobgr24)(const uint8_t *src, uint8_t *dst, int src_size);
  42. extern void (*rgb16to32)(const uint8_t *src, uint8_t *dst, int src_size);
  43. extern void (*rgb24tobgr24)(const uint8_t *src, uint8_t *dst, int src_size);
  44. extern void (*rgb24to16)(const uint8_t *src, uint8_t *dst, int src_size);
  45. extern void (*rgb24to15)(const uint8_t *src, uint8_t *dst, int src_size);
  46. extern void (*rgb32tobgr16)(const uint8_t *src, uint8_t *dst, int src_size);
  47. extern void (*rgb32tobgr15)(const uint8_t *src, uint8_t *dst, int src_size);
  48. extern void (*shuffle_bytes_2103)(const uint8_t *src, uint8_t *dst, int src_size);
  49. void rgb48tobgr48_LL(const uint8_t *src, uint8_t *dst, int src_size);
  50. void rgb48tobgr48_LB(const uint8_t *src, uint8_t *dst, int src_size);
  51. void rgb24to32(const uint8_t *src, uint8_t *dst, int src_size);
  52. void rgb32to24(const uint8_t *src, uint8_t *dst, int src_size);
  53. void rgb16tobgr32(const uint8_t *src, uint8_t *dst, int src_size);
  54. void rgb16to24(const uint8_t *src, uint8_t *dst, int src_size);
  55. void rgb16tobgr16(const uint8_t *src, uint8_t *dst, int src_size);
  56. void rgb16tobgr15(const uint8_t *src, uint8_t *dst, int src_size);
  57. void rgb15tobgr32(const uint8_t *src, uint8_t *dst, int src_size);
  58. void rgb15to24(const uint8_t *src, uint8_t *dst, int src_size);
  59. void rgb15tobgr16(const uint8_t *src, uint8_t *dst, int src_size);
  60. void rgb15tobgr15(const uint8_t *src, uint8_t *dst, int src_size);
  61. void rgb12tobgr12(const uint8_t *src, uint8_t *dst, int src_size);
  62. void rgb12to15(const uint8_t *src, uint8_t *dst, int src_size);
  63. void shuffle_bytes_0321(const uint8_t *src, uint8_t *dst, int src_size);
  64. void shuffle_bytes_1230(const uint8_t *src, uint8_t *dst, int src_size);
  65. void shuffle_bytes_3012(const uint8_t *src, uint8_t *dst, int src_size);
  66. void shuffle_bytes_3210(const uint8_t *src, uint8_t *dst, int src_size);
  67. void rgb24toyv12_c(const uint8_t *src, uint8_t *ydst, uint8_t *udst,
  68. uint8_t *vdst, int width, int height, int lumStride,
  69. int chromStride, int srcStride);
  70. /**
  71. * Height should be a multiple of 2 and width should be a multiple of 16.
  72. * (If this is a problem for anyone then tell me, and I will fix it.)
  73. */
  74. extern void (*yv12toyuy2)(const uint8_t *ysrc, const uint8_t *usrc, const uint8_t *vsrc, uint8_t *dst,
  75. int width, int height,
  76. int lumStride, int chromStride, int dstStride);
  77. /**
  78. * Width should be a multiple of 16.
  79. */
  80. extern void (*yuv422ptoyuy2)(const uint8_t *ysrc, const uint8_t *usrc, const uint8_t *vsrc, uint8_t *dst,
  81. int width, int height,
  82. int lumStride, int chromStride, int dstStride);
  83. /**
  84. * Height should be a multiple of 2 and width should be a multiple of 16.
  85. * (If this is a problem for anyone then tell me, and I will fix it.)
  86. */
  87. extern void (*yuy2toyv12)(const uint8_t *src, uint8_t *ydst, uint8_t *udst, uint8_t *vdst,
  88. int width, int height,
  89. int lumStride, int chromStride, int srcStride);
  90. /**
  91. * Height should be a multiple of 2 and width should be a multiple of 16.
  92. * (If this is a problem for anyone then tell me, and I will fix it.)
  93. */
  94. extern void (*yv12touyvy)(const uint8_t *ysrc, const uint8_t *usrc, const uint8_t *vsrc, uint8_t *dst,
  95. int width, int height,
  96. int lumStride, int chromStride, int dstStride);
  97. /**
  98. * Width should be a multiple of 16.
  99. */
  100. extern void (*yuv422ptouyvy)(const uint8_t *ysrc, const uint8_t *usrc, const uint8_t *vsrc, uint8_t *dst,
  101. int width, int height,
  102. int lumStride, int chromStride, int dstStride);
  103. /**
  104. * Height should be a multiple of 2 and width should be a multiple of 2.
  105. * (If this is a problem for anyone then tell me, and I will fix it.)
  106. * Chrominance data is only taken from every second line, others are ignored.
  107. * FIXME: Write high quality version.
  108. */
  109. extern void (*rgb24toyv12)(const uint8_t *src, uint8_t *ydst, uint8_t *udst, uint8_t *vdst,
  110. int width, int height,
  111. int lumStride, int chromStride, int srcStride);
  112. extern void (*planar2x)(const uint8_t *src, uint8_t *dst, int width, int height,
  113. int srcStride, int dstStride);
  114. extern void (*interleaveBytes)(const uint8_t *src1, const uint8_t *src2, uint8_t *dst,
  115. int width, int height, int src1Stride,
  116. int src2Stride, int dstStride);
  117. extern void (*vu9_to_vu12)(const uint8_t *src1, const uint8_t *src2,
  118. uint8_t *dst1, uint8_t *dst2,
  119. int width, int height,
  120. int srcStride1, int srcStride2,
  121. int dstStride1, int dstStride2);
  122. extern void (*yvu9_to_yuy2)(const uint8_t *src1, const uint8_t *src2, const uint8_t *src3,
  123. uint8_t *dst,
  124. int width, int height,
  125. int srcStride1, int srcStride2,
  126. int srcStride3, int dstStride);
  127. extern void (*uyvytoyuv420)(uint8_t *ydst, uint8_t *udst, uint8_t *vdst, const uint8_t *src,
  128. int width, int height,
  129. int lumStride, int chromStride, int srcStride);
  130. extern void (*uyvytoyuv422)(uint8_t *ydst, uint8_t *udst, uint8_t *vdst, const uint8_t *src,
  131. int width, int height,
  132. int lumStride, int chromStride, int srcStride);
  133. extern void (*yuyvtoyuv420)(uint8_t *ydst, uint8_t *udst, uint8_t *vdst, const uint8_t *src,
  134. int width, int height,
  135. int lumStride, int chromStride, int srcStride);
  136. extern void (*yuyvtoyuv422)(uint8_t *ydst, uint8_t *udst, uint8_t *vdst, const uint8_t *src,
  137. int width, int height,
  138. int lumStride, int chromStride, int srcStride);
  139. void sws_rgb2rgb_init(void);
  140. void rgb2rgb_init_x86(void);
  141. #endif /* SWSCALE_RGB2RGB_H */