From: tixy@linaro.org (Jon Medhurst (Tixy))
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH v4 15/15] ARM: vexpress: Select multi-cluster SMP operation if required
Date: Mon, 08 Apr 2013 10:10:11 +0100 [thread overview]
Message-ID: <1365412211.3384.16.camel@linaro1.home> (raw)
In-Reply-To: <alpine.LFD.2.03.1304060943370.1171@syhkavp.arg>
On Sat, 2013-04-06 at 10:02 -0400, Nicolas Pitre wrote:
> I've amended this patch slightly so to:
>
> 1) Keep the default .smp = &vexpress_smp_ops and only perform an
> override in vexpress_smp_init_ops() when appropriate. This should
> remove one potential issue with Xen support that was highlighted
> recently.
>
> 2) Add a mcpm_smp_set_ops() instead of installing mcpm_smp_ops directly
> for better abstraction.
>
> 3) Added a comment about and checked for the CCI node being enabled.
>
> That results in the patch below. Given those are minor changes, I kept
> the existing review tags.
>
> From: Jon Medhurst <tixy@linaro.org>
> Date: Wed, 30 Jan 2013 09:12:55 +0000
> Subject: [PATCH] ARM: vexpress: Select multi-cluster SMP operation if required
>
> Signed-off-by: Jon Medhurst <tixy@linaro.org>
> Signed-off-by: Nicolas Pitre <nicolas.pitre@linaro.org>
> Reviewed-by: Santosh Shilimkar <santosh.shilimkar@ti.com>
> Acked-by: Pawel Moll <pawel.moll@arm.com>
>
> diff --git a/arch/arm/common/mcpm_platsmp.c b/arch/arm/common/mcpm_platsmp.c
> index 34f236af09..cc82040877 100644
> --- a/arch/arm/common/mcpm_platsmp.c
> +++ b/arch/arm/common/mcpm_platsmp.c
> @@ -85,3 +85,8 @@ struct smp_operations __initdata mcpm_smp_ops = {
> .cpu_die = mcpm_cpu_die,
> #endif
> };
> +
> +void __init mcpm_smp_set_ops(void)
> +{
> + smp_set_ops(&mcpm_smp_ops);
> +}
> diff --git a/arch/arm/include/asm/mcpm_entry.h b/arch/arm/include/asm/mcpm_entry.h
> index 814623e6a1..34dfb86ff5 100644
> --- a/arch/arm/include/asm/mcpm_entry.h
> +++ b/arch/arm/include/asm/mcpm_entry.h
> @@ -190,5 +190,7 @@ int __mcpm_cluster_state(unsigned int cluster);
> int __init mcpm_sync_init(
> void (*power_up_setup)(unsigned int affinity_level));
>
> +void __init mcpm_smp_set_ops(void);
> +
> #endif /* ! __ASSEMBLY__ */
> #endif
Do the changes to the above mcpm files want to be in a separate patch as
it's generic ARM code, not vexpress specific?
> diff --git a/arch/arm/mach-vexpress/core.h b/arch/arm/mach-vexpress/core.h
> index f134cd4a85..3a761fd76c 100644
> --- a/arch/arm/mach-vexpress/core.h
> +++ b/arch/arm/mach-vexpress/core.h
> @@ -6,6 +6,8 @@
>
> void vexpress_dt_smp_map_io(void);
>
> +void vexpress_smp_init_ops(void);
> +
> extern struct smp_operations vexpress_smp_ops;
>
> extern void vexpress_cpu_die(unsigned int cpu);
> diff --git a/arch/arm/mach-vexpress/platsmp.c b/arch/arm/mach-vexpress/platsmp.c
> index dc1ace55d5..06317bc714 100644
> --- a/arch/arm/mach-vexpress/platsmp.c
> +++ b/arch/arm/mach-vexpress/platsmp.c
> @@ -12,9 +12,11 @@
> #include <linux/errno.h>
> #include <linux/smp.h>
> #include <linux/io.h>
> +#include <linux/of.h>
> #include <linux/of_fdt.h>
> #include <linux/vexpress.h>
>
> +#include <asm/mcpm_entry.h>
> #include <asm/smp_scu.h>
> #include <asm/mach/map.h>
>
> @@ -203,3 +205,18 @@ struct smp_operations __initdata vexpress_smp_ops = {
> .cpu_die = vexpress_cpu_die,
> #endif
> };
> +
> +void __init vexpress_smp_init_ops(void)
> +{
> +#ifdef CONFIG_MCPM
> + /*
> + * The best way to detect a multi-cluster configuration at the moment
> + * is to look for the presence of a CCI in the system.
> + * Override the default vexpress_smp_ops if so.
> + */
> + struct device_node *node;
> + node = of_find_compatible_node(NULL, NULL, "arm,cci");
> + if (node && of_device_is_available(node))
> + mcpm_smp_set_ops();
> +#endif
> +}
What now sets smp_ops if mcpm_smp_set_ops doesn't get called above? I
know there are umpteen versions of the patch "ARM: Enable selection of
SMP operations at boot time", but none of them seem to resolve that
issue.
> diff --git a/arch/arm/mach-vexpress/v2m.c b/arch/arm/mach-vexpress/v2m.c
> index 915683cb67..16b42c10e0 100644
> --- a/arch/arm/mach-vexpress/v2m.c
> +++ b/arch/arm/mach-vexpress/v2m.c
> @@ -476,6 +476,7 @@ static const char * const v2m_dt_match[] __initconst = {
> DT_MACHINE_START(VEXPRESS_DT, "ARM-Versatile Express")
> .dt_compat = v2m_dt_match,
> .smp = smp_ops(vexpress_smp_ops),
> + .smp_init = smp_init_ops(vexpress_smp_init_ops),
> .map_io = v2m_dt_map_io,
> .init_early = v2m_dt_init_early,
> .init_irq = irqchip_init,
--
Tixy
next prev parent reply other threads:[~2013-04-08 9:10 UTC|newest]
Thread overview: 55+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-02-05 5:21 [PATCH v4 00/15] multi-cluster power management Nicolas Pitre
2013-02-05 5:21 ` [PATCH v4 01/15] ARM: multi-cluster PM: secondary kernel entry code Nicolas Pitre
2013-04-23 19:19 ` Russell King - ARM Linux
2013-04-23 19:34 ` Nicolas Pitre
2013-04-23 20:09 ` Russell King - ARM Linux
2013-04-23 20:19 ` Nicolas Pitre
2013-02-05 5:21 ` [PATCH v4 02/15] ARM: mcpm: introduce the CPU/cluster power API Nicolas Pitre
2013-02-05 5:22 ` [PATCH v4 03/15] ARM: mcpm: introduce helpers for platform coherency exit/setup Nicolas Pitre
2013-04-05 23:00 ` Olof Johansson
2013-04-06 13:41 ` Nicolas Pitre
2013-04-24 9:10 ` Dave Martin
2013-02-05 5:22 ` [PATCH v4 04/15] ARM: mcpm: Add baremetal voting mutexes Nicolas Pitre
2013-02-05 5:22 ` [PATCH v4 05/15] ARM: mcpm_head.S: vlock-based first man election Nicolas Pitre
2013-02-05 5:22 ` [PATCH v4 06/15] ARM: mcpm: generic SMP secondary bringup and hotplug support Nicolas Pitre
2013-04-23 19:31 ` Russell King - ARM Linux
2013-04-23 19:36 ` Nicolas Pitre
2013-02-05 5:22 ` [PATCH v4 07/15] ARM: introduce common set_auxcr/get_auxcr functions Nicolas Pitre
2013-02-05 5:22 ` [PATCH v4 08/15] ARM: vexpress: introduce DCSCB support Nicolas Pitre
2013-02-07 18:14 ` Catalin Marinas
2013-02-07 18:56 ` Nicolas Pitre
2013-02-05 5:22 ` [PATCH v4 09/15] ARM: vexpress/dcscb: add CPU use counts to the power up/down API implementation Nicolas Pitre
2013-02-05 5:22 ` [PATCH v4 10/15] ARM: vexpress/dcscb: do not hardcode number of CPUs per cluster Nicolas Pitre
2013-02-05 5:22 ` [PATCH v4 11/15] drivers/bus: add ARM CCI support Nicolas Pitre
2013-04-23 19:38 ` Russell King - ARM Linux
2013-04-23 19:53 ` Nicolas Pitre
2013-02-05 5:22 ` [PATCH v4 12/15] ARM: CCI: ensure powerdown-time data is flushed from cache Nicolas Pitre
2013-04-23 19:40 ` Russell King - ARM Linux
2013-02-05 5:22 ` [PATCH v4 13/15] ARM: vexpress/dcscb: handle platform coherency exit/setup and CCI Nicolas Pitre
2013-02-05 5:22 ` [PATCH v4 14/15] ARM: Enable selection of SMP operations at boot time Nicolas Pitre
2013-04-05 22:43 ` Olof Johansson
2013-04-06 13:43 ` Nicolas Pitre
2013-04-09 16:30 ` Nicolas Pitre
2013-04-09 16:55 ` Jon Medhurst (Tixy)
2013-02-05 5:22 ` [PATCH v4 15/15] ARM: vexpress: Select multi-cluster SMP operation if required Nicolas Pitre
2013-02-06 16:38 ` Pawel Moll
2013-02-06 17:55 ` Nicolas Pitre
2013-04-05 22:48 ` Olof Johansson
2013-04-06 14:02 ` Nicolas Pitre
2013-04-08 9:10 ` Jon Medhurst (Tixy) [this message]
2013-04-09 5:41 ` Nicolas Pitre
2013-04-09 6:00 ` Jon Medhurst (Tixy)
2013-04-09 16:34 ` Nicolas Pitre
2013-04-09 17:28 ` Jon Medhurst (Tixy)
2013-04-23 19:42 ` Russell King - ARM Linux
2013-04-23 19:56 ` Nicolas Pitre
2013-04-23 20:04 ` [PATCH v4 00/15] multi-cluster power management Russell King - ARM Linux
2013-04-23 21:03 ` Nicolas Pitre
2013-04-23 21:46 ` Russell King - ARM Linux
2013-04-23 21:56 ` Nicolas Pitre
2013-04-23 22:44 ` Russell King - ARM Linux
2013-04-24 4:11 ` Nicolas Pitre
2013-04-24 20:25 ` Russell King - ARM Linux
2013-04-24 23:31 ` Nicolas Pitre
2013-04-24 14:25 ` Dave Martin
2013-04-23 21:11 ` Nicolas Pitre
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1365412211.3384.16.camel@linaro1.home \
--to=tixy@linaro.org \
--cc=linux-arm-kernel@lists.infradead.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).