1 /*****************************************************************************
2 * chroma.c: libavutil <-> libvlc conversion routines
3 *****************************************************************************
4 * Copyright (C) 1999-2008 the VideoLAN team
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
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation; either version 2 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 General Public License for more details.
20 * You should have received a copy of the GNU General Public License
21 * along with this program; if not, write to the Free Software
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>
36 /*****************************************************************************
37 * Chroma fourcc -> ffmpeg_id mapping
38 *****************************************************************************/
39 #if defined(WORDS_BIGENDIAN)
40 # define VLC_RGB_ES( fcc, leid, beid ) \
41 { fcc, beid, 0, 0, 0 },
43 # define VLC_RGB_ES( fcc, leid, beid ) \
44 { fcc, leid, 0, 0, 0 },
47 #define VLC_RGB( fcc, leid, beid, rmask, gmask, bmask ) \
48 { fcc, leid, rmask, gmask, bmask }, \
49 { fcc, beid, bmask, gmask, rmask }, \
50 VLC_RGB_ES( fcc, leid, beid )
55 vlc_fourcc_t i_chroma;
63 /* Planar YUV formats */
64 {VLC_CODEC_I444, PIX_FMT_YUV444P, 0, 0, 0 },
65 {VLC_CODEC_J444, PIX_FMT_YUVJ444P, 0, 0, 0 },
67 #if LIBAVUTIL_VERSION_INT >= ((49<<16)+(5<<8)+0)
68 {VLC_CODEC_I440, PIX_FMT_YUV440P, 0, 0, 0 },
69 {VLC_CODEC_J440, PIX_FMT_YUVJ440P, 0, 0, 0 },
72 {VLC_CODEC_I422, PIX_FMT_YUV422P, 0, 0, 0 },
73 {VLC_CODEC_J422, PIX_FMT_YUVJ422P, 0, 0, 0 },
75 {VLC_CODEC_I420, PIX_FMT_YUV420P, 0, 0, 0 },
76 {VLC_CODEC_YV12, PIX_FMT_YUV420P, 0, 0, 0 },
77 {VLC_FOURCC('I','Y','U','V'), PIX_FMT_YUV420P, 0, 0, 0 },
78 {VLC_CODEC_J420, PIX_FMT_YUVJ420P, 0, 0, 0 },
79 {VLC_CODEC_I411, PIX_FMT_YUV411P, 0, 0, 0 },
80 {VLC_CODEC_I410, PIX_FMT_YUV410P, 0, 0, 0 },
81 {VLC_FOURCC('Y','V','U','9'), PIX_FMT_YUV410P, 0, 0, 0 },
83 {VLC_FOURCC('N','V','1','2'), PIX_FMT_NV12, 0, 0, 0 },
84 {VLC_FOURCC('N','V','2','1'), PIX_FMT_NV21, 0, 0, 0 },
86 #if LIBAVUTIL_VERSION_INT >= ((51<<16)+(4<<8)+0)
87 {VLC_CODEC_I420_9L, PIX_FMT_YUV420P9LE, 0, 0, 0 },
88 {VLC_CODEC_I420_9B, PIX_FMT_YUV420P9BE, 0, 0, 0 },
89 {VLC_CODEC_I420_10L, PIX_FMT_YUV420P10LE, 0, 0, 0 },
90 {VLC_CODEC_I420_10B, PIX_FMT_YUV420P10BE, 0, 0, 0 },
92 #if LIBAVUTIL_VERSION_INT > ((51<<16)+(22<<8)+0)
93 {VLC_CODEC_I422_9L, PIX_FMT_YUV422P9LE, 0, 0, 0 },
94 {VLC_CODEC_I422_9B, PIX_FMT_YUV422P9BE, 0, 0, 0 },
96 #if LIBAVUTIL_VERSION_INT >= ((51<<16)+(9<<8)+0)
97 {VLC_CODEC_I422_10L, PIX_FMT_YUV422P10LE, 0, 0, 0 },
98 {VLC_CODEC_I422_10B, PIX_FMT_YUV422P10BE, 0, 0, 0 },
100 {VLC_CODEC_I444_9L, PIX_FMT_YUV444P9LE, 0, 0, 0 },
101 {VLC_CODEC_I444_9B, PIX_FMT_YUV444P9BE, 0, 0, 0 },
102 {VLC_CODEC_I444_10L, PIX_FMT_YUV444P10LE, 0, 0, 0 },
103 {VLC_CODEC_I444_10B, PIX_FMT_YUV444P10BE, 0, 0, 0 },
106 /* Packed YUV formats */
107 {VLC_CODEC_YUYV, PIX_FMT_YUYV422, 0, 0, 0 },
108 {VLC_FOURCC('Y','U','Y','V'), PIX_FMT_YUYV422, 0, 0, 0 },
109 {VLC_CODEC_UYVY, PIX_FMT_UYVY422, 0, 0, 0 },
110 {VLC_FOURCC('Y','4','1','1'), PIX_FMT_UYYVYY411, 0, 0, 0 },
112 /* Packed RGB formats */
113 VLC_RGB( VLC_FOURCC('R','G','B','4'), PIX_FMT_RGB4, PIX_FMT_BGR4, 0x10, 0x06, 0x01 )
114 VLC_RGB( VLC_FOURCC('R','G','B','8'), PIX_FMT_RGB8, PIX_FMT_BGR8, 0xC0, 0x38, 0x07 )
116 VLC_RGB( VLC_CODEC_RGB15, PIX_FMT_RGB555, PIX_FMT_BGR555, 0x7c00, 0x03e0, 0x001f )
117 VLC_RGB( VLC_CODEC_RGB16, PIX_FMT_RGB565, PIX_FMT_BGR565, 0xf800, 0x07e0, 0x001f )
118 VLC_RGB( VLC_CODEC_RGB24, PIX_FMT_BGR24, PIX_FMT_RGB24, 0xff0000, 0x00ff00, 0x0000ff )
120 VLC_RGB( VLC_CODEC_RGB32, PIX_FMT_RGB32, PIX_FMT_BGR32, 0x00ff0000, 0x0000ff00, 0x000000ff )
121 VLC_RGB( VLC_CODEC_RGB32, PIX_FMT_RGB32_1, PIX_FMT_BGR32_1, 0xff000000, 0x00ff0000, 0x0000ff00 )
123 {VLC_CODEC_RGBA, PIX_FMT_RGBA, 0xff000000, 0x00ff0000, 0x0000ff00},
124 {VLC_CODEC_GREY, PIX_FMT_GRAY8, 0, 0, 0},
127 {VLC_CODEC_RGBP, PIX_FMT_PAL8, 0, 0, 0},
133 int TestFfmpegChroma( const int i_ffmpeg_id, const vlc_fourcc_t i_vlc_fourcc )
135 for( int i = 0; chroma_table[i].i_chroma != 0; i++ )
137 if( chroma_table[i].i_chroma == i_vlc_fourcc || chroma_table[i].i_chroma_id == i_ffmpeg_id )
143 /* FIXME special case the RGB formats */
144 int GetFfmpegChroma( int *i_ffmpeg_chroma, const video_format_t fmt )
146 for( int i = 0; chroma_table[i].i_chroma != 0; i++ )
148 if( chroma_table[i].i_chroma == fmt.i_chroma )
150 if( ( chroma_table[i].i_rmask == 0 &&
151 chroma_table[i].i_gmask == 0 &&
152 chroma_table[i].i_bmask == 0 ) ||
153 ( chroma_table[i].i_rmask == fmt.i_rmask &&
154 chroma_table[i].i_gmask == fmt.i_gmask &&
155 chroma_table[i].i_bmask == fmt.i_bmask ) )
157 *i_ffmpeg_chroma = chroma_table[i].i_chroma_id;
165 int GetVlcChroma( video_format_t *fmt, const int i_ffmpeg_chroma )
167 /* TODO FIXME for rgb format we HAVE to set rgb mask/shift */
168 for( int i = 0; chroma_table[i].i_chroma != 0; i++ )
170 if( chroma_table[i].i_chroma_id == i_ffmpeg_chroma )
172 fmt->i_rmask = chroma_table[i].i_rmask;
173 fmt->i_gmask = chroma_table[i].i_gmask;
174 fmt->i_bmask = chroma_table[i].i_bmask;
175 fmt->i_chroma = chroma_table[i].i_chroma;