From: tixy@linaro.org (Jon Medhurst (Tixy))
To: linux-arm-kernel@lists.infradead.org
Subject: [PATCH v4 14/15] ARM: Enable selection of SMP operations at boot time
Date: Tue, 09 Apr 2013 17:55:02 +0100 [thread overview]
Message-ID: <1365526502.3434.90.camel@linaro1.home> (raw)
In-Reply-To: <alpine.LFD.2.03.1304091223200.1171@syhkavp.arg>
On Tue, 2013-04-09 at 12:30 -0400, Nicolas Pitre wrote:
> On Tue, 5 Feb 2013, Nicolas Pitre wrote:
>
> > From: Jon Medhurst <tixy@linaro.org>
> >
> > Add a new 'smp_init' hook to machine_desc so platforms can specify a
> > function to be used to setup smp ops instead of having a statically
> > defined value.
> >
> > 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>
>
> I've slightly amended this patch to make its usage more flexible, please
> see below.
Looks good to me.
Reviewed-by: Jon Medhurst <tixy@linaro.org>
> > diff --git a/arch/arm/include/asm/mach/arch.h b/arch/arm/include/asm/mach/arch.h
> > index 917d4fcfd9..3d01c6d6c3 100644
> > --- a/arch/arm/include/asm/mach/arch.h
> > +++ b/arch/arm/include/asm/mach/arch.h
> > @@ -17,8 +17,10 @@ struct pt_regs;
> > struct smp_operations;
> > #ifdef CONFIG_SMP
> > #define smp_ops(ops) (&(ops))
> > +#define smp_init_ops(ops) (&(ops))
> > #else
> > #define smp_ops(ops) (struct smp_operations *)NULL
> > +#define smp_init_ops(ops) (void (*)(void))NULL
> > #endif
> >
> > struct machine_desc {
> > @@ -42,6 +44,7 @@ struct machine_desc {
> > unsigned char reserve_lp2 :1; /* never has lp2 */
> > char restart_mode; /* default restart mode */
> > struct smp_operations *smp; /* SMP operations */
> > + void (*smp_init)(void);
> > void (*fixup)(struct tag *, char **,
> > struct meminfo *);
> > void (*reserve)(void);/* reserve mem blocks */
> > diff --git a/arch/arm/kernel/setup.c b/arch/arm/kernel/setup.c
> > index 3f6cbb2e3e..41edca8582 100644
> > --- a/arch/arm/kernel/setup.c
> > +++ b/arch/arm/kernel/setup.c
> > @@ -768,7 +768,10 @@ void __init setup_arch(char **cmdline_p)
> > arm_dt_init_cpu_maps();
> > #ifdef CONFIG_SMP
> > if (is_smp()) {
> > - smp_set_ops(mdesc->smp);
> > + if(mdesc->smp_init)
> > + (*mdesc->smp_init)();
> > + else
> > + smp_set_ops(mdesc->smp);
> > smp_init_cpus();
> > }
> > #endif
>
> I've amended it with the following changes to deal with an issue
> highlighted by Tixy. If the runtime hook does not initialize the smp
> ops, the core may continue with a default. That should let MCPM, PSCI
> and Xen play well together.
>
> diff --git a/arch/arm/include/asm/mach/arch.h b/arch/arm/include/asm/mach/arch.h
> index c01bf53b85..af8c54c6c6 100644
> --- a/arch/arm/include/asm/mach/arch.h
> +++ b/arch/arm/include/asm/mach/arch.h
> @@ -19,7 +19,7 @@ struct smp_operations;
> #define smp_init_ops(ops) (&(ops))
> #else
> #define smp_ops(ops) (struct smp_operations *)NULL
> -#define smp_init_ops(ops) (void (*)(void))NULL
> +#define smp_init_ops(ops) (bool (*)(void))NULL
> #endif
>
> struct machine_desc {
> @@ -43,7 +43,7 @@ struct machine_desc {
> unsigned char reserve_lp2 :1; /* never has lp2 */
> char restart_mode; /* default restart mode */
> struct smp_operations *smp; /* SMP operations */
> - void (*smp_init)(void);
> + bool (*smp_init)(void);
> void (*fixup)(struct tag *, char **,
> struct meminfo *);
> void (*reserve)(void);/* reserve mem blocks */
> diff --git a/arch/arm/kernel/setup.c b/arch/arm/kernel/setup.c
> index e69c580c6f..cf4b08c0f9 100644
> --- a/arch/arm/kernel/setup.c
> +++ b/arch/arm/kernel/setup.c
> @@ -768,9 +768,7 @@ void __init setup_arch(char **cmdline_p)
> arm_dt_init_cpu_maps();
> #ifdef CONFIG_SMP
> if (is_smp()) {
> - if (mdesc->smp_init)
> - mdesc->smp_init();
> - else
> + if (!mdesc->smp_init || !mdesc->smp_init())
> smp_set_ops(mdesc->smp);
> smp_init_cpus();
> }
>
>
> Nicolas
next prev parent reply other threads:[~2013-04-09 16:55 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) [this message]
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)
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=1365526502.3434.90.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).