Commit | Line | Data |
---|---|---|
f5e706ad SR |
1 | /* smp.h: Sparc64 specific SMP stuff. |
2 | * | |
3 | * Copyright (C) 1996, 2008 David S. Miller (davem@davemloft.net) | |
4 | */ | |
5 | ||
6 | #ifndef _SPARC64_SMP_H | |
7 | #define _SPARC64_SMP_H | |
8 | ||
9 | #include <linux/threads.h> | |
10 | #include <asm/asi.h> | |
11 | #include <asm/starfire.h> | |
12 | #include <asm/spitfire.h> | |
13 | ||
14 | #ifndef __ASSEMBLY__ | |
15 | ||
16 | #include <linux/cpumask.h> | |
17 | #include <linux/cache.h> | |
18 | ||
19 | #endif /* !(__ASSEMBLY__) */ | |
20 | ||
21 | #ifdef CONFIG_SMP | |
22 | ||
23 | #ifndef __ASSEMBLY__ | |
24 | ||
25 | /* | |
26 | * Private routines/data | |
27 | */ | |
28 | ||
29 | #include <linux/bitops.h> | |
60063497 | 30 | #include <linux/atomic.h> |
f5e706ad SR |
31 | #include <asm/percpu.h> |
32 | ||
33 | DECLARE_PER_CPU(cpumask_t, cpu_sibling_map); | |
34 | extern cpumask_t cpu_core_map[NR_CPUS]; | |
f5e706ad | 35 | |
f05a6865 SR |
36 | void arch_send_call_function_single_ipi(int cpu); |
37 | void arch_send_call_function_ipi_mask(const struct cpumask *mask); | |
d172ad18 | 38 | |
f5e706ad SR |
39 | /* |
40 | * General functions that each host system must provide. | |
41 | */ | |
42 | ||
f05a6865 | 43 | int hard_smp_processor_id(void); |
f5e706ad SR |
44 | #define raw_smp_processor_id() (current_thread_info()->cpu) |
45 | ||
9b2f753e | 46 | void smp_fill_in_cpu_possible_map(void); |
f05a6865 SR |
47 | void smp_fill_in_sib_core_maps(void); |
48 | void cpu_play_dead(void); | |
f5e706ad | 49 | |
f05a6865 SR |
50 | void smp_fetch_global_regs(void); |
51 | void smp_fetch_global_pmu(void); | |
f5e706ad | 52 | |
cb1b8209 SR |
53 | struct seq_file; |
54 | void smp_bogo(struct seq_file *); | |
55 | void smp_info(struct seq_file *); | |
56 | ||
a0c54a21 SR |
57 | void smp_callin(void); |
58 | void cpu_panic(void); | |
59 | void smp_synchronize_tick_client(void); | |
60 | void smp_capture(void); | |
61 | void smp_release(void); | |
62 | ||
f5e706ad | 63 | #ifdef CONFIG_HOTPLUG_CPU |
f05a6865 SR |
64 | int __cpu_disable(void); |
65 | void __cpu_die(unsigned int cpu); | |
f5e706ad SR |
66 | #endif |
67 | ||
68 | #endif /* !(__ASSEMBLY__) */ | |
69 | ||
70 | #else | |
71 | ||
72 | #define hard_smp_processor_id() 0 | |
73 | #define smp_fill_in_sib_core_maps() do { } while (0) | |
74 | #define smp_fetch_global_regs() do { } while (0) | |
916ca14a | 75 | #define smp_fetch_global_pmu() do { } while (0) |
2a0100d7 | 76 | #define smp_fill_in_cpu_possible_map() do { } while (0) |
f5e706ad SR |
77 | |
78 | #endif /* !(CONFIG_SMP) */ | |
79 | ||
80 | #endif /* !(_SPARC64_SMP_H) */ |