summaryrefslogtreecommitdiffstats
path: root/arch/powerpc/boot/cuboot-amigaone.c
diff options
context:
space:
mode:
authorGerhard Pircher <gerhard_pircher@gmx.net>2009-02-10 13:26:11 +0100
committerBenjamin Herrenschmidt <benh@kernel.crashing.org>2009-02-11 06:00:09 +0100
commit8f23735d8f8cfd4d46e3aa336690f52b8b5d3c75 (patch)
tree7e8644dc5661cfe80ee8685914589de1b1ab3faa /arch/powerpc/boot/cuboot-amigaone.c
parentpowerpc/amigaone: Generic device tree for all AmigaOne boards (diff)
downloadlinux-8f23735d8f8cfd4d46e3aa336690f52b8b5d3c75.tar.xz
linux-8f23735d8f8cfd4d46e3aa336690f52b8b5d3c75.zip
powerpc/amigaone: Bootwrapper and serial console support for AmigaOne
This adds the bootwrapper for the cuImage target and a compatible property check for "pnpPNP,501" to the generic serial console support code. The default link address for the cuImage target is set to 0x800000. This allows to boot the kernel with AmigaOS4's second level bootloader, which always loads a uImage at 0x500000. Signed-off-by: Gerhard Pircher <gerhard_pircher@gmx.net> Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Diffstat (limited to 'arch/powerpc/boot/cuboot-amigaone.c')
-rw-r--r--arch/powerpc/boot/cuboot-amigaone.c35
1 files changed, 35 insertions, 0 deletions
diff --git a/arch/powerpc/boot/cuboot-amigaone.c b/arch/powerpc/boot/cuboot-amigaone.c
new file mode 100644
index 000000000000..d5029674030b
--- /dev/null
+++ b/arch/powerpc/boot/cuboot-amigaone.c
@@ -0,0 +1,35 @@
+/*
+ * Old U-boot compatibility for AmigaOne
+ *
+ * Author: Gerhard Pircher (gerhard_pircher@gmx.net)
+ *
+ * Based on cuboot-83xx.c
+ * Copyright (c) 2007 Freescale Semiconductor, Inc.
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU General Public License version 2 as published
+ * by the Free Software Foundation.
+ */
+
+#include "ops.h"
+#include "stdio.h"
+#include "cuboot.h"
+
+#include "ppcboot.h"
+
+static bd_t bd;
+
+static void platform_fixups(void)
+{
+ dt_fixup_memory(bd.bi_memstart, bd.bi_memsize);
+ dt_fixup_cpu_clocks(bd.bi_intfreq, bd.bi_busfreq / 4, bd.bi_busfreq);
+}
+
+void platform_init(unsigned long r3, unsigned long r4, unsigned long r5,
+ unsigned long r6, unsigned long r7)
+{
+ CUBOOT_INIT();
+ fdt_init(_dtb_start);
+ serial_console_init();
+ platform_ops.fixups = platform_fixups;
+}