Use g_atomic_int_(inc|dec_and_test) for reference counting.

2004-02-27  Sebastian Wilhelmi  <seppi@seppi.de>

	* glib/gasyncqueue.c, glib/gasyncqueue.h: Use
	g_atomic_int_(inc|dec_and_test) for reference
	counting. g_async_queue_unref_and_unlock and
	g_async_queue_ref_locked is deprecated, but still there to
	preserve ABI.
This commit is contained in:
Sebastian Wilhelmi 2004-02-27 16:06:31 +00:00 committed by Sebastian Wilhelmi
parent a4d564c592
commit 4054cc5979
8 changed files with 73 additions and 39 deletions

View File

@ -1,3 +1,11 @@
2004-02-27 Sebastian Wilhelmi <seppi@seppi.de>
* glib/gasyncqueue.c, glib/gasyncqueue.h: Use
g_atomic_int_(inc|dec_and_test) for reference
counting. g_async_queue_unref_and_unlock and
g_async_queue_ref_locked is deprecated, but still there to
preserve ABI.
Fri Feb 27 02:00:34 2004 Matthias Clasen <maclas@gmx.de> Fri Feb 27 02:00:34 2004 Matthias Clasen <maclas@gmx.de>
* acglib.m4: quote AC_DEFUN macro names so automake * acglib.m4: quote AC_DEFUN macro names so automake

View File

@ -1,3 +1,11 @@
2004-02-27 Sebastian Wilhelmi <seppi@seppi.de>
* glib/gasyncqueue.c, glib/gasyncqueue.h: Use
g_atomic_int_(inc|dec_and_test) for reference
counting. g_async_queue_unref_and_unlock and
g_async_queue_ref_locked is deprecated, but still there to
preserve ABI.
Fri Feb 27 02:00:34 2004 Matthias Clasen <maclas@gmx.de> Fri Feb 27 02:00:34 2004 Matthias Clasen <maclas@gmx.de>
* acglib.m4: quote AC_DEFUN macro names so automake * acglib.m4: quote AC_DEFUN macro names so automake

View File

@ -1,3 +1,11 @@
2004-02-27 Sebastian Wilhelmi <seppi@seppi.de>
* glib/gasyncqueue.c, glib/gasyncqueue.h: Use
g_atomic_int_(inc|dec_and_test) for reference
counting. g_async_queue_unref_and_unlock and
g_async_queue_ref_locked is deprecated, but still there to
preserve ABI.
Fri Feb 27 02:00:34 2004 Matthias Clasen <maclas@gmx.de> Fri Feb 27 02:00:34 2004 Matthias Clasen <maclas@gmx.de>
* acglib.m4: quote AC_DEFUN macro names so automake * acglib.m4: quote AC_DEFUN macro names so automake

View File

@ -1,3 +1,11 @@
2004-02-27 Sebastian Wilhelmi <seppi@seppi.de>
* glib/gasyncqueue.c, glib/gasyncqueue.h: Use
g_atomic_int_(inc|dec_and_test) for reference
counting. g_async_queue_unref_and_unlock and
g_async_queue_ref_locked is deprecated, but still there to
preserve ABI.
Fri Feb 27 02:00:34 2004 Matthias Clasen <maclas@gmx.de> Fri Feb 27 02:00:34 2004 Matthias Clasen <maclas@gmx.de>
* acglib.m4: quote AC_DEFUN macro names so automake * acglib.m4: quote AC_DEFUN macro names so automake

View File

@ -1,3 +1,11 @@
2004-02-27 Sebastian Wilhelmi <seppi@seppi.de>
* glib/gasyncqueue.c, glib/gasyncqueue.h: Use
g_atomic_int_(inc|dec_and_test) for reference
counting. g_async_queue_unref_and_unlock and
g_async_queue_ref_locked is deprecated, but still there to
preserve ABI.
Fri Feb 27 02:00:34 2004 Matthias Clasen <maclas@gmx.de> Fri Feb 27 02:00:34 2004 Matthias Clasen <maclas@gmx.de>
* acglib.m4: quote AC_DEFUN macro names so automake * acglib.m4: quote AC_DEFUN macro names so automake

View File

@ -1,3 +1,11 @@
2004-02-27 Sebastian Wilhelmi <seppi@seppi.de>
* glib/gasyncqueue.c, glib/gasyncqueue.h: Use
g_atomic_int_(inc|dec_and_test) for reference
counting. g_async_queue_unref_and_unlock and
g_async_queue_ref_locked is deprecated, but still there to
preserve ABI.
Fri Feb 27 02:00:34 2004 Matthias Clasen <maclas@gmx.de> Fri Feb 27 02:00:34 2004 Matthias Clasen <maclas@gmx.de>
* acglib.m4: quote AC_DEFUN macro names so automake * acglib.m4: quote AC_DEFUN macro names so automake

View File

@ -35,7 +35,7 @@ struct _GAsyncQueue
GCond *cond; GCond *cond;
GQueue *queue; GQueue *queue;
guint waiting_threads; guint waiting_threads;
guint ref_count; gint32 ref_count;
}; };
/** /**
@ -61,7 +61,8 @@ g_async_queue_new ()
* g_async_queue_ref: * g_async_queue_ref:
* @queue: a #GAsyncQueue. * @queue: a #GAsyncQueue.
* *
* Increases the reference count of the asynchronous @queue by 1. * Increases the reference count of the asynchronous @queue by 1. You
* do not need to hold the lock to call this function.
**/ **/
void void
g_async_queue_ref (GAsyncQueue *queue) g_async_queue_ref (GAsyncQueue *queue)
@ -69,17 +70,14 @@ g_async_queue_ref (GAsyncQueue *queue)
g_return_if_fail (queue); g_return_if_fail (queue);
g_return_if_fail (queue->ref_count > 0); g_return_if_fail (queue->ref_count > 0);
g_mutex_lock (queue->mutex); g_atomic_int_inc (&queue->ref_count);
queue->ref_count++;
g_mutex_unlock (queue->mutex);
} }
/** /**
* g_async_queue_ref_unlocked: * g_async_queue_ref_unlocked:
* @queue: a #GAsyncQueue. * @queue: a #GAsyncQueue.
* *
* Increases the reference count of the asynchronous @queue by 1. This * Increases the reference count of the asynchronous @queue by 1.
* function must be called while holding the @queue's lock.
**/ **/
void void
g_async_queue_ref_unlocked (GAsyncQueue *queue) g_async_queue_ref_unlocked (GAsyncQueue *queue)
@ -87,7 +85,7 @@ g_async_queue_ref_unlocked (GAsyncQueue *queue)
g_return_if_fail (queue); g_return_if_fail (queue);
g_return_if_fail (queue->ref_count > 0); g_return_if_fail (queue->ref_count > 0);
queue->ref_count++; g_atomic_int_inc (&queue->ref_count);
} }
/** /**
@ -97,33 +95,16 @@ g_async_queue_ref_unlocked (GAsyncQueue *queue)
* Decreases the reference count of the asynchronous @queue by 1 and * Decreases the reference count of the asynchronous @queue by 1 and
* releases the lock. This function must be called while holding the * releases the lock. This function must be called while holding the
* @queue's lock. If the reference count went to 0, the @queue will be * @queue's lock. If the reference count went to 0, the @queue will be
* destroyed and the memory allocated will be freed. So you are not * destroyed and the memory allocated will be freed.
* allowed to use the @queue afterwards, as it might have disappeared.
* The obvious asymmetry (it is not named
* g_async_queue_unref_unlocked(<!-- -->)) is because the queue can't be
* unlocked after unreffing it, as it might already have disappeared.
**/ **/
void void
g_async_queue_unref_and_unlock (GAsyncQueue *queue) g_async_queue_unref_and_unlock (GAsyncQueue *queue)
{ {
gboolean stop;
g_return_if_fail (queue); g_return_if_fail (queue);
g_return_if_fail (queue->ref_count > 0); g_return_if_fail (queue->ref_count > 0);
queue->ref_count--;
stop = (queue->ref_count == 0);
g_mutex_unlock (queue->mutex); g_mutex_unlock (queue->mutex);
g_async_queue_unref (queue);
if (stop)
{
g_return_if_fail (queue->waiting_threads == 0);
g_mutex_free (queue->mutex);
if (queue->cond)
g_cond_free (queue->cond);
g_queue_free (queue->queue);
g_free (queue);
}
} }
/** /**
@ -133,16 +114,24 @@ g_async_queue_unref_and_unlock (GAsyncQueue *queue)
* Decreases the reference count of the asynchronous @queue by 1. If * Decreases the reference count of the asynchronous @queue by 1. If
* the reference count went to 0, the @queue will be destroyed and the * the reference count went to 0, the @queue will be destroyed and the
* memory allocated will be freed. So you are not allowed to use the * memory allocated will be freed. So you are not allowed to use the
* @queue afterwards, as it might have disappeared. * @queue afterwards, as it might have disappeared. You do not need to
* hold the lock to call this function.
**/ **/
void void
g_async_queue_unref (GAsyncQueue *queue) g_async_queue_unref (GAsyncQueue *queue)
{ {
g_return_if_fail (queue); g_return_if_fail (queue);
g_return_if_fail (queue->ref_count > 0); g_return_if_fail (queue->ref_count > 0);
g_mutex_lock (queue->mutex); if (g_atomic_int_dec_and_test (&queue->ref_count))
g_async_queue_unref_and_unlock (queue); {
g_return_if_fail (queue->waiting_threads == 0);
g_mutex_free (queue->mutex);
if (queue->cond)
g_cond_free (queue->cond);
g_queue_free (queue->queue);
g_free (queue);
}
} }
/** /**

View File

@ -46,17 +46,14 @@ GAsyncQueue* g_async_queue_new (void);
void g_async_queue_lock (GAsyncQueue *queue); void g_async_queue_lock (GAsyncQueue *queue);
void g_async_queue_unlock (GAsyncQueue *queue); void g_async_queue_unlock (GAsyncQueue *queue);
/* Ref and unref the GAsyncQueue. g_async_queue_unref_unlocked makes /* Ref and unref the GAsyncQueue. */
* no sense, as after the unreffing the Queue might be gone and can't
* be unlocked. So you have a function to call, if you don't hold the
* lock (g_async_queue_unref) and one to call, when you already hold
* the lock (g_async_queue_unref_and_unlock). After that however, you
* don't hold the lock anymore and the Queue might in fact be
* destroyed, if you unrefed to zero. */
void g_async_queue_ref (GAsyncQueue *queue); void g_async_queue_ref (GAsyncQueue *queue);
void g_async_queue_ref_unlocked (GAsyncQueue *queue);
void g_async_queue_unref (GAsyncQueue *queue); void g_async_queue_unref (GAsyncQueue *queue);
#ifndef G_DISABLE_DEPRECATED
/* You don't have to hold the lock for calling *_ref and *_unref anymore. */
void g_async_queue_ref_unlocked (GAsyncQueue *queue);
void g_async_queue_unref_and_unlock (GAsyncQueue *queue); void g_async_queue_unref_and_unlock (GAsyncQueue *queue);
#endif /* !G_DISABLE_DEPRECATED */
/* Push data into the async queue. Must not be NULL. */ /* Push data into the async queue. Must not be NULL. */
void g_async_queue_push (GAsyncQueue *queue, void g_async_queue_push (GAsyncQueue *queue,