提交 52a119fe 编写于 作者: A Ashok Raj 提交者: Linus Torvalds

[PATCH] make smp_prepare_cpu to a weak function

I really wish smp_prepare_cpu() would disappear eventually.  In the interim
this is ideally a weak function, so we dont end up changing several places
to define this dummy in headers.

Today since the dummy declaration is done only in drivers/base/cpu.c but
the function is called in kernel/power/smp.c i get undefined reference in
my cpu hotplug code for x86_64 under development.
Signed-off-by: NAshok Raj <ashok.raj@intel.com>
Signed-off-by: NAndrew Morton <akpm@osdl.org>
Signed-off-by: NLinus Torvalds <torvalds@osdl.org>
上级 e1367daf
...@@ -16,9 +16,10 @@ struct sysdev_class cpu_sysdev_class = { ...@@ -16,9 +16,10 @@ struct sysdev_class cpu_sysdev_class = {
EXPORT_SYMBOL(cpu_sysdev_class); EXPORT_SYMBOL(cpu_sysdev_class);
#ifdef CONFIG_HOTPLUG_CPU #ifdef CONFIG_HOTPLUG_CPU
#ifndef __HAVE_ARCH_SMP_PREPARE_CPU int __attribute__((weak)) smp_prepare_cpu (int cpu)
#define smp_prepare_cpu(cpu) (0) {
#endif return 0;
}
static ssize_t show_online(struct sys_device *dev, char *buf) static ssize_t show_online(struct sys_device *dev, char *buf)
{ {
...@@ -41,7 +42,7 @@ static ssize_t store_online(struct sys_device *dev, const char *buf, ...@@ -41,7 +42,7 @@ static ssize_t store_online(struct sys_device *dev, const char *buf,
break; break;
case '1': case '1':
ret = smp_prepare_cpu(cpu->sysdev.id); ret = smp_prepare_cpu(cpu->sysdev.id);
if (ret == 0) if (!ret)
ret = cpu_up(cpu->sysdev.id); ret = cpu_up(cpu->sysdev.id);
break; break;
default: default:
......
...@@ -51,9 +51,6 @@ extern u8 x86_cpu_to_apicid[]; ...@@ -51,9 +51,6 @@ extern u8 x86_cpu_to_apicid[];
#ifdef CONFIG_HOTPLUG_CPU #ifdef CONFIG_HOTPLUG_CPU
extern void cpu_exit_clear(void); extern void cpu_exit_clear(void);
extern void cpu_uninit(void); extern void cpu_uninit(void);
#define __HAVE_ARCH_SMP_PREPARE_CPU
extern int smp_prepare_cpu(int cpu);
#endif #endif
/* /*
......
...@@ -69,6 +69,7 @@ extern struct semaphore cpucontrol; ...@@ -69,6 +69,7 @@ extern struct semaphore cpucontrol;
register_cpu_notifier(&fn##_nb); \ register_cpu_notifier(&fn##_nb); \
} }
int cpu_down(unsigned int cpu); int cpu_down(unsigned int cpu);
extern int __attribute__((weak)) smp_prepare_cpu(int cpu);
#define cpu_is_offline(cpu) unlikely(!cpu_online(cpu)) #define cpu_is_offline(cpu) unlikely(!cpu_online(cpu))
#else #else
#define lock_cpu_hotplug() do { } while (0) #define lock_cpu_hotplug() do { } while (0)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册