rgb2rgb.h 6.14 KB
Newer Older
1
/*
Nick Kurshev's avatar
Nick Kurshev committed
2
 *
3
 *  rgb2rgb.h, Software RGB to RGB convertor
4 5 6
 *  pluralize by Software PAL8 to RGB convertor
 *               Software YUV to YUV convertor
 *               Software YUV to RGB convertor
Nick Kurshev's avatar
Nick Kurshev committed
7 8 9 10 11
 */

#ifndef RGB2RGB_INCLUDED
#define RGB2RGB_INCLUDED

12
/* A full collection of rgb to rgb(bgr) convertors */
13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31
extern void (*rgb24to32)(const uint8_t *src,uint8_t *dst,unsigned src_size);
extern void (*rgb24to16)(const uint8_t *src,uint8_t *dst,unsigned src_size);
extern void (*rgb24to15)(const uint8_t *src,uint8_t *dst,unsigned src_size);
extern void (*rgb32to24)(const uint8_t *src,uint8_t *dst,unsigned src_size);
extern void (*rgb32to16)(const uint8_t *src,uint8_t *dst,unsigned src_size);
extern void (*rgb32to15)(const uint8_t *src,uint8_t *dst,unsigned src_size);
extern void (*rgb15to16)(const uint8_t *src,uint8_t *dst,unsigned src_size);
extern void (*rgb15to24)(const uint8_t *src,uint8_t *dst,unsigned src_size);
extern void (*rgb15to32)(const uint8_t *src,uint8_t *dst,unsigned src_size);
extern void (*rgb16to15)(const uint8_t *src,uint8_t *dst,unsigned src_size);
extern void (*rgb16to24)(const uint8_t *src,uint8_t *dst,unsigned src_size);
extern void (*rgb16to32)(const uint8_t *src,uint8_t *dst,unsigned src_size);
extern void (*rgb24tobgr24)(const uint8_t *src, uint8_t *dst, unsigned src_size);
extern void (*rgb24tobgr16)(const uint8_t *src, uint8_t *dst, unsigned src_size);
extern void (*rgb24tobgr15)(const uint8_t *src, uint8_t *dst, unsigned src_size);
extern void (*rgb32tobgr32)(const uint8_t *src, uint8_t *dst, unsigned src_size);
extern void (*rgb32tobgr16)(const uint8_t *src, uint8_t *dst, unsigned src_size);
extern void (*rgb32tobgr15)(const uint8_t *src, uint8_t *dst, unsigned src_size);

32 33 34 35 36 37 38 39 40 41 42
extern void rgb24tobgr32(const uint8_t *src, uint8_t *dst, unsigned src_size);
extern void rgb32tobgr24(const uint8_t *src, uint8_t *dst, unsigned src_size);
extern void rgb16tobgr32(const uint8_t *src, uint8_t *dst, unsigned src_size);
extern void rgb16tobgr24(const uint8_t *src, uint8_t *dst, unsigned src_size);
extern void rgb16tobgr16(const uint8_t *src, uint8_t *dst, unsigned src_size);
extern void rgb16tobgr15(const uint8_t *src, uint8_t *dst, unsigned src_size);
extern void rgb15tobgr32(const uint8_t *src, uint8_t *dst, unsigned src_size);
extern void rgb15tobgr24(const uint8_t *src, uint8_t *dst, unsigned src_size);
extern void rgb15tobgr16(const uint8_t *src, uint8_t *dst, unsigned src_size);
extern void rgb15tobgr15(const uint8_t *src, uint8_t *dst, unsigned src_size);
extern void rgb8tobgr8(const uint8_t *src, uint8_t *dst, unsigned src_size);
Nick Kurshev's avatar
Nick Kurshev committed
43

44

45
extern void palette8torgb32(const uint8_t *src, uint8_t *dst, unsigned num_pixels, const uint8_t *palette);
46 47 48
extern void palette8tobgr32(const uint8_t *src, uint8_t *dst, unsigned num_pixels, const uint8_t *palette);
extern void palette8torgb24(const uint8_t *src, uint8_t *dst, unsigned num_pixels, const uint8_t *palette);
extern void palette8tobgr24(const uint8_t *src, uint8_t *dst, unsigned num_pixels, const uint8_t *palette);
49
extern void palette8torgb16(const uint8_t *src, uint8_t *dst, unsigned num_pixels, const uint8_t *palette);
50
extern void palette8tobgr16(const uint8_t *src, uint8_t *dst, unsigned num_pixels, const uint8_t *palette);
51
extern void palette8torgb15(const uint8_t *src, uint8_t *dst, unsigned num_pixels, const uint8_t *palette);
52
extern void palette8tobgr15(const uint8_t *src, uint8_t *dst, unsigned num_pixels, const uint8_t *palette);
53

54 55 56 57 58 59 60 61 62 63 64 65 66 67
/**
 *
 * height should be a multiple of 2 and width should be a multiple of 16 (if this is a
 * problem for anyone then tell me, and ill fix it)
 * chrominance data is only taken from every secound line others are ignored FIXME write HQ version
 */
//void uyvytoyv12(const uint8_t *src, uint8_t *ydst, uint8_t *udst, uint8_t *vdst,

/**
 *
 * height should be a multiple of 2 and width should be a multiple of 16 (if this is a
 * problem for anyone then tell me, and ill fix it)
 */
extern void (*yv12toyuy2)(const uint8_t *ysrc, const uint8_t *usrc, const uint8_t *vsrc, uint8_t *dst,
68
	unsigned int width, unsigned int height,
69
	int lumStride, int chromStride, int dstStride);
70 71 72 73 74 75

/**
 *
 * width should be a multiple of 16
 */
extern void (*yuv422ptoyuy2)(const uint8_t *ysrc, const uint8_t *usrc, const uint8_t *vsrc, uint8_t *dst,
Michael Niedermayer's avatar
Michael Niedermayer committed
76
	unsigned int width, unsigned int height,
77
	int lumStride, int chromStride, int dstStride);
78 79 80 81 82 83 84

/**
 *
 * height should be a multiple of 2 and width should be a multiple of 16 (if this is a
 * problem for anyone then tell me, and ill fix it)
 */
extern void (*yuy2toyv12)(const uint8_t *src, uint8_t *ydst, uint8_t *udst, uint8_t *vdst,
Michael Niedermayer's avatar
Michael Niedermayer committed
85
	unsigned int width, unsigned int height,
86
	int lumStride, int chromStride, int srcStride);
87 88 89 90 91 92 93 94

/**
 *
 * height should be a multiple of 2 and width should be a multiple of 2 (if this is a
 * problem for anyone then tell me, and ill fix it)
 * chrominance data is only taken from every secound line others are ignored FIXME write HQ version
 */
extern void (*rgb24toyv12)(const uint8_t *src, uint8_t *ydst, uint8_t *udst, uint8_t *vdst,
Michael Niedermayer's avatar
Michael Niedermayer committed
95
	unsigned int width, unsigned int height,
96
	int lumStride, int chromStride, int srcStride);
97
extern void (*planar2x)(const uint8_t *src, uint8_t *dst, int width, int height, int srcStride, int dstStride);
Michael Niedermayer's avatar
Michael Niedermayer committed
98

99
extern void (*interleaveBytes)(uint8_t *src1, uint8_t *src2, uint8_t *dst,
100 101
			    unsigned width, unsigned height, int src1Stride,
			    int src2Stride, int dstStride);
102

103
extern void (*vu9_to_vu12)(const uint8_t *src1, const uint8_t *src2,
104 105
			uint8_t *dst1, uint8_t *dst2,
			unsigned width, unsigned height,
106 107
			int srcStride1, int srcStride2,
			int dstStride1, int dstStride2);
108

109
extern void (*yvu9_to_yuy2)(const uint8_t *src1, const uint8_t *src2, const uint8_t *src3,
110 111
			uint8_t *dst,
			unsigned width, unsigned height,
112 113
			int srcStride1, int srcStride2,
			int srcStride3, int dstStride);
114 115
	

116 117 118
#define MODE_RGB  0x1
#define MODE_BGR  0x2

119
static void yuv2rgb(uint8_t * image, uint8_t * py,
120
			      uint8_t * pu, uint8_t * pv,
Arpi's avatar
Arpi committed
121
			      unsigned h_size, unsigned v_size,
122 123 124
			      int rgb_stride, int y_stride, int uv_stride){
printf("broken, this should use the swscaler\n");
}
125

126 127 128
static void yuv2rgb_init (unsigned bpp, int mode){
printf("broken, this should use the swscaler\n");
}
129

130 131
void sws_rgb2rgb_init(int flags);

Nick Kurshev's avatar
Nick Kurshev committed
132
#endif