blob: d9782f4f469ea59fce5d0806fa6f9f765b2cb911 [file] [log] [blame]
Glauber Costac27cfef2008-03-03 14:12:29 -03001#ifndef _ASM_X86_SMP_H_
2#define _ASM_X86_SMP_H_
3#ifndef __ASSEMBLY__
Glauber Costa53ebef42008-03-03 14:12:31 -03004#include <linux/cpumask.h>
5
6extern cpumask_t cpu_callout_map;
7
8extern int smp_num_siblings;
9extern unsigned int num_processors;
Glauber Costac27cfef2008-03-03 14:12:29 -030010
Glauber Costa16694022008-03-03 14:12:32 -030011struct smp_ops {
12 void (*smp_prepare_boot_cpu)(void);
13 void (*smp_prepare_cpus)(unsigned max_cpus);
14 int (*cpu_up)(unsigned cpu);
15 void (*smp_cpus_done)(unsigned max_cpus);
16
17 void (*smp_send_stop)(void);
18 void (*smp_send_reschedule)(int cpu);
19 int (*smp_call_function_mask)(cpumask_t mask,
20 void (*func)(void *info), void *info,
21 int wait);
22};
23
Glauber Costac76cb362008-03-03 14:12:33 -030024#ifdef CONFIG_SMP
25extern struct smp_ops smp_ops;
Glauber Costa86789692008-03-03 14:12:34 -030026
27static inline void smp_send_reschedule(int cpu)
28{
29 smp_ops.smp_send_reschedule(cpu);
30}
Glauber Costa64b1a21e02008-03-03 14:12:35 -030031
32static inline int smp_call_function_mask(cpumask_t mask,
33 void (*func) (void *info), void *info,
34 int wait)
35{
36 return smp_ops.smp_call_function_mask(mask, func, info, wait);
37}
Glauber Costac76cb362008-03-03 14:12:33 -030038#endif
Glauber Costa16694022008-03-03 14:12:32 -030039
Thomas Gleixner96a388d2007-10-11 11:20:03 +020040#ifdef CONFIG_X86_32
41# include "smp_32.h"
42#else
43# include "smp_64.h"
44#endif
Glauber Costac27cfef2008-03-03 14:12:29 -030045
Glauber Costa639acb12008-03-03 14:12:30 -030046extern void smp_alloc_memory(void);
47extern void lock_ipi_call_lock(void);
48extern void unlock_ipi_call_lock(void);
Glauber Costac27cfef2008-03-03 14:12:29 -030049#endif /* __ASSEMBLY__ */
50#endif