提交 b282b6f8 编写于 作者: G Gautham R Shenoy 提交者: Linus Torvalds

[PATCH] Change cpu_up and co from __devinit to __cpuinit

Compiling the kernel with CONFIG_HOTPLUG = y and CONFIG_HOTPLUG_CPU = n
with CONFIG_RELOCATABLE = y generates the following modpost warnings

WARNING: vmlinux - Section mismatch: reference to .init.data: from
.text between '_cpu_up' (at offset 0xc0141b7d) and 'cpu_up'
WARNING: vmlinux - Section mismatch: reference to .init.data: from
.text between '_cpu_up' (at offset 0xc0141b9c) and 'cpu_up'
WARNING: vmlinux - Section mismatch: reference to .init.text:__cpu_up
from .text between '_cpu_up' (at offset 0xc0141bd8) and 'cpu_up'
WARNING: vmlinux - Section mismatch: reference to .init.data: from
.text between '_cpu_up' (at offset 0xc0141c05) and 'cpu_up'
WARNING: vmlinux - Section mismatch: reference to .init.data: from
.text between '_cpu_up' (at offset 0xc0141c26) and 'cpu_up'
WARNING: vmlinux - Section mismatch: reference to .init.data: from
.text between '_cpu_up' (at offset 0xc0141c37) and 'cpu_up'

This is because cpu_up, _cpu_up and __cpu_up (in some architectures) are
defined as __devinit
AND
__cpu_up calls some __cpuinit functions.

Since __cpuinit would map to __init with this kind of a configuration,
we get a .text refering .init.data warning.

This patch solves the problem by converting all of __cpu_up, _cpu_up
and cpu_up from __devinit to __cpuinit. The approach is justified since
the callers of cpu_up are either dependent on CONFIG_HOTPLUG_CPU or
are of __init type.

Thus when CONFIG_HOTPLUG_CPU=y, all these cpu up functions would land up
in .text section, and when CONFIG_HOTPLUG_CPU=n, all these functions would
land up in .init section.

Tested on a i386 SMP machine running linux-2.6.20-rc3-mm1.
Signed-off-by: NGautham R Shenoy <ego@in.ibm.com>
Cc: Vivek Goyal <vgoyal@in.ibm.com>
Cc: Mikael Starvik <starvik@axis.com>
Cc: Ralf Baechle <ralf@linux-mips.org>
Cc: Kyle McMartin <kyle@mcmartin.ca>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Cc: "David S. Miller" <davem@davemloft.net>
Signed-off-by: NAndrew Morton <akpm@osdl.org>
Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
上级 0d103e90
...@@ -195,7 +195,7 @@ int setup_profiling_timer(unsigned int multiplier) ...@@ -195,7 +195,7 @@ int setup_profiling_timer(unsigned int multiplier)
*/ */
unsigned long cache_decay_ticks = 1; unsigned long cache_decay_ticks = 1;
int __devinit __cpu_up(unsigned int cpu) int __cpuinit __cpu_up(unsigned int cpu)
{ {
smp_boot_one_cpu(cpu); smp_boot_one_cpu(cpu);
return cpu_online(cpu) ? 0 : -ENOSYS; return cpu_online(cpu) ? 0 : -ENOSYS;
......
...@@ -351,7 +351,7 @@ static void __init do_boot_cpu(int phys_id) ...@@ -351,7 +351,7 @@ static void __init do_boot_cpu(int phys_id)
} }
} }
int __devinit __cpu_up(unsigned int cpu_id) int __cpuinit __cpu_up(unsigned int cpu_id)
{ {
int timeout; int timeout;
......
...@@ -271,7 +271,7 @@ void __devinit smp_prepare_boot_cpu(void) ...@@ -271,7 +271,7 @@ void __devinit smp_prepare_boot_cpu(void)
* and keep control until "cpu_online(cpu)" is set. Note: cpu is * and keep control until "cpu_online(cpu)" is set. Note: cpu is
* physical, not logical. * physical, not logical.
*/ */
int __devinit __cpu_up(unsigned int cpu) int __cpuinit __cpu_up(unsigned int cpu)
{ {
struct task_struct *idle; struct task_struct *idle;
......
...@@ -608,7 +608,7 @@ void smp_cpus_done(unsigned int cpu_max) ...@@ -608,7 +608,7 @@ void smp_cpus_done(unsigned int cpu_max)
} }
int __devinit __cpu_up(unsigned int cpu) int __cpuinit __cpu_up(unsigned int cpu)
{ {
if (cpu != 0 && cpu < parisc_max_cpus) if (cpu != 0 && cpu < parisc_max_cpus)
smp_boot_one_cpu(cpu); smp_boot_one_cpu(cpu);
......
...@@ -468,7 +468,7 @@ static int __devinit cpu_enable(unsigned int cpu) ...@@ -468,7 +468,7 @@ static int __devinit cpu_enable(unsigned int cpu)
return -ENOSYS; return -ENOSYS;
} }
int __devinit __cpu_up(unsigned int cpu) int __cpuinit __cpu_up(unsigned int cpu)
{ {
int c; int c;
......
...@@ -1388,7 +1388,7 @@ void __devinit smp_prepare_boot_cpu(void) ...@@ -1388,7 +1388,7 @@ void __devinit smp_prepare_boot_cpu(void)
{ {
} }
int __devinit __cpu_up(unsigned int cpu) int __cpuinit __cpu_up(unsigned int cpu)
{ {
int ret = smp_boot_one_cpu(cpu); int ret = smp_boot_one_cpu(cpu);
......
...@@ -204,7 +204,7 @@ int cpu_down(unsigned int cpu) ...@@ -204,7 +204,7 @@ int cpu_down(unsigned int cpu)
#endif /*CONFIG_HOTPLUG_CPU*/ #endif /*CONFIG_HOTPLUG_CPU*/
/* Requires cpu_add_remove_lock to be held */ /* Requires cpu_add_remove_lock to be held */
static int __devinit _cpu_up(unsigned int cpu) static int __cpuinit _cpu_up(unsigned int cpu)
{ {
int ret; int ret;
void *hcpu = (void *)(long)cpu; void *hcpu = (void *)(long)cpu;
...@@ -239,7 +239,7 @@ static int __devinit _cpu_up(unsigned int cpu) ...@@ -239,7 +239,7 @@ static int __devinit _cpu_up(unsigned int cpu)
return ret; return ret;
} }
int __devinit cpu_up(unsigned int cpu) int __cpuinit cpu_up(unsigned int cpu)
{ {
int err = 0; int err = 0;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册