aacparse: Avoid over-skipping when checking LOAS config

There might be multiple LOAS config in a row in a full frame. The first
one might be a multi-layer config (which we can't properly parse yet)...
but then followed by a valid (single-layer) one.

The code was previously skipping whole frames (instead of just the LOAS
config we failed to read) resulting in multiple frames (seen up to 6s in
some situation) being dropped before finally getting the configuration.

https://bugzilla.gnome.org/show_bug.cgi?id=758826
This commit is contained in:
Edward Hervey 2015-11-30 08:42:35 +01:00 committed by Edward Hervey
parent f173bd7d16
commit 6888871d2a

View file

@ -1302,7 +1302,10 @@ gst_aac_parse_handle_frame (GstBaseParse * parse,
/* This is pretty normal when skipping data at the start of
* random stream (MPEG-TS capture for example) */
GST_DEBUG_OBJECT (aacparse, "Error reading LOAS config. Skipping.");
*skipsize = map.size;
/* Since we don't fully parse the LOAS config, we don't know for sure
* how much to skip. Just skip 1 to end up to the next marker and
* resume parsing from there */
*skipsize = 1;
goto exit;
}