From 376089db14f0dd74da7936956e7eedc320058d07 Mon Sep 17 00:00:00 2001 From: Philippe Normand Date: Mon, 15 Nov 2010 11:49:24 +0100 Subject: [PATCH] buffer: fix memory corruption --- gst/gstbuffer.c | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/gst/gstbuffer.c b/gst/gstbuffer.c index e00769943c..fa2e17f66f 100644 --- a/gst/gstbuffer.c +++ b/gst/gstbuffer.c @@ -289,7 +289,7 @@ _gst_buffer_copy (GstBuffer * buffer) static void _gst_buffer_free (GstBuffer * buffer) { - GList *walk; + GstBufferMetaItem *walk, *next; g_return_if_fail (buffer != NULL); @@ -304,8 +304,9 @@ _gst_buffer_free (GstBuffer * buffer) if (buffer->parent) gst_buffer_unref (buffer->parent); + /* free metadata */ - for (walk = buffer->priv; walk; walk = walk->next) { + for (walk = buffer->priv; walk; walk = next) { GstBufferMeta *meta = &walk->meta; const GstBufferMetaInfo *info = meta->info; @@ -313,7 +314,8 @@ _gst_buffer_free (GstBuffer * buffer) if (info->free_func) info->free_func (meta, buffer); /* and free the slice */ - g_slice_free1 (ITEM_SIZE (info), meta); + next = walk->next; + g_slice_free (GstBufferMetaItem, walk); } g_slice_free1 (GST_MINI_OBJECT_SIZE (buffer), buffer);