2008-07-18 12:55:51 +08:00
|
|
|
/* smp.h: Sparc64 specific SMP stuff.
|
|
|
|
*
|
|
|
|
* Copyright (C) 1996, 2008 David S. Miller (davem@davemloft.net)
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef _SPARC64_SMP_H
|
|
|
|
#define _SPARC64_SMP_H
|
|
|
|
|
|
|
|
#include <linux/threads.h>
|
|
|
|
#include <asm/asi.h>
|
|
|
|
#include <asm/starfire.h>
|
|
|
|
#include <asm/spitfire.h>
|
|
|
|
|
|
|
|
#ifndef __ASSEMBLY__
|
|
|
|
|
|
|
|
#include <linux/cpumask.h>
|
|
|
|
#include <linux/cache.h>
|
|
|
|
|
|
|
|
#endif /* !(__ASSEMBLY__) */
|
|
|
|
|
|
|
|
#ifdef CONFIG_SMP
|
|
|
|
|
|
|
|
#ifndef __ASSEMBLY__
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Private routines/data
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <linux/bitops.h>
|
2011-07-27 07:09:06 +08:00
|
|
|
#include <linux/atomic.h>
|
2008-07-18 12:55:51 +08:00
|
|
|
#include <asm/percpu.h>
|
|
|
|
|
|
|
|
DECLARE_PER_CPU(cpumask_t, cpu_sibling_map);
|
|
|
|
extern cpumask_t cpu_core_map[NR_CPUS];
|
|
|
|
|
2014-05-17 05:25:50 +08:00
|
|
|
void arch_send_call_function_single_ipi(int cpu);
|
|
|
|
void arch_send_call_function_ipi_mask(const struct cpumask *mask);
|
2008-07-18 14:44:50 +08:00
|
|
|
|
2008-07-18 12:55:51 +08:00
|
|
|
/*
|
|
|
|
* General functions that each host system must provide.
|
|
|
|
*/
|
|
|
|
|
2014-05-17 05:25:50 +08:00
|
|
|
int hard_smp_processor_id(void);
|
2008-07-18 12:55:51 +08:00
|
|
|
#define raw_smp_processor_id() (current_thread_info()->cpu)
|
|
|
|
|
2016-09-16 04:54:40 +08:00
|
|
|
void smp_fill_in_cpu_possible_map(void);
|
2014-05-17 05:25:50 +08:00
|
|
|
void smp_fill_in_sib_core_maps(void);
|
|
|
|
void cpu_play_dead(void);
|
2008-07-18 12:55:51 +08:00
|
|
|
|
2014-05-17 05:25:50 +08:00
|
|
|
void smp_fetch_global_regs(void);
|
|
|
|
void smp_fetch_global_pmu(void);
|
2008-07-18 12:55:51 +08:00
|
|
|
|
2011-04-22 06:45:45 +08:00
|
|
|
struct seq_file;
|
|
|
|
void smp_bogo(struct seq_file *);
|
|
|
|
void smp_info(struct seq_file *);
|
|
|
|
|
2014-05-17 05:25:57 +08:00
|
|
|
void smp_callin(void);
|
|
|
|
void cpu_panic(void);
|
|
|
|
void smp_synchronize_tick_client(void);
|
|
|
|
void smp_capture(void);
|
|
|
|
void smp_release(void);
|
|
|
|
|
2008-07-18 12:55:51 +08:00
|
|
|
#ifdef CONFIG_HOTPLUG_CPU
|
2014-05-17 05:25:50 +08:00
|
|
|
int __cpu_disable(void);
|
|
|
|
void __cpu_die(unsigned int cpu);
|
2008-07-18 12:55:51 +08:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif /* !(__ASSEMBLY__) */
|
|
|
|
|
|
|
|
#else
|
|
|
|
|
|
|
|
#define hard_smp_processor_id() 0
|
|
|
|
#define smp_fill_in_sib_core_maps() do { } while (0)
|
|
|
|
#define smp_fetch_global_regs() do { } while (0)
|
2012-10-17 00:34:01 +08:00
|
|
|
#define smp_fetch_global_pmu() do { } while (0)
|
2016-09-29 08:40:52 +08:00
|
|
|
#define smp_fill_in_cpu_possible_map() do { } while (0)
|
2008-07-18 12:55:51 +08:00
|
|
|
|
|
|
|
#endif /* !(CONFIG_SMP) */
|
|
|
|
|
|
|
|
#endif /* !(_SPARC64_SMP_H) */
|