rgb2rgb.h 7.33 KB
Newer Older
1
/*
2 3 4 5
 *  software RGB to RGB converter
 *  pluralize by Software PAL8 to RGB converter
 *               Software YUV to YUV converter
 *               Software YUV to RGB converter
Diego Biurrun's avatar
Diego Biurrun committed
6 7 8
 *  Written by Nick Kurshev.
 *  palette & YUV & runtime CPU stuff by Michael (michaelni@gmx.at)
 *
9 10
 * This file is part of FFmpeg.
 *
11 12 13 14
 * FFmpeg is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
Diego Biurrun's avatar
Diego Biurrun committed
15
 *
16
 * FFmpeg is distributed in the hope that it will be useful,
Diego Biurrun's avatar
Diego Biurrun committed
17
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
18 19
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
Diego Biurrun's avatar
Diego Biurrun committed
20
 *
21 22
 * You should have received a copy of the GNU Lesser General Public
 * License along with FFmpeg; if not, write to the Free Software
23
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
Nick Kurshev's avatar
Nick Kurshev committed
24 25
 */

26 27
#ifndef SWSCALE_RGB2RGB_H
#define SWSCALE_RGB2RGB_H
Nick Kurshev's avatar
Nick Kurshev committed
28

Diego Biurrun's avatar
Diego Biurrun committed
29 30
#include <inttypes.h>

31
/* A full collection of RGB to RGB(BGR) converters */
32 33 34 35
extern void (*rgb24tobgr32)(const uint8_t *src, uint8_t *dst, long src_size);
extern void (*rgb24tobgr16)(const uint8_t *src, uint8_t *dst, long src_size);
extern void (*rgb24tobgr15)(const uint8_t *src, uint8_t *dst, long src_size);
extern void (*rgb32tobgr24)(const uint8_t *src, uint8_t *dst, long src_size);
36 37 38
extern void (*rgb32to16)   (const uint8_t *src, uint8_t *dst, long src_size);
extern void (*rgb32to15)   (const uint8_t *src, uint8_t *dst, long src_size);
extern void (*rgb15to16)   (const uint8_t *src, uint8_t *dst, long src_size);
39
extern void (*rgb15tobgr24)(const uint8_t *src, uint8_t *dst, long src_size);
40 41
extern void (*rgb15to32)   (const uint8_t *src, uint8_t *dst, long src_size);
extern void (*rgb16to15)   (const uint8_t *src, uint8_t *dst, long src_size);
42
extern void (*rgb16tobgr24)(const uint8_t *src, uint8_t *dst, long src_size);
43
extern void (*rgb16to32)   (const uint8_t *src, uint8_t *dst, long src_size);
44
extern void (*rgb24tobgr24)(const uint8_t *src, uint8_t *dst, long src_size);
45 46
extern void (*rgb24to16)   (const uint8_t *src, uint8_t *dst, long src_size);
extern void (*rgb24to15)   (const uint8_t *src, uint8_t *dst, long src_size);
47 48 49 50
extern void (*rgb32tobgr32)(const uint8_t *src, uint8_t *dst, long src_size);
extern void (*rgb32tobgr16)(const uint8_t *src, uint8_t *dst, long src_size);
extern void (*rgb32tobgr15)(const uint8_t *src, uint8_t *dst, long src_size);

51 52 53 54 55 56 57 58 59 60 61
void rgb24to32   (const uint8_t *src, uint8_t *dst, long src_size);
void rgb32to24   (const uint8_t *src, uint8_t *dst, long src_size);
void rgb16tobgr32(const uint8_t *src, uint8_t *dst, long src_size);
void rgb16to24   (const uint8_t *src, uint8_t *dst, long src_size);
void rgb16tobgr16(const uint8_t *src, uint8_t *dst, long src_size);
void rgb16tobgr15(const uint8_t *src, uint8_t *dst, long src_size);
void rgb15tobgr32(const uint8_t *src, uint8_t *dst, long src_size);
void rgb15to24   (const uint8_t *src, uint8_t *dst, long src_size);
void rgb15tobgr16(const uint8_t *src, uint8_t *dst, long src_size);
void rgb15tobgr15(const uint8_t *src, uint8_t *dst, long src_size);
void bgr8torgb8  (const uint8_t *src, uint8_t *dst, long src_size);
62 63


64 65 66 67 68 69
void palette8topacked32(const uint8_t *src, uint8_t *dst, long num_pixels, const uint8_t *palette);
void palette8topacked24(const uint8_t *src, uint8_t *dst, long num_pixels, const uint8_t *palette);
void palette8torgb16(const uint8_t *src, uint8_t *dst, long num_pixels, const uint8_t *palette);
void palette8tobgr16(const uint8_t *src, uint8_t *dst, long num_pixels, const uint8_t *palette);
void palette8torgb15(const uint8_t *src, uint8_t *dst, long num_pixels, const uint8_t *palette);
void palette8tobgr15(const uint8_t *src, uint8_t *dst, long num_pixels, const uint8_t *palette);
70

71
/**
72 73 74
 * 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 I will fix it.)
 * Chrominance data is only taken from every second line, others are ignored.
75
 * FIXME: Write high quality version.
76 77 78 79
 */
//void uyvytoyv12(const uint8_t *src, uint8_t *ydst, uint8_t *udst, uint8_t *vdst,

/**
80 81
 * 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 I will fix it.)
82 83
 */
extern void (*yv12toyuy2)(const uint8_t *ysrc, const uint8_t *usrc, const uint8_t *vsrc, uint8_t *dst,
84 85
                          long width, long height,
                          long lumStride, long chromStride, long dstStride);
86 87

/**
88
 * Width should be a multiple of 16.
89 90
 */
extern void (*yuv422ptoyuy2)(const uint8_t *ysrc, const uint8_t *usrc, const uint8_t *vsrc, uint8_t *dst,
91 92
                             long width, long height,
                             long lumStride, long chromStride, long dstStride);
93 94

/**
95 96
 * 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 I will fix it.)
97 98
 */
extern void (*yuy2toyv12)(const uint8_t *src, uint8_t *ydst, uint8_t *udst, uint8_t *vdst,
99 100
                          long width, long height,
                          long lumStride, long chromStride, long srcStride);
101

Michael Niedermayer's avatar
Michael Niedermayer committed
102
/**
103 104
 * 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 I will fix it.)
Michael Niedermayer's avatar
Michael Niedermayer committed
105 106
 */
extern void (*yv12touyvy)(const uint8_t *ysrc, const uint8_t *usrc, const uint8_t *vsrc, uint8_t *dst,
107 108
                          long width, long height,
                          long lumStride, long chromStride, long dstStride);
Michael Niedermayer's avatar
Michael Niedermayer committed
109

110
/**
111
 * Width should be a multiple of 16.
112 113 114 115 116
 */
extern void (*yuv422ptouyvy)(const uint8_t *ysrc, const uint8_t *usrc, const uint8_t *vsrc, uint8_t *dst,
                             long width, long height,
                             long lumStride, long chromStride, long dstStride);

117
/**
118 119 120
 * 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 I will fix it.)
 * Chrominance data is only taken from every second line, others are ignored.
121
 * FIXME: Write high quality version.
122 123
 */
extern void (*rgb24toyv12)(const uint8_t *src, uint8_t *ydst, uint8_t *udst, uint8_t *vdst,
124 125
                           long width, long height,
                           long lumStride, long chromStride, long srcStride);
126
extern void (*planar2x)(const uint8_t *src, uint8_t *dst, long width, long height,
127
                        long srcStride, long dstStride);
Michael Niedermayer's avatar
Michael Niedermayer committed
128

129
extern void (*interleaveBytes)(uint8_t *src1, uint8_t *src2, uint8_t *dst,
130 131
                               long width, long height, long src1Stride,
                               long src2Stride, long dstStride);
132

133
extern void (*vu9_to_vu12)(const uint8_t *src1, const uint8_t *src2,
134 135 136 137
                           uint8_t *dst1, uint8_t *dst2,
                           long width, long height,
                           long srcStride1, long srcStride2,
                           long dstStride1, long dstStride2);
138

139
extern void (*yvu9_to_yuy2)(const uint8_t *src1, const uint8_t *src2, const uint8_t *src3,
140 141 142 143
                            uint8_t *dst,
                            long width, long height,
                            long srcStride1, long srcStride2,
                            long srcStride3, long dstStride);
144

145 146
void sws_rgb2rgb_init(int flags);

147
#endif /* SWSCALE_RGB2RGB_H */