summaryrefslogtreecommitdiffstats
path: root/ext/mimic/gstmimdec.c
diff options
context:
space:
mode:
authorDave Robillard <dave@drobilla.net>2009-07-10 20:44:23 -0400
committerDave Robillard <dave@drobilla.net>2009-07-10 20:44:23 -0400
commite3f368047b84fa35a3df286ef9775fed09e9eef9 (patch)
tree3893f3a6297d382c30e7a0744a1af4efec71c5ee /ext/mimic/gstmimdec.c
parente289c875a5e0ee56dd8289e78b63f36f709b6534 (diff)
parentba89c9e518ded3d919461903a444799a5115c34f (diff)
downloadgst-plugins-bad-e3f368047b84fa35a3df286ef9775fed09e9eef9.tar.gz
gst-plugins-bad-e3f368047b84fa35a3df286ef9775fed09e9eef9.tar.bz2
gst-plugins-bad-e3f368047b84fa35a3df286ef9775fed09e9eef9.zip
Merge branch 'fdo' into lv2
Diffstat (limited to 'ext/mimic/gstmimdec.c')
-rw-r--r--ext/mimic/gstmimdec.c8
1 files changed, 7 insertions, 1 deletions
diff --git a/ext/mimic/gstmimdec.c b/ext/mimic/gstmimdec.c
index c7f1ec87..1579bd41 100644
--- a/ext/mimic/gstmimdec.c
+++ b/ext/mimic/gstmimdec.c
@@ -172,7 +172,7 @@ gst_mimdec_chain (GstPad * pad, GstBuffer * in)
(mimdec->have_header ? mimdec->payload_size : 24)) {
if (!mimdec->have_header) {
header = (guchar *) gst_adapter_peek (mimdec->adapter, 24);
- header_size = GUINT16_FROM_LE (*(guint16 *) (header + 0));
+ header_size = header[0];
if (header_size != 24) {
GST_WARNING_OBJECT (mimdec,
"invalid frame: header size %d incorrect", header_size);
@@ -201,6 +201,12 @@ gst_mimdec_chain (GstPad * pad, GstBuffer * in)
mimdec->have_header = TRUE;
}
+ /* Check if its paused frame, drop it */
+ if (mimdec->payload_size == 0) {
+ mimdec->have_header = FALSE;
+ continue;
+ }
+
if (gst_adapter_available (mimdec->adapter) < mimdec->payload_size) {
goto out;
}