# HG changeset patch # User michael # Date 1246481568 0 # Node ID 45ee449ae6ef9e79cb83ad072205271e3b089ead # Parent 8d5dd051d055c733b3715ef9da04f468a858fa71 Make sure av_set_pts_info() does not set the fields of a timebase to negative values. diff -r 8d5dd051d055 -r 45ee449ae6ef utils.c --- a/utils.c Wed Jul 01 18:50:31 2009 +0000 +++ b/utils.c Wed Jul 01 20:52:48 2009 +0000 @@ -3306,11 +3306,11 @@ void av_set_pts_info(AVStream *s, int pts_wrap_bits, unsigned int pts_num, unsigned int pts_den) { - unsigned int gcd= av_gcd(pts_num, pts_den); s->pts_wrap_bits = pts_wrap_bits; - s->time_base.num = pts_num/gcd; - s->time_base.den = pts_den/gcd; - - if(gcd>1) - av_log(NULL, AV_LOG_DEBUG, "st:%d removing common factor %d from timebase\n", s->index, gcd); + + if(av_reduce(&s->time_base.num, &s->time_base.den, pts_num, pts_den, INT_MAX)){ + if(s->time_base.num != pts_num) + av_log(NULL, AV_LOG_DEBUG, "st:%d removing common factor %d from timebase\n", s->index, pts_num/s->time_base.num); + }else + av_log(NULL, AV_LOG_WARNING, "st:%d has too large timebase, reducing\n", s->index); }