|
|
@ -26,7 +26,7 @@ |
|
|
|
|
|
|
|
|
|
|
|
#include <stddef.h> |
|
|
|
#include <stddef.h> |
|
|
|
|
|
|
|
|
|
|
|
static inline void rgb24tobgr32_c(const uint8_t *src, uint8_t *dst, long src_size) |
|
|
|
static inline void rgb24tobgr32_c(const uint8_t *src, uint8_t *dst, int src_size) |
|
|
|
{ |
|
|
|
{ |
|
|
|
uint8_t *dest = dst; |
|
|
|
uint8_t *dest = dst; |
|
|
|
const uint8_t *s = src; |
|
|
|
const uint8_t *s = src; |
|
|
@ -50,7 +50,7 @@ static inline void rgb24tobgr32_c(const uint8_t *src, uint8_t *dst, long src_siz |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
static inline void rgb32tobgr24_c(const uint8_t *src, uint8_t *dst, long src_size) |
|
|
|
static inline void rgb32tobgr24_c(const uint8_t *src, uint8_t *dst, int src_size) |
|
|
|
{ |
|
|
|
{ |
|
|
|
uint8_t *dest = dst; |
|
|
|
uint8_t *dest = dst; |
|
|
|
const uint8_t *s = src; |
|
|
|
const uint8_t *s = src; |
|
|
@ -81,7 +81,7 @@ static inline void rgb32tobgr24_c(const uint8_t *src, uint8_t *dst, long src_siz |
|
|
|
MMX2, 3DNOW optimization by Nick Kurshev |
|
|
|
MMX2, 3DNOW optimization by Nick Kurshev |
|
|
|
32-bit C version, and and&add trick by Michael Niedermayer |
|
|
|
32-bit C version, and and&add trick by Michael Niedermayer |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
static inline void rgb15to16_c(const uint8_t *src, uint8_t *dst, long src_size) |
|
|
|
static inline void rgb15to16_c(const uint8_t *src, uint8_t *dst, int src_size) |
|
|
|
{ |
|
|
|
{ |
|
|
|
register const uint8_t* s=src; |
|
|
|
register const uint8_t* s=src; |
|
|
|
register uint8_t* d=dst; |
|
|
|
register uint8_t* d=dst; |
|
|
@ -101,7 +101,7 @@ static inline void rgb15to16_c(const uint8_t *src, uint8_t *dst, long src_size) |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
static inline void rgb16to15_c(const uint8_t *src, uint8_t *dst, long src_size) |
|
|
|
static inline void rgb16to15_c(const uint8_t *src, uint8_t *dst, int src_size) |
|
|
|
{ |
|
|
|
{ |
|
|
|
register const uint8_t* s=src; |
|
|
|
register const uint8_t* s=src; |
|
|
|
register uint8_t* d=dst; |
|
|
|
register uint8_t* d=dst; |
|
|
@ -122,7 +122,7 @@ static inline void rgb16to15_c(const uint8_t *src, uint8_t *dst, long src_size) |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
static inline void rgb32to16_c(const uint8_t *src, uint8_t *dst, long src_size) |
|
|
|
static inline void rgb32to16_c(const uint8_t *src, uint8_t *dst, int src_size) |
|
|
|
{ |
|
|
|
{ |
|
|
|
const uint8_t *s = src; |
|
|
|
const uint8_t *s = src; |
|
|
|
const uint8_t *end; |
|
|
|
const uint8_t *end; |
|
|
@ -135,7 +135,7 @@ static inline void rgb32to16_c(const uint8_t *src, uint8_t *dst, long src_size) |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
static inline void rgb32tobgr16_c(const uint8_t *src, uint8_t *dst, long src_size) |
|
|
|
static inline void rgb32tobgr16_c(const uint8_t *src, uint8_t *dst, int src_size) |
|
|
|
{ |
|
|
|
{ |
|
|
|
const uint8_t *s = src; |
|
|
|
const uint8_t *s = src; |
|
|
|
const uint8_t *end; |
|
|
|
const uint8_t *end; |
|
|
@ -147,7 +147,7 @@ static inline void rgb32tobgr16_c(const uint8_t *src, uint8_t *dst, long src_siz |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
static inline void rgb32to15_c(const uint8_t *src, uint8_t *dst, long src_size) |
|
|
|
static inline void rgb32to15_c(const uint8_t *src, uint8_t *dst, int src_size) |
|
|
|
{ |
|
|
|
{ |
|
|
|
const uint8_t *s = src; |
|
|
|
const uint8_t *s = src; |
|
|
|
const uint8_t *end; |
|
|
|
const uint8_t *end; |
|
|
@ -159,7 +159,7 @@ static inline void rgb32to15_c(const uint8_t *src, uint8_t *dst, long src_size) |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
static inline void rgb32tobgr15_c(const uint8_t *src, uint8_t *dst, long src_size) |
|
|
|
static inline void rgb32tobgr15_c(const uint8_t *src, uint8_t *dst, int src_size) |
|
|
|
{ |
|
|
|
{ |
|
|
|
const uint8_t *s = src; |
|
|
|
const uint8_t *s = src; |
|
|
|
const uint8_t *end; |
|
|
|
const uint8_t *end; |
|
|
@ -171,7 +171,7 @@ static inline void rgb32tobgr15_c(const uint8_t *src, uint8_t *dst, long src_siz |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
static inline void rgb24tobgr16_c(const uint8_t *src, uint8_t *dst, long src_size) |
|
|
|
static inline void rgb24tobgr16_c(const uint8_t *src, uint8_t *dst, int src_size) |
|
|
|
{ |
|
|
|
{ |
|
|
|
const uint8_t *s = src; |
|
|
|
const uint8_t *s = src; |
|
|
|
const uint8_t *end; |
|
|
|
const uint8_t *end; |
|
|
@ -185,7 +185,7 @@ static inline void rgb24tobgr16_c(const uint8_t *src, uint8_t *dst, long src_siz |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
static inline void rgb24to16_c(const uint8_t *src, uint8_t *dst, long src_size) |
|
|
|
static inline void rgb24to16_c(const uint8_t *src, uint8_t *dst, int src_size) |
|
|
|
{ |
|
|
|
{ |
|
|
|
const uint8_t *s = src; |
|
|
|
const uint8_t *s = src; |
|
|
|
const uint8_t *end; |
|
|
|
const uint8_t *end; |
|
|
@ -199,7 +199,7 @@ static inline void rgb24to16_c(const uint8_t *src, uint8_t *dst, long src_size) |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
static inline void rgb24tobgr15_c(const uint8_t *src, uint8_t *dst, long src_size) |
|
|
|
static inline void rgb24tobgr15_c(const uint8_t *src, uint8_t *dst, int src_size) |
|
|
|
{ |
|
|
|
{ |
|
|
|
const uint8_t *s = src; |
|
|
|
const uint8_t *s = src; |
|
|
|
const uint8_t *end; |
|
|
|
const uint8_t *end; |
|
|
@ -213,7 +213,7 @@ static inline void rgb24tobgr15_c(const uint8_t *src, uint8_t *dst, long src_siz |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
static inline void rgb24to15_c(const uint8_t *src, uint8_t *dst, long src_size) |
|
|
|
static inline void rgb24to15_c(const uint8_t *src, uint8_t *dst, int src_size) |
|
|
|
{ |
|
|
|
{ |
|
|
|
const uint8_t *s = src; |
|
|
|
const uint8_t *s = src; |
|
|
|
const uint8_t *end; |
|
|
|
const uint8_t *end; |
|
|
@ -248,7 +248,7 @@ static inline void rgb24to15_c(const uint8_t *src, uint8_t *dst, long src_size) |
|
|
|
| |
|
|
|
| |
|
|
|
original bits |
|
|
|
original bits |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
static inline void rgb15tobgr24_c(const uint8_t *src, uint8_t *dst, long src_size) |
|
|
|
static inline void rgb15tobgr24_c(const uint8_t *src, uint8_t *dst, int src_size) |
|
|
|
{ |
|
|
|
{ |
|
|
|
const uint16_t *end; |
|
|
|
const uint16_t *end; |
|
|
|
uint8_t *d = dst; |
|
|
|
uint8_t *d = dst; |
|
|
@ -263,7 +263,7 @@ static inline void rgb15tobgr24_c(const uint8_t *src, uint8_t *dst, long src_siz |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
static inline void rgb16tobgr24_c(const uint8_t *src, uint8_t *dst, long src_size) |
|
|
|
static inline void rgb16tobgr24_c(const uint8_t *src, uint8_t *dst, int src_size) |
|
|
|
{ |
|
|
|
{ |
|
|
|
const uint16_t *end; |
|
|
|
const uint16_t *end; |
|
|
|
uint8_t *d = (uint8_t *)dst; |
|
|
|
uint8_t *d = (uint8_t *)dst; |
|
|
@ -278,7 +278,7 @@ static inline void rgb16tobgr24_c(const uint8_t *src, uint8_t *dst, long src_siz |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
static inline void rgb15to32_c(const uint8_t *src, uint8_t *dst, long src_size) |
|
|
|
static inline void rgb15to32_c(const uint8_t *src, uint8_t *dst, int src_size) |
|
|
|
{ |
|
|
|
{ |
|
|
|
const uint16_t *end; |
|
|
|
const uint16_t *end; |
|
|
|
uint8_t *d = dst; |
|
|
|
uint8_t *d = dst; |
|
|
@ -301,7 +301,7 @@ static inline void rgb15to32_c(const uint8_t *src, uint8_t *dst, long src_size) |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
static inline void rgb16to32_c(const uint8_t *src, uint8_t *dst, long src_size) |
|
|
|
static inline void rgb16to32_c(const uint8_t *src, uint8_t *dst, int src_size) |
|
|
|
{ |
|
|
|
{ |
|
|
|
const uint16_t *end; |
|
|
|
const uint16_t *end; |
|
|
|
uint8_t *d = dst; |
|
|
|
uint8_t *d = dst; |
|
|
@ -324,7 +324,7 @@ static inline void rgb16to32_c(const uint8_t *src, uint8_t *dst, long src_size) |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
static inline void shuffle_bytes_2103_c(const uint8_t *src, uint8_t *dst, long src_size) |
|
|
|
static inline void shuffle_bytes_2103_c(const uint8_t *src, uint8_t *dst, int src_size) |
|
|
|
{ |
|
|
|
{ |
|
|
|
int idx = 15 - src_size; |
|
|
|
int idx = 15 - src_size; |
|
|
|
const uint8_t *s = src-idx; |
|
|
|
const uint8_t *s = src-idx; |
|
|
@ -336,7 +336,7 @@ static inline void shuffle_bytes_2103_c(const uint8_t *src, uint8_t *dst, long s |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
static inline void rgb24tobgr24_c(const uint8_t *src, uint8_t *dst, long src_size) |
|
|
|
static inline void rgb24tobgr24_c(const uint8_t *src, uint8_t *dst, int src_size) |
|
|
|
{ |
|
|
|
{ |
|
|
|
unsigned i; |
|
|
|
unsigned i; |
|
|
|
for (i=0; i<src_size; i+=3) { |
|
|
|
for (i=0; i<src_size; i+=3) { |
|
|
@ -350,11 +350,11 @@ static inline void rgb24tobgr24_c(const uint8_t *src, uint8_t *dst, long src_siz |
|
|
|
|
|
|
|
|
|
|
|
static inline void yuvPlanartoyuy2_c(const uint8_t *ysrc, const uint8_t *usrc, |
|
|
|
static inline void yuvPlanartoyuy2_c(const uint8_t *ysrc, const uint8_t *usrc, |
|
|
|
const uint8_t *vsrc, uint8_t *dst, |
|
|
|
const uint8_t *vsrc, uint8_t *dst, |
|
|
|
long width, long height, |
|
|
|
int width, int height, |
|
|
|
long lumStride, long chromStride, |
|
|
|
int lumStride, int chromStride, |
|
|
|
long dstStride, long vertLumPerChroma) |
|
|
|
int dstStride, int vertLumPerChroma) |
|
|
|
{ |
|
|
|
{ |
|
|
|
long y; |
|
|
|
int y; |
|
|
|
const int chromWidth = width >> 1; |
|
|
|
const int chromWidth = width >> 1; |
|
|
|
for (y=0; y<height; y++) { |
|
|
|
for (y=0; y<height; y++) { |
|
|
|
#if HAVE_FAST_64BIT |
|
|
|
#if HAVE_FAST_64BIT |
|
|
@ -404,9 +404,9 @@ static inline void yuvPlanartoyuy2_c(const uint8_t *ysrc, const uint8_t *usrc, |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
static inline void yv12toyuy2_c(const uint8_t *ysrc, const uint8_t *usrc, |
|
|
|
static inline void yv12toyuy2_c(const uint8_t *ysrc, const uint8_t *usrc, |
|
|
|
const uint8_t *vsrc, uint8_t *dst, |
|
|
|
const uint8_t *vsrc, uint8_t *dst, |
|
|
|
long width, long height, |
|
|
|
int width, int height, |
|
|
|
long lumStride, long chromStride, |
|
|
|
int lumStride, int chromStride, |
|
|
|
long dstStride) |
|
|
|
int dstStride) |
|
|
|
{ |
|
|
|
{ |
|
|
|
//FIXME interpolate chroma
|
|
|
|
//FIXME interpolate chroma
|
|
|
|
yuvPlanartoyuy2_c(ysrc, usrc, vsrc, dst, width, height, lumStride, |
|
|
|
yuvPlanartoyuy2_c(ysrc, usrc, vsrc, dst, width, height, lumStride, |
|
|
@ -415,11 +415,11 @@ static inline void yv12toyuy2_c(const uint8_t *ysrc, const uint8_t *usrc, |
|
|
|
|
|
|
|
|
|
|
|
static inline void yuvPlanartouyvy_c(const uint8_t *ysrc, const uint8_t *usrc, |
|
|
|
static inline void yuvPlanartouyvy_c(const uint8_t *ysrc, const uint8_t *usrc, |
|
|
|
const uint8_t *vsrc, uint8_t *dst, |
|
|
|
const uint8_t *vsrc, uint8_t *dst, |
|
|
|
long width, long height, |
|
|
|
int width, int height, |
|
|
|
long lumStride, long chromStride, |
|
|
|
int lumStride, int chromStride, |
|
|
|
long dstStride, long vertLumPerChroma) |
|
|
|
int dstStride, int vertLumPerChroma) |
|
|
|
{ |
|
|
|
{ |
|
|
|
long y; |
|
|
|
int y; |
|
|
|
const int chromWidth = width >> 1; |
|
|
|
const int chromWidth = width >> 1; |
|
|
|
for (y=0; y<height; y++) { |
|
|
|
for (y=0; y<height; y++) { |
|
|
|
#if HAVE_FAST_64BIT |
|
|
|
#if HAVE_FAST_64BIT |
|
|
@ -469,9 +469,9 @@ static inline void yuvPlanartouyvy_c(const uint8_t *ysrc, const uint8_t *usrc, |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
static inline void yv12touyvy_c(const uint8_t *ysrc, const uint8_t *usrc, |
|
|
|
static inline void yv12touyvy_c(const uint8_t *ysrc, const uint8_t *usrc, |
|
|
|
const uint8_t *vsrc, uint8_t *dst, |
|
|
|
const uint8_t *vsrc, uint8_t *dst, |
|
|
|
long width, long height, |
|
|
|
int width, int height, |
|
|
|
long lumStride, long chromStride, |
|
|
|
int lumStride, int chromStride, |
|
|
|
long dstStride) |
|
|
|
int dstStride) |
|
|
|
{ |
|
|
|
{ |
|
|
|
//FIXME interpolate chroma
|
|
|
|
//FIXME interpolate chroma
|
|
|
|
yuvPlanartouyvy_c(ysrc, usrc, vsrc, dst, width, height, lumStride, |
|
|
|
yuvPlanartouyvy_c(ysrc, usrc, vsrc, dst, width, height, lumStride, |
|
|
@ -483,9 +483,9 @@ static inline void yv12touyvy_c(const uint8_t *ysrc, const uint8_t *usrc, |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
static inline void yuv422ptouyvy_c(const uint8_t *ysrc, const uint8_t *usrc, |
|
|
|
static inline void yuv422ptouyvy_c(const uint8_t *ysrc, const uint8_t *usrc, |
|
|
|
const uint8_t *vsrc, uint8_t *dst, |
|
|
|
const uint8_t *vsrc, uint8_t *dst, |
|
|
|
long width, long height, |
|
|
|
int width, int height, |
|
|
|
long lumStride, long chromStride, |
|
|
|
int lumStride, int chromStride, |
|
|
|
long dstStride) |
|
|
|
int dstStride) |
|
|
|
{ |
|
|
|
{ |
|
|
|
yuvPlanartouyvy_c(ysrc, usrc, vsrc, dst, width, height, lumStride, |
|
|
|
yuvPlanartouyvy_c(ysrc, usrc, vsrc, dst, width, height, lumStride, |
|
|
|
chromStride, dstStride, 1); |
|
|
|
chromStride, dstStride, 1); |
|
|
@ -496,9 +496,9 @@ static inline void yuv422ptouyvy_c(const uint8_t *ysrc, const uint8_t *usrc, |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
static inline void yuv422ptoyuy2_c(const uint8_t *ysrc, const uint8_t *usrc, |
|
|
|
static inline void yuv422ptoyuy2_c(const uint8_t *ysrc, const uint8_t *usrc, |
|
|
|
const uint8_t *vsrc, uint8_t *dst, |
|
|
|
const uint8_t *vsrc, uint8_t *dst, |
|
|
|
long width, long height, |
|
|
|
int width, int height, |
|
|
|
long lumStride, long chromStride, |
|
|
|
int lumStride, int chromStride, |
|
|
|
long dstStride) |
|
|
|
int dstStride) |
|
|
|
{ |
|
|
|
{ |
|
|
|
yuvPlanartoyuy2_c(ysrc, usrc, vsrc, dst, width, height, lumStride, |
|
|
|
yuvPlanartoyuy2_c(ysrc, usrc, vsrc, dst, width, height, lumStride, |
|
|
|
chromStride, dstStride, 1); |
|
|
|
chromStride, dstStride, 1); |
|
|
@ -510,14 +510,14 @@ static inline void yuv422ptoyuy2_c(const uint8_t *ysrc, const uint8_t *usrc, |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
static inline void yuy2toyv12_c(const uint8_t *src, uint8_t *ydst, |
|
|
|
static inline void yuy2toyv12_c(const uint8_t *src, uint8_t *ydst, |
|
|
|
uint8_t *udst, uint8_t *vdst, |
|
|
|
uint8_t *udst, uint8_t *vdst, |
|
|
|
long width, long height, |
|
|
|
int width, int height, |
|
|
|
long lumStride, long chromStride, |
|
|
|
int lumStride, int chromStride, |
|
|
|
long srcStride) |
|
|
|
int srcStride) |
|
|
|
{ |
|
|
|
{ |
|
|
|
long y; |
|
|
|
int y; |
|
|
|
const int chromWidth = width >> 1; |
|
|
|
const int chromWidth = width >> 1; |
|
|
|
for (y=0; y<height; y+=2) { |
|
|
|
for (y=0; y<height; y+=2) { |
|
|
|
long i; |
|
|
|
int i; |
|
|
|
for (i=0; i<chromWidth; i++) { |
|
|
|
for (i=0; i<chromWidth; i++) { |
|
|
|
ydst[2*i+0] = src[4*i+0]; |
|
|
|
ydst[2*i+0] = src[4*i+0]; |
|
|
|
udst[i] = src[4*i+1]; |
|
|
|
udst[i] = src[4*i+1]; |
|
|
@ -538,10 +538,10 @@ static inline void yuy2toyv12_c(const uint8_t *src, uint8_t *ydst, |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
static inline void planar2x_c(const uint8_t *src, uint8_t *dst, long srcWidth, |
|
|
|
static inline void planar2x_c(const uint8_t *src, uint8_t *dst, int srcWidth, |
|
|
|
long srcHeight, long srcStride, long dstStride) |
|
|
|
int srcHeight, int srcStride, int dstStride) |
|
|
|
{ |
|
|
|
{ |
|
|
|
long x,y; |
|
|
|
int x,y; |
|
|
|
|
|
|
|
|
|
|
|
dst[0]= src[0]; |
|
|
|
dst[0]= src[0]; |
|
|
|
|
|
|
|
|
|
|
@ -598,14 +598,14 @@ static inline void planar2x_c(const uint8_t *src, uint8_t *dst, long srcWidth, |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
static inline void uyvytoyv12_c(const uint8_t *src, uint8_t *ydst, |
|
|
|
static inline void uyvytoyv12_c(const uint8_t *src, uint8_t *ydst, |
|
|
|
uint8_t *udst, uint8_t *vdst, |
|
|
|
uint8_t *udst, uint8_t *vdst, |
|
|
|
long width, long height, |
|
|
|
int width, int height, |
|
|
|
long lumStride, long chromStride, |
|
|
|
int lumStride, int chromStride, |
|
|
|
long srcStride) |
|
|
|
int srcStride) |
|
|
|
{ |
|
|
|
{ |
|
|
|
long y; |
|
|
|
int y; |
|
|
|
const int chromWidth = width >> 1; |
|
|
|
const int chromWidth = width >> 1; |
|
|
|
for (y=0; y<height; y+=2) { |
|
|
|
for (y=0; y<height; y+=2) { |
|
|
|
long i; |
|
|
|
int i; |
|
|
|
for (i=0; i<chromWidth; i++) { |
|
|
|
for (i=0; i<chromWidth; i++) { |
|
|
|
udst[i] = src[4*i+0]; |
|
|
|
udst[i] = src[4*i+0]; |
|
|
|
ydst[2*i+0] = src[4*i+1]; |
|
|
|
ydst[2*i+0] = src[4*i+1]; |
|
|
@ -634,14 +634,14 @@ static inline void uyvytoyv12_c(const uint8_t *src, uint8_t *ydst, |
|
|
|
* FIXME: Write HQ version. |
|
|
|
* FIXME: Write HQ version. |
|
|
|
*/ |
|
|
|
*/ |
|
|
|
void rgb24toyv12_c(const uint8_t *src, uint8_t *ydst, uint8_t *udst, |
|
|
|
void rgb24toyv12_c(const uint8_t *src, uint8_t *ydst, uint8_t *udst, |
|
|
|
uint8_t *vdst, long width, long height, long lumStride, |
|
|
|
uint8_t *vdst, int width, int height, int lumStride, |
|
|
|
long chromStride, long srcStride) |
|
|
|
int chromStride, int srcStride) |
|
|
|
{ |
|
|
|
{ |
|
|
|
long y; |
|
|
|
int y; |
|
|
|
const int chromWidth = width >> 1; |
|
|
|
const int chromWidth = width >> 1; |
|
|
|
y=0; |
|
|
|
y=0; |
|
|
|
for (; y<height; y+=2) { |
|
|
|
for (; y<height; y+=2) { |
|
|
|
long i; |
|
|
|
int i; |
|
|
|
for (i=0; i<chromWidth; i++) { |
|
|
|
for (i=0; i<chromWidth; i++) { |
|
|
|
unsigned int b = src[6*i+0]; |
|
|
|
unsigned int b = src[6*i+0]; |
|
|
|
unsigned int g = src[6*i+1]; |
|
|
|
unsigned int g = src[6*i+1]; |
|
|
@ -689,14 +689,14 @@ void rgb24toyv12_c(const uint8_t *src, uint8_t *ydst, uint8_t *udst, |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
static void interleaveBytes_c(const uint8_t *src1, const uint8_t *src2, |
|
|
|
static void interleaveBytes_c(const uint8_t *src1, const uint8_t *src2, |
|
|
|
uint8_t *dest, long width, |
|
|
|
uint8_t *dest, int width, |
|
|
|
long height, long src1Stride, |
|
|
|
int height, int src1Stride, |
|
|
|
long src2Stride, long dstStride) |
|
|
|
int src2Stride, int dstStride) |
|
|
|
{ |
|
|
|
{ |
|
|
|
long h; |
|
|
|
int h; |
|
|
|
|
|
|
|
|
|
|
|
for (h=0; h < height; h++) { |
|
|
|
for (h=0; h < height; h++) { |
|
|
|
long w; |
|
|
|
int w; |
|
|
|
for (w=0; w < width; w++) { |
|
|
|
for (w=0; w < width; w++) { |
|
|
|
dest[2*w+0] = src1[w]; |
|
|
|
dest[2*w+0] = src1[w]; |
|
|
|
dest[2*w+1] = src2[w]; |
|
|
|
dest[2*w+1] = src2[w]; |
|
|
@ -709,12 +709,12 @@ static void interleaveBytes_c(const uint8_t *src1, const uint8_t *src2, |
|
|
|
|
|
|
|
|
|
|
|
static inline void vu9_to_vu12_c(const uint8_t *src1, const uint8_t *src2, |
|
|
|
static inline void vu9_to_vu12_c(const uint8_t *src1, const uint8_t *src2, |
|
|
|
uint8_t *dst1, uint8_t *dst2, |
|
|
|
uint8_t *dst1, uint8_t *dst2, |
|
|
|
long width, long height, |
|
|
|
int width, int height, |
|
|
|
long srcStride1, long srcStride2, |
|
|
|
int srcStride1, int srcStride2, |
|
|
|
long dstStride1, long dstStride2) |
|
|
|
int dstStride1, int dstStride2) |
|
|
|
{ |
|
|
|
{ |
|
|
|
int y; |
|
|
|
int y; |
|
|
|
long x,w,h; |
|
|
|
int x,w,h; |
|
|
|
w=width/2; h=height/2; |
|
|
|
w=width/2; h=height/2; |
|
|
|
for (y=0;y<h;y++) { |
|
|
|
for (y=0;y<h;y++) { |
|
|
|
const uint8_t* s1=src1+srcStride1*(y>>1); |
|
|
|
const uint8_t* s1=src1+srcStride1*(y>>1); |
|
|
@ -732,12 +732,12 @@ static inline void vu9_to_vu12_c(const uint8_t *src1, const uint8_t *src2, |
|
|
|
|
|
|
|
|
|
|
|
static inline void yvu9_to_yuy2_c(const uint8_t *src1, const uint8_t *src2, |
|
|
|
static inline void yvu9_to_yuy2_c(const uint8_t *src1, const uint8_t *src2, |
|
|
|
const uint8_t *src3, uint8_t *dst, |
|
|
|
const uint8_t *src3, uint8_t *dst, |
|
|
|
long width, long height, |
|
|
|
int width, int height, |
|
|
|
long srcStride1, long srcStride2, |
|
|
|
int srcStride1, int srcStride2, |
|
|
|
long srcStride3, long dstStride) |
|
|
|
int srcStride3, int dstStride) |
|
|
|
{ |
|
|
|
{ |
|
|
|
int x; |
|
|
|
int x; |
|
|
|
long y,w,h; |
|
|
|
int y,w,h; |
|
|
|
w=width/2; h=height; |
|
|
|
w=width/2; h=height; |
|
|
|
for (y=0;y<h;y++) { |
|
|
|
for (y=0;y<h;y++) { |
|
|
|
const uint8_t* yp=src1+srcStride1*y; |
|
|
|
const uint8_t* yp=src1+srcStride1*y; |
|
|
@ -746,7 +746,7 @@ static inline void yvu9_to_yuy2_c(const uint8_t *src1, const uint8_t *src2, |
|
|
|
uint8_t* d=dst+dstStride*y; |
|
|
|
uint8_t* d=dst+dstStride*y; |
|
|
|
x=0; |
|
|
|
x=0; |
|
|
|
for (; x<w; x++) { |
|
|
|
for (; x<w; x++) { |
|
|
|
const long x2 = x<<2; |
|
|
|
const int x2 = x<<2; |
|
|
|
d[8*x+0] = yp[x2]; |
|
|
|
d[8*x+0] = yp[x2]; |
|
|
|
d[8*x+1] = up[x]; |
|
|
|
d[8*x+1] = up[x]; |
|
|
|
d[8*x+2] = yp[x2+1]; |
|
|
|
d[8*x+2] = yp[x2+1]; |
|
|
@ -833,11 +833,11 @@ static void extract_odd2avg_c(const uint8_t *src0, const uint8_t *src1, |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
static void yuyvtoyuv420_c(uint8_t *ydst, uint8_t *udst, uint8_t *vdst, |
|
|
|
static void yuyvtoyuv420_c(uint8_t *ydst, uint8_t *udst, uint8_t *vdst, |
|
|
|
const uint8_t *src, long width, long height, |
|
|
|
const uint8_t *src, int width, int height, |
|
|
|
long lumStride, long chromStride, long srcStride) |
|
|
|
int lumStride, int chromStride, int srcStride) |
|
|
|
{ |
|
|
|
{ |
|
|
|
long y; |
|
|
|
int y; |
|
|
|
const long chromWidth= -((-width)>>1); |
|
|
|
const int chromWidth= -((-width)>>1); |
|
|
|
|
|
|
|
|
|
|
|
for (y=0; y<height; y++) { |
|
|
|
for (y=0; y<height; y++) { |
|
|
|
extract_even_c(src, ydst, width); |
|
|
|
extract_even_c(src, ydst, width); |
|
|
@ -853,11 +853,11 @@ static void yuyvtoyuv420_c(uint8_t *ydst, uint8_t *udst, uint8_t *vdst, |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
static void yuyvtoyuv422_c(uint8_t *ydst, uint8_t *udst, uint8_t *vdst, |
|
|
|
static void yuyvtoyuv422_c(uint8_t *ydst, uint8_t *udst, uint8_t *vdst, |
|
|
|
const uint8_t *src, long width, long height, |
|
|
|
const uint8_t *src, int width, int height, |
|
|
|
long lumStride, long chromStride, long srcStride) |
|
|
|
int lumStride, int chromStride, int srcStride) |
|
|
|
{ |
|
|
|
{ |
|
|
|
long y; |
|
|
|
int y; |
|
|
|
const long chromWidth= -((-width)>>1); |
|
|
|
const int chromWidth= -((-width)>>1); |
|
|
|
|
|
|
|
|
|
|
|
for (y=0; y<height; y++) { |
|
|
|
for (y=0; y<height; y++) { |
|
|
|
extract_even_c(src, ydst, width); |
|
|
|
extract_even_c(src, ydst, width); |
|
|
@ -871,11 +871,11 @@ static void yuyvtoyuv422_c(uint8_t *ydst, uint8_t *udst, uint8_t *vdst, |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
static void uyvytoyuv420_c(uint8_t *ydst, uint8_t *udst, uint8_t *vdst, |
|
|
|
static void uyvytoyuv420_c(uint8_t *ydst, uint8_t *udst, uint8_t *vdst, |
|
|
|
const uint8_t *src, long width, long height, |
|
|
|
const uint8_t *src, int width, int height, |
|
|
|
long lumStride, long chromStride, long srcStride) |
|
|
|
int lumStride, int chromStride, int srcStride) |
|
|
|
{ |
|
|
|
{ |
|
|
|
long y; |
|
|
|
int y; |
|
|
|
const long chromWidth= -((-width)>>1); |
|
|
|
const int chromWidth= -((-width)>>1); |
|
|
|
|
|
|
|
|
|
|
|
for (y=0; y<height; y++) { |
|
|
|
for (y=0; y<height; y++) { |
|
|
|
extract_even_c(src + 1, ydst, width); |
|
|
|
extract_even_c(src + 1, ydst, width); |
|
|
@ -891,11 +891,11 @@ static void uyvytoyuv420_c(uint8_t *ydst, uint8_t *udst, uint8_t *vdst, |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
static void uyvytoyuv422_c(uint8_t *ydst, uint8_t *udst, uint8_t *vdst, |
|
|
|
static void uyvytoyuv422_c(uint8_t *ydst, uint8_t *udst, uint8_t *vdst, |
|
|
|
const uint8_t *src, long width, long height, |
|
|
|
const uint8_t *src, int width, int height, |
|
|
|
long lumStride, long chromStride, long srcStride) |
|
|
|
int lumStride, int chromStride, int srcStride) |
|
|
|
{ |
|
|
|
{ |
|
|
|
long y; |
|
|
|
int y; |
|
|
|
const long chromWidth= -((-width)>>1); |
|
|
|
const int chromWidth= -((-width)>>1); |
|
|
|
|
|
|
|
|
|
|
|
for (y=0; y<height; y++) { |
|
|
|
for (y=0; y<height; y++) { |
|
|
|
extract_even_c(src + 1, ydst, width); |
|
|
|
extract_even_c(src + 1, ydst, width); |
|
|
|