[ltt-dev] [PATCH] urcu_ref: do error checking on urcu_ref_put

Paolo Bonzini pbonzini at redhat.com
Thu Jun 9 09:57:43 EDT 2011


Underflow is what you really want to trap.  When you reach urcu_ref_get, it
is already too late.

Signed-off-by: Paolo Bonzini <pbonzini at redhat.com>
---
 urcu/urcu_ref.h |    7 ++++---
 1 files changed, 4 insertions(+), 3 deletions(-)

diff --git a/urcu/urcu_ref.h b/urcu/urcu_ref.h
index bce7116..06b81b9 100644
--- a/urcu/urcu_ref.h
+++ b/urcu/urcu_ref.h
@@ -33,14 +33,15 @@ static inline void urcu_ref_init(struct urcu_ref *ref)
 
 static inline void urcu_ref_get(struct urcu_ref *ref)
 {
-	long res = uatomic_add_return(&ref->refcount, 1);
-	assert(res != 0);
+	uatomic_add(&ref->refcount, 1);
 }
 
 static inline void urcu_ref_put(struct urcu_ref *ref,
 				void (*release)(struct urcu_ref *))
 {
-	if (!uatomic_sub_return(&ref->refcount, 1))
+        long res = uatomic_sub_return(&ref->refcount, 1);
+        assert (res >= 0);
+        if (res == 0)
 		release(ref);
 }
 
-- 
1.7.4.4






More information about the lttng-dev mailing list