aboutsummaryrefslogtreecommitdiffstats
path: root/arch/s390/kernel/smp.c
diff options
context:
space:
mode:
Diffstat (limited to 'arch/s390/kernel/smp.c')
-rw-r--r--arch/s390/kernel/smp.c16
1 files changed, 7 insertions, 9 deletions
diff --git a/arch/s390/kernel/smp.c b/arch/s390/kernel/smp.c
index 182c085ae4dd..aff9f853fc30 100644
--- a/arch/s390/kernel/smp.c
+++ b/arch/s390/kernel/smp.c
@@ -170,30 +170,28 @@ int smp_call_function(void (*func) (void *info), void *info, int nonatomic,
170EXPORT_SYMBOL(smp_call_function); 170EXPORT_SYMBOL(smp_call_function);
171 171
172/* 172/*
173 * smp_call_function_on: 173 * smp_call_function_single:
174 * @cpu: the CPU where func should run
174 * @func: the function to run; this must be fast and non-blocking 175 * @func: the function to run; this must be fast and non-blocking
175 * @info: an arbitrary pointer to pass to the function 176 * @info: an arbitrary pointer to pass to the function
176 * @nonatomic: unused 177 * @nonatomic: unused
177 * @wait: if true, wait (atomically) until function has completed on other CPUs 178 * @wait: if true, wait (atomically) until function has completed on other CPUs
178 * @cpu: the CPU where func should run
179 * 179 *
180 * Run a function on one processor. 180 * Run a function on one processor.
181 * 181 *
182 * You must not call this function with disabled interrupts, from a 182 * You must not call this function with disabled interrupts, from a
183 * hardware interrupt handler or from a bottom half. 183 * hardware interrupt handler or from a bottom half.
184 */ 184 */
185int smp_call_function_on(void (*func) (void *info), void *info, int nonatomic, 185int smp_call_function_single(int cpu, void (*func) (void *info), void *info,
186 int wait, int cpu) 186 int nonatomic, int wait)
187{ 187{
188 cpumask_t map = CPU_MASK_NONE;
189
190 preempt_disable(); 188 preempt_disable();
191 cpu_set(cpu, map); 189 __smp_call_function_map(func, info, nonatomic, wait,
192 __smp_call_function_map(func, info, nonatomic, wait, map); 190 cpumask_of_cpu(cpu));
193 preempt_enable(); 191 preempt_enable();
194 return 0; 192 return 0;
195} 193}
196EXPORT_SYMBOL(smp_call_function_on); 194EXPORT_SYMBOL(smp_call_function_single);
197 195
198static void do_send_stop(void) 196static void do_send_stop(void)
199{ 197{