summaryrefslogtreecommitdiffstats
path: root/arch/arm/boards/vexpress/init.c
diff options
context:
space:
mode:
authorJean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com>2013-02-12 14:03:27 +0100
committerSascha Hauer <s.hauer@pengutronix.de>2013-02-13 09:21:44 +0100
commit64b873ccba69a6311e03de1c68585f32f5a86524 (patch)
tree186ffb7ad10ba36b51a6ce68f300ce57c40bbfca /arch/arm/boards/vexpress/init.c
parented4da3f2de93bf445f10b762aeb1fc75967b5660 (diff)
downloadbarebox-64b873ccba69a6311e03de1c68585f32f5a86524.tar.gz
barebox-64b873ccba69a6311e03de1c68585f32f5a86524.tar.xz
vexpress: detect the board periph mapping and detecting the sp804 mapping
at 0x10011000 for a9 legacy otherwise at 0x1c110000 as the new board also support Cortex-A9 so this is working qemu/arm-softmmu/qemu-system-arm -M vexpress-a15 -m 1024 -smp 1 -kernel build/vexpress/barebox -pflash build/vexpress/flash -nographic -cpu cortex-a9 Signed-off-by: Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com> Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
Diffstat (limited to 'arch/arm/boards/vexpress/init.c')
-rw-r--r--arch/arm/boards/vexpress/init.c35
1 files changed, 19 insertions, 16 deletions
diff --git a/arch/arm/boards/vexpress/init.c b/arch/arm/boards/vexpress/init.c
index f940824be1..2b2d085a54 100644
--- a/arch/arm/boards/vexpress/init.c
+++ b/arch/arm/boards/vexpress/init.c
@@ -15,6 +15,7 @@
#include <sizes.h>
#include <io.h>
#include <globalvar.h>
+#include <linux/amba/sp804.h>
struct vexpress_init {
void (*core_init)(void);
@@ -57,12 +58,12 @@ struct vexpress_init vexpress_init_ax = {
.devices_init = vexpress_ax_devices_init,
};
-static void vexpress_a9_mem_init(void)
+static void vexpress_a9_legacy_mem_init(void)
{
- vexpress_a9_add_ddram(SZ_512M, SZ_512M);
+ vexpress_a9_legacy_add_ddram(SZ_512M, SZ_512M);
}
-static void vexpress_a9_devices_init(void)
+static void vexpress_a9_legacy_devices_init(void)
{
add_cfi_flash_device(0, 0x40000000, SZ_64M, 0);
add_cfi_flash_device(1, 0x44000000, SZ_64M, 0);
@@ -73,20 +74,20 @@ static void vexpress_a9_devices_init(void)
armlinux_set_bootparams((void *)(0x60000100));
}
-static void vexpress_a9_console_init(void)
+static void vexpress_a9_legacy_console_init(void)
{
- vexpress_a9_register_uart(0);
- vexpress_a9_register_uart(1);
- vexpress_a9_register_uart(2);
- vexpress_a9_register_uart(3);
+ vexpress_a9_legacy_register_uart(0);
+ vexpress_a9_legacy_register_uart(1);
+ vexpress_a9_legacy_register_uart(2);
+ vexpress_a9_legacy_register_uart(3);
}
-struct vexpress_init vexpress_init_a9 = {
- .core_init = vexpress_a9_init,
- .mem_init = vexpress_a9_mem_init,
- .console_init = vexpress_a9_console_init,
- .devices_init = vexpress_a9_devices_init,
- .hostname = "vexpress-a9",
+struct vexpress_init vexpress_init_a9_legacy = {
+ .core_init = vexpress_a9_legacy_init,
+ .mem_init = vexpress_a9_legacy_mem_init,
+ .console_init = vexpress_a9_legacy_console_init,
+ .devices_init = vexpress_a9_legacy_devices_init,
+ .hostname = "vexpress-a9-legacy",
};
static int vexpress_mem_init(void)
@@ -123,14 +124,16 @@ console_initcall(vexpress_console_init);
static int vexpress_core_init(void)
{
- if (cpu_is_cortex_a9()) {
- v2m_init = &vexpress_init_a9;
+ if (amba_is_arm_sp804(IOMEM(0x10011000))) {
+ v2m_init = &vexpress_init_a9_legacy;
} else {
v2m_init = &vexpress_init_ax;
if (cpu_is_cortex_a5())
v2m_init->hostname = "vexpress-a5";
else if (cpu_is_cortex_a7())
v2m_init->hostname = "vexpress-a7";
+ else if (cpu_is_cortex_a9())
+ v2m_init->hostname = "vexpress-a9";
else if (cpu_is_cortex_a15())
v2m_init->hostname = "vexpress-a15";
}