blob: 26d9e77268673601f8809537b5d14aa3642bb334 [file] [log] [blame]
Sam Ravnborgf5e706a2008-07-17 21:55:51 -07001/* 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>
Arun Sharma600634972011-07-26 16:09:06 -070030#include <linux/atomic.h>
Sam Ravnborgf5e706a2008-07-17 21:55:51 -070031#include <asm/percpu.h>
32
33DECLARE_PER_CPU(cpumask_t, cpu_sibling_map);
34extern cpumask_t cpu_core_map[NR_CPUS];
Sam Ravnborgf5e706a2008-07-17 21:55:51 -070035
Sam Ravnborgf05a6862014-05-16 23:25:50 +020036void arch_send_call_function_single_ipi(int cpu);
37void arch_send_call_function_ipi_mask(const struct cpumask *mask);
David S. Millerd172ad12008-07-17 23:44:50 -070038
Sam Ravnborgf5e706a2008-07-17 21:55:51 -070039/*
40 * General functions that each host system must provide.
41 */
42
Sam Ravnborgf05a6862014-05-16 23:25:50 +020043int hard_smp_processor_id(void);
Sam Ravnborgf5e706a2008-07-17 21:55:51 -070044#define raw_smp_processor_id() (current_thread_info()->cpu)
45
Sam Ravnborgf05a6862014-05-16 23:25:50 +020046void smp_fill_in_sib_core_maps(void);
47void cpu_play_dead(void);
Sam Ravnborgf5e706a2008-07-17 21:55:51 -070048
Sam Ravnborgf05a6862014-05-16 23:25:50 +020049void smp_fetch_global_regs(void);
50void smp_fetch_global_pmu(void);
Sam Ravnborgf5e706a2008-07-17 21:55:51 -070051
Sam Ravnborgcb1b8202011-04-21 15:45:45 -070052struct seq_file;
53void smp_bogo(struct seq_file *);
54void smp_info(struct seq_file *);
55
Sam Ravnborga0c54a22014-05-16 23:25:57 +020056void smp_callin(void);
57void cpu_panic(void);
58void smp_synchronize_tick_client(void);
59void smp_capture(void);
60void smp_release(void);
61
Sam Ravnborgf5e706a2008-07-17 21:55:51 -070062#ifdef CONFIG_HOTPLUG_CPU
Sam Ravnborgf05a6862014-05-16 23:25:50 +020063int __cpu_disable(void);
64void __cpu_die(unsigned int cpu);
Sam Ravnborgf5e706a2008-07-17 21:55:51 -070065#endif
66
67#endif /* !(__ASSEMBLY__) */
68
69#else
70
71#define hard_smp_processor_id() 0
72#define smp_fill_in_sib_core_maps() do { } while (0)
73#define smp_fetch_global_regs() do { } while (0)
David S. Miller916ca142012-10-16 09:34:01 -070074#define smp_fetch_global_pmu() do { } while (0)
Sam Ravnborgf5e706a2008-07-17 21:55:51 -070075
76#endif /* !(CONFIG_SMP) */
77
78#endif /* !(_SPARC64_SMP_H) */