blob: 124ffb16909382f1383673783812fd5a1354f70c [file] [log] [blame]
Russell King59ac59f2010-02-11 21:56:07 +00001/*
2 * linux/arch/arm/mach-vexpress/platsmp.c
3 *
4 * Copyright (C) 2002 ARM Ltd.
5 * All Rights Reserved
6 *
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License version 2 as
9 * published by the Free Software Foundation.
10 */
11#include <linux/init.h>
12#include <linux/errno.h>
Russell King59ac59f2010-02-11 21:56:07 +000013#include <linux/smp.h>
14#include <linux/io.h>
15
Russell King59ac59f2010-02-11 21:56:07 +000016#include <mach/motherboard.h>
17#define V2M_PA_CS7 0x10000000
18
19#include "core.h"
20
Russell King0462b442011-01-19 10:24:56 +000021extern void versatile_secondary_startup(void);
Russell King3705ff62010-12-18 10:53:12 +000022
Russell King59ac59f2010-02-11 21:56:07 +000023/*
24 * Initialise the CPU possible map early - this describes the CPUs
25 * which may be present or become present in the system.
26 */
27void __init smp_init_cpus(void)
28{
Will Deacon80b5efb2011-02-28 17:01:04 +010029 ct_desc->init_cpu_map();
Russell King59ac59f2010-02-11 21:56:07 +000030}
31
Russell King05c74a62010-12-03 11:09:48 +000032void __init platform_smp_prepare_cpus(unsigned int max_cpus)
Russell King59ac59f2010-02-11 21:56:07 +000033{
Russell King59ac59f2010-02-11 21:56:07 +000034 /*
35 * Initialise the present map, which describes the set of CPUs
36 * actually populated at the present time.
37 */
Will Deacon80b5efb2011-02-28 17:01:04 +010038 ct_desc->smp_enable(max_cpus);
Russell King05c74a62010-12-03 11:09:48 +000039
Russell King59ac59f2010-02-11 21:56:07 +000040 /*
Russell King05c74a62010-12-03 11:09:48 +000041 * Write the address of secondary startup into the
42 * system-wide flags register. The boot monitor waits
43 * until it receives a soft interrupt, and then the
44 * secondary CPU branches to this address.
Russell King59ac59f2010-02-11 21:56:07 +000045 */
Russell King05c74a62010-12-03 11:09:48 +000046 writel(~0, MMIO_P2V(V2M_SYS_FLAGSCLR));
Pawel Moll764a5792011-12-15 14:02:33 +000047 writel(virt_to_phys(versatile_secondary_startup),
Russell King05c74a62010-12-03 11:09:48 +000048 MMIO_P2V(V2M_SYS_FLAGSSET));
Russell King59ac59f2010-02-11 21:56:07 +000049}