VP3/Theora: validate aspect and reduce it before exporting it
authorReimar Döffinger <Reimar.Doeffinger@gmx.de>
Mon, 6 Sep 2010 17:53:29 +0000 (17:53 +0000)
committerReimar Döffinger <Reimar.Doeffinger@gmx.de>
Mon, 6 Sep 2010 17:53:29 +0000 (17:53 +0000)
via the context.

Originally committed as revision 25050 to svn://svn.ffmpeg.org/ffmpeg/trunk

libavcodec/vp3.c

index 9b9cbd9be7a5aebf48673c0fbea100bfed1d8573..7e1a8ef95d5d335e5c8b4cf5c563f7c9715b43fd 100644 (file)
@@ -1965,7 +1965,7 @@ static int theora_decode_header(AVCodecContext *avctx, GetBitContext *gb)
     Vp3DecodeContext *s = avctx->priv_data;
     int visible_width, visible_height, colorspace;
     int offset_x = 0, offset_y = 0;
-    AVRational fps;
+    AVRational fps, aspect;
 
     s->theora = get_bits_long(gb, 24);
     av_log(avctx, AV_LOG_DEBUG, "Theora bitstream version %X\n", s->theora);
@@ -2002,8 +2002,13 @@ static int theora_decode_header(AVCodecContext *avctx, GetBitContext *gb)
                   fps.den, fps.num, 1<<30);
     }
 
-    avctx->sample_aspect_ratio.num = get_bits_long(gb, 24);
-    avctx->sample_aspect_ratio.den = get_bits_long(gb, 24);
+    aspect.num = get_bits_long(gb, 24);
+    aspect.den = get_bits_long(gb, 24);
+    if (aspect.num && aspect.den) {
+        av_reduce(&avctx->sample_aspect_ratio.num,
+                  &avctx->sample_aspect_ratio.den,
+                  aspect.num, aspect.den, 1<<30);
+    }
 
     if (s->theora < 0x030200)
         skip_bits(gb, 5); /* keyframe frequency force */