After an evaluation, GNOME has moved from Bugzilla to GitLab. Learn more about GitLab.
No new issues can be reported in GNOME Bugzilla anymore.
To report an issue in a GNOME project, go to GNOME GitLab.
Do not go to GNOME Gitlab for: Bluefish, Doxygen, GnuCash, GStreamer, java-gnome, LDTP, NetworkManager, Tomboy.
Bug 597749 - [pulsesink] audio clock is inaccurate
[pulsesink] audio clock is inaccurate
Status: RESOLVED OBSOLETE
Product: GStreamer
Classification: Platform
Component: gst-plugins-good
git master
Other Linux
: Normal critical
: NONE
Assigned To: GStreamer Maintainers
GStreamer Maintainers
Depends on:
Blocks:
 
 
Reported: 2009-10-08 00:00 UTC by René Stadler
Modified: 2012-10-04 15:38 UTC
See Also:
GNOME target: ---
GNOME version: ---



Description René Stadler 2009-10-08 00:00:26 UTC
Pulsesink seems to have some problems determining what the internal stream time is. It shows up negatively when it is slaved to a different clock and the skew algorithm has to kick in:

$ GST_DEBUG=2 gst-launch-0.10 audiotestsrc is-live=true ! pulsesink
Setting pipeline to PAUSED ...
Pipeline is live and does not need PREROLL ...
Setting pipeline to PLAYING ...
0:00:00.017263543 14755      0x1d96030 WARN                     bin gstbin.c:2312:gst_bin_do_latency_func:<pipeline0> failed to query latency
New clock: GstSystemClock
0:00:00.156788119 14755      0x1f5ab70 WARN           baseaudiosink gstbaseaudiosink.c:1028:gst_base_audio_sink_skew_slaving:<pulsesink0> correct clock skew -11298628 < -10000000
0:00:00.403085040 14755      0x1f5ab70 WARN           baseaudiosink gstbaseaudiosink.c:1028:gst_base_audio_sink_skew_slaving:<pulsesink0> correct clock skew -10319104 < -10000000
0:00:00.737286961 14755      0x1f5ab70 WARN           baseaudiosink gstbaseaudiosink.c:1028:gst_base_audio_sink_skew_slaving:<pulsesink0> correct clock skew -10134766 < -10000000
0:00:01.341005566 14755      0x1f5ab70 WARN           baseaudiosink gstbaseaudiosink.c:1028:gst_base_audio_sink_skew_slaving:<pulsesink0> correct clock skew -10418319 < -10000000

(there's noticable clicks in the audio in the beginning)

In about 98% of the cases, audio plays normal after that. In the remaining 2%, it ends up in a loop of pulse stream underruns from which it cannot recover. I guess that has something to do with the skew slaving adjusting the sample position.

I'm having the feeling that pa_stream_get_time() doesn't work as expected or is misused. I think it's suspicious that the internal time is 0 until the playback buffer is filled up initially (the first skew correction happens during that time already). Also, after when the drift seems stabilized, the skew oscillates between +/-7ms still.
Comment 1 René Stadler 2009-10-14 22:20:42 UTC
Wim told me that this is a known pulseaudio bug.

Indeed I can confirm that alsasink using PA through ALSA emulation has the same issue.

So, where's the workaround for this? Having a decent VoIP call is impossible with this bug around. In fact, it renders pulseaudio unusable for GStreamer.
Comment 2 René Stadler 2009-10-17 19:18:01 UTC
I'm not sure the problem is 100% on pulseaudio side. It looks like pulsesink doesn't wait for the uncork to be completed (when I set wait to TRUE it just hangs?!). I see the first latency_update with a non-zero read index coming in ~120ms after the uncork is initiated (which is done on the first write). This looks reasonable to me, assuming that pulseaudio gets the automatic timing update every 100ms.

I'm starting to think that maybe pulseaudio cannot provide accurate timing because it should not. Wouldn't it be more logical that clock drift compensation would be done in pulseaudio itself?
Comment 3 Arun Raghavan 2011-02-01 10:12:31 UTC
Just adding some observations from testing here - in recent core/base (0.10.31), I don't see the glitches that you are talking about in pulsesink. I do see this with alsasink going through PA, however.

Side note: we now uncork the stream after getting enough data to push out.
Comment 4 Sebastian Dröge (slomo) 2011-05-23 12:53:44 UTC
Is there anything left to fix on the GStreamer side?
Comment 5 René Stadler 2011-05-23 13:12:07 UTC
The problem isn't anymore as bad as it used to be. The only thing remaining is the infamous single glitch at the beginning of a live pipeline (there is always one and exactly one skew correction kicking in during the first second).

Maybe Wim has some experimental pulseaudio/ALSA changes that can be used to try this out.
Comment 6 Jan Schmidt 2012-10-03 22:19:57 UTC
Ping?
Comment 7 Arun Raghavan 2012-10-04 04:47:37 UTC
René, do you still see this? With audiotestsrc is-live=true ! pulsesink I don't see any skew correction warnings
Comment 8 René Stadler 2012-10-04 15:32:31 UTC
It seems to be fixed. I can still see the messages and hear a glitch very rarely, but it's not a real-time system (so this is probably fine).
Comment 9 Tim-Philipp Müller 2012-10-04 15:38:07 UTC
(Changing to OBSOLETE since we don't really know what fixed it when etc.)