]> git.proxmox.com Git - mirror_ubuntu-focal-kernel.git/blame - arch/sparc/include/asm/smp_64.h
Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/net
[mirror_ubuntu-focal-kernel.git] / arch / sparc / include / asm / smp_64.h
CommitLineData
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
33DECLARE_PER_CPU(cpumask_t, cpu_sibling_map);
34extern cpumask_t cpu_core_map[NR_CPUS];
f5e706ad 35
8536e02e
VK
36void smp_init_cpu_poke(void);
37void scheduler_poke(void);
38
f05a6865
SR
39void arch_send_call_function_single_ipi(int cpu);
40void arch_send_call_function_ipi_mask(const struct cpumask *mask);
d172ad18 41
f5e706ad
SR
42/*
43 * General functions that each host system must provide.
44 */
45
f05a6865 46int hard_smp_processor_id(void);
f5e706ad
SR
47#define raw_smp_processor_id() (current_thread_info()->cpu)
48
9b2f753e 49void smp_fill_in_cpu_possible_map(void);
f05a6865
SR
50void smp_fill_in_sib_core_maps(void);
51void cpu_play_dead(void);
f5e706ad 52
f05a6865
SR
53void smp_fetch_global_regs(void);
54void smp_fetch_global_pmu(void);
f5e706ad 55
cb1b8209
SR
56struct seq_file;
57void smp_bogo(struct seq_file *);
58void smp_info(struct seq_file *);
59
a0c54a21
SR
60void smp_callin(void);
61void cpu_panic(void);
62void smp_synchronize_tick_client(void);
63void smp_capture(void);
64void smp_release(void);
65
f5e706ad 66#ifdef CONFIG_HOTPLUG_CPU
f05a6865
SR
67int __cpu_disable(void);
68void __cpu_die(unsigned int cpu);
f5e706ad
SR
69#endif
70
71#endif /* !(__ASSEMBLY__) */
72
73#else
74
75#define hard_smp_processor_id() 0
76#define smp_fill_in_sib_core_maps() do { } while (0)
77#define smp_fetch_global_regs() do { } while (0)
916ca14a 78#define smp_fetch_global_pmu() do { } while (0)
2a0100d7 79#define smp_fill_in_cpu_possible_map() do { } while (0)
8536e02e
VK
80#define smp_init_cpu_poke() do { } while (0)
81#define scheduler_poke() do { } while (0)
f5e706ad
SR
82
83#endif /* !(CONFIG_SMP) */
84
85#endif /* !(_SPARC64_SMP_H) */