2007-11-19 07:23:51 -05:00
|
|
|
/*
|
|
|
|
* This file is subject to the terms and conditions of the GNU General
|
|
|
|
* Public License. See the file "COPYING" in the main directory of this
|
|
|
|
* archive for more details.
|
|
|
|
*
|
|
|
|
* Copyright (C) 2000 - 2001 by Kanoj Sarcar (kanoj@sgi.com)
|
|
|
|
* Copyright (C) 2000 - 2001 by Silicon Graphics, Inc.
|
|
|
|
* Copyright (C) 2000, 2001, 2002 Ralf Baechle
|
|
|
|
* Copyright (C) 2000, 2001 Broadcom Corporation
|
|
|
|
*/
|
|
|
|
#ifndef __ASM_SMP_OPS_H
|
|
|
|
#define __ASM_SMP_OPS_H
|
|
|
|
|
2011-06-01 09:20:09 -04:00
|
|
|
#include <linux/errno.h>
|
|
|
|
|
2017-08-12 22:49:41 -04:00
|
|
|
#include <asm/mips-cps.h>
|
2014-01-15 05:31:54 -05:00
|
|
|
|
2007-11-19 07:23:51 -05:00
|
|
|
#ifdef CONFIG_SMP
|
|
|
|
|
|
|
|
#include <linux/cpumask.h>
|
|
|
|
|
2009-03-25 09:41:09 -04:00
|
|
|
struct task_struct;
|
|
|
|
|
2007-11-19 07:23:51 -05:00
|
|
|
struct plat_smp_ops {
|
|
|
|
void (*send_ipi_single)(int cpu, unsigned int action);
|
2009-09-24 11:34:44 -04:00
|
|
|
void (*send_ipi_mask)(const struct cpumask *mask, unsigned int action);
|
2007-11-19 07:23:51 -05:00
|
|
|
void (*init_secondary)(void);
|
|
|
|
void (*smp_finish)(void);
|
2017-08-12 22:49:40 -04:00
|
|
|
int (*boot_secondary)(int cpu, struct task_struct *idle);
|
2007-11-19 07:23:51 -05:00
|
|
|
void (*smp_setup)(void);
|
|
|
|
void (*prepare_cpus)(unsigned int max_cpus);
|
2019-02-19 10:57:19 -05:00
|
|
|
void (*prepare_boot_cpu)(void);
|
2009-06-23 05:00:31 -04:00
|
|
|
#ifdef CONFIG_HOTPLUG_CPU
|
|
|
|
int (*cpu_disable)(void);
|
|
|
|
void (*cpu_die)(unsigned int cpu);
|
|
|
|
#endif
|
2018-09-11 17:49:21 -04:00
|
|
|
#ifdef CONFIG_KEXEC
|
|
|
|
void (*kexec_nonboot_cpu)(void);
|
|
|
|
#endif
|
2007-11-19 07:23:51 -05:00
|
|
|
};
|
|
|
|
|
2017-07-19 04:21:03 -04:00
|
|
|
extern void register_smp_ops(const struct plat_smp_ops *ops);
|
2007-11-19 07:23:51 -05:00
|
|
|
|
|
|
|
static inline void plat_smp_setup(void)
|
|
|
|
{
|
2017-07-19 04:21:03 -04:00
|
|
|
extern const struct plat_smp_ops *mp_ops; /* private */
|
2007-11-19 07:23:51 -05:00
|
|
|
|
|
|
|
mp_ops->smp_setup();
|
|
|
|
}
|
|
|
|
|
2015-12-08 08:20:28 -05:00
|
|
|
extern void mips_smp_send_ipi_single(int cpu, unsigned int action);
|
|
|
|
extern void mips_smp_send_ipi_mask(const struct cpumask *mask,
|
|
|
|
unsigned int action);
|
2014-03-24 06:19:33 -04:00
|
|
|
|
2007-11-19 07:23:51 -05:00
|
|
|
#else /* !CONFIG_SMP */
|
|
|
|
|
|
|
|
struct plat_smp_ops;
|
|
|
|
|
|
|
|
static inline void plat_smp_setup(void)
|
|
|
|
{
|
|
|
|
/* UP, nothing to do ... */
|
|
|
|
}
|
|
|
|
|
2017-07-19 04:21:03 -04:00
|
|
|
static inline void register_smp_ops(const struct plat_smp_ops *ops)
|
2007-11-19 07:23:51 -05:00
|
|
|
{
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif /* !CONFIG_SMP */
|
|
|
|
|
2011-05-28 10:27:59 -04:00
|
|
|
static inline int register_up_smp_ops(void)
|
|
|
|
{
|
|
|
|
#ifdef CONFIG_SMP_UP
|
2017-07-19 04:21:03 -04:00
|
|
|
extern const struct plat_smp_ops up_smp_ops;
|
2011-05-28 10:27:59 -04:00
|
|
|
|
|
|
|
register_smp_ops(&up_smp_ops);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
#else
|
|
|
|
return -ENODEV;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int register_cmp_smp_ops(void)
|
|
|
|
{
|
|
|
|
#ifdef CONFIG_MIPS_CMP
|
2017-07-19 04:21:03 -04:00
|
|
|
extern const struct plat_smp_ops cmp_smp_ops;
|
2011-05-28 10:27:59 -04:00
|
|
|
|
2014-01-15 05:31:54 -05:00
|
|
|
if (!mips_cm_present())
|
|
|
|
return -ENODEV;
|
|
|
|
|
2011-05-28 10:27:59 -04:00
|
|
|
register_smp_ops(&cmp_smp_ops);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
#else
|
|
|
|
return -ENODEV;
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int register_vsmp_smp_ops(void)
|
|
|
|
{
|
|
|
|
#ifdef CONFIG_MIPS_MT_SMP
|
2017-07-19 04:21:03 -04:00
|
|
|
extern const struct plat_smp_ops vsmp_smp_ops;
|
2011-05-28 10:27:59 -04:00
|
|
|
|
|
|
|
register_smp_ops(&vsmp_smp_ops);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
#else
|
|
|
|
return -ENODEV;
|
|
|
|
#endif
|
|
|
|
}
|
2007-11-19 07:23:51 -05:00
|
|
|
|
2014-01-15 05:31:53 -05:00
|
|
|
#ifdef CONFIG_MIPS_CPS
|
|
|
|
extern int register_cps_smp_ops(void);
|
|
|
|
#else
|
|
|
|
static inline int register_cps_smp_ops(void)
|
|
|
|
{
|
|
|
|
return -ENODEV;
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2007-11-19 07:23:51 -05:00
|
|
|
#endif /* __ASM_SMP_OPS_H */
|