[ltt-dev] [PATCH] urcu_ref: do error checking on urcu_ref_put
Mathieu Desnoyers
compudj at krystal.dyndns.org
Thu Jun 9 10:14:51 EDT 2011
* Paolo Bonzini (pbonzini at redhat.com) wrote:
> Underflow is what you really want to trap. When you reach urcu_ref_get, it
> is already too late.
Merged, thanks!
Mathieu
>
> 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
>
>
>
> _______________________________________________
> ltt-dev mailing list
> ltt-dev at lists.casi.polymtl.ca
> http://lists.casi.polymtl.ca/cgi-bin/mailman/listinfo/ltt-dev
>
--
Mathieu Desnoyers
Operating System Efficiency R&D Consultant
EfficiOS Inc.
http://www.efficios.com
More information about the lttng-dev
mailing list