[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