From: Tejun Heo Date: Thu, 26 Feb 2009 01:54:17 +0000 (+0900) Subject: percpu: fix too low alignment restriction on UP X-Git-Tag: firefly_0821_release~13991^2~247^2~14^2 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=e317603694bfd17b28a40de9d65e1a4ec12f816e;p=firefly-linux-kernel-4.4.55.git percpu: fix too low alignment restriction on UP UP __alloc_percpu() triggered WARN_ON_ONCE() if the requested alignment is larger than that of unsigned long long, which is too small for all the cacheline aligned allocations. Bump it up to SMP_CACHE_BYTES which kmalloc allocations generally guarantee. Signed-off-by: Tejun Heo Reported-by: Ingo Molnar --- diff --git a/include/linux/percpu.h b/include/linux/percpu.h index d8e5a9abbce0..545b068bcb70 100644 --- a/include/linux/percpu.h +++ b/include/linux/percpu.h @@ -156,7 +156,7 @@ static inline void *__alloc_percpu(size_t size, size_t align) * on it. Larger alignment should only be used for module * percpu sections on SMP for which this path isn't used. */ - WARN_ON_ONCE(align > __alignof__(unsigned long long)); + WARN_ON_ONCE(align > SMP_CACHE_BYTES); return kzalloc(size, GFP_KERNEL); }