depay: correctly skip caps header size
authorAndrzej Bieniek <andrzej.bieniek@pure.com>
Wed, 31 Oct 2012 16:09:26 +0000 (16:09 +0000)
committerWim Taymans <wim.taymans@collabora.co.uk>
Thu, 1 Nov 2012 11:27:13 +0000 (11:27 +0000)
Conflicts:
gst/rtp/gstrtpgstdepay.c

gst/rtp/gstrtpgstdepay.c

index 8c211b67f9aa567d0ce38179693123f23211ef91..2f6fdecaf2780d47169a7ba23bab4a4c97a4d58a 100644 (file)
@@ -231,6 +231,8 @@ gst_rtp_gst_depay_process (GstRTPBaseDepayload * depayload, GstBuffer * buf)
       /* C bit, we have inline caps */
       gst_buffer_map (outbuf, &map, GST_MAP_READ);
 
+      GST_DEBUG_OBJECT (rtpgstdepay, "buffer size %u", map.size);
+
       /* start reading the length, we need this to skip to the data later */
       csize = offset = 0;
       left = map.size;
@@ -243,6 +245,8 @@ gst_rtp_gst_depay_process (GstRTPBaseDepayload * depayload, GstBuffer * buf)
         csize = (csize << 7) | (b & 0x7f);
       } while (b & 0x80);
 
+      /* we have read csize, reduce remaining buffer size */
+      left -= offset;
       if (left < csize) {
         gst_buffer_unmap (outbuf, &map);
         goto too_small;
@@ -259,8 +263,10 @@ gst_rtp_gst_depay_process (GstRTPBaseDepayload * depayload, GstBuffer * buf)
       GST_DEBUG_OBJECT (rtpgstdepay,
           "inline caps %u, length %u, %" GST_PTR_FORMAT, CV, csize, outcaps);
 
+      GST_DEBUG_OBJECT (rtpgstdepay, "sub buffer: offset %u, size %u", offset,
+          left);
       /* create real data buffer when needed */
-      if (map.size)
+      if (left)
         subbuf =
             gst_buffer_copy_region (outbuf, GST_BUFFER_COPY_ALL, offset, left);
       else