diff options
Diffstat (limited to 'include/asm-powerpc/smp.h')
-rw-r--r-- | include/asm-powerpc/smp.h | 125 |
1 files changed, 0 insertions, 125 deletions
diff --git a/include/asm-powerpc/smp.h b/include/asm-powerpc/smp.h deleted file mode 100644 index 416d4c288cea..000000000000 --- a/include/asm-powerpc/smp.h +++ /dev/null | |||
@@ -1,125 +0,0 @@ | |||
1 | /* | ||
2 | * smp.h: PowerPC-specific SMP code. | ||
3 | * | ||
4 | * Original was a copy of sparc smp.h. Now heavily modified | ||
5 | * for PPC. | ||
6 | * | ||
7 | * Copyright (C) 1996 David S. Miller (davem@caip.rutgers.edu) | ||
8 | * Copyright (C) 1996-2001 Cort Dougan <cort@fsmlabs.com> | ||
9 | * | ||
10 | * This program is free software; you can redistribute it and/or | ||
11 | * modify it under the terms of the GNU General Public License | ||
12 | * as published by the Free Software Foundation; either version | ||
13 | * 2 of the License, or (at your option) any later version. | ||
14 | */ | ||
15 | |||
16 | #ifndef _ASM_POWERPC_SMP_H | ||
17 | #define _ASM_POWERPC_SMP_H | ||
18 | #ifdef __KERNEL__ | ||
19 | |||
20 | #include <linux/threads.h> | ||
21 | #include <linux/cpumask.h> | ||
22 | #include <linux/kernel.h> | ||
23 | |||
24 | #ifndef __ASSEMBLY__ | ||
25 | |||
26 | #ifdef CONFIG_PPC64 | ||
27 | #include <asm/paca.h> | ||
28 | #endif | ||
29 | #include <asm/percpu.h> | ||
30 | |||
31 | extern int boot_cpuid; | ||
32 | |||
33 | extern void cpu_die(void); | ||
34 | |||
35 | #ifdef CONFIG_SMP | ||
36 | |||
37 | extern void smp_send_debugger_break(int cpu); | ||
38 | extern void smp_message_recv(int); | ||
39 | |||
40 | DECLARE_PER_CPU(unsigned int, pvr); | ||
41 | |||
42 | #ifdef CONFIG_HOTPLUG_CPU | ||
43 | extern void fixup_irqs(cpumask_t map); | ||
44 | int generic_cpu_disable(void); | ||
45 | int generic_cpu_enable(unsigned int cpu); | ||
46 | void generic_cpu_die(unsigned int cpu); | ||
47 | void generic_mach_cpu_die(void); | ||
48 | #endif | ||
49 | |||
50 | #ifdef CONFIG_PPC64 | ||
51 | #define raw_smp_processor_id() (local_paca->paca_index) | ||
52 | #define hard_smp_processor_id() (get_paca()->hw_cpu_id) | ||
53 | #else | ||
54 | /* 32-bit */ | ||
55 | extern int smp_hw_index[]; | ||
56 | |||
57 | #define raw_smp_processor_id() (current_thread_info()->cpu) | ||
58 | #define hard_smp_processor_id() (smp_hw_index[smp_processor_id()]) | ||
59 | #define get_hard_smp_processor_id(cpu) (smp_hw_index[(cpu)]) | ||
60 | #define set_hard_smp_processor_id(cpu, phys)\ | ||
61 | (smp_hw_index[(cpu)] = (phys)) | ||
62 | #endif | ||
63 | |||
64 | DECLARE_PER_CPU(cpumask_t, cpu_sibling_map); | ||
65 | |||
66 | /* Since OpenPIC has only 4 IPIs, we use slightly different message numbers. | ||
67 | * | ||
68 | * Make sure this matches openpic_request_IPIs in open_pic.c, or what shows up | ||
69 | * in /proc/interrupts will be wrong!!! --Troy */ | ||
70 | #define PPC_MSG_CALL_FUNCTION 0 | ||
71 | #define PPC_MSG_RESCHEDULE 1 | ||
72 | #define PPC_MSG_CALL_FUNC_SINGLE 2 | ||
73 | #define PPC_MSG_DEBUGGER_BREAK 3 | ||
74 | |||
75 | void smp_init_iSeries(void); | ||
76 | void smp_init_pSeries(void); | ||
77 | void smp_init_cell(void); | ||
78 | void smp_init_celleb(void); | ||
79 | void smp_setup_cpu_maps(void); | ||
80 | void smp_setup_cpu_sibling_map(void); | ||
81 | |||
82 | extern int __cpu_disable(void); | ||
83 | extern void __cpu_die(unsigned int cpu); | ||
84 | |||
85 | #else | ||
86 | /* for UP */ | ||
87 | #define hard_smp_processor_id() 0 | ||
88 | #define smp_setup_cpu_maps() | ||
89 | |||
90 | #endif /* CONFIG_SMP */ | ||
91 | |||
92 | #ifdef CONFIG_PPC64 | ||
93 | #define get_hard_smp_processor_id(CPU) (paca[(CPU)].hw_cpu_id) | ||
94 | #define set_hard_smp_processor_id(CPU, VAL) \ | ||
95 | do { (paca[(CPU)].hw_cpu_id = (VAL)); } while (0) | ||
96 | |||
97 | extern void smp_release_cpus(void); | ||
98 | |||
99 | #else | ||
100 | /* 32-bit */ | ||
101 | #ifndef CONFIG_SMP | ||
102 | extern int boot_cpuid_phys; | ||
103 | #define get_hard_smp_processor_id(cpu) boot_cpuid_phys | ||
104 | #define set_hard_smp_processor_id(cpu, phys) | ||
105 | #endif | ||
106 | #endif | ||
107 | |||
108 | extern int smt_enabled_at_boot; | ||
109 | |||
110 | extern int smp_mpic_probe(void); | ||
111 | extern void smp_mpic_setup_cpu(int cpu); | ||
112 | extern void smp_generic_kick_cpu(int nr); | ||
113 | |||
114 | extern void smp_generic_give_timebase(void); | ||
115 | extern void smp_generic_take_timebase(void); | ||
116 | |||
117 | extern struct smp_ops_t *smp_ops; | ||
118 | |||
119 | extern void arch_send_call_function_single_ipi(int cpu); | ||
120 | extern void arch_send_call_function_ipi(cpumask_t mask); | ||
121 | |||
122 | #endif /* __ASSEMBLY__ */ | ||
123 | |||
124 | #endif /* __KERNEL__ */ | ||
125 | #endif /* _ASM_POWERPC_SMP_H) */ | ||