aboutsummaryrefslogtreecommitdiffstats
path: root/arch/powerpc
diff options
context:
space:
mode:
Diffstat (limited to 'arch/powerpc')
-rw-r--r--arch/powerpc/kernel/smp.c14
1 files changed, 8 insertions, 6 deletions
diff --git a/arch/powerpc/kernel/smp.c b/arch/powerpc/kernel/smp.c
index 338950aeb6f6..cefeee81c52e 100644
--- a/arch/powerpc/kernel/smp.c
+++ b/arch/powerpc/kernel/smp.c
@@ -181,12 +181,13 @@ static struct call_data_struct {
181 * <wait> If true, wait (atomically) until function has completed on other CPUs. 181 * <wait> If true, wait (atomically) until function has completed on other CPUs.
182 * [RETURNS] 0 on success, else a negative status code. Does not return until 182 * [RETURNS] 0 on success, else a negative status code. Does not return until
183 * remote CPUs are nearly ready to execute <<func>> or are or have executed. 183 * remote CPUs are nearly ready to execute <<func>> or are or have executed.
184 * <map> is a cpu map of the cpus to send IPI to.
184 * 185 *
185 * You must not call this function with disabled interrupts or from a 186 * You must not call this function with disabled interrupts or from a
186 * hardware interrupt handler or from a bottom half handler. 187 * hardware interrupt handler or from a bottom half handler.
187 */ 188 */
188int smp_call_function_map(void (*func) (void *info), void *info, int nonatomic, 189static int __smp_call_function_map(void (*func) (void *info), void *info,
189 int wait, cpumask_t map) 190 int nonatomic, int wait, cpumask_t map)
190{ 191{
191 struct call_data_struct data; 192 struct call_data_struct data;
192 int ret = -1, num_cpus; 193 int ret = -1, num_cpus;
@@ -265,7 +266,8 @@ int smp_call_function_map(void (*func) (void *info), void *info, int nonatomic,
265static int __smp_call_function(void (*func)(void *info), void *info, 266static int __smp_call_function(void (*func)(void *info), void *info,
266 int nonatomic, int wait) 267 int nonatomic, int wait)
267{ 268{
268 return smp_call_function_map(func,info,nonatomic,wait,cpu_online_map); 269 return __smp_call_function_map(func, info, nonatomic, wait,
270 cpu_online_map);
269} 271}
270 272
271int smp_call_function(void (*func) (void *info), void *info, int nonatomic, 273int smp_call_function(void (*func) (void *info), void *info, int nonatomic,
@@ -278,8 +280,8 @@ int smp_call_function(void (*func) (void *info), void *info, int nonatomic,
278} 280}
279EXPORT_SYMBOL(smp_call_function); 281EXPORT_SYMBOL(smp_call_function);
280 282
281int smp_call_function_single(int cpu, void (*func) (void *info), void *info, int nonatomic, 283int smp_call_function_single(int cpu, void (*func) (void *info), void *info,
282 int wait) 284 int nonatomic, int wait)
283{ 285{
284 cpumask_t map = CPU_MASK_NONE; 286 cpumask_t map = CPU_MASK_NONE;
285 int ret = 0; 287 int ret = 0;
@@ -292,7 +294,7 @@ int smp_call_function_single(int cpu, void (*func) (void *info), void *info, int
292 294
293 cpu_set(cpu, map); 295 cpu_set(cpu, map);
294 if (cpu != get_cpu()) 296 if (cpu != get_cpu())
295 ret = smp_call_function_map(func,info,nonatomic,wait,map); 297 ret = __smp_call_function_map(func, info, nonatomic, wait, map);
296 else { 298 else {
297 local_irq_disable(); 299 local_irq_disable();
298 func(info); 300 func(info);