-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Nicolas Pitre
committed
Apr 24, 2013
1 parent
63f0352
commit 546ac90
Showing
3 changed files
with
89 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,2 +1,2 @@ | ||
--- | ||
refs/heads/master: 1ae98561b16f305e43151405f226727c00ee52bc | ||
refs/heads/master: 9ff221bad8869f73141c6a3c187afe2e933c991f |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,87 @@ | ||
/* | ||
* linux/arch/arm/mach-vexpress/mcpm_platsmp.c | ||
* | ||
* Created by: Nicolas Pitre, November 2012 | ||
* Copyright: (C) 2012-2013 Linaro Limited | ||
* | ||
* 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. | ||
* | ||
* Code to handle secondary CPU bringup and hotplug for the cluster power API. | ||
*/ | ||
|
||
#include <linux/init.h> | ||
#include <linux/smp.h> | ||
#include <linux/spinlock.h> | ||
|
||
#include <linux/irqchip/arm-gic.h> | ||
|
||
#include <asm/mcpm.h> | ||
#include <asm/smp.h> | ||
#include <asm/smp_plat.h> | ||
|
||
static void __init simple_smp_init_cpus(void) | ||
{ | ||
} | ||
|
||
static int __cpuinit mcpm_boot_secondary(unsigned int cpu, struct task_struct *idle) | ||
{ | ||
unsigned int mpidr, pcpu, pcluster, ret; | ||
extern void secondary_startup(void); | ||
|
||
mpidr = cpu_logical_map(cpu); | ||
pcpu = MPIDR_AFFINITY_LEVEL(mpidr, 0); | ||
pcluster = MPIDR_AFFINITY_LEVEL(mpidr, 1); | ||
pr_debug("%s: logical CPU %d is physical CPU %d cluster %d\n", | ||
__func__, cpu, pcpu, pcluster); | ||
|
||
mcpm_set_entry_vector(pcpu, pcluster, NULL); | ||
ret = mcpm_cpu_power_up(pcpu, pcluster); | ||
if (ret) | ||
return ret; | ||
mcpm_set_entry_vector(pcpu, pcluster, secondary_startup); | ||
arch_send_wakeup_ipi_mask(cpumask_of(cpu)); | ||
dsb_sev(); | ||
return 0; | ||
} | ||
|
||
static void __cpuinit mcpm_secondary_init(unsigned int cpu) | ||
{ | ||
mcpm_cpu_powered_up(); | ||
gic_secondary_init(0); | ||
} | ||
|
||
#ifdef CONFIG_HOTPLUG_CPU | ||
|
||
static int mcpm_cpu_disable(unsigned int cpu) | ||
{ | ||
/* | ||
* We assume all CPUs may be shut down. | ||
* This would be the hook to use for eventual Secure | ||
* OS migration requests as described in the PSCI spec. | ||
*/ | ||
return 0; | ||
} | ||
|
||
static void mcpm_cpu_die(unsigned int cpu) | ||
{ | ||
unsigned int mpidr, pcpu, pcluster; | ||
mpidr = read_cpuid_mpidr(); | ||
pcpu = MPIDR_AFFINITY_LEVEL(mpidr, 0); | ||
pcluster = MPIDR_AFFINITY_LEVEL(mpidr, 1); | ||
mcpm_set_entry_vector(pcpu, pcluster, NULL); | ||
mcpm_cpu_power_down(); | ||
} | ||
|
||
#endif | ||
|
||
struct smp_operations __initdata mcpm_smp_ops = { | ||
.smp_init_cpus = simple_smp_init_cpus, | ||
.smp_boot_secondary = mcpm_boot_secondary, | ||
.smp_secondary_init = mcpm_secondary_init, | ||
#ifdef CONFIG_HOTPLUG_CPU | ||
.cpu_disable = mcpm_cpu_disable, | ||
.cpu_die = mcpm_cpu_die, | ||
#endif | ||
}; |