mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-18 21:35:44 +00:00
gst/gstdata.c: Adding a categorized debug on data_ref because data_unref has one and i prefer the debug to be symetric.
Original commit message from CVS: 2004-02-09 Julien MOUTTE <julien@moutte.net> * gst/gstdata.c: (gst_data_ref): Adding a categorized debug on data_ref because data_unref has one and i prefer the debug to be symetric. * gst/gstqueue.c: (gst_queue_locked_flush): Fix a huge memleak. Buffers were refed when added to the queue and unrefed only once when the queue was flushed. Now the flush handler unref the buffers two times : first unref for the ref added when pushing in the queue's tail and second unref to destroy the flushed buffer.
This commit is contained in:
parent
9558626b50
commit
df6a979243
4 changed files with 21 additions and 0 deletions
10
ChangeLog
10
ChangeLog
|
@ -1,3 +1,13 @@
|
||||||
|
2004-02-09 Julien MOUTTE <julien@moutte.net>
|
||||||
|
|
||||||
|
* gst/gstdata.c: (gst_data_ref): Adding a categorized debug on data_ref
|
||||||
|
because data_unref has one and i prefer the debug to be symetric.
|
||||||
|
* gst/gstqueue.c: (gst_queue_locked_flush): Fix a huge memleak. Buffers
|
||||||
|
were refed when added to the queue and unrefed only once when the queue
|
||||||
|
was flushed. Now the flush handler unref the buffers two times : first
|
||||||
|
unref for the ref added when pushing in the queue's tail and second
|
||||||
|
unref to destroy the flushed buffer.
|
||||||
|
|
||||||
2004-02-08 Thomas Vander Stichele <thomas at apestaart dot org>
|
2004-02-08 Thomas Vander Stichele <thomas at apestaart dot org>
|
||||||
|
|
||||||
* docs/pwg/building-boiler.xml: fix cvs checkout documentation
|
* docs/pwg/building-boiler.xml: fix cvs checkout documentation
|
||||||
|
|
|
@ -187,6 +187,9 @@ gst_data_ref (GstData *data)
|
||||||
g_return_val_if_fail (data != NULL, NULL);
|
g_return_val_if_fail (data != NULL, NULL);
|
||||||
g_return_val_if_fail (GST_DATA_REFCOUNT_VALUE(data) > 0, NULL);
|
g_return_val_if_fail (GST_DATA_REFCOUNT_VALUE(data) > 0, NULL);
|
||||||
|
|
||||||
|
GST_CAT_LOG (GST_CAT_BUFFER, "ref data %p, count before ref is %d",
|
||||||
|
data, GST_DATA_REFCOUNT_VALUE (data));
|
||||||
|
|
||||||
gst_atomic_int_inc (&data->refcount);
|
gst_atomic_int_inc (&data->refcount);
|
||||||
|
|
||||||
return data;
|
return data;
|
||||||
|
|
|
@ -361,6 +361,10 @@ gst_queue_locked_flush (GstQueue *queue)
|
||||||
{
|
{
|
||||||
while (!g_queue_is_empty (queue->queue)) {
|
while (!g_queue_is_empty (queue->queue)) {
|
||||||
GstData *data = g_queue_pop_head (queue->queue);
|
GstData *data = g_queue_pop_head (queue->queue);
|
||||||
|
/* First loose the reference we added when putting that data in the queue */
|
||||||
|
gst_data_unref (data);
|
||||||
|
/* Then loose another reference because we are supposed to destroy that
|
||||||
|
data when flushing */
|
||||||
gst_data_unref (data);
|
gst_data_unref (data);
|
||||||
}
|
}
|
||||||
queue->timeval = NULL;
|
queue->timeval = NULL;
|
||||||
|
|
|
@ -361,6 +361,10 @@ gst_queue_locked_flush (GstQueue *queue)
|
||||||
{
|
{
|
||||||
while (!g_queue_is_empty (queue->queue)) {
|
while (!g_queue_is_empty (queue->queue)) {
|
||||||
GstData *data = g_queue_pop_head (queue->queue);
|
GstData *data = g_queue_pop_head (queue->queue);
|
||||||
|
/* First loose the reference we added when putting that data in the queue */
|
||||||
|
gst_data_unref (data);
|
||||||
|
/* Then loose another reference because we are supposed to destroy that
|
||||||
|
data when flushing */
|
||||||
gst_data_unref (data);
|
gst_data_unref (data);
|
||||||
}
|
}
|
||||||
queue->timeval = NULL;
|
queue->timeval = NULL;
|
||||||
|
|
Loading…
Reference in a new issue