diff options
-rw-r--r-- | arch/x86/kernel/smpboot.c | 28 | ||||
-rw-r--r-- | arch/x86/kernel/smpboot_32.c | 27 | ||||
-rw-r--r-- | arch/x86/kernel/smpboot_64.c | 33 | ||||
-rw-r--r-- | include/asm-x86/smp_64.h | 1 |
4 files changed, 29 insertions, 60 deletions
diff --git a/arch/x86/kernel/smpboot.c b/arch/x86/kernel/smpboot.c index bffe10861390..40a3b56952ef 100644 --- a/arch/x86/kernel/smpboot.c +++ b/arch/x86/kernel/smpboot.c | |||
@@ -1,6 +1,34 @@ | |||
1 | #include <linux/init.h> | 1 | #include <linux/init.h> |
2 | #include <linux/smp.h> | 2 | #include <linux/smp.h> |
3 | #include <linux/module.h> | ||
3 | 4 | ||
5 | /* Number of siblings per CPU package */ | ||
6 | int smp_num_siblings = 1; | ||
7 | EXPORT_SYMBOL(smp_num_siblings); | ||
8 | |||
9 | /* Last level cache ID of each logical CPU */ | ||
10 | DEFINE_PER_CPU(u16, cpu_llc_id) = BAD_APICID; | ||
11 | |||
12 | /* bitmap of online cpus */ | ||
13 | cpumask_t cpu_online_map __read_mostly; | ||
14 | EXPORT_SYMBOL(cpu_online_map); | ||
15 | |||
16 | cpumask_t cpu_callin_map; | ||
17 | cpumask_t cpu_callout_map; | ||
18 | cpumask_t cpu_possible_map; | ||
19 | EXPORT_SYMBOL(cpu_possible_map); | ||
20 | |||
21 | /* representing HT siblings of each logical CPU */ | ||
22 | DEFINE_PER_CPU(cpumask_t, cpu_sibling_map); | ||
23 | EXPORT_PER_CPU_SYMBOL(cpu_sibling_map); | ||
24 | |||
25 | /* representing HT and core siblings of each logical CPU */ | ||
26 | DEFINE_PER_CPU(cpumask_t, cpu_core_map); | ||
27 | EXPORT_PER_CPU_SYMBOL(cpu_core_map); | ||
28 | |||
29 | /* Per CPU bogomips and other parameters */ | ||
30 | DEFINE_PER_CPU_SHARED_ALIGNED(struct cpuinfo_x86, cpu_info); | ||
31 | EXPORT_PER_CPU_SYMBOL(cpu_info); | ||
4 | #ifdef CONFIG_HOTPLUG_CPU | 32 | #ifdef CONFIG_HOTPLUG_CPU |
5 | 33 | ||
6 | int additional_cpus __initdata = -1; | 34 | int additional_cpus __initdata = -1; |
diff --git a/arch/x86/kernel/smpboot_32.c b/arch/x86/kernel/smpboot_32.c index 5a446f079b33..0fbc98163b4e 100644 --- a/arch/x86/kernel/smpboot_32.c +++ b/arch/x86/kernel/smpboot_32.c | |||
@@ -62,35 +62,8 @@ | |||
62 | /* Set if we find a B stepping CPU */ | 62 | /* Set if we find a B stepping CPU */ |
63 | static int __cpuinitdata smp_b_stepping; | 63 | static int __cpuinitdata smp_b_stepping; |
64 | 64 | ||
65 | /* Number of siblings per CPU package */ | ||
66 | int smp_num_siblings = 1; | ||
67 | EXPORT_SYMBOL(smp_num_siblings); | ||
68 | |||
69 | /* Last level cache ID of each logical CPU */ | ||
70 | DEFINE_PER_CPU(u16, cpu_llc_id) = BAD_APICID; | ||
71 | |||
72 | /* representing HT siblings of each logical CPU */ | ||
73 | DEFINE_PER_CPU(cpumask_t, cpu_sibling_map); | ||
74 | EXPORT_PER_CPU_SYMBOL(cpu_sibling_map); | ||
75 | |||
76 | /* representing HT and core siblings of each logical CPU */ | ||
77 | DEFINE_PER_CPU(cpumask_t, cpu_core_map); | ||
78 | EXPORT_PER_CPU_SYMBOL(cpu_core_map); | ||
79 | |||
80 | /* bitmap of online cpus */ | ||
81 | cpumask_t cpu_online_map __read_mostly; | ||
82 | EXPORT_SYMBOL(cpu_online_map); | ||
83 | |||
84 | cpumask_t cpu_callin_map; | ||
85 | cpumask_t cpu_callout_map; | ||
86 | cpumask_t cpu_possible_map; | ||
87 | EXPORT_SYMBOL(cpu_possible_map); | ||
88 | static cpumask_t smp_commenced_mask; | 65 | static cpumask_t smp_commenced_mask; |
89 | 66 | ||
90 | /* Per CPU bogomips and other parameters */ | ||
91 | DEFINE_PER_CPU_SHARED_ALIGNED(struct cpuinfo_x86, cpu_info); | ||
92 | EXPORT_PER_CPU_SYMBOL(cpu_info); | ||
93 | |||
94 | /* which logical CPU number maps to which CPU (physical APIC ID) */ | 67 | /* which logical CPU number maps to which CPU (physical APIC ID) */ |
95 | u16 x86_cpu_to_apicid_init[NR_CPUS] __initdata = | 68 | u16 x86_cpu_to_apicid_init[NR_CPUS] __initdata = |
96 | { [0 ... NR_CPUS-1] = BAD_APICID }; | 69 | { [0 ... NR_CPUS-1] = BAD_APICID }; |
diff --git a/arch/x86/kernel/smpboot_64.c b/arch/x86/kernel/smpboot_64.c index 953b0ff72b65..c51279f05316 100644 --- a/arch/x86/kernel/smpboot_64.c +++ b/arch/x86/kernel/smpboot_64.c | |||
@@ -60,42 +60,9 @@ | |||
60 | #include <asm/hw_irq.h> | 60 | #include <asm/hw_irq.h> |
61 | #include <asm/numa.h> | 61 | #include <asm/numa.h> |
62 | 62 | ||
63 | /* Number of siblings per CPU package */ | ||
64 | int smp_num_siblings = 1; | ||
65 | EXPORT_SYMBOL(smp_num_siblings); | ||
66 | |||
67 | /* Last level cache ID of each logical CPU */ | ||
68 | DEFINE_PER_CPU(u16, cpu_llc_id) = BAD_APICID; | ||
69 | |||
70 | /* Bitmask of currently online CPUs */ | ||
71 | cpumask_t cpu_online_map __read_mostly; | ||
72 | |||
73 | EXPORT_SYMBOL(cpu_online_map); | ||
74 | |||
75 | /* | ||
76 | * Private maps to synchronize booting between AP and BP. | ||
77 | * Probably not needed anymore, but it makes for easier debugging. -AK | ||
78 | */ | ||
79 | cpumask_t cpu_callin_map; | ||
80 | cpumask_t cpu_callout_map; | ||
81 | cpumask_t cpu_possible_map; | ||
82 | EXPORT_SYMBOL(cpu_possible_map); | ||
83 | |||
84 | /* Per CPU bogomips and other parameters */ | ||
85 | DEFINE_PER_CPU_SHARED_ALIGNED(struct cpuinfo_x86, cpu_info); | ||
86 | EXPORT_PER_CPU_SYMBOL(cpu_info); | ||
87 | |||
88 | /* Set when the idlers are all forked */ | 63 | /* Set when the idlers are all forked */ |
89 | int smp_threads_ready; | 64 | int smp_threads_ready; |
90 | 65 | ||
91 | /* representing HT siblings of each logical CPU */ | ||
92 | DEFINE_PER_CPU(cpumask_t, cpu_sibling_map); | ||
93 | EXPORT_PER_CPU_SYMBOL(cpu_sibling_map); | ||
94 | |||
95 | /* representing HT and core siblings of each logical CPU */ | ||
96 | DEFINE_PER_CPU(cpumask_t, cpu_core_map); | ||
97 | EXPORT_PER_CPU_SYMBOL(cpu_core_map); | ||
98 | |||
99 | /* | 66 | /* |
100 | * Trampoline 80x86 program as an array. | 67 | * Trampoline 80x86 program as an array. |
101 | */ | 68 | */ |
diff --git a/include/asm-x86/smp_64.h b/include/asm-x86/smp_64.h index e5bc1be70827..1ecf8134bdc9 100644 --- a/include/asm-x86/smp_64.h +++ b/include/asm-x86/smp_64.h | |||
@@ -14,6 +14,7 @@ | |||
14 | #include <asm/thread_info.h> | 14 | #include <asm/thread_info.h> |
15 | 15 | ||
16 | extern cpumask_t cpu_initialized; | 16 | extern cpumask_t cpu_initialized; |
17 | extern cpumask_t cpu_callin_map; | ||
17 | 18 | ||
18 | extern int smp_call_function_mask(cpumask_t mask, void (*func)(void *), | 19 | extern int smp_call_function_mask(cpumask_t mask, void (*func)(void *), |
19 | void *info, int wait); | 20 | void *info, int wait); |