[PATCH 5/5] ARM: imx: Add Freescale LS1021A SMP support
Mark Rutland
mark.rutland at arm.com
Wed Jul 2 04:30:58 PDT 2014
On Wed, Jul 02, 2014 at 10:02:52AM +0100, Jingchang Lu wrote:
> From: Jingchang Lu <b35083 at freescale.com>
>
> Freescale LS1021A SoC deploys two cortex-A7 processors,
> this adds bring-up support for the secondary core.
>
> Signed-off-by: Jingchang Lu <b35083 at freescale.com>
> ---
> arch/arm/mach-imx/common.h | 2 ++
> arch/arm/mach-imx/headsmp.S | 11 ++++++++++
> arch/arm/mach-imx/mach-ls1021a.c | 1 +
> arch/arm/mach-imx/platsmp.c | 44 ++++++++++++++++++++++++++++++++++++++++
> 4 files changed, 58 insertions(+)
[...]
> diff --git a/arch/arm/mach-imx/headsmp.S b/arch/arm/mach-imx/headsmp.S
> index de5047c..fdd93d9 100644
> --- a/arch/arm/mach-imx/headsmp.S
> +++ b/arch/arm/mach-imx/headsmp.S
> @@ -29,3 +29,14 @@ ENTRY(v7_secondary_startup)
> set_diag_reg
> b secondary_startup
> ENDPROC(v7_secondary_startup)
> +
> +ENTRY(ls1021a_secondary_startup)
> + /* set CNTFREQ of secondary core */
> + ldr r0, =12500000
> + mcr p15, 0, r0, c14, c0, 0
> + /* disable Physical and Virtural Timer */
> + mov r0, #0x0
> + mcr p15, 0, r0, c14, c2, 1
> + mcr p15, 0, r0, c14, c3, 1
> + b secondary_startup
Urrgh...
What about CNTVOFF? That's been a source of problems elsewhere.
Is the boot CPU set up correctly?
Is that frequency always going to be correct?
[...]
> +static void __init ls1021a_smp_init_cpus(void)
> +{
> + int i, ncores;
> + /* get number of cores from CP15 L2 controller register(L2CTLR)*/
> + asm volatile ("mrc p15, 1, %0, c9, c0, 2" : "=r" (ncores));
> +
> + ncores = ((ncores >> 24) & 0x3) + 1;
> + for (i = ncores; i < NR_CPUS; i++)
> + set_cpu_possible(i, false);
> +}
NAK.
This information is _already_ in the DT. This adds more code to do
redundant work, and it's broken.
The physical<->logical CPU ID mapping is arbitrary, so you set arbitrary
CPUs as being online despite this not necessarily being the case.
Get rid of this, and rely on the DT being correct. There;s no reason it
shouldn't be for a new platform.
Thanks,
Mark.
More information about the linux-arm-kernel
mailing list