summaryrefslogtreecommitdiff
path: root/arch/mips/mach-octeon/dram.c
diff options
context:
space:
mode:
authorAaron Williams <awilliams@marvell.com>2020-06-30 13:08:56 +0300
committerDaniel Schwierzeck <daniel.schwierzeck@gmail.com>2020-07-18 16:47:50 +0300
commit0dc4ab9c43ff6a235b4c0c5295a1a9747ea684c9 (patch)
tree27c647c9fbc99170c2761f28d434e8431f668304 /arch/mips/mach-octeon/dram.c
parent59aea37abf6bf6d5119a9e2f0237b26bf820b285 (diff)
downloadu-boot-0dc4ab9c43ff6a235b4c0c5295a1a9747ea684c9.tar.xz
mips: octeon: Initial minimal support for the Marvell Octeon SoC
This patch adds very basic support for the Octeon III SoCs. Only CFI parallel NOR flash and UART is supported for now. Please note that the basic Octeon port does not include the DDR3/4 initialization yet. This will be added in some follow-up patches later. To still use U-Boot on with this port, the L2 cache (4MiB on Octeon III CN73xx) is used as RAM. This way, U-Boot can boot to the prompt on such boards. Signed-off-by: Aaron Williams <awilliams@marvell.com> Signed-off-by: Stefan Roese <sr@denx.de>
Diffstat (limited to 'arch/mips/mach-octeon/dram.c')
-rw-r--r--arch/mips/mach-octeon/dram.c28
1 files changed, 28 insertions, 0 deletions
diff --git a/arch/mips/mach-octeon/dram.c b/arch/mips/mach-octeon/dram.c
new file mode 100644
index 0000000000..ff7a59f2ab
--- /dev/null
+++ b/arch/mips/mach-octeon/dram.c
@@ -0,0 +1,28 @@
+// SPDX-License-Identifier: GPL-2.0+
+/*
+ * Copyright (C) Stefan Roese <sr@denx.de>
+ */
+
+#include <dm.h>
+#include <ram.h>
+#include <asm/global_data.h>
+#include <linux/compat.h>
+
+DECLARE_GLOBAL_DATA_PTR;
+
+int dram_init(void)
+{
+ /*
+ * No DDR init yet -> run in L2 cache
+ */
+ gd->ram_size = (4 << 20);
+ gd->bd->bi_dram[0].size = gd->ram_size;
+ gd->bd->bi_dram[1].size = 0;
+
+ return 0;
+}
+
+ulong board_get_usable_ram_top(ulong total_size)
+{
+ return gd->ram_top;
+}