diff options
author | Haavard Skinnemoen <haavard.skinnemoen@atmel.com> | 2008-07-27 07:54:08 -0400 |
---|---|---|
committer | Haavard Skinnemoen <haavard.skinnemoen@atmel.com> | 2008-07-27 07:54:08 -0400 |
commit | eda3d8f5604860aae1bb9996bb5efc4213778369 (patch) | |
tree | 9d3887d2665bcc5f5abf200758794545c7b2c69b /include/asm-sparc/smp_64.h | |
parent | 87a9f704658a40940e740b1d73d861667e9164d3 (diff) | |
parent | 8be1a6d6c77ab4532e4476fdb8177030ef48b52c (diff) |
Merge commit 'upstream/master'
Diffstat (limited to 'include/asm-sparc/smp_64.h')
-rw-r--r-- | include/asm-sparc/smp_64.h | 67 |
1 files changed, 67 insertions, 0 deletions
diff --git a/include/asm-sparc/smp_64.h b/include/asm-sparc/smp_64.h new file mode 100644 index 000000000000..57224dd37b3a --- /dev/null +++ b/include/asm-sparc/smp_64.h | |||
@@ -0,0 +1,67 @@ | |||
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> | ||
30 | #include <asm/atomic.h> | ||
31 | #include <asm/percpu.h> | ||
32 | |||
33 | DECLARE_PER_CPU(cpumask_t, cpu_sibling_map); | ||
34 | extern cpumask_t cpu_core_map[NR_CPUS]; | ||
35 | extern int sparc64_multi_core; | ||
36 | |||
37 | extern void arch_send_call_function_single_ipi(int cpu); | ||
38 | extern void arch_send_call_function_ipi(cpumask_t mask); | ||
39 | |||
40 | /* | ||
41 | * General functions that each host system must provide. | ||
42 | */ | ||
43 | |||
44 | extern int hard_smp_processor_id(void); | ||
45 | #define raw_smp_processor_id() (current_thread_info()->cpu) | ||
46 | |||
47 | extern void smp_fill_in_sib_core_maps(void); | ||
48 | extern void cpu_play_dead(void); | ||
49 | |||
50 | extern void smp_fetch_global_regs(void); | ||
51 | |||
52 | #ifdef CONFIG_HOTPLUG_CPU | ||
53 | extern int __cpu_disable(void); | ||
54 | extern void __cpu_die(unsigned int cpu); | ||
55 | #endif | ||
56 | |||
57 | #endif /* !(__ASSEMBLY__) */ | ||
58 | |||
59 | #else | ||
60 | |||
61 | #define hard_smp_processor_id() 0 | ||
62 | #define smp_fill_in_sib_core_maps() do { } while (0) | ||
63 | #define smp_fetch_global_regs() do { } while (0) | ||
64 | |||
65 | #endif /* !(CONFIG_SMP) */ | ||
66 | |||
67 | #endif /* !(_SPARC64_SMP_H) */ | ||