[PATCH 09/13] ARM: OMAP5: Add SMP support.
Will Deacon
will.deacon at arm.com
Tue May 8 08:47:59 EDT 2012
Hello,
On Thu, May 03, 2012 at 08:26:18AM +0100, R Sricharan wrote:
> From: Santosh Shilimkar <santosh.shilimkar at ti.com>
>
> Add OMAP5 SMP boot support using OMAP4 SMP code. The relevant code paths
> are runtime checked using cpu id
>
> Signed-off-by: Santosh Shilimkar <santosh.shilimkar at ti.com>
> Signed-off-by: R Sricharan <r.sricharan at ti.com>
> ---
> arch/arm/mach-omap2/common.h | 1 +
> arch/arm/mach-omap2/omap-headsmp.S | 21 ++++++++++++++++++
> arch/arm/mach-omap2/omap-smp.c | 41 +++++++++++++++++++++++++----------
> 3 files changed, 51 insertions(+), 12 deletions(-)
[...]
> diff --git a/arch/arm/mach-omap2/omap-smp.c b/arch/arm/mach-omap2/omap-smp.c
> index 151fd5b..9424bb6 100644
> --- a/arch/arm/mach-omap2/omap-smp.c
> +++ b/arch/arm/mach-omap2/omap-smp.c
> @@ -33,6 +33,10 @@
> #include "common.h"
> #include "clockdomain.h"
>
> +#define CPU_MASK 0xff0ffff0
> +#define CPU_CORTEX_A9 0x410FC090
> +#define CPU_CORTEX_A15 0x410FC0F0
> +
> /* SCU base address */
> static void __iomem *scu_base;
>
> @@ -43,6 +47,14 @@ void __iomem *omap4_get_scu_base(void)
> return scu_base;
> }
>
> +static inline unsigned int get_a15_core_count(void)
> +{
> + unsigned int ncores;
> +
> + asm volatile("mrc p15, 1, %0, c9, c0, 2\n" : "=r" (ncores));
> + return ((ncores >> 24) & 3) + 1;
> +}
This register (L2 control) only tells you how many cores you have hanging
off the L2 cache, which isn't really viable for future multi-cluster
configurations. You're probably better off either reading the number of CPU
nodes out of the DT (ppc, vexpress) or returning a constant for now
(exynos5).
Will
More information about the linux-arm-kernel
mailing list