From: David Schleef Date: Thu, 14 Mar 2013 00:08:03 +0000 (-0700) Subject: qtmux: Fix problems causing bad durations in file X-Git-Tag: 1.1.1~280 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=ee56a7cb99641804c573665ac551490c96e79f90;p=platform%2Fupstream%2Fgst-plugins-good.git qtmux: Fix problems causing bad durations in file - Fix up out-of-order incoming DTS values. - Fix duration of initial sample. --- diff --git a/gst/isomp4/gstqtmux.c b/gst/isomp4/gstqtmux.c index 2b4a4e2..9875853 100644 --- a/gst/isomp4/gstqtmux.c +++ b/gst/isomp4/gstqtmux.c @@ -2154,6 +2154,7 @@ gst_qt_mux_add_buffer (GstQTMux * qtmux, GstQTPad * pad, GstBuffer * buf) if (G_UNLIKELY (pad->first_ts == GST_CLOCK_TIME_NONE) && last_buf) { if (GST_CLOCK_TIME_IS_VALID (GST_BUFFER_PTS (last_buf))) { pad->first_ts = GST_BUFFER_PTS (last_buf); + GST_DEBUG ("setting first_ts to %" G_GUINT64_FORMAT, pad->first_ts); check_and_subtract_ts (qtmux, &GST_BUFFER_DTS (last_buf), pad->first_ts); check_and_subtract_ts (qtmux, &GST_BUFFER_PTS (last_buf), pad->first_ts); check_and_subtract_ts (qtmux, &GST_BUFFER_DTS (buf), pad->first_ts); @@ -2169,6 +2170,15 @@ gst_qt_mux_add_buffer (GstQTMux * qtmux, GstQTPad * pad, GstBuffer * buf) } + if (last_buf && buf && GST_CLOCK_TIME_IS_VALID (GST_BUFFER_DTS (buf)) && + GST_CLOCK_TIME_IS_VALID (GST_BUFFER_DTS (last_buf)) && + GST_BUFFER_DTS (buf) < GST_BUFFER_DTS (last_buf)) { + GST_ERROR ("decreasing DTS value %" GST_TIME_FORMAT " < %" GST_TIME_FORMAT, + GST_TIME_ARGS (GST_BUFFER_DTS (buf)), + GST_TIME_ARGS (GST_BUFFER_DTS (last_buf))); + GST_BUFFER_DTS (buf) = GST_BUFFER_DTS (last_buf); + } + duration = GST_BUFFER_DURATION (last_buf); /* for computing the avg bitrate */ @@ -2208,7 +2218,12 @@ gst_qt_mux_add_buffer (GstQTMux * qtmux, GstQTPad * pad, GstBuffer * buf) sample_size = gst_buffer_get_size (last_buf); if (pad->have_dts) { gint64 scaled_dts; - pad->last_dts = GST_BUFFER_DTS (last_buf); + if (pad->last_buf) { + pad->last_dts = GST_BUFFER_DTS (pad->last_buf); + } else { + pad->last_dts = GST_BUFFER_DTS (last_buf) + + GST_BUFFER_DURATION (last_buf); + } if ((gint64) (pad->last_dts) < 0) { scaled_dts = -gst_util_uint64_scale_round (-pad->last_dts, atom_trak_get_timescale (pad->trak), GST_SECOND);