1 /*****************************************************************************
2 * chroma.c: libavutil <-> libvlc conversion routines
3 *****************************************************************************
4 * Copyright (C) 1999-2008 VLC authors and VideoLAN
7 * Authors: Laurent Aimar <fenrir@via.ecp.fr>
8 * Gildas Bazin <gbazin@videolan.org>
10 * This program is free software; you can redistribute it and/or modify it
11 * under the terms of the GNU Lesser General Public License as published by
12 * the Free Software Foundation; either version 2.1 of the License, or
13 * (at your option) any later version.
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU Lesser General Public License for more details.
20 * You should have received a copy of the GNU Lesser General Public License
21 * along with this program; if not, write to the Free Software Foundation,
22 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston MA 021100301, USA.
23 *****************************************************************************/
29 #include <vlc_common.h>
30 #include <vlc_codec.h>
32 #include <libavutil/avutil.h>
33 #include <libavutil/pixfmt.h>
37 /*****************************************************************************
38 * Chroma fourcc -> libavutil pixfmt mapping
39 *****************************************************************************/
40 #if defined(WORDS_BIGENDIAN)
41 # define VLC_RGB_ES( fcc, leid, beid ) \
42 { fcc, beid, 0, 0, 0 },
44 # define VLC_RGB_ES( fcc, leid, beid ) \
45 { fcc, leid, 0, 0, 0 },
48 #define VLC_RGB( fcc, leid, beid, rmask, gmask, bmask ) \
49 { fcc, leid, rmask, gmask, bmask }, \
50 { fcc, beid, bmask, gmask, rmask }, \
51 VLC_RGB_ES( fcc, leid, beid )
56 vlc_fourcc_t i_chroma;
64 /* Planar YUV formats */
65 {VLC_CODEC_I444, PIX_FMT_YUV444P, 0, 0, 0 },
66 {VLC_CODEC_J444, PIX_FMT_YUVJ444P, 0, 0, 0 },
68 {VLC_CODEC_I440, PIX_FMT_YUV440P, 0, 0, 0 },
69 {VLC_CODEC_J440, PIX_FMT_YUVJ440P, 0, 0, 0 },
71 {VLC_CODEC_I422, PIX_FMT_YUV422P, 0, 0, 0 },
72 {VLC_CODEC_J422, PIX_FMT_YUVJ422P, 0, 0, 0 },
74 {VLC_CODEC_I420, PIX_FMT_YUV420P, 0, 0, 0 },
75 {VLC_CODEC_YV12, PIX_FMT_YUV420P, 0, 0, 0 },
76 {VLC_FOURCC('I','Y','U','V'), PIX_FMT_YUV420P, 0, 0, 0 },
77 {VLC_CODEC_J420, PIX_FMT_YUVJ420P, 0, 0, 0 },
78 {VLC_CODEC_I411, PIX_FMT_YUV411P, 0, 0, 0 },
79 {VLC_CODEC_I410, PIX_FMT_YUV410P, 0, 0, 0 },
80 {VLC_FOURCC('Y','V','U','9'), PIX_FMT_YUV410P, 0, 0, 0 },
82 {VLC_FOURCC('N','V','1','2'), PIX_FMT_NV12, 0, 0, 0 },
83 {VLC_FOURCC('N','V','2','1'), PIX_FMT_NV21, 0, 0, 0 },
85 {VLC_CODEC_I420_9L, PIX_FMT_YUV420P9LE, 0, 0, 0 },
86 {VLC_CODEC_I420_9B, PIX_FMT_YUV420P9BE, 0, 0, 0 },
87 {VLC_CODEC_I420_10L, PIX_FMT_YUV420P10LE, 0, 0, 0 },
88 {VLC_CODEC_I420_10B, PIX_FMT_YUV420P10BE, 0, 0, 0 },
89 #if LIBAVUTIL_VERSION_INT >= AV_VERSION_INT(51,13,0)
90 {VLC_CODEC_I422_9L, PIX_FMT_YUV422P9LE, 0, 0, 0 },
91 {VLC_CODEC_I422_9B, PIX_FMT_YUV422P9BE, 0, 0, 0 },
93 {VLC_CODEC_I422_10L, PIX_FMT_YUV422P10LE, 0, 0, 0 },
94 {VLC_CODEC_I422_10B, PIX_FMT_YUV422P10BE, 0, 0, 0 },
96 {VLC_CODEC_I444_9L, PIX_FMT_YUV444P9LE, 0, 0, 0 },
97 {VLC_CODEC_I444_9B, PIX_FMT_YUV444P9BE, 0, 0, 0 },
98 {VLC_CODEC_I444_10L, PIX_FMT_YUV444P10LE, 0, 0, 0 },
99 {VLC_CODEC_I444_10B, PIX_FMT_YUV444P10BE, 0, 0, 0 },
101 /* Packed YUV formats */
102 {VLC_CODEC_YUYV, PIX_FMT_YUYV422, 0, 0, 0 },
103 {VLC_FOURCC('Y','U','Y','V'), PIX_FMT_YUYV422, 0, 0, 0 },
104 {VLC_CODEC_UYVY, PIX_FMT_UYVY422, 0, 0, 0 },
105 {VLC_FOURCC('Y','4','1','1'), PIX_FMT_UYYVYY411, 0, 0, 0 },
107 /* Packed RGB formats */
108 VLC_RGB( VLC_FOURCC('R','G','B','4'), PIX_FMT_RGB4, PIX_FMT_BGR4, 0x10, 0x06, 0x01 )
109 VLC_RGB( VLC_FOURCC('R','G','B','8'), PIX_FMT_RGB8, PIX_FMT_BGR8, 0xC0, 0x38, 0x07 )
111 VLC_RGB( VLC_CODEC_RGB15, PIX_FMT_RGB555, PIX_FMT_BGR555, 0x7c00, 0x03e0, 0x001f )
112 VLC_RGB( VLC_CODEC_RGB16, PIX_FMT_RGB565, PIX_FMT_BGR565, 0xf800, 0x07e0, 0x001f )
113 VLC_RGB( VLC_CODEC_RGB24, PIX_FMT_BGR24, PIX_FMT_RGB24, 0xff0000, 0x00ff00, 0x0000ff )
115 VLC_RGB( VLC_CODEC_RGB32, PIX_FMT_RGB32, PIX_FMT_BGR32, 0x00ff0000, 0x0000ff00, 0x000000ff )
116 VLC_RGB( VLC_CODEC_RGB32, PIX_FMT_RGB32_1, PIX_FMT_BGR32_1, 0xff000000, 0x00ff0000, 0x0000ff00 )
118 {VLC_CODEC_RGBA, PIX_FMT_RGBA, 0xff000000, 0x00ff0000, 0x0000ff00},
119 {VLC_CODEC_GREY, PIX_FMT_GRAY8, 0, 0, 0},
122 {VLC_CODEC_RGBP, PIX_FMT_PAL8, 0, 0, 0},
125 #if LIBAVUTIL_VERSION_CHECK(52, 10, 0, 25, 100)
126 {VLC_CODEC_XYZ12, AV_PIX_FMT_XYZ12, 0xfff0, 0xfff0, 0xfff0},
131 /* FIXME special case the RGB formats */
132 int GetFfmpegChroma( int *restrict i_ffmpeg_chroma, const video_format_t *fmt )
134 for( int i = 0; chroma_table[i].i_chroma != 0; i++ )
136 if( chroma_table[i].i_chroma == fmt->i_chroma )
138 if( ( chroma_table[i].i_rmask == 0 &&
139 chroma_table[i].i_gmask == 0 &&
140 chroma_table[i].i_bmask == 0 ) ||
141 ( chroma_table[i].i_rmask == fmt->i_rmask &&
142 chroma_table[i].i_gmask == fmt->i_gmask &&
143 chroma_table[i].i_bmask == fmt->i_bmask ) )
145 *i_ffmpeg_chroma = chroma_table[i].i_chroma_id;
153 vlc_fourcc_t FindVlcChroma( int i_ffmpeg_id )
155 for( int i = 0; chroma_table[i].i_chroma != 0; i++ )
156 if( chroma_table[i].i_chroma_id == i_ffmpeg_id )
157 return chroma_table[i].i_chroma;
161 int GetVlcChroma( video_format_t *fmt, int i_ffmpeg_chroma )
163 /* TODO FIXME for rgb format we HAVE to set rgb mask/shift */
164 for( int i = 0; chroma_table[i].i_chroma != 0; i++ )
166 if( chroma_table[i].i_chroma_id == i_ffmpeg_chroma )
168 fmt->i_rmask = chroma_table[i].i_rmask;
169 fmt->i_gmask = chroma_table[i].i_gmask;
170 fmt->i_bmask = chroma_table[i].i_bmask;
171 fmt->i_chroma = chroma_table[i].i_chroma;
178 int FindFfmpegChroma( vlc_fourcc_t fourcc )
180 for( int i = 0; chroma_table[i].i_chroma != 0; i++ )
181 if( chroma_table[i].i_chroma == fourcc )
182 return chroma_table[i].i_chroma_id;