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 737396 - decodebin doesn't limit src caps on parsers
decodebin doesn't limit src caps on parsers
Status: RESOLVED OBSOLETE
Product: GStreamer
Classification: Platform
Component: gst-plugins-base
git master
Other All
: Normal major
: git master
Assigned To: GStreamer Maintainers
GStreamer Maintainers
Depends on:
Blocks: 737455
 
 
Reported: 2014-09-26 00:30 UTC by Matej Knopp
Modified: 2018-05-06 09:29 UTC
See Also:
GNOME target: ---
GNOME version: ---



Description Matej Knopp 2014-09-26 00:30:32 UTC
AAC parser never transforms stream:
  - aacparse srccaps are not fixed, so decodebin only knows the caps when aacparse sets them on pad; by then it is too late and decodebin won't find decoder factory
 - example - ADTS input and decoder that can only decode raw stream;

Same happens with h.264 parser. i.e. h.264 decoder that accepts byte-stream only will not currently work with h.264 parser.

Behavior is slightly different between these two. H.264 parser defaults to AVC, so unless srccaps are filtered, regardless of input it outputs AVC; aacparse outputs stream in same format as input, unless srccaps are filtered.
Comment 1 Sebastian Dröge (slomo) 2014-09-26 07:31:24 UTC
Do you have a testcase for this? This is supposed to be handled by the capsfilter magic in decodebin that happens when a Parser/Converter is added to the pipeline.
Comment 2 Matej Knopp 2014-09-26 17:33:51 UTC
So, the magic is there but it doesn't really seem to work :)

1.aacparse doesn't have Converter in metadata, so decodebin doesn't execute the is_parser_converter branch

2. even when is_parser_converter branch is executed, the following code in decodebin

    /* Append the parser caps to prevent any not-negotiated errors */
    filter_caps = gst_caps_merge (filter_caps, gst_caps_ref (caps));

just merges the filtered caps with parser original srcpad caps, so it ends up where it was at the beginning. perhaps it should be in "else" block?
Comment 3 Matej Knopp 2014-09-26 17:39:32 UTC
(sorry, disregard the else block. the is_parse_converter branch is longer than I realized)
Comment 4 Tim-Philipp Müller 2014-09-26 18:01:31 UTC
It would be really good to have a unit test for this :)
Comment 5 Sebastian Dröge (slomo) 2014-09-26 19:20:54 UTC
(In reply to comment #2)

> 2. even when is_parser_converter branch is executed, the following code in
> decodebin
> 
>     /* Append the parser caps to prevent any not-negotiated errors */
>     filter_caps = gst_caps_merge (filter_caps, gst_caps_ref (caps));
> 
> just merges the filtered caps with parser original srcpad caps, so it ends up
> where it was at the beginning. perhaps it should be in "else" block?

But the decoder preferred caps are at the beginning. And e.g. h264parse prefers them over others then.
Comment 6 Matej Knopp 2014-09-26 20:18:57 UTC
It doesn't seem that this is enough to force stream transformation. I don't understand how this is supposed to work. 

Are you saying that the parser/converter should always transform to caps at the beginning, even though second structure srccaps is same as sink caps? If so then how is the converter supposed to know that passthrough is not ok in this case (even though as far as it is concerned the peer accepts parser sink caps)?
Comment 7 Edward Hervey 2018-05-06 09:29:33 UTC
The issue doesn't happen with parsebin/decodebin3 (because everything is linked at negotiation time).