Linux Audio

Check our new training course

Loading...
v6.8
  1/*
  2 * This file is subject to the terms and conditions of the GNU General
  3 * Public License.  See the file "COPYING" in the main directory of this
  4 * archive for more details.
  5 *
  6 * Copyright (C) 2000 - 2001 by Kanoj Sarcar (kanoj@sgi.com)
  7 * Copyright (C) 2000 - 2001 by Silicon Graphics, Inc.
  8 * Copyright (C) 2000, 2001, 2002 Ralf Baechle
  9 * Copyright (C) 2000, 2001 Broadcom Corporation
 10 */
 11#ifndef __ASM_SMP_OPS_H
 12#define __ASM_SMP_OPS_H
 13
 14#include <linux/errno.h>
 15
 
 
 16#ifdef CONFIG_SMP
 17
 18#include <linux/cpumask.h>
 19
 20struct task_struct;
 21
 22struct plat_smp_ops {
 23	void (*send_ipi_single)(int cpu, unsigned int action);
 24	void (*send_ipi_mask)(const struct cpumask *mask, unsigned int action);
 25	void (*init_secondary)(void);
 26	void (*smp_finish)(void);
 27	int (*boot_secondary)(int cpu, struct task_struct *idle);
 
 28	void (*smp_setup)(void);
 29	void (*prepare_cpus)(unsigned int max_cpus);
 30	void (*prepare_boot_cpu)(void);
 31#ifdef CONFIG_HOTPLUG_CPU
 32	int (*cpu_disable)(void);
 33	void (*cpu_die)(unsigned int cpu);
 34	void (*cleanup_dead_cpu)(unsigned cpu);
 35#endif
 36#ifdef CONFIG_KEXEC_CORE
 37	void (*kexec_nonboot_cpu)(void);
 38#endif
 39};
 40
 41extern void register_smp_ops(const struct plat_smp_ops *ops);
 42
 43static inline void plat_smp_setup(void)
 44{
 45	extern const struct plat_smp_ops *mp_ops;	/* private */
 46
 47	mp_ops->smp_setup();
 48}
 49
 50extern void mips_smp_send_ipi_single(int cpu, unsigned int action);
 51extern void mips_smp_send_ipi_mask(const struct cpumask *mask,
 52				      unsigned int action);
 53
 54#else /* !CONFIG_SMP */
 55
 56struct plat_smp_ops;
 57
 58static inline void plat_smp_setup(void)
 59{
 60	/* UP, nothing to do ...  */
 61}
 62
 63static inline void register_smp_ops(const struct plat_smp_ops *ops)
 64{
 65}
 66
 67#endif /* !CONFIG_SMP */
 68
 69static inline int register_up_smp_ops(void)
 70{
 71#ifdef CONFIG_SMP_UP
 72	extern const struct plat_smp_ops up_smp_ops;
 73
 74	register_smp_ops(&up_smp_ops);
 75
 76	return 0;
 77#else
 78	return -ENODEV;
 79#endif
 80}
 81
 82static inline int register_vsmp_smp_ops(void)
 83{
 84#ifdef CONFIG_MIPS_MT_SMP
 85	extern const struct plat_smp_ops vsmp_smp_ops;
 86
 87	if (!cpu_has_mipsmt)
 88		return -ENODEV;
 
 
 
 
 
 
 
 
 
 
 
 
 
 89
 90	register_smp_ops(&vsmp_smp_ops);
 91
 92	return 0;
 93#else
 94	return -ENODEV;
 95#endif
 96}
 97
 98#ifdef CONFIG_MIPS_CPS
 99extern int register_cps_smp_ops(void);
100#else
101static inline int register_cps_smp_ops(void)
102{
103	return -ENODEV;
104}
105#endif
106
107#endif /* __ASM_SMP_OPS_H */
v3.15
  1/*
  2 * This file is subject to the terms and conditions of the GNU General
  3 * Public License.  See the file "COPYING" in the main directory of this
  4 * archive for more details.
  5 *
  6 * Copyright (C) 2000 - 2001 by Kanoj Sarcar (kanoj@sgi.com)
  7 * Copyright (C) 2000 - 2001 by Silicon Graphics, Inc.
  8 * Copyright (C) 2000, 2001, 2002 Ralf Baechle
  9 * Copyright (C) 2000, 2001 Broadcom Corporation
 10 */
 11#ifndef __ASM_SMP_OPS_H
 12#define __ASM_SMP_OPS_H
 13
 14#include <linux/errno.h>
 15
 16#include <asm/mips-cm.h>
 17
 18#ifdef CONFIG_SMP
 19
 20#include <linux/cpumask.h>
 21
 22struct task_struct;
 23
 24struct plat_smp_ops {
 25	void (*send_ipi_single)(int cpu, unsigned int action);
 26	void (*send_ipi_mask)(const struct cpumask *mask, unsigned int action);
 27	void (*init_secondary)(void);
 28	void (*smp_finish)(void);
 29	void (*cpus_done)(void);
 30	void (*boot_secondary)(int cpu, struct task_struct *idle);
 31	void (*smp_setup)(void);
 32	void (*prepare_cpus)(unsigned int max_cpus);
 
 33#ifdef CONFIG_HOTPLUG_CPU
 34	int (*cpu_disable)(void);
 35	void (*cpu_die)(unsigned int cpu);
 
 
 
 
 36#endif
 37};
 38
 39extern void register_smp_ops(struct plat_smp_ops *ops);
 40
 41static inline void plat_smp_setup(void)
 42{
 43	extern struct plat_smp_ops *mp_ops;	/* private */
 44
 45	mp_ops->smp_setup();
 46}
 47
 48extern void gic_send_ipi_single(int cpu, unsigned int action);
 49extern void gic_send_ipi_mask(const struct cpumask *mask, unsigned int action);
 
 50
 51#else /* !CONFIG_SMP */
 52
 53struct plat_smp_ops;
 54
 55static inline void plat_smp_setup(void)
 56{
 57	/* UP, nothing to do ...  */
 58}
 59
 60static inline void register_smp_ops(struct plat_smp_ops *ops)
 61{
 62}
 63
 64#endif /* !CONFIG_SMP */
 65
 66static inline int register_up_smp_ops(void)
 67{
 68#ifdef CONFIG_SMP_UP
 69	extern struct plat_smp_ops up_smp_ops;
 70
 71	register_smp_ops(&up_smp_ops);
 72
 73	return 0;
 74#else
 75	return -ENODEV;
 76#endif
 77}
 78
 79static inline int register_cmp_smp_ops(void)
 80{
 81#ifdef CONFIG_MIPS_CMP
 82	extern struct plat_smp_ops cmp_smp_ops;
 83
 84	if (!mips_cm_present())
 85		return -ENODEV;
 86
 87	register_smp_ops(&cmp_smp_ops);
 88
 89	return 0;
 90#else
 91	return -ENODEV;
 92#endif
 93}
 94
 95static inline int register_vsmp_smp_ops(void)
 96{
 97#ifdef CONFIG_MIPS_MT_SMP
 98	extern struct plat_smp_ops vsmp_smp_ops;
 99
100	register_smp_ops(&vsmp_smp_ops);
101
102	return 0;
103#else
104	return -ENODEV;
105#endif
106}
107
108#ifdef CONFIG_MIPS_CPS
109extern int register_cps_smp_ops(void);
110#else
111static inline int register_cps_smp_ops(void)
112{
113	return -ENODEV;
114}
115#endif
116
117#endif /* __ASM_SMP_OPS_H */