Re: [PATCH] generic dynamic per cpu refcounting
From: Tejun Heo
Date: Tue Jan 29 2013 - 14:29:19 EST
Hey, Kent.
On Tue, Jan 29, 2013 at 08:39:42AM -0800, Kent Overstreet wrote:
> Oh, if this is going to be widely used I should probably have a
> different implementation for archs that don't have atomic64_t in
> hardware. Don't suppose you know the CONFIG_ macro to test against? I
> couldn't find it when I was looking recently.
!CONFIG_GENERIC_ATOMIC64, I think. I don't think it's worthwhile to
worry about tho. Reverting to simple atomic_t ops on !CONFIG_SMP
should cover most relevant cases.
Very tentative review follows.
> +#define PCPU_REF_PTR 0
> +#define PCPU_REF_NONE 1
> +#define PCPU_REF_DEAD 2
Do we still need to distinguish between NONE and DEAD? It would be
nice if we can just test against NULL.
> +/**
> + * percpu_ref_get - increment a dynamic percpu refcount
> + *
> + * Analagous to atomic_inc().
> + */
> +static inline void percpu_ref_get(struct percpu_ref *ref)
> +{
> + unsigned long pcpu_count;
> +
> + preempt_disable();
> +
> + pcpu_count = ACCESS_ONCE(ref->pcpu_count);
> +
> + if (REF_STATUS(pcpu_count) == PCPU_REF_PTR) {
> + /* for rcu - we're not using rcu_dereference() */
> + smp_read_barrier_depends();
Let's explain more. :)
> + __this_cpu_inc(*((unsigned __percpu *) pcpu_count));
What about overflow? Note that we can have systemetic cases where ref
is gotten on one cpu and put on another transferring counts in a
specific direction.
> +#define PCPU_COUNT_BITS 50
> +#define PCPU_COUNT_MASK ((1LL << PCPU_COUNT_BITS) - 1)
> +
> +#define PCPU_COUNT_BIAS (1ULL << 32)
I really don't get this. Why use 1<<32 for bias which isn't too
difficult to overflow especially if you have many cpu threads and some
systemetic drift in percpu refs? What's the point of not using the
higher bits? Is it to encode count usage statistics into the same
counter? If so, just add another field. 24bytes is fine.
I'd really like to see just basic percpu refcnt with async and sync
interfaces w/o dynamic allocation. At this point, we aren't really
sure if there are gonna be enough benefits or use cases from dynamic
allocation, so I don't really see the point in the added complexity.
Let's start with basic stuff and add on dynamic alloc if it actually
is necessary.
Thanks.
--
tejun
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/