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 324807 - GstBin: re-enable duration caching
GstBin: re-enable duration caching
Status: RESOLVED OBSOLETE
Product: GStreamer
Classification: Platform
Component: gstreamer (core)
git master
Other Linux
: Normal enhancement
: git master
Assigned To: GStreamer Maintainers
GStreamer Maintainers
Depends on:
Blocks:
 
 
Reported: 2005-12-22 14:42 UTC by Tim-Philipp Müller
Modified: 2018-11-03 12:12 UTC
See Also:
GNOME target: ---
GNOME version: ---



Description Tim-Philipp Müller 2005-12-22 14:42:29 UTC
Something seems to be wrong with duration query caching in bins.

I've got a playbin using a cd audio source. When the source changes tracks, it posts a new DURATION message on the bus with the duration of the new track. That should clear the existing cached durations, yet further gst_element_query (playbin, ...) after that return the same duration as previous calls.

Haven't had a chance to look into it yet. Things work fine though if I comment out the block where it returns cached durations in gstbin.c, gst_bin_query().
Comment 1 alfredoj69 2005-12-22 14:47:40 UTC
Thanks for taking the time to report this bug.
This bug report isn't very useful because it doesn't describe the bug well. If you have time and can still reproduce the bug, please read http://bugzilla.gnome.org/bug-HOWTO.html and add a more useful description to this bug.
Comment 2 Elijah Newren 2005-12-22 16:07:00 UTC
alfredoj69: Tim described it well enough--he even pointed out a workaround by saying what part of the code to modify.
Comment 3 Tim-Philipp Müller 2005-12-23 19:42:12 UTC
So, here's roughly what I think happens (schematically):

 - playbin contains, say,
     - bin1 with the source and decoder
     - bin2 bin with volume ! audioconvert ! audiosink

now, the source posts a DURATION message, which clears all cached durations for bin1 and then clears all cached durations for bin2. However, the cached durations from bin2 will not be cleard. So then, next time one does


   gst_element_query_duration (playbin, ....)

there is no cached query, so the bin will pass the query on to its children. If that child is bin2, it will return the outdated previously cached query.

Not sure what the right solution for this is. Maybe have all elements post a duration message on the bus whenever they come across a NEW_SEGMENT event maybe? Or introduce some kind of gst_bin_clear_cached_durations() which a bin calls on all children that are bins after clearing its own cached durations.

Comment 4 Tim-Philipp Müller 2005-12-29 18:50:41 UTC
I've disabled duration query caching in bins for the time being (just in case anyone tries to reproduce the problem with current CVS ;)).

Comment 5 Wim Taymans 2006-02-14 15:00:23 UTC
interesting... looks like query caching should only be done by toplevel bins (possibly only GstPipeline). It's quite important to have this caching working as for very precise time reporting (NLE) this needs to be *FAAAST*, we don't want to dive into the pipeline for each query.
Comment 6 Tim-Philipp Müller 2006-02-14 15:18:03 UTC
Before re-enabling this we should also a look at the usual suspects like mad/mpegdemux etc. to make sure they emit DURATION messages when the duration changes by more than ~1 second (or whatever value).
Comment 7 Wim Taymans 2006-02-14 15:33:57 UTC
bah.. what about the unusual suspects? Andy suggests making a list of plugins and fix them at the same time.
Comment 8 Jan Schmidt 2012-10-02 14:03:21 UTC
Is this bug obsolete?
Comment 9 Tim-Philipp Müller 2012-10-02 15:49:44 UTC
It was obsolete for a while, but it's not obsolete any longer.

Duration caching has been disabled in GstBin because of the duration message changes. It needs to be re-implemented. Should just cache durations in various formats and throw away all cached durations in all formats on duration-changed messages.
Comment 10 GStreamer system administrator 2018-11-03 12:12:25 UTC
-- GitLab Migration Automatic Message --

This bug has been migrated to freedesktop.org's GitLab instance and has been closed from further activity.

You can subscribe and participate further through the new bug through this link to our GitLab instance: https://gitlab.freedesktop.org/gstreamer/gstreamer/issues/4.