gst-libs/gst/audio/gstbaseaudiosink.c: After an interrupt (PAUSED/flush) assume that...
authorWim Taymans <wim.taymans@gmail.com>
Thu, 24 May 2007 16:22:23 +0000 (16:22 +0000)
committerWim Taymans <wim.taymans@gmail.com>
Thu, 24 May 2007 16:22:23 +0000 (16:22 +0000)
Original commit message from CVS:
* gst-libs/gst/audio/gstbaseaudiosink.c:
(gst_base_audio_sink_render):
After an interrupt (PAUSED/flush) assume that the next sample should not
be aligned to the previous sample. Fixes #417992.

ChangeLog
gst-libs/gst/audio/gstbaseaudiosink.c

index 4c5db41a0b37de4a8774033cf149c347fbe6c24a..b573be519b5541373ffdde8c20dd4197584daf07 100644 (file)
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,10 @@
+2007-05-24  Wim Taymans  <wim@fluendo.com>
+
+       * gst-libs/gst/audio/gstbaseaudiosink.c:
+       (gst_base_audio_sink_render):
+       After an interrupt (PAUSED/flush) assume that the next sample should not
+       be aligned to the previous sample. Fixes #417992.
+
 2007-05-24  Tim-Philipp Müller  <tim at centricular dot net>
 
        * gst-libs/gst/riff/riff-media.c: (gst_riff_create_audio_caps):
index 2a128e312a0b14912cecd1ec0e1e6a526ba11548..3aa94c67f70dbb7757f80a7d8ab8df8ffd16130b 100644 (file)
@@ -853,9 +853,9 @@ gst_base_audio_sink_render (GstBaseSink * bsink, GstBuffer * buf)
   gint bps;
   gint accum;
   gint out_samples;
-  GstClockTime base_time, latency;
+  GstClockTime base_time = -1, latency;
   GstClock *clock;
-  gboolean sync, slaved;
+  gboolean sync, slaved, align_next;
 
   sink = GST_BASE_AUDIO_SINK (bsink);
 
@@ -1062,6 +1062,7 @@ no_sync:
 
   /* we need to accumulate over different runs for when we get interrupted */
   accum = 0;
+  align_next = TRUE;
   do {
     written =
         gst_ring_buffer_commit_full (ringbuf, &sample_offset, data, samples,
@@ -1076,11 +1077,18 @@ no_sync:
     if (gst_base_sink_wait_preroll (bsink) != GST_FLOW_OK)
       goto stopping;
 
+    /* if we got interrupted, we cannot assume that the next sample should
+     * be aligned to this one */
+    align_next = FALSE;
+
     samples -= written;
     data += written * bps;
   } while (TRUE);
 
-  sink->next_sample = sample_offset;
+  if (align_next)
+    sink->next_sample = sample_offset;
+  else
+    sink->next_sample = -1;
 
   GST_DEBUG_OBJECT (sink, "next sample expected at %" G_GUINT64_FORMAT,
       sink->next_sample);