[FFmpeg-cvslog] eacmv: check the framerate before setting it.

Anton Khirnov git at videolan.org
Sat Jan 4 01:13:38 CET 2014


ffmpeg | branch: master | Anton Khirnov <anton at khirnov.net> | Thu Dec 12 07:31:26 2013 +0100| [24057c83207d6ea8bfd824155ac37be8a33dfd0c] | committer: Anton Khirnov

eacmv: check the framerate before setting it.

Found-by: Mateusz "j00ru" Jurczyk and Gynvael Coldwind
CC:libav-stable at libav.org

> http://git.videolan.org/gitweb.cgi/ffmpeg.git/?a=commit;h=24057c83207d6ea8bfd824155ac37be8a33dfd0c
---

 libavcodec/eacmv.c |    7 ++++---
 1 file changed, 4 insertions(+), 3 deletions(-)

diff --git a/libavcodec/eacmv.c b/libavcodec/eacmv.c
index d39ebd3..1a4e16e 100644
--- a/libavcodec/eacmv.c
+++ b/libavcodec/eacmv.c
@@ -131,7 +131,7 @@ static void cmv_decode_inter(CmvContext *s, AVFrame *frame, const uint8_t *buf,
 
 static int cmv_process_header(CmvContext *s, const uint8_t *buf, const uint8_t *buf_end)
 {
-    int pal_start, pal_count, i, ret;
+    int pal_start, pal_count, i, ret, fps;
 
     if(buf_end - buf < 16) {
         av_log(s->avctx, AV_LOG_WARNING, "truncated header\n");
@@ -145,8 +145,9 @@ static int cmv_process_header(CmvContext *s, const uint8_t *buf, const uint8_t *
     if (ret < 0)
         return ret;
 
-    s->avctx->time_base.num = 1;
-    s->avctx->time_base.den = AV_RL16(&buf[10]);
+    fps = AV_RL16(&buf[10]);
+    if (fps > 0)
+        s->avctx->time_base = (AVRational){ 1, fps };
 
     pal_start = AV_RL16(&buf[12]);
     pal_count = AV_RL16(&buf[14]);



More information about the ffmpeg-cvslog mailing list