miniobject: free qdata array when the last qdata is removed
authorDavid Svensson Fors <davidsf@axis.com>
Tue, 3 Sep 2019 08:38:13 +0000 (10:38 +0200)
committerTim-Philipp Müller <tim@centricular.com>
Sun, 8 Sep 2019 19:42:59 +0000 (19:42 +0000)
In cases with many long-lived buffers that have qdata only very
briefly, the memory overhead of keeping an array of 16 GstQData
structs for each buffer can be significant. We free the array when
the last qdata is removed, like it was done in 1.14.

Fixes #436

gst/gstminiobject.c

index b55ff58228772812239d446537712e3243ba6667..d5c28baa1166a5250dfa637ca2cd51bf8b0ced43 100644 (file)
@@ -506,7 +506,12 @@ remove_notify (GstMiniObject * object, gint index)
 
   /* remove item */
   priv_data->n_qdata--;
-  if (index != priv_data->n_qdata) {
+  if (priv_data->n_qdata == 0) {
+    /* we don't shrink but free when everything is gone */
+    g_free (priv_data->qdata);
+    priv_data->qdata = NULL;
+    priv_data->n_qdata_len = 0;
+  } else if (index != priv_data->n_qdata) {
     QDATA (priv_data, index) = QDATA (priv_data, priv_data->n_qdata);
   }
 }