diff options
author | Nicolas Pitre <nicolas.pitre@linaro.org> | 2012-11-28 03:54:41 +0100 |
---|---|---|
committer | Nicolas Pitre <nicolas.pitre@linaro.org> | 2013-09-24 00:47:26 +0200 |
commit | 5135d875e1457ef946a055003d8f80713e862135 (patch) | |
tree | 6cd37d9a8fd486ac2af3205b9baf2dce20ac0040 /arch/arm/include/asm/smp.h | |
parent | ARM: bL_switcher: synchronize the outbound with the inbound (diff) | |
download | linux-5135d875e1457ef946a055003d8f80713e862135.tar.xz linux-5135d875e1457ef946a055003d8f80713e862135.zip |
ARM: SMP: basic IPI triggered completion support
We need a mechanism to let an inbound CPU signal that it is alive before
even getting into the kernel environment i.e. from early assembly code.
Using an IPI is the simplest way to achieve that.
This adds some basic infrastructure to register a struct completion
pointer to be "completed" when the dedicated IPI for this task is
received.
Signed-off-by: Nicolas Pitre <nico@linaro.org>
Diffstat (limited to 'arch/arm/include/asm/smp.h')
-rw-r--r-- | arch/arm/include/asm/smp.h | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/arch/arm/include/asm/smp.h b/arch/arm/include/asm/smp.h index a8cae71caceb..22a3b9b5d4a1 100644 --- a/arch/arm/include/asm/smp.h +++ b/arch/arm/include/asm/smp.h @@ -84,6 +84,8 @@ extern void arch_send_call_function_single_ipi(int cpu); extern void arch_send_call_function_ipi_mask(const struct cpumask *mask); extern void arch_send_wakeup_ipi_mask(const struct cpumask *mask); +extern int register_ipi_completion(struct completion *completion, int cpu); + struct smp_operations { #ifdef CONFIG_SMP /* |