提交 8616dff5 编写于 作者: V Vladimir Murzin 提交者: Benjamin Herrenschmidt

powerpc: Fix section mismatch warning in free_lppacas

While cross-building for PPC64 I've got bunch of

WARNING: arch/powerpc/kernel/built-in.o(.text.unlikely+0x2d2): Section
mismatch in reference from the function .free_lppacas() to the variable
.init.data:lppaca_size The function .free_lppacas() references the variable
__initdata lppaca_size. This is often because .free_lppacas lacks a __initdata
annotation or the annotation of lppaca_size is wrong.

Fix it by using proper annotation for free_lppacas. Additionally, annotate
{allocate,new}_llpcas properly.
Signed-off-by: NVladimir Murzin <murzin.v@gmail.com>
Acked-by: NMichael Ellerman <michael@ellerman.id.au>
Signed-off-by: NBenjamin Herrenschmidt <benh@kernel.crashing.org>
上级 0edfdd10
...@@ -46,7 +46,7 @@ struct lppaca lppaca[] = { ...@@ -46,7 +46,7 @@ struct lppaca lppaca[] = {
static struct lppaca *extra_lppacas; static struct lppaca *extra_lppacas;
static long __initdata lppaca_size; static long __initdata lppaca_size;
static void allocate_lppacas(int nr_cpus, unsigned long limit) static void __init allocate_lppacas(int nr_cpus, unsigned long limit)
{ {
if (nr_cpus <= NR_LPPACAS) if (nr_cpus <= NR_LPPACAS)
return; return;
...@@ -57,7 +57,7 @@ static void allocate_lppacas(int nr_cpus, unsigned long limit) ...@@ -57,7 +57,7 @@ static void allocate_lppacas(int nr_cpus, unsigned long limit)
PAGE_SIZE, limit)); PAGE_SIZE, limit));
} }
static struct lppaca *new_lppaca(int cpu) static struct lppaca * __init new_lppaca(int cpu)
{ {
struct lppaca *lp; struct lppaca *lp;
...@@ -70,7 +70,7 @@ static struct lppaca *new_lppaca(int cpu) ...@@ -70,7 +70,7 @@ static struct lppaca *new_lppaca(int cpu)
return lp; return lp;
} }
static void free_lppacas(void) static void __init free_lppacas(void)
{ {
long new_size = 0, nr; long new_size = 0, nr;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册