36 const uint8_t *end = s + src_size;
60 const uint8_t *end = s + src_size;
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);
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;
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;
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;
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;
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;
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;
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;
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;
233 const uint8_t *end = s + src_size;
239 *d++ = (b >> 3) | ((g & 0xF8) << 2) | ((r & 0xF8) << 7);
268 const uint16_t *s = (
const uint16_t *)src;
269 const uint16_t *end = s + src_size / 2;
272 register uint16_t bgr = *s++;
273 *d++ = (bgr & 0x1F) << 3;
274 *d++ = (bgr & 0x3E0) >> 2;
275 *d++ = (bgr & 0x7C00) >> 7;
283 const uint16_t *s = (
const uint16_t *)src;
284 const uint16_t *end = s + src_size / 2;
287 register uint16_t bgr = *s++;
288 *d++ = (bgr & 0x1F) << 3;
289 *d++ = (bgr & 0x7E0) >> 3;
290 *d++ = (bgr & 0xF800) >> 8;
297 const uint16_t *s = (
const uint16_t *)src;
298 const uint16_t *end = s + src_size / 2;
301 register uint16_t bgr = *s++;
304 *d++ = (bgr & 0x7C00) >> 7;
305 *d++ = (bgr & 0x3E0) >> 2;
306 *d++ = (bgr & 0x1F) << 3;
308 *d++ = (bgr & 0x1F) << 3;
309 *d++ = (bgr & 0x3E0) >> 2;
310 *d++ = (bgr & 0x7C00) >> 7;
319 const uint16_t *s = (
const uint16_t *)src;
320 const uint16_t *end = s + src_size / 2;
323 register uint16_t bgr = *s++;
326 *d++ = (bgr & 0xF800) >> 8;
327 *d++ = (bgr & 0x7E0) >> 3;
328 *d++ = (bgr & 0x1F) << 3;
330 *d++ = (bgr & 0x1F) << 3;
331 *d++ = (bgr & 0x7E0) >> 3;
332 *d++ = (bgr & 0xF800) >> 8;
341 int idx = 15 - src_size;
345 for (; idx < 15; idx += 4) {
346 register int v = *(
const uint32_t *)&s[idx],
g = v & 0xff00ff00;
348 *(uint32_t *)&d[idx] = (v >> 16) +
g + (v << 16);
356 for (i = 0; i < src_size; i += 3) {
357 register uint8_t x = src[i + 2];
358 dst[i + 1] = src[i + 1];
359 dst[i + 2] = src[i + 0];
367 int lumStride,
int chromStride,
368 int dstStride,
int vertLumPerChroma)
371 const int chromWidth = width >> 1;
373 for (y = 0; y <
height; y++) {
375 uint64_t *ldst = (uint64_t *)dst;
376 const uint8_t *yc = ysrc, *uc = usrc, *vc = vsrc;
377 for (i = 0; i < chromWidth; i += 2) {
378 uint64_t k = yc[0] + (uc[0] << 8) +
379 (yc[1] << 16) + ((unsigned) vc[0] << 24);
380 uint64_t l = yc[2] + (uc[1] << 8) +
381 (yc[3] << 16) + ((unsigned) vc[1] << 24);
382 *ldst++ = k + (l << 32);
390 const uint8_t *yc = ysrc, *uc = usrc, *vc = vsrc;
392 for (i = 0; i < chromWidth; i++) {
394 *idst++ = (yc[0] << 24) + (uc[0] << 16) +
395 (yc[1] << 8) + (vc[0] << 0);
397 *idst++ = yc[0] + (uc[0] << 8) +
398 (yc[1] << 16) + (vc[0] << 24);
405 if ((y & (vertLumPerChroma - 1)) == vertLumPerChroma - 1) {
421 int chromStride,
int dstStride)
425 chromStride, dstStride, 2);
431 int lumStride,
int chromStride,
432 int dstStride,
int vertLumPerChroma)
435 const int chromWidth = width >> 1;
437 for (y = 0; y <
height; y++) {
439 uint64_t *ldst = (uint64_t *)dst;
440 const uint8_t *yc = ysrc, *uc = usrc, *vc = vsrc;
441 for (i = 0; i < chromWidth; i += 2) {
442 uint64_t k = uc[0] + (yc[0] << 8) +
443 (vc[0] << 16) + ((unsigned) yc[1] << 24);
444 uint64_t l = uc[1] + (yc[2] << 8) +
445 (vc[1] << 16) + ((unsigned) yc[3] << 24);
446 *ldst++ = k + (l << 32);
454 const uint8_t *yc = ysrc, *uc = usrc, *vc = vsrc;
456 for (i = 0; i < chromWidth; i++) {
458 *idst++ = (uc[0] << 24) + (yc[0] << 16) +
459 (vc[0] << 8) + (yc[1] << 0);
461 *idst++ = uc[0] + (yc[0] << 8) +
462 (vc[0] << 16) + (yc[1] << 24);
469 if ((y & (vertLumPerChroma - 1)) == vertLumPerChroma - 1) {
485 int chromStride,
int dstStride)
489 chromStride, dstStride, 2);
498 int chromStride,
int dstStride)
501 chromStride, dstStride, 1);
510 int chromStride,
int dstStride)
513 chromStride, dstStride, 1);
523 int chromStride,
int srcStride)
526 const int chromWidth = width >> 1;
528 for (y = 0; y <
height; y += 2) {
530 for (i = 0; i < chromWidth; i++) {
531 ydst[2 * i + 0] = src[4 * i + 0];
532 udst[i] = src[4 * i + 1];
533 ydst[2 * i + 1] = src[4 * i + 2];
534 vdst[i] = src[4 * i + 3];
539 for (i = 0; i < chromWidth; i++) {
540 ydst[2 * i + 0] = src[4 * i + 0];
541 ydst[2 * i + 1] = src[4 * i + 2];
551 int srcHeight,
int srcStride,
int dstStride)
558 for (x = 0; x < srcWidth - 1; x++) {
559 dst[2 * x + 1] = (3 * src[x] + src[x + 1]) >> 2;
560 dst[2 * x + 2] = (src[x] + 3 * src[x + 1]) >> 2;
562 dst[2 * srcWidth - 1] = src[srcWidth - 1];
566 for (y = 1; y < srcHeight; y++) {
567 const int mmxSize = 1;
569 dst[0] = (src[0] * 3 + src[srcStride]) >> 2;
570 dst[dstStride] = (src[0] + 3 * src[srcStride]) >> 2;
572 for (x = mmxSize - 1; x < srcWidth - 1; x++) {
573 dst[2 * x + 1] = (src[x + 0] * 3 + src[x + srcStride + 1]) >> 2;
574 dst[2 * x + dstStride + 2] = (src[x + 0] + 3 * src[x + srcStride + 1]) >> 2;
575 dst[2 * x + dstStride + 1] = (src[x + 1] + 3 * src[x + srcStride]) >> 2;
576 dst[2 * x + 2] = (src[x + 1] * 3 + src[x + srcStride]) >> 2;
578 dst[srcWidth * 2 - 1] = (src[srcWidth - 1] * 3 + src[srcWidth - 1 + srcStride]) >> 2;
579 dst[srcWidth * 2 - 1 + dstStride] = (src[srcWidth - 1] + 3 * src[srcWidth - 1 + srcStride]) >> 2;
581 dst += dstStride * 2;
588 for (x = 0; x < srcWidth - 1; x++) {
589 dst[2 * x + 1] = (src[x] * 3 + src[x + 1]) >> 2;
590 dst[2 * x + 2] = (src[x] + 3 * src[x + 1]) >> 2;
592 dst[2 * srcWidth - 1] = src[srcWidth - 1];
604 int chromStride,
int srcStride)
607 const int chromWidth = width >> 1;
609 for (y = 0; y <
height; y += 2) {
611 for (i = 0; i < chromWidth; i++) {
612 udst[i] = src[4 * i + 0];
613 ydst[2 * i + 0] = src[4 * i + 1];
614 vdst[i] = src[4 * i + 2];
615 ydst[2 * i + 1] = src[4 * i + 3];
620 for (i = 0; i < chromWidth; i++) {
621 ydst[2 * i + 0] = src[4 * i + 1];
622 ydst[2 * i + 1] = src[4 * i + 3];
640 int chromStride,
int srcStride)
643 const int chromWidth = width >> 1;
645 for (y = 0; y <
height; y += 2) {
647 for (i = 0; i < chromWidth; i++) {
648 unsigned int b = src[6 * i + 0];
649 unsigned int g = src[6 * i + 1];
650 unsigned int r = src[6 * i + 2];
670 for (i = 0; i < chromWidth; i++) {
671 unsigned int b = src[6 * i + 0];
672 unsigned int g = src[6 * i + 1];
673 unsigned int r = src[6 * i + 2];
695 int src1Stride,
int src2Stride,
int dstStride)
699 for (h = 0; h <
height; h++) {
701 for (w = 0; w <
width; w++) {
702 dest[2 * w + 0] = src1[w];
703 dest[2 * w + 1] = src2[w];
713 int dst1Stride,
int dst2Stride)
717 for (h = 0; h <
height; h++) {
719 for (w = 0; w <
width; w++) {
720 dst1[w] = src[2 * w + 0];
721 dst2[w] = src[2 * w + 1];
732 int srcStride1,
int srcStride2,
733 int dstStride1,
int dstStride2)
739 for (y = 0; y < h; y++) {
740 const uint8_t *s1 = src1 + srcStride1 * (y >> 1);
741 uint8_t *d = dst1 + dstStride1 * y;
742 for (x = 0; x < w; x++)
743 d[2 * x] = d[2 * x + 1] = s1[x];
745 for (y = 0; y < h; y++) {
746 const uint8_t *s2 = src2 + srcStride2 * (y >> 1);
747 uint8_t *d = dst2 + dstStride2 * y;
748 for (x = 0; x < w; x++)
749 d[2 * x] = d[2 * x + 1] = s2[x];
756 int srcStride1,
int srcStride2,
757 int srcStride3,
int dstStride)
763 for (y = 0; y < h; y++) {
764 const uint8_t *yp = src1 + srcStride1 * y;
765 const uint8_t *up = src2 + srcStride2 * (y >> 2);
766 const uint8_t *vp = src3 + srcStride3 * (y >> 2);
767 uint8_t *d = dst + dstStride * y;
768 for (x = 0; x < w; x++) {
769 const int x2 = x << 2;
770 d[8 * x + 0] = yp[x2];
771 d[8 * x + 1] = up[x];
772 d[8 * x + 2] = yp[x2 + 1];
773 d[8 * x + 3] = vp[x];
774 d[8 * x + 4] = yp[x2 + 2];
775 d[8 * x + 5] = up[x];
776 d[8 * x + 6] = yp[x2 + 3];
777 d[8 * x + 7] = vp[x];
788 dst[count] = src[2 * count];
801 dst0[count] = src[4 * count + 0];
802 dst1[count] = src[4 * count + 2];
816 dst0[count] = (src0[4 * count + 0] + src1[4 * count + 0]) >> 1;
817 dst1[count] = (src0[4 * count + 2] + src1[4 * count + 2]) >> 1;
831 dst0[count] = src[4 * count + 0];
832 dst1[count] = src[4 * count + 2];
848 dst0[count] = (src0[4 * count + 0] + src1[4 * count + 0]) >> 1;
849 dst1[count] = (src0[4 * count + 2] + src1[4 * count + 2]) >> 1;
856 int lumStride,
int chromStride,
int srcStride)
859 const int chromWidth = -((-
width) >> 1);
861 for (y = 0; y <
height; y++) {
876 int lumStride,
int chromStride,
int srcStride)
879 const int chromWidth = -((-
width) >> 1);
881 for (y = 0; y <
height; y++) {
894 int lumStride,
int chromStride,
int srcStride)
897 const int chromWidth = -((-
width) >> 1);
899 for (y = 0; y <
height; y++) {
914 int lumStride,
int chromStride,
int srcStride)
917 const int chromWidth = -((-
width) >> 1);
919 for (y = 0; y <
height; y++) {
static void RENAME() rgb32tobgr15(const uint8_t *src, uint8_t *dst, int src_size)
static void RENAME() yuyvtoyuv422(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 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)
static void RENAME() vu9_to_vu12(const uint8_t *src1, const uint8_t *src2, uint8_t *dst1, uint8_t *dst2, int width, int height, int srcStride1, int srcStride2, int dstStride1, int dstStride2)
static void RENAME() uyvytoyuv422(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 uyvytoyv12_c(const uint8_t *src, uint8_t *ydst, uint8_t *udst, uint8_t *vdst, int width, int height, int lumStride, int chromStride, int srcStride)
Height should be a multiple of 2 and width should be a multiple of 16.
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 RENAME() rgb16tobgr24(const uint8_t *src, uint8_t *dst, int src_size)
static void extract_odd2avg_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 RENAME() rgb24toyv12(const uint8_t *src, uint8_t *ydst, uint8_t *udst, uint8_t *vdst, int width, int height, int lumStride, int chromStride, int srcStride)
Height should be a multiple of 2 and width should be a multiple of 2.
static void RENAME() rgb32tobgr16(const uint8_t *src, uint8_t *dst, int src_size)
static void RENAME() rgb24tobgr24(const uint8_t *src, uint8_t *dst, int src_size)
static void planar2x_c(const uint8_t *src, uint8_t *dst, int srcWidth, int srcHeight, int srcStride, int dstStride)
static void rgb16to32_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)
static void RENAME() 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.
static void rgb15tobgr24_c(const uint8_t *src, uint8_t *dst, int src_size)
static void RENAME() rgb15to32(const uint8_t *src, uint8_t *dst, int src_size)
static void vu9_to_vu12_c(const uint8_t *src1, const uint8_t *src2, uint8_t *dst1, uint8_t *dst2, int width, int height, int srcStride1, int srcStride2, int dstStride1, int dstStride2)
static void yuy2toyv12_c(const uint8_t *src, uint8_t *ydst, uint8_t *udst, uint8_t *vdst, int width, int height, int lumStride, int chromStride, int srcStride)
Height should be a multiple of 2 and width should be a multiple of 16.
Macro definitions for various function/variable attributes.
static void rgb16tobgr24_c(const uint8_t *src, uint8_t *dst, int src_size)
static void rgb24tobgr16_c(const uint8_t *src, uint8_t *dst, int src_size)
static void RENAME() yuy2toyv12(const uint8_t *src, uint8_t *ydst, uint8_t *udst, uint8_t *vdst, int width, int height, int lumStride, int chromStride, int srcStride)
Height should be a multiple of 2 and width should be a multiple of 16.
static void extract_even_c(const uint8_t *src, uint8_t *dst, int count)
void 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)
Height should be a multiple of 2 and width should be a multiple of 2.
static void RENAME() rgb24tobgr15(const uint8_t *src, uint8_t *dst, int src_size)
static void rgb16to15_c(const uint8_t *src, uint8_t *dst, int src_size)
static void RENAME() rgb24tobgr16(const uint8_t *src, uint8_t *dst, int src_size)
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 av_cold void rgb2rgb_init_c(void)
static void RENAME() uyvytoyuv420(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 RENAME() shuffle_bytes_2103(const uint8_t *src, uint8_t *dst, int src_size)
static void RENAME() 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 (If this is a problem for anyon...
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 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 rgb24to16_c(const uint8_t *src, uint8_t *dst, int src_size)
static void extract_even2_c(const uint8_t *src, uint8_t *dst0, uint8_t *dst1, int count)
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 RENAME() rgb24to15(const uint8_t *src, uint8_t *dst, int src_size)
static void RENAME() rgb15to16(const uint8_t *src, uint8_t *dst, int src_size)
static void rgb24tobgr24_c(const uint8_t *src, uint8_t *dst, int src_size)
static void RENAME() rgb16to15(const uint8_t *src, uint8_t *dst, int src_size)
static void RENAME() rgb32to16(const uint8_t *src, uint8_t *dst, int src_size)
static void rgb32tobgr24_c(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)
static void RENAME() 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.
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)
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 void deinterleaveBytes_c(const uint8_t *src, uint8_t *dst1, uint8_t *dst2, int width, int height, int srcStride, int dst1Stride, int dst2Stride)
void(* deinterleaveBytes)(const uint8_t *src, uint8_t *dst1, uint8_t *dst2, int width, int height, int srcStride, int dst1Stride, int dst2Stride)
static void RENAME() rgb16to32(const uint8_t *src, uint8_t *dst, int src_size)
static void yvu9_to_yuy2_c(const uint8_t *src1, const uint8_t *src2, const uint8_t *src3, uint8_t *dst, int width, int height, int srcStride1, int srcStride2, int srcStride3, int dstStride)
static void rgb15to32_c(const uint8_t *src, uint8_t *dst, int src_size)
static void RENAME() rgb15tobgr24(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 RENAME() rgb32tobgr24(const uint8_t *src, uint8_t *dst, int src_size)
static void rgb32to16_c(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 extract_odd2_c(const uint8_t *src, uint8_t *dst0, uint8_t *dst1, int count)
static void RENAME() yuyvtoyuv420(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 rgb32to15_c(const uint8_t *src, uint8_t *dst, int src_size)
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 rgb24tobgr15_c(const uint8_t *src, uint8_t *dst, int src_size)
static void RENAME() yvu9_to_yuy2(const uint8_t *src1, const uint8_t *src2, const uint8_t *src3, uint8_t *dst, int width, int height, int srcStride1, int srcStride2, int srcStride3, int dstStride)
static void rgb32tobgr15_c(const uint8_t *src, uint8_t *dst, int src_size)
static void RENAME() rgb24tobgr32(const uint8_t *src, uint8_t *dst, int src_size)
static void RENAME() 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 shuffle_bytes_2103_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 rgb24to15_c(const uint8_t *src, uint8_t *dst, int src_size)
static void RENAME() rgb24to16(const uint8_t *src, uint8_t *dst, int src_size)
static void rgb32tobgr16_c(const uint8_t *src, uint8_t *dst, int src_size)
static void RENAME() rgb32to15(const uint8_t *src, uint8_t *dst, int src_size)
static void RENAME() interleaveBytes(const uint8_t *src1, const uint8_t *src2, uint8_t *dest, int width, int height, int src1Stride, int src2Stride, int dstStride)