From 0b23d689d850c636ba4594b578007aa2b0fdc88a Mon Sep 17 00:00:00 2001 From: Steve L'Homme Date: Fri, 18 Aug 2006 07:55:08 +0000 Subject: Add YV12 support, patch by Steve Lhomme % steve P lhomme A free P fr % Original thread: Date: Aug 17, 2006 5:45 PM Subject: Re: [Ffmpeg-devel] [PATCH] AVISynth support Originally committed as revision 6018 to svn://svn.ffmpeg.org/ffmpeg/trunk --- libavcodec/raw.c | 10 ++++++++++ 1 file changed, 10 insertions(+) (limited to 'libavcodec/raw.c') diff --git a/libavcodec/raw.c b/libavcodec/raw.c index e777397feb..6204cf7975 100644 --- a/libavcodec/raw.c +++ b/libavcodec/raw.c @@ -38,6 +38,7 @@ typedef struct PixelFormatTag { const PixelFormatTag pixelFormatTags[] = { { PIX_FMT_YUV420P, MKTAG('I', '4', '2', '0') }, /* Planar formats */ { PIX_FMT_YUV420P, MKTAG('I', 'Y', 'U', 'V') }, + { PIX_FMT_YUV420P, MKTAG('Y', 'V', '1', '2') }, { PIX_FMT_YUV410P, MKTAG('Y', 'U', 'V', '9') }, { PIX_FMT_YUV411P, MKTAG('Y', '4', '1', 'B') }, { PIX_FMT_YUV422P, MKTAG('Y', '4', '2', 'B') }, @@ -141,6 +142,15 @@ static int raw_decode(AVCodecContext *avctx, } flip(avctx, picture); + + if (avctx->codec_tag == MKTAG('Y', 'V', '1', '2')) + { + // swap fields + unsigned char *tmp = picture->data[1]; + picture->data[1] = picture->data[2]; + picture->data[2] = tmp; + } + *data_size = sizeof(AVPicture); return buf_size; } -- cgit v1.2.3