2010-12-14 15:56:55 +08:00
|
|
|
/*
|
|
|
|
* SMP support for R-Mobile / SH-Mobile
|
|
|
|
*
|
|
|
|
* Copyright (C) 2010 Magnus Damm
|
2011-01-07 11:03:22 +08:00
|
|
|
* Copyright (C) 2011 Paul Mundt
|
2010-12-14 15:56:55 +08:00
|
|
|
*
|
|
|
|
* Based on vexpress, Copyright (C) 2002 ARM Ltd, All Rights Reserved
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License version 2 as
|
|
|
|
* published by the Free Software Foundation.
|
|
|
|
*/
|
|
|
|
#include <linux/init.h>
|
2013-08-01 02:38:18 +08:00
|
|
|
#include <asm/cacheflush.h>
|
|
|
|
#include <asm/smp_plat.h>
|
2014-06-17 15:47:37 +08:00
|
|
|
#include "common.h"
|
2010-12-14 15:56:55 +08:00
|
|
|
|
2013-08-01 02:38:18 +08:00
|
|
|
extern unsigned long shmobile_smp_fn[];
|
|
|
|
extern unsigned long shmobile_smp_arg[];
|
|
|
|
extern unsigned long shmobile_smp_mpidr[];
|
|
|
|
|
|
|
|
void shmobile_smp_hook(unsigned int cpu, unsigned long fn, unsigned long arg)
|
|
|
|
{
|
|
|
|
shmobile_smp_fn[cpu] = 0;
|
|
|
|
flush_cache_all();
|
|
|
|
|
|
|
|
shmobile_smp_mpidr[cpu] = cpu_logical_map(cpu);
|
|
|
|
shmobile_smp_fn[cpu] = fn;
|
|
|
|
shmobile_smp_arg[cpu] = arg;
|
|
|
|
flush_cache_all();
|
|
|
|
}
|
2013-08-08 06:13:30 +08:00
|
|
|
|
|
|
|
#ifdef CONFIG_HOTPLUG_CPU
|
2015-07-29 07:34:48 +08:00
|
|
|
bool shmobile_smp_cpu_can_disable(unsigned int cpu)
|
2013-08-08 06:13:30 +08:00
|
|
|
{
|
2015-07-29 07:34:48 +08:00
|
|
|
return true; /* Hotplug of any CPU is supported */
|
2013-08-08 06:13:30 +08:00
|
|
|
}
|
|
|
|
#endif
|
2016-06-28 22:10:37 +08:00
|
|
|
|
|
|
|
bool __init shmobile_smp_init_fallback_ops(void)
|
|
|
|
{
|
|
|
|
/* fallback on PSCI/smp_ops if no other DT based method is detected */
|
2016-06-30 20:25:19 +08:00
|
|
|
if (!IS_ENABLED(CONFIG_SMP))
|
|
|
|
return false;
|
|
|
|
|
2016-06-28 22:10:37 +08:00
|
|
|
return platform_can_secondary_boot() ? true : false;
|
|
|
|
}
|