Go to the documentation of this file.
35 const uint8_t *
s =
src;
36 const uint8_t *end =
s + src_size;
59 const uint8_t *
s =
src;
60 const uint8_t *end =
s + src_size;
87 register uint8_t *d =
dst;
88 register const uint8_t *
s =
src;
89 register const uint8_t *end =
s + src_size;
90 const uint8_t *mm_end = end - 3;
93 register unsigned x = *((
const uint32_t *)
s);
94 *((uint32_t *)d) = (x & 0x7FFF7FFF) + (x & 0x7FE07FE0);
99 register unsigned short x = *((
const uint16_t *)
s);
100 *((uint16_t *)d) = (x & 0x7FFF) + (x & 0x7FE0);
106 register uint8_t *d =
dst;
107 register const uint8_t *
s =
src;
108 register const uint8_t *end =
s + src_size;
109 const uint8_t *mm_end = end - 3;
112 register uint32_t x = *((
const uint32_t *)
s);
113 *((uint32_t *)d) = ((x >> 1) & 0x7FE07FE0) | (x & 0x001F001F);
118 register uint16_t x = *((
const uint16_t *)
s);
119 *((uint16_t *)d) = ((x >> 1) & 0x7FE0) | (x & 0x001F);
125 uint16_t *d = (uint16_t *)
dst;
126 const uint8_t *
s =
src;
127 const uint8_t *end =
s + src_size;
130 register int rgb = *(
const uint32_t *)
s;
132 *d++ = ((
rgb & 0xFF) >> 3) +
133 ((
rgb & 0xFC00) >> 5) +
134 ((
rgb & 0xF80000) >> 8);
141 uint16_t *d = (uint16_t *)
dst;
142 const uint8_t *
s =
src;
143 const uint8_t *end =
s + src_size;
146 register int rgb = *(
const uint32_t *)
s;
148 *d++ = ((
rgb & 0xF8) << 8) +
149 ((
rgb & 0xFC00) >> 5) +
150 ((
rgb & 0xF80000) >> 19);
156 uint16_t *d = (uint16_t *)
dst;
157 const uint8_t *
s =
src;
158 const uint8_t *end =
s + src_size;
161 register int rgb = *(
const uint32_t *)
s;
163 *d++ = ((
rgb & 0xFF) >> 3) +
164 ((
rgb & 0xF800) >> 6) +
165 ((
rgb & 0xF80000) >> 9);
172 uint16_t *d = (uint16_t *)
dst;
173 const uint8_t *
s =
src;
174 const uint8_t *end =
s + src_size;
177 register int rgb = *(
const uint32_t *)
s;
179 *d++ = ((
rgb & 0xF8) << 7) +
180 ((
rgb & 0xF800) >> 6) +
181 ((
rgb & 0xF80000) >> 19);
188 uint16_t *d = (uint16_t *)
dst;
189 const uint8_t *
s =
src;
190 const uint8_t *end =
s + src_size;
196 *d++ = (
b >> 3) | ((
g & 0xFC) << 3) | ((
r & 0xF8) << 8);
202 uint16_t *d = (uint16_t *)
dst;
203 const uint8_t *
s =
src;
204 const uint8_t *end =
s + src_size;
210 *d++ = (
b >> 3) | ((
g & 0xFC) << 3) | ((
r & 0xF8) << 8);
217 uint16_t *d = (uint16_t *)
dst;
218 const uint8_t *
s =
src;
219 const uint8_t *end =
s + src_size;
225 *d++ = (
b >> 3) | ((
g & 0xF8) << 2) | ((
r & 0xF8) << 7);
231 uint16_t *d = (uint16_t *)
dst;
232 const uint8_t *
s =
src;
233 const uint8_t *end =
s + src_size;
239 *d++ = (
b >> 3) | ((
g & 0xF8) << 2) | ((
r & 0xF8) << 7);
247 const uint16_t *
s = (
const uint16_t *)
src;
248 const uint16_t *end =
s + src_size / 2;
251 register uint16_t bgr = *
s++;
252 *d++ = ((bgr&0x001F)<<3) | ((bgr&0x001F)>> 2);
253 *d++ = ((bgr&0x03E0)>>2) | ((bgr&0x03E0)>> 7);
254 *d++ = ((bgr&0x7C00)>>7) | ((bgr&0x7C00)>>12);
261 uint8_t *d = (uint8_t *)
dst;
262 const uint16_t *
s = (
const uint16_t *)
src;
263 const uint16_t *end =
s + src_size / 2;
266 register uint16_t bgr = *
s++;
267 *d++ = ((bgr&0x001F)<<3) | ((bgr&0x001F)>> 2);
268 *d++ = ((bgr&0x07E0)>>3) | ((bgr&0x07E0)>> 9);
269 *d++ = ((bgr&0xF800)>>8) | ((bgr&0xF800)>>13);
276 const uint16_t *
s = (
const uint16_t *)
src;
277 const uint16_t *end =
s + src_size / 2;
280 register uint16_t bgr = *
s++;
283 *d++ = ((bgr&0x7C00)>>7) | ((bgr&0x7C00)>>12);
284 *d++ = ((bgr&0x03E0)>>2) | ((bgr&0x03E0)>> 7);
285 *d++ = ((bgr&0x001F)<<3) | ((bgr&0x001F)>> 2);
287 *d++ = ((bgr&0x001F)<<3) | ((bgr&0x001F)>> 2);
288 *d++ = ((bgr&0x03E0)>>2) | ((bgr&0x03E0)>> 7);
289 *d++ = ((bgr&0x7C00)>>7) | ((bgr&0x7C00)>>12);
298 const uint16_t *
s = (
const uint16_t *)
src;
299 const uint16_t *end =
s + src_size / 2;
302 register uint16_t bgr = *
s++;
305 *d++ = ((bgr&0xF800)>>8) | ((bgr&0xF800)>>13);
306 *d++ = ((bgr&0x07E0)>>3) | ((bgr&0x07E0)>> 9);
307 *d++ = ((bgr&0x001F)<<3) | ((bgr&0x001F)>> 2);
309 *d++ = ((bgr&0x001F)<<3) | ((bgr&0x001F)>> 2);
310 *d++ = ((bgr&0x07E0)>>3) | ((bgr&0x07E0)>> 9);
311 *d++ = ((bgr&0xF800)>>8) | ((bgr&0xF800)>>13);
320 int idx = 15 - src_size;
321 const uint8_t *
s =
src - idx;
322 uint8_t *d =
dst - idx;
324 for (; idx < 15; idx += 4) {
325 register unsigned v = *(
const uint32_t *)&
s[idx],
g = v & 0xff00ff00;
327 *(uint32_t *)&d[idx] = (v >> 16) +
g + (v << 16);
334 int idx = 15 - src_size;
335 const uint8_t *
s =
src - idx;
336 uint8_t *d =
dst - idx;
338 for (; idx < 15; idx += 4) {
339 register unsigned v = *(
const uint32_t *)&
s[idx],
g = v & 0x00ff00ff;
341 *(uint32_t *)&d[idx] = (v >> 16) +
g + (v << 16);
345 #define DEFINE_SHUFFLE_BYTES(name, a, b, c, d) \
346 static void shuffle_bytes_##name (const uint8_t *src, \
347 uint8_t *dst, int src_size) \
351 for (i = 0; i < src_size; i += 4) { \
352 dst[i + 0] = src[i + a]; \
353 dst[i + 1] = src[i + b]; \
354 dst[i + 2] = src[i + c]; \
355 dst[i + 3] = src[i + d]; \
371 for (
i = 0;
i < src_size;
i += 3) {
372 register uint8_t x =
src[
i + 2];
380 const uint8_t *vsrc, uint8_t *
dst,
382 int lumStride,
int chromStride,
383 int dstStride,
int vertLumPerChroma)
386 const int chromWidth =
width >> 1;
388 for (y = 0; y <
height; y++) {
390 uint64_t *ldst = (uint64_t *)
dst;
391 const uint8_t *yc = ysrc, *uc = usrc, *vc = vsrc;
392 for (
i = 0;
i < chromWidth;
i += 2) {
393 uint64_t k = yc[0] + (uc[0] << 8) +
394 (yc[1] << 16) + ((unsigned) vc[0] << 24);
395 uint64_t l = yc[2] + (uc[1] << 8) +
396 (yc[3] << 16) + ((unsigned) vc[1] << 24);
397 *ldst++ = k + (l << 32);
405 const uint8_t *yc = ysrc, *uc = usrc, *vc = vsrc;
407 for (
i = 0;
i < chromWidth;
i++) {
409 *idst++ = (yc[0] << 24) + (uc[0] << 16) +
410 (yc[1] << 8) + (vc[0] << 0);
412 *idst++ = yc[0] + (uc[0] << 8) +
413 (yc[1] << 16) + (vc[0] << 24);
420 if ((y & (vertLumPerChroma - 1)) == vertLumPerChroma - 1) {
433 static inline void yv12toyuy2_c(
const uint8_t *ysrc,
const uint8_t *usrc,
434 const uint8_t *vsrc, uint8_t *
dst,
436 int chromStride,
int dstStride)
440 chromStride, dstStride, 2);
444 const uint8_t *vsrc, uint8_t *
dst,
446 int lumStride,
int chromStride,
447 int dstStride,
int vertLumPerChroma)
450 const int chromWidth =
width >> 1;
452 for (y = 0; y <
height; y++) {
454 uint64_t *ldst = (uint64_t *)
dst;
455 const uint8_t *yc = ysrc, *uc = usrc, *vc = vsrc;
456 for (
i = 0;
i < chromWidth;
i += 2) {
457 uint64_t k = uc[0] + (yc[0] << 8) +
458 (vc[0] << 16) + ((unsigned) yc[1] << 24);
459 uint64_t l = uc[1] + (yc[2] << 8) +
460 (vc[1] << 16) + ((unsigned) yc[3] << 24);
461 *ldst++ = k + (l << 32);
469 const uint8_t *yc = ysrc, *uc = usrc, *vc = vsrc;
471 for (
i = 0;
i < chromWidth;
i++) {
473 *idst++ = ((unsigned)uc[0] << 24) + (yc[0] << 16) +
474 (vc[0] << 8) + (yc[1] << 0);
476 *idst++ = uc[0] + (yc[0] << 8) +
477 (vc[0] << 16) + ((unsigned)yc[1] << 24);
484 if ((y & (vertLumPerChroma - 1)) == vertLumPerChroma - 1) {
497 static inline void yv12touyvy_c(
const uint8_t *ysrc,
const uint8_t *usrc,
498 const uint8_t *vsrc, uint8_t *
dst,
500 int chromStride,
int dstStride)
504 chromStride, dstStride, 2);
511 const uint8_t *vsrc, uint8_t *
dst,
513 int chromStride,
int dstStride)
516 chromStride, dstStride, 1);
523 const uint8_t *vsrc, uint8_t *
dst,
525 int chromStride,
int dstStride)
528 chromStride, dstStride, 1);
532 int srcHeight,
int srcStride,
int dstStride)
539 for (x = 0; x < srcWidth - 1; x++) {
540 dst[2 * x + 1] = (3 *
src[x] +
src[x + 1]) >> 2;
541 dst[2 * x + 2] = (
src[x] + 3 *
src[x + 1]) >> 2;
543 dst[2 * srcWidth - 1] =
src[srcWidth - 1];
547 for (y = 1; y < srcHeight; y++) {
548 const int mmxSize = 1;
550 dst[0] = (
src[0] * 3 +
src[srcStride]) >> 2;
551 dst[dstStride] = (
src[0] + 3 *
src[srcStride]) >> 2;
553 for (x = mmxSize - 1; x < srcWidth - 1; x++) {
554 dst[2 * x + 1] = (
src[x + 0] * 3 +
src[x + srcStride + 1]) >> 2;
555 dst[2 * x + dstStride + 2] = (
src[x + 0] + 3 *
src[x + srcStride + 1]) >> 2;
556 dst[2 * x + dstStride + 1] = (
src[x + 1] + 3 *
src[x + srcStride]) >> 2;
557 dst[2 * x + 2] = (
src[x + 1] * 3 +
src[x + srcStride]) >> 2;
559 dst[srcWidth * 2 - 1] = (
src[srcWidth - 1] * 3 +
src[srcWidth - 1 + srcStride]) >> 2;
560 dst[srcWidth * 2 - 1 + dstStride] = (
src[srcWidth - 1] + 3 *
src[srcWidth - 1 + srcStride]) >> 2;
562 dst += dstStride * 2;
569 for (x = 0; x < srcWidth - 1; x++) {
570 dst[2 * x + 1] = (
src[x] * 3 +
src[x + 1]) >> 2;
571 dst[2 * x + 2] = (
src[x] + 3 *
src[x + 1]) >> 2;
573 dst[2 * srcWidth - 1] =
src[srcWidth - 1];
581 uint8_t *vdst,
int width,
int height,
int lumStride,
588 const int chromWidth =
width >> 1;
590 const uint8_t *
src2 =
src1 + srcStride;
591 uint8_t *ydst1 = ydst;
592 uint8_t *ydst2 = ydst + lumStride;
594 for (y = 0; y <
height; y += 2) {
601 for (
i = 0;
i < chromWidth;
i++) {
602 unsigned int b11 =
src1[6 *
i + 0];
603 unsigned int g11 =
src1[6 *
i + 1];
604 unsigned int r11 =
src1[6 *
i + 2];
605 unsigned int b12 =
src1[6 *
i + 3];
606 unsigned int g12 =
src1[6 *
i + 4];
607 unsigned int r12 =
src1[6 *
i + 5];
608 unsigned int b21 =
src2[6 *
i + 0];
609 unsigned int g21 =
src2[6 *
i + 1];
610 unsigned int r21 =
src2[6 *
i + 2];
611 unsigned int b22 =
src2[6 *
i + 3];
612 unsigned int g22 =
src2[6 *
i + 4];
613 unsigned int r22 =
src2[6 *
i + 5];
615 unsigned int Y11 = ((ry * r11 + gy * g11 + by * b11) >>
RGB2YUV_SHIFT) + 16;
616 unsigned int Y12 = ((ry * r12 + gy * g12 + by * b12) >>
RGB2YUV_SHIFT) + 16;
617 unsigned int Y21 = ((ry * r21 + gy * g21 + by * b21) >>
RGB2YUV_SHIFT) + 16;
618 unsigned int Y22 = ((ry * r22 + gy * g22 + by * b22) >>
RGB2YUV_SHIFT) + 16;
620 unsigned int bx = (b11 + b12 + b21 + b22) >> 2;
621 unsigned int gx = (g11 + g12 + g21 + g22) >> 2;
622 unsigned int rx = (r11 + r12 + r21 + r22) >> 2;
624 unsigned int U = ((ru * rx + gu * gx + bu * bx) >>
RGB2YUV_SHIFT) + 128;
625 unsigned int V = ((rv * rx + gv * gx + bv * bx) >>
RGB2YUV_SHIFT) + 128;
627 ydst1[2 *
i + 0] = Y11;
628 ydst1[2 *
i + 1] = Y12;
629 ydst2[2 *
i + 0] = Y21;
630 ydst2[2 *
i + 1] = Y22;
634 src1 += srcStride * 2;
635 src2 += srcStride * 2;
636 ydst1 += lumStride * 2;
637 ydst2 += lumStride * 2;
645 int src1Stride,
int src2Stride,
int dstStride)
652 dest[2 *
w + 0] =
src1[
w];
653 dest[2 *
w + 1] =
src2[
w];
663 int dst1Stride,
int dst2Stride)
670 dst1[
w] =
src[2 *
w + 0];
671 dst2[
w] =
src[2 *
w + 1];
685 dst[count] =
src[2 * count];
698 dst0[count] =
src[4 * count + 0];
699 dst1[count] =
src[4 * count + 2];
705 uint8_t *dst0, uint8_t *dst1,
int count)
713 dst0[count] = (
src0[4 * count + 0] +
src1[4 * count + 0]) >> 1;
714 dst1[count] = (
src0[4 * count + 2] +
src1[4 * count + 2]) >> 1;
728 dst0[count] =
src[4 * count + 0];
729 dst1[count] =
src[4 * count + 2];
735 uint8_t *dst0, uint8_t *dst1,
int count)
745 dst0[count] = (
src0[4 * count + 0] +
src1[4 * count + 0]) >> 1;
746 dst1[count] = (
src0[4 * count + 2] +
src1[4 * count + 2]) >> 1;
753 int lumStride,
int chromStride,
int srcStride)
758 for (y = 0; y <
height; y++) {
773 int lumStride,
int chromStride,
int srcStride)
778 for (y = 0; y <
height; y++) {
791 int lumStride,
int chromStride,
int srcStride)
796 for (y = 0; y <
height; y++) {
811 int lumStride,
int chromStride,
int srcStride)
816 for (y = 0; y <
height; y++) {
static void yuvPlanartouyvy_c(const uint8_t *ysrc, const uint8_t *usrc, const uint8_t *vsrc, uint8_t *dst, int width, int height, int lumStride, int chromStride, int dstStride, int vertLumPerChroma)
static void rgb32to15_c(const uint8_t *src, uint8_t *dst, int src_size)
void(* rgb32tobgr24)(const uint8_t *src, uint8_t *dst, int src_size)
void(* shuffle_bytes_3012)(const uint8_t *src, uint8_t *dst, int src_size)
static void yuv422ptoyuy2_c(const uint8_t *ysrc, const uint8_t *usrc, const uint8_t *vsrc, uint8_t *dst, int width, int height, int lumStride, int chromStride, int dstStride)
Width should be a multiple of 16.
static void extract_even2_c(const uint8_t *src, uint8_t *dst0, uint8_t *dst1, int count)
void(* yv12toyuy2)(const uint8_t *ysrc, const uint8_t *usrc, const uint8_t *vsrc, uint8_t *dst, int width, int height, int lumStride, int chromStride, int dstStride)
Height should be a multiple of 2 and width should be a multiple of 16.
static void rgb16to15_c(const uint8_t *src, uint8_t *dst, int src_size)
static void yv12touyvy_c(const uint8_t *ysrc, const uint8_t *usrc, const uint8_t *vsrc, uint8_t *dst, int width, int height, int lumStride, int chromStride, int dstStride)
Height should be a multiple of 2 and width should be a multiple of 16 (If this is a problem for anyon...
static void rgb24tobgr24_c(const uint8_t *src, uint8_t *dst, int src_size)
void(* shuffle_bytes_3210)(const uint8_t *src, uint8_t *dst, int src_size)
static const char rgb2yuv[]
static void yuyvtoyuv422_c(uint8_t *ydst, uint8_t *udst, uint8_t *vdst, const uint8_t *src, int width, int height, int lumStride, int chromStride, int srcStride)
void(* rgb32tobgr16)(const uint8_t *src, uint8_t *dst, int src_size)
void(* yuyvtoyuv422)(uint8_t *ydst, uint8_t *udst, uint8_t *vdst, const uint8_t *src, int width, int height, int lumStride, int chromStride, int srcStride)
void(* rgb24tobgr16)(const uint8_t *src, uint8_t *dst, int src_size)
void(* rgb15to32)(const uint8_t *src, uint8_t *dst, int src_size)
void(* yv12touyvy)(const uint8_t *ysrc, const uint8_t *usrc, const uint8_t *vsrc, uint8_t *dst, int width, int height, int lumStride, int chromStride, int dstStride)
Height should be a multiple of 2 and width should be a multiple of 16.
static void rgb32tobgr15_c(const uint8_t *src, uint8_t *dst, int src_size)
void(* rgb32to16)(const uint8_t *src, uint8_t *dst, int src_size)
static void deinterleaveBytes_c(const uint8_t *src, uint8_t *dst1, uint8_t *dst2, int width, int height, int srcStride, int dst1Stride, int dst2Stride)
void(* shuffle_bytes_2130)(const uint8_t *src, uint8_t *dst, int src_size)
static void rgb15to32_c(const uint8_t *src, uint8_t *dst, int src_size)
static void shuffle_bytes_0321_c(const uint8_t *src, uint8_t *dst, int src_size)
#define DEFINE_SHUFFLE_BYTES(name, a, b, c, d)
static void interleaveBytes_c(const uint8_t *src1, const uint8_t *src2, uint8_t *dest, int width, int height, int src1Stride, int src2Stride, int dstStride)
static void extract_odd2avg_c(const uint8_t *src0, const uint8_t *src1, uint8_t *dst0, uint8_t *dst1, int count)
void ff_rgb24toyv12_c(const uint8_t *src, uint8_t *ydst, uint8_t *udst, uint8_t *vdst, int width, int height, int lumStride, int chromStride, int srcStride, const int32_t *rgb2yuv)
width should be a multiple of 2.
static void rgb32to16_c(const uint8_t *src, uint8_t *dst, int src_size)
static void rgb24to15_c(const uint8_t *src, uint8_t *dst, int src_size)
void(* rgb16tobgr24)(const uint8_t *src, uint8_t *dst, int src_size)
static void rgb15to16_c(const uint8_t *src, uint8_t *dst, int src_size)
static void rgb24tobgr32_c(const uint8_t *src, uint8_t *dst, int src_size)
#define AV_CEIL_RSHIFT(a, b)
static void rgb16to32_c(const uint8_t *src, uint8_t *dst, int src_size)
void(* shuffle_bytes_1230)(const uint8_t *src, uint8_t *dst, int src_size)
void(* rgb15tobgr24)(const uint8_t *src, uint8_t *dst, int src_size)
static void extract_odd2_c(const uint8_t *src, uint8_t *dst0, uint8_t *dst1, int count)
void(* yuv422ptoyuy2)(const uint8_t *ysrc, const uint8_t *usrc, const uint8_t *vsrc, uint8_t *dst, int width, int height, int lumStride, int chromStride, int dstStride)
Width should be a multiple of 16.
void(* shuffle_bytes_2103)(const uint8_t *src, uint8_t *dst, int src_size)
void(* rgb32tobgr15)(const uint8_t *src, uint8_t *dst, int src_size)
void(* interleaveBytes)(const uint8_t *src1, const uint8_t *src2, uint8_t *dst, int width, int height, int src1Stride, int src2Stride, int dstStride)
static void rgb24to16_c(const uint8_t *src, uint8_t *dst, int src_size)
void(* shuffle_bytes_3102)(const uint8_t *src, uint8_t *dst, int src_size)
static void uyvytoyuv422_c(uint8_t *ydst, uint8_t *udst, uint8_t *vdst, const uint8_t *src, int width, int height, int lumStride, int chromStride, int srcStride)
void(* rgb16to15)(const uint8_t *src, uint8_t *dst, int src_size)
static void yv12toyuy2_c(const uint8_t *ysrc, const uint8_t *usrc, const uint8_t *vsrc, uint8_t *dst, int width, int height, int lumStride, int chromStride, int dstStride)
Height should be a multiple of 2 and width should be a multiple of 16.
static void shuffle_bytes_2103_c(const uint8_t *src, uint8_t *dst, int src_size)
static void rgb32tobgr16_c(const uint8_t *src, uint8_t *dst, int src_size)
void(* yuyvtoyuv420)(uint8_t *ydst, uint8_t *udst, uint8_t *vdst, const uint8_t *src, int width, int height, int lumStride, int chromStride, int srcStride)
void(* rgb24tobgr32)(const uint8_t *src, uint8_t *dst, int src_size)
uint8_t ptrdiff_t const uint8_t ptrdiff_t int intptr_t intptr_t int int16_t * dst
#define i(width, name, range_min, range_max)
void(* shuffle_bytes_0321)(const uint8_t *src, uint8_t *dst, int src_size)
static void uyvytoyuv420_c(uint8_t *ydst, uint8_t *udst, uint8_t *vdst, const uint8_t *src, int width, int height, int lumStride, int chromStride, int srcStride)
void(* rgb24to16)(const uint8_t *src, uint8_t *dst, int src_size)
static void rgb24tobgr16_c(const uint8_t *src, uint8_t *dst, int src_size)
void(* uyvytoyuv422)(uint8_t *ydst, uint8_t *udst, uint8_t *vdst, const uint8_t *src, int width, int height, int lumStride, int chromStride, int srcStride)
void(* ff_rgb24toyv12)(const uint8_t *src, uint8_t *ydst, uint8_t *udst, uint8_t *vdst, int width, int height, int lumStride, int chromStride, int srcStride, const int32_t *rgb2yuv)
Height should be a multiple of 2 and width should be a multiple of 2.
void(* rgb24to15)(const uint8_t *src, uint8_t *dst, int src_size)
static void extract_even_c(const uint8_t *src, uint8_t *dst, int count)
void(* rgb32to15)(const uint8_t *src, uint8_t *dst, int src_size)
static void rgb32tobgr24_c(const uint8_t *src, uint8_t *dst, int src_size)
void(* deinterleaveBytes)(const uint8_t *src, uint8_t *dst1, uint8_t *dst2, int width, int height, int srcStride, int dst1Stride, int dst2Stride)
static void yuv422ptouyvy_c(const uint8_t *ysrc, const uint8_t *usrc, const uint8_t *vsrc, uint8_t *dst, int width, int height, int lumStride, int chromStride, int dstStride)
Width should be a multiple of 16.
static av_cold void rgb2rgb_init_c(void)
void(* uyvytoyuv420)(uint8_t *ydst, uint8_t *udst, uint8_t *vdst, const uint8_t *src, int width, int height, int lumStride, int chromStride, int srcStride)
void(* rgb16to32)(const uint8_t *src, uint8_t *dst, int src_size)
static void rgb24tobgr15_c(const uint8_t *src, uint8_t *dst, int src_size)
void(* rgb24tobgr15)(const uint8_t *src, uint8_t *dst, int src_size)
void(* shuffle_bytes_2013)(const uint8_t *src, uint8_t *dst, int src_size)
void(* rgb15to16)(const uint8_t *src, uint8_t *dst, int src_size)
void(* shuffle_bytes_1203)(const uint8_t *src, uint8_t *dst, int src_size)
void(* yuv422ptouyvy)(const uint8_t *ysrc, const uint8_t *usrc, const uint8_t *vsrc, uint8_t *dst, int width, int height, int lumStride, int chromStride, int dstStride)
Width should be a multiple of 16.
void(* rgb24tobgr24)(const uint8_t *src, uint8_t *dst, int src_size)
static void extract_even2avg_c(const uint8_t *src0, const uint8_t *src1, uint8_t *dst0, uint8_t *dst1, int count)
static void yuyvtoyuv420_c(uint8_t *ydst, uint8_t *udst, uint8_t *vdst, const uint8_t *src, int width, int height, int lumStride, int chromStride, int srcStride)
static void rgb15tobgr24_c(const uint8_t *src, uint8_t *dst, int src_size)
void(* planar2x)(const uint8_t *src, uint8_t *dst, int width, int height, int srcStride, int dstStride)
static void planar2x_c(const uint8_t *src, uint8_t *dst, int srcWidth, int srcHeight, int srcStride, int dstStride)
static void yuvPlanartoyuy2_c(const uint8_t *ysrc, const uint8_t *usrc, const uint8_t *vsrc, uint8_t *dst, int width, int height, int lumStride, int chromStride, int dstStride, int vertLumPerChroma)
static void rgb16tobgr24_c(const uint8_t *src, uint8_t *dst, int src_size)