matroska: catch failure to map buffer
authorVincent Penquerc'h <vincent.penquerch@collabora.co.uk>
Fri, 2 May 2014 10:20:33 +0000 (11:20 +0100)
committerVincent Penquerc'h <vincent.penquerch@collabora.co.uk>
Fri, 2 May 2014 10:20:33 +0000 (11:20 +0100)
Avoids dereferencing NULL.

Coverity 1139712

gst/matroska/ebml-write.c

index 4596c2f20090deb77943f8f2ebcfbdda1807570f..d39a23adbffc83c2b07eb38dca315dad60eb4c4d 100644 (file)
@@ -427,7 +427,10 @@ gst_ebml_write_element_push (GstEbmlWrite * ebml, GstBuffer * buf,
       gst_buffer_map (buf, &map, GST_MAP_READ);
       buf_data = map.data;
     }
-    if (!gst_byte_writer_put_data (ebml->streamheader, buf_data, data_size))
+    if (!buf_data)
+      GST_WARNING ("Failed to map buffer");
+    else if (!gst_byte_writer_put_data (ebml->streamheader, buf_data,
+            data_size))
       GST_WARNING ("Error writing data to streamheader");
   }
   if (ebml->cache) {
@@ -435,7 +438,9 @@ gst_ebml_write_element_push (GstEbmlWrite * ebml, GstBuffer * buf,
       gst_buffer_map (buf, &map, GST_MAP_READ);
       buf_data = map.data;
     }
-    if (!gst_byte_writer_put_data (ebml->cache, buf_data, data_size))
+    if (!buf_data)
+      GST_WARNING ("Failed to map buffer");
+    else if (!gst_byte_writer_put_data (ebml->cache, buf_data, data_size))
       GST_WARNING ("Error writing data to cache");
     if (map.data)
       gst_buffer_unmap (buf, &map);