On Mon, 2015-01-05 at 10:36 +0900, Joonsoo Kim wrote:
> -     preempt_disable();
> -     c = this_cpu_ptr(s->cpu_slab);
> +     do {
> +             tid = this_cpu_read(s->cpu_slab->tid);
> +             c = this_cpu_ptr(s->cpu_slab);
> +     } while (IS_ENABLED(CONFIG_PREEMPT) && unlikely(tid != c->tid));
> +     barrier();

I don't see the compiler reodering the object/page stores below, since c
is updated in the loop anyway. Is this really necessary (same goes for
slab_free)? The generated code by gcc 4.8 looks correct without it.
Additionally, the implied barriers for preemption control aren't really
the same semantics used here (if that is actually the reason why you are
using them).

Thanks,
Davidlohr

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to