# HG changeset patch # User michael # Date 1098450918 0 # Node ID 640706a29efb47288e42af5c099528fef8b7e421 # Parent 4a755492b90b0ed5dcc0fe2c33d6721aab3d72f7 bug in libavformat av_update_cur_dts(), patch by (Nathan Kurz ) diff -r 4a755492b90b -r 640706a29efb utils.c --- a/utils.c Fri Oct 22 02:04:30 2004 +0000 +++ b/utils.c Fri Oct 22 13:15:18 2004 +0000 @@ -916,18 +916,21 @@ } /** - * updates the cur_dts field based on the given timestamp and AVStream. - * only needed if (dts are not set and pts!=dts) or for timestamp wrapping + * updates cur_dts of all streams based on given timestamp and AVStream. + * stream ref_st unchanged, others set cur_dts in their native timebase + * only needed for timestamp wrapping or if (dts not set and pts!=dts) + * @param timestamp new dts expressed in time_base of param ref_st + * @param ref_st reference stream giving time_base of param timestamp */ -static void av_update_cur_dts(AVFormatContext *s, AVStream *st, int64_t timestamp){ +static void av_update_cur_dts(AVFormatContext *s, AVStream *ref_st, int64_t timestamp){ int i; for(i = 0; i < s->nb_streams; i++) { - AVStream *st2 = s->streams[i]; + AVStream *st = s->streams[i]; st->cur_dts = av_rescale(timestamp, - st2->time_base.den * (int64_t)st ->time_base.num, - st ->time_base.den * (int64_t)st2->time_base.num); + st->time_base.den * (int64_t)ref_st->time_base.num, + st->time_base.num * (int64_t)ref_st->time_base.den); } }