All of lore.kernel.org
 help / color / mirror / Atom feed
* [U-Boot] [PATCH 0/6] Add support for VCore III SoCs found in Microsemi switches
@ 2018-09-25 13:01 Gregory CLEMENT
  2018-09-25 13:01 ` [U-Boot] [PATCH 1/6] MIPS: move create_tlb() in an proper header: mipsregs.h Gregory CLEMENT
                   ` (7 more replies)
  0 siblings, 8 replies; 22+ messages in thread
From: Gregory CLEMENT @ 2018-09-25 13:01 UTC (permalink / raw)
  To: u-boot

Hello,

This series add the support of 2 SoCs: Ocelot and Luton from
Microsemi. Both of them belongs to the same family Vcore III.

We found them on various advanced switches product.

The support for Ocelot already have been submit to Linux, but not yet
the Luton support.

Besides this series 3 others patches are needed but they are driver
related:
DW SPI: Allow to overload the management of the external CS
gpio: mscc-bitbang-spi: Add a simple gpio driver for bitbgang spi
pinctrl: mscc: Add gpio and pinctrl driver for MSCC MIPS SoCs (VcoreIII based)

They will be submitted separately.

Thanks,

Gregory


Gregory CLEMENT (6):
  MIPS: move create_tlb() in an proper header: mipsregs.h
  MSCC: add support for VCoreIII SoCs
  MSCC: add board support for the VCoreIII based evaluation boards
  MSCC: add device tree for Ocelot and Luton (boards and SoCs)
  MSCC: add configuration for Ocelot and Luton based boards
  MIPS: bootm: Add support for Vcore III linux kernel

 arch/mips/Kconfig                             |   6 +
 arch/mips/Makefile                            |   1 +
 arch/mips/cpu/cpu.c                           |  10 -
 arch/mips/dts/luton_pcb091.dts                |  36 +
 arch/mips/dts/mscc,luton.dtsi                 |  87 ++
 arch/mips/dts/mscc,ocelot.dtsi                | 132 +++
 arch/mips/dts/mscc,ocelot_pcb.dtsi            |  37 +
 arch/mips/dts/ocelot_pcb120.dts               |  12 +
 arch/mips/dts/ocelot_pcb123.dts               |  12 +
 arch/mips/include/asm/mipsregs.h              |  11 +
 arch/mips/lib/bootm.c                         |  62 +-
 arch/mips/mach-mscc/Kconfig                   | 101 ++
 arch/mips/mach-mscc/Makefile                  |   6 +
 arch/mips/mach-mscc/cpu.c                     |  72 ++
 arch/mips/mach-mscc/dram.c                    |  62 ++
 arch/mips/mach-mscc/include/ioremap.h         |  49 +
 arch/mips/mach-mscc/include/mach/cache.h      |  36 +
 arch/mips/mach-mscc/include/mach/common.h     |  31 +
 arch/mips/mach-mscc/include/mach/ddr.h        | 753 +++++++++++++++
 .../mips/mach-mscc/include/mach/luton/luton.h |  37 +
 .../include/mach/luton/luton_devcpu_gcb.h     |  16 +
 .../include/mach/luton/luton_icpu_cfg-ref.h   | 884 ++++++++++++++++++
 .../include/mach/luton/luton_icpu_cfg.h       | 247 +++++
 .../mach-mscc/include/mach/ocelot/ocelot.h    |  35 +
 .../include/mach/ocelot/ocelot_devcpu_gcb.h   | 353 +++++++
 .../include/mach/ocelot/ocelot_icpu_cfg.h     | 884 ++++++++++++++++++
 arch/mips/mach-mscc/include/mach/tlb.h        |  65 ++
 arch/mips/mach-mscc/lowlevel_init.S           |  29 +
 arch/mips/mach-mscc/lowlevel_init_luton.S     |  63 ++
 arch/mips/mach-mscc/reset.c                   |  37 +
 board/mscc/common/board.c                     |  29 +
 board/mscc/luton/Kconfig                      |  14 +
 board/mscc/luton/Makefile                     |   4 +
 board/mscc/luton/luton.c                      |  14 +
 board/mscc/ocelot/Kconfig                     |  24 +
 board/mscc/ocelot/Makefile                    |   5 +
 board/mscc/ocelot/ocelot.c                    |  38 +
 configs/mscc_luton_defconfig                  |  66 ++
 configs/mscc_ocelot_defconfig                 |  57 ++
 configs/mscc_ocelot_pcb120_defconfig          |  56 ++
 include/configs/vcoreiii.h                    |  72 ++
 41 files changed, 4515 insertions(+), 30 deletions(-)
 create mode 100644 arch/mips/dts/luton_pcb091.dts
 create mode 100644 arch/mips/dts/mscc,luton.dtsi
 create mode 100644 arch/mips/dts/mscc,ocelot.dtsi
 create mode 100644 arch/mips/dts/mscc,ocelot_pcb.dtsi
 create mode 100644 arch/mips/dts/ocelot_pcb120.dts
 create mode 100644 arch/mips/dts/ocelot_pcb123.dts
 create mode 100644 arch/mips/mach-mscc/Kconfig
 create mode 100644 arch/mips/mach-mscc/Makefile
 create mode 100644 arch/mips/mach-mscc/cpu.c
 create mode 100644 arch/mips/mach-mscc/dram.c
 create mode 100644 arch/mips/mach-mscc/include/ioremap.h
 create mode 100644 arch/mips/mach-mscc/include/mach/cache.h
 create mode 100644 arch/mips/mach-mscc/include/mach/common.h
 create mode 100644 arch/mips/mach-mscc/include/mach/ddr.h
 create mode 100644 arch/mips/mach-mscc/include/mach/luton/luton.h
 create mode 100644 arch/mips/mach-mscc/include/mach/luton/luton_devcpu_gcb.h
 create mode 100644 arch/mips/mach-mscc/include/mach/luton/luton_icpu_cfg-ref.h
 create mode 100644 arch/mips/mach-mscc/include/mach/luton/luton_icpu_cfg.h
 create mode 100644 arch/mips/mach-mscc/include/mach/ocelot/ocelot.h
 create mode 100644 arch/mips/mach-mscc/include/mach/ocelot/ocelot_devcpu_gcb.h
 create mode 100644 arch/mips/mach-mscc/include/mach/ocelot/ocelot_icpu_cfg.h
 create mode 100644 arch/mips/mach-mscc/include/mach/tlb.h
 create mode 100644 arch/mips/mach-mscc/lowlevel_init.S
 create mode 100644 arch/mips/mach-mscc/lowlevel_init_luton.S
 create mode 100644 arch/mips/mach-mscc/reset.c
 create mode 100644 board/mscc/common/board.c
 create mode 100644 board/mscc/luton/Kconfig
 create mode 100644 board/mscc/luton/Makefile
 create mode 100644 board/mscc/luton/luton.c
 create mode 100644 board/mscc/ocelot/Kconfig
 create mode 100644 board/mscc/ocelot/Makefile
 create mode 100644 board/mscc/ocelot/ocelot.c
 create mode 100644 configs/mscc_luton_defconfig
 create mode 100644 configs/mscc_ocelot_defconfig
 create mode 100644 configs/mscc_ocelot_pcb120_defconfig
 create mode 100644 include/configs/vcoreiii.h

-- 
2.19.0

^ permalink raw reply	[flat|nested] 22+ messages in thread

* [U-Boot] [PATCH 1/6] MIPS: move create_tlb() in an proper header: mipsregs.h
  2018-09-25 13:01 [U-Boot] [PATCH 0/6] Add support for VCore III SoCs found in Microsemi switches Gregory CLEMENT
@ 2018-09-25 13:01 ` Gregory CLEMENT
  2018-09-25 13:01 ` [U-Boot] [PATCH 3/6] MSCC: add board support for the VCoreIII based evaluation boards Gregory CLEMENT
                   ` (6 subsequent siblings)
  7 siblings, 0 replies; 22+ messages in thread
From: Gregory CLEMENT @ 2018-09-25 13:01 UTC (permalink / raw)
  To: u-boot

Export create_tlb() as an inline function in mipsregs.h. It allows to
remove the declaration of the function from the board files.

Then it will allow also to use this function very early in the boot when
the stack is not usable.

Signed-off-by: Gregory CLEMENT <gregory.clement@bootlin.com>
---
 arch/mips/cpu/cpu.c              | 10 ----------
 arch/mips/include/asm/mipsregs.h | 11 +++++++++++
 2 files changed, 11 insertions(+), 10 deletions(-)

diff --git a/arch/mips/cpu/cpu.c b/arch/mips/cpu/cpu.c
index 5c56ab0289..a403ff729b 100644
--- a/arch/mips/cpu/cpu.c
+++ b/arch/mips/cpu/cpu.c
@@ -28,16 +28,6 @@ int do_reset(cmd_tbl_t *cmdtp, int flag, int argc, char * const argv[])
 }
 #endif
 
-void write_one_tlb(int index, u32 pagemask, u32 hi, u32 low0, u32 low1)
-{
-	write_c0_entrylo0(low0);
-	write_c0_pagemask(pagemask);
-	write_c0_entrylo1(low1);
-	write_c0_entryhi(hi);
-	write_c0_index(index);
-	tlb_write_indexed();
-}
-
 int arch_cpu_init(void)
 {
 	mips_cache_probe();
diff --git a/arch/mips/include/asm/mipsregs.h b/arch/mips/include/asm/mipsregs.h
index 48fa1f1f7f..930562ebb2 100644
--- a/arch/mips/include/asm/mipsregs.h
+++ b/arch/mips/include/asm/mipsregs.h
@@ -2005,6 +2005,17 @@ static inline unsigned int get_ebase_cpunum(void)
 	return read_c0_ebase() & 0x3ff;
 }
 
+static inline void write_one_tlb(int index, u32 pagemask, u32 hi, u32 low0,
+				 u32 low1)
+{
+	write_c0_entrylo0(low0);
+	write_c0_pagemask(pagemask);
+	write_c0_entrylo1(low1);
+	write_c0_entryhi(hi);
+	write_c0_index(index);
+	tlb_write_indexed();
+}
+
 #endif /* !__ASSEMBLY__ */
 
 #endif /* _ASM_MIPSREGS_H */
-- 
2.19.0

^ permalink raw reply related	[flat|nested] 22+ messages in thread

* [U-Boot] [PATCH 3/6] MSCC: add board support for the VCoreIII based evaluation boards
  2018-09-25 13:01 [U-Boot] [PATCH 0/6] Add support for VCore III SoCs found in Microsemi switches Gregory CLEMENT
  2018-09-25 13:01 ` [U-Boot] [PATCH 1/6] MIPS: move create_tlb() in an proper header: mipsregs.h Gregory CLEMENT
@ 2018-09-25 13:01 ` Gregory CLEMENT
  2018-09-26 19:28   ` Daniel Schwierzeck
  2018-09-26 23:03   ` Marek Vasut
  2018-09-25 13:01 ` [U-Boot] [PATCH 4/6] MSCC: add device tree for Ocelot and Luton (boards and SoCs) Gregory CLEMENT
                   ` (5 subsequent siblings)
  7 siblings, 2 replies; 22+ messages in thread
From: Gregory CLEMENT @ 2018-09-25 13:01 UTC (permalink / raw)
  To: u-boot

Adding the support for 3 boards sharing common code:
 - PCB120 and PCB 123 for Ocelot chip
 - PCB 91 for Luton chip

Signed-off-by: Gregory CLEMENT <gregory.clement@bootlin.com>
---
 board/mscc/common/board.c  | 29 +++++++++++++++++++++++++++++
 board/mscc/luton/Kconfig   | 14 ++++++++++++++
 board/mscc/luton/Makefile  |  4 ++++
 board/mscc/luton/luton.c   | 14 ++++++++++++++
 board/mscc/ocelot/Kconfig  | 24 ++++++++++++++++++++++++
 board/mscc/ocelot/Makefile |  5 +++++
 board/mscc/ocelot/ocelot.c | 38 ++++++++++++++++++++++++++++++++++++++
 7 files changed, 128 insertions(+)
 create mode 100644 board/mscc/common/board.c
 create mode 100644 board/mscc/luton/Kconfig
 create mode 100644 board/mscc/luton/Makefile
 create mode 100644 board/mscc/luton/luton.c
 create mode 100644 board/mscc/ocelot/Kconfig
 create mode 100644 board/mscc/ocelot/Makefile
 create mode 100644 board/mscc/ocelot/ocelot.c

diff --git a/board/mscc/common/board.c b/board/mscc/common/board.c
new file mode 100644
index 0000000000..86e7bf3353
--- /dev/null
+++ b/board/mscc/common/board.c
@@ -0,0 +1,29 @@
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+/*
+ * Copyright (c) 2018 Microsemi Corporation
+ */
+
+#include <common.h>
+#include <asm/io.h>
+#include <asm/addrspace.h>
+#include <asm/types.h>
+#include <environment.h>
+
+DECLARE_GLOBAL_DATA_PTR;
+
+int board_early_init_r(void)
+{
+	u32 ctrl;
+
+	/* Prepare SPI controller to be used in master mode */
+	writel(0, REG_CFG(ICPU_SW_MODE));
+	ctrl = readl(REG_CFG(ICPU_GENERAL_CTRL));
+
+	writel((ctrl & ~ICPU_GENERAL_CTRL_IF_SI_OWNER_M) |
+	       ICPU_GENERAL_CTRL_IF_SI_OWNER(2),
+	       REG_CFG(ICPU_GENERAL_CTRL));
+
+	/* Address of boot parameters */
+	gd->bd->bi_boot_params = CONFIG_SYS_SDRAM_BASE;
+	return 0;
+}
diff --git a/board/mscc/luton/Kconfig b/board/mscc/luton/Kconfig
new file mode 100644
index 0000000000..e1199808d5
--- /dev/null
+++ b/board/mscc/luton/Kconfig
@@ -0,0 +1,14 @@
+# SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+
+if SOC_LUTON
+
+config SYS_VENDOR
+	default "mscc"
+
+config SYS_BOARD
+	default "luton"
+
+config SYS_CONFIG_NAME
+	default "luton"
+
+endif
diff --git a/board/mscc/luton/Makefile b/board/mscc/luton/Makefile
new file mode 100644
index 0000000000..98bc47ba82
--- /dev/null
+++ b/board/mscc/luton/Makefile
@@ -0,0 +1,4 @@
+# SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+
+obj-$(CONFIG_SOC_LUTON)	:= luton.o
+obj-y += ../common/board.o
diff --git a/board/mscc/luton/luton.c b/board/mscc/luton/luton.c
new file mode 100644
index 0000000000..8c31bbb12a
--- /dev/null
+++ b/board/mscc/luton/luton.c
@@ -0,0 +1,14 @@
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+/*
+ * Copyright (c) 2018 Microsemi Corporation
+ */
+
+#include <common.h>
+#include <asm/io.h>
+
+void board_debug_uart_init(void)
+{
+	/* too early for the pinctrl driver, so configure the UART pins here */
+	writel(BIT(30)|BIT(31), REG_GCB((0x68+8*4)));
+	writel(~(BIT(30)|BIT(31)), REG_GCB((0x68+9*4)));
+}
diff --git a/board/mscc/ocelot/Kconfig b/board/mscc/ocelot/Kconfig
new file mode 100644
index 0000000000..0804f5081d
--- /dev/null
+++ b/board/mscc/ocelot/Kconfig
@@ -0,0 +1,24 @@
+# SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+
+config SYS_VENDOR
+	default "mscc"
+
+if SOC_OCELOT
+
+config SYS_BOARD
+	default "ocelot"
+
+config SYS_CONFIG_NAME
+	default "ocelot"
+
+endif
+
+if SOC_LUTON
+
+config SYS_BOARD
+	default "luton"
+
+config SYS_CONFIG_NAME
+	default "luton"
+
+endif
diff --git a/board/mscc/ocelot/Makefile b/board/mscc/ocelot/Makefile
new file mode 100644
index 0000000000..f6a665ca83
--- /dev/null
+++ b/board/mscc/ocelot/Makefile
@@ -0,0 +1,5 @@
+# SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+
+obj-$(CONFIG_SOC_OCELOT)	:= ocelot.o
+obj-y += ../common/board.o
+
diff --git a/board/mscc/ocelot/ocelot.c b/board/mscc/ocelot/ocelot.c
new file mode 100644
index 0000000000..971fa93d07
--- /dev/null
+++ b/board/mscc/ocelot/ocelot.c
@@ -0,0 +1,38 @@
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+/*
+ * Copyright (c) 2018 Microsemi Corporation
+ */
+
+#include <common.h>
+#include <asm/io.h>
+#include <asm/addrspace.h>
+#include <asm/types.h>
+#include <environment.h>
+#include <spi.h>
+
+DECLARE_GLOBAL_DATA_PTR;
+
+void external_cs_manage(struct udevice *dev, bool enable)
+{
+	u32 cs = spi_chip_select(dev);
+        /* IF_SI0_OWNER, select the owner of the SI interface
+         * Encoding: 0: SI Slave
+         *           1: SI Boot Master
+         *           2: SI Master Controller
+         */
+        if (!enable) {
+                writel(ICPU_SW_MODE_SW_PIN_CTRL_MODE |
+		       ICPU_SW_MODE_SW_SPI_CS(BIT(cs)),
+		       REG_CFG(ICPU_SW_MODE));
+                writel((readl(REG_CFG(ICPU_GENERAL_CTRL))
+			& ~ICPU_GENERAL_CTRL_IF_SI_OWNER_M) |
+		       ICPU_GENERAL_CTRL_IF_SI_OWNER(2),
+		       REG_CFG(ICPU_GENERAL_CTRL));
+        } else {
+                writel(0, REG_CFG(ICPU_SW_MODE));
+                writel((readl(REG_CFG(ICPU_GENERAL_CTRL)) &
+			~ICPU_GENERAL_CTRL_IF_SI_OWNER_M) |
+		       ICPU_GENERAL_CTRL_IF_SI_OWNER(1),
+		       REG_CFG(ICPU_GENERAL_CTRL));
+        }
+}
-- 
2.19.0

^ permalink raw reply related	[flat|nested] 22+ messages in thread

* [U-Boot] [PATCH 4/6] MSCC: add device tree for Ocelot and Luton (boards and SoCs)
  2018-09-25 13:01 [U-Boot] [PATCH 0/6] Add support for VCore III SoCs found in Microsemi switches Gregory CLEMENT
  2018-09-25 13:01 ` [U-Boot] [PATCH 1/6] MIPS: move create_tlb() in an proper header: mipsregs.h Gregory CLEMENT
  2018-09-25 13:01 ` [U-Boot] [PATCH 3/6] MSCC: add board support for the VCoreIII based evaluation boards Gregory CLEMENT
@ 2018-09-25 13:01 ` Gregory CLEMENT
  2018-09-26 19:31   ` Daniel Schwierzeck
  2018-09-25 13:01 ` [U-Boot] [PATCH 5/6] MSCC: add configuration for Ocelot and Luton based boards Gregory CLEMENT
                   ` (4 subsequent siblings)
  7 siblings, 1 reply; 22+ messages in thread
From: Gregory CLEMENT @ 2018-09-25 13:01 UTC (permalink / raw)
  To: u-boot

Adding device tree for Ocelot SoC (extract from Linux) and the 2
evaluation boards using this SoC: PCB120 and PCB132.

Adding device tree for Luton SoC (not yet in Linux) and the evaluation
boards using this SoC: PCB91.

Signed-off-by: Gregory CLEMENT <gregory.clement@bootlin.com>
---
 arch/mips/dts/luton_pcb091.dts     |  36 ++++++++
 arch/mips/dts/mscc,luton.dtsi      |  87 +++++++++++++++++++
 arch/mips/dts/mscc,ocelot.dtsi     | 132 +++++++++++++++++++++++++++++
 arch/mips/dts/mscc,ocelot_pcb.dtsi |  37 ++++++++
 arch/mips/dts/ocelot_pcb120.dts    |  12 +++
 arch/mips/dts/ocelot_pcb123.dts    |  12 +++
 6 files changed, 316 insertions(+)
 create mode 100644 arch/mips/dts/luton_pcb091.dts
 create mode 100644 arch/mips/dts/mscc,luton.dtsi
 create mode 100644 arch/mips/dts/mscc,ocelot.dtsi
 create mode 100644 arch/mips/dts/mscc,ocelot_pcb.dtsi
 create mode 100644 arch/mips/dts/ocelot_pcb120.dts
 create mode 100644 arch/mips/dts/ocelot_pcb123.dts

diff --git a/arch/mips/dts/luton_pcb091.dts b/arch/mips/dts/luton_pcb091.dts
new file mode 100644
index 0000000000..b5e0df8d04
--- /dev/null
+++ b/arch/mips/dts/luton_pcb091.dts
@@ -0,0 +1,36 @@
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+/*
+ * Copyright (c) 2018 Microsemi Corporation
+ */
+
+/dts-v1/;
+#include "mscc,luton.dtsi"
+
+/ {
+	model = "Luton PCB091 Reference Board";
+	compatible = "mscc,luton-pcb091", "mscc,luton";
+
+	aliases {
+		serial0 = &uart0;
+		spi0 = &spi0;
+	};
+
+	chosen {
+		stdout-path = "serial0:115200n8";
+	};
+
+};
+
+&uart0 {
+	status = "okay";
+};
+
+&spi0 {
+	status = "okay";
+	spi-flash at 0 {
+		compatible = "spi-flash";
+                spi-max-frequency = <18000000>; /* input clock */
+                reg = <0>; /* CS0 */
+	};
+};
+
diff --git a/arch/mips/dts/mscc,luton.dtsi b/arch/mips/dts/mscc,luton.dtsi
new file mode 100644
index 0000000000..6a4ad2a5be
--- /dev/null
+++ b/arch/mips/dts/mscc,luton.dtsi
@@ -0,0 +1,87 @@
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+/*
+ * Copyright (c) 2018 Microsemi Corporation
+ */
+
+#include <dt-bindings/gpio/gpio.h>
+
+/ {
+	#address-cells = <1>;
+	#size-cells = <1>;
+	compatible = "mscc,luton";
+
+	cpus {
+		#address-cells = <1>;
+		#size-cells = <0>;
+
+		cpu at 0 {
+			compatible = "mips,mips24KEc";
+			device_type = "cpu";
+			reg = <0>;
+		};
+	};
+
+	aliases {
+		serial0 = &uart0;
+	};
+
+	ahb_clk: ahb-clk {
+		compatible = "fixed-clock";
+		#clock-cells = <0>;
+		clock-frequency = <208333333>;
+	};
+
+	ahb {
+		compatible = "simple-bus";
+		#address-cells = <1>;
+		#size-cells = <1>;
+		ranges = <0 0x60000000 0x10200000>;
+
+		uart0: serial at 10100000 {
+			pinctrl-0 = <&uart_pins>;
+			pinctrl-names = "default";
+
+			compatible = "ns16550a";
+			reg = <0x10100000 0x20>;
+			clocks = <&ahb_clk>;
+			reg-io-width = <4>;
+			reg-shift = <2>;
+
+			status = "disabled";
+		};
+
+		gpio: pinctrl at 70068 {
+			compatible = "mscc,luton-pinctrl";
+			reg = <0x70068 0x68>;
+			gpio-controller;
+			#gpio-cells = <2>;
+			gpio-ranges = <&gpio 0 0 32>;
+
+			uart_pins: uart-pins {
+				pins = "GPIO_30", "GPIO_31";
+				function = "uart";
+			};
+
+		};
+
+		gpio_spi_bitbang: gpio at 10000064 {
+			compatible = "mscc,spi-bitbang-gpio";
+			reg = <0x10000064 0x4>;
+			gpio-controller;
+			#gpio-cells = <2>;
+
+		};
+
+		spi0: spi-bitbang {
+			compatible = "spi-gpio";
+			status = "okay";
+			gpio-sck = <&gpio_spi_bitbang 6 0>;
+			gpio-miso = <&gpio_spi_bitbang 0 0>;
+			gpio-mosi = <&gpio_spi_bitbang 5 0>;
+			cs-gpios = <&gpio_spi_bitbang 1 0>;
+			num-chipselects = <1>;
+			#address-cells = <1>;
+			#size-cells = <0>;
+		};
+	};
+};
diff --git a/arch/mips/dts/mscc,ocelot.dtsi b/arch/mips/dts/mscc,ocelot.dtsi
new file mode 100644
index 0000000000..81afdffd4b
--- /dev/null
+++ b/arch/mips/dts/mscc,ocelot.dtsi
@@ -0,0 +1,132 @@
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+/*
+ * Copyright (c) 2018 Microsemi Corporation
+ */
+
+/ {
+	#address-cells = <1>;
+	#size-cells = <1>;
+	compatible = "mscc,ocelot";
+
+	cpus {
+		#address-cells = <1>;
+		#size-cells = <0>;
+
+		cpu at 0 {
+			compatible = "mips,mips24KEc";
+			device_type = "cpu";
+			clocks = <&cpu_clk>;
+			reg = <0>;
+		};
+	};
+
+	aliases {
+		serial0 = &uart0;
+	};
+
+	cpuintc: interrupt-controller at 0 {
+		#address-cells = <0>;
+		#interrupt-cells = <1>;
+		interrupt-controller;
+		compatible = "mti,cpu-interrupt-controller";
+	};
+
+	cpu_clk: cpu-clock {
+		compatible = "fixed-clock";
+		#clock-cells = <0>;
+		clock-frequency = <500000000>;
+	};
+
+	ahb_clk: ahb-clk {
+		compatible = "fixed-clock";
+		#clock-cells = <0>;
+		clock-frequency = <250000000>;
+	};
+
+	ahb {
+		compatible = "simple-bus";
+		#address-cells = <1>;
+		#size-cells = <1>;
+		ranges = <0 0x70000000 0x2000000>;
+
+		interrupt-parent = <&intc>;
+
+		cpu_ctrl: syscon at 0 {
+			compatible = "mscc,ocelot-cpu-syscon", "syscon";
+			reg = <0x0 0x2c>;
+		};
+
+		intc: interrupt-controller at 70 {
+			compatible = "mscc,ocelot-icpu-intr";
+			reg = <0x70 0x70>;
+			#interrupt-cells = <1>;
+			interrupt-controller;
+			interrupt-parent = <&cpuintc>;
+			interrupts = <2>;
+		};
+
+		uart0: serial at 100000 {
+			pinctrl-0 = <&uart_pins>;
+			pinctrl-names = "default";
+			compatible = "ns16550a";
+			reg = <0x100000 0x20>;
+			interrupts = <6>;
+			clocks = <&ahb_clk>;
+			reg-io-width = <4>;
+			reg-shift = <2>;
+
+			status = "disabled";
+		};
+
+		uart2: serial at 100800 {
+			pinctrl-0 = <&uart2_pins>;
+			pinctrl-names = "default";
+			compatible = "ns16550a";
+			reg = <0x100800 0x20>;
+			interrupts = <7>;
+			clocks = <&ahb_clk>;
+			reg-io-width = <4>;
+			reg-shift = <2>;
+
+			status = "disabled";
+		};
+
+		spi0: spi-master at 101000 {
+			#address-cells = <1>;
+			#size-cells = <0>;
+			compatible = "snps,dw-apb-ssi";
+			reg = <0x101000 0x40>;
+			num-chipselect = <4>;
+			bus-num = <0>;
+			reg-io-width = <4>;
+			reg-shift = <2>;
+			spi-max-frequency = <18000000>; /* input clock */
+			clocks = <&ahb_clk>;
+
+			status = "disabled";
+		};
+
+		reset at 1070008 {
+			compatible = "mscc,ocelot-chip-reset";
+			reg = <0x1070008 0x4>;
+		};
+
+		gpio: pinctrl at 1070034 {
+			compatible = "mscc,ocelot-pinctrl";
+			reg = <0x1070034 0x68>;
+			gpio-controller;
+			#gpio-cells = <2>;
+			gpio-ranges = <&gpio 0 0 22>;
+
+			uart_pins: uart-pins {
+				pins = "GPIO_6", "GPIO_7";
+				function = "uart";
+			};
+
+			uart2_pins: uart2-pins {
+				pins = "GPIO_12", "GPIO_13";
+				function = "uart2";
+			};
+		};
+	};
+};
diff --git a/arch/mips/dts/mscc,ocelot_pcb.dtsi b/arch/mips/dts/mscc,ocelot_pcb.dtsi
new file mode 100644
index 0000000000..4e532363c3
--- /dev/null
+++ b/arch/mips/dts/mscc,ocelot_pcb.dtsi
@@ -0,0 +1,37 @@
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+/*
+ * Copyright (c) 2018 Microsemi Corporation
+ */
+
+/dts-v1/;
+#include "mscc,ocelot.dtsi"
+
+/ {
+	compatible = "mscc,ocelot";
+
+	aliases {
+		spi0 = &spi0;
+		serial0 = &uart0;
+	};
+
+	chosen {
+		stdout-path = "serial0:115200n8";
+	};
+};
+
+&uart0 {
+	status = "okay";
+};
+
+&spi0 {
+	status = "okay";
+	spi-flash at 0 {
+		compatible = "spi-flash";
+                spi-max-frequency = <18000000>; /* input clock */
+                reg = <0>; /* CS0 */
+	};
+};
+
+&ethernet {
+	status = "okay";
+};
diff --git a/arch/mips/dts/ocelot_pcb120.dts b/arch/mips/dts/ocelot_pcb120.dts
new file mode 100644
index 0000000000..47d305a614
--- /dev/null
+++ b/arch/mips/dts/ocelot_pcb120.dts
@@ -0,0 +1,12 @@
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+/*
+ * Copyright (c) 2018 Microsemi Corporation
+ */
+
+/dts-v1/;
+#include "mscc,ocelot_pcb.dtsi"
+
+/ {
+	model = "Ocelot PCB120 Reference Board";
+	compatible = "mscc,ocelot-pcb120", "mscc,ocelot";
+};
diff --git a/arch/mips/dts/ocelot_pcb123.dts b/arch/mips/dts/ocelot_pcb123.dts
new file mode 100644
index 0000000000..17d8d326ce
--- /dev/null
+++ b/arch/mips/dts/ocelot_pcb123.dts
@@ -0,0 +1,12 @@
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+/*
+ * Copyright (c) 2018 Microsemi Corporation
+ */
+
+/dts-v1/;
+#include "mscc,ocelot_pcb.dtsi"
+
+/ {
+	model = "Ocelot PCB123 Reference Board";
+	compatible = "mscc,ocelot-pcb123", "mscc,ocelot";
+};
-- 
2.19.0

^ permalink raw reply related	[flat|nested] 22+ messages in thread

* [U-Boot] [PATCH 5/6] MSCC: add configuration for Ocelot and Luton based boards
  2018-09-25 13:01 [U-Boot] [PATCH 0/6] Add support for VCore III SoCs found in Microsemi switches Gregory CLEMENT
                   ` (2 preceding siblings ...)
  2018-09-25 13:01 ` [U-Boot] [PATCH 4/6] MSCC: add device tree for Ocelot and Luton (boards and SoCs) Gregory CLEMENT
@ 2018-09-25 13:01 ` Gregory CLEMENT
  2018-09-26 19:31   ` Daniel Schwierzeck
  2018-09-25 13:01 ` [U-Boot] [PATCH 6/6] MIPS: bootm: Add support for Vcore III linux kernel Gregory CLEMENT
                   ` (3 subsequent siblings)
  7 siblings, 1 reply; 22+ messages in thread
From: Gregory CLEMENT @ 2018-09-25 13:01 UTC (permalink / raw)
  To: u-boot

Add common configuration header for the VCore III SoCs (currently Ocelot
and Luton), but also the defconfig for the evaluation boards of these
SoCs.

Signed-off-by: Gregory CLEMENT <gregory.clement@bootlin.com>
---
 configs/mscc_luton_defconfig         | 66 +++++++++++++++++++++++++
 configs/mscc_ocelot_defconfig        | 57 ++++++++++++++++++++++
 configs/mscc_ocelot_pcb120_defconfig | 56 ++++++++++++++++++++++
 include/configs/vcoreiii.h           | 72 ++++++++++++++++++++++++++++
 4 files changed, 251 insertions(+)
 create mode 100644 configs/mscc_luton_defconfig
 create mode 100644 configs/mscc_ocelot_defconfig
 create mode 100644 configs/mscc_ocelot_pcb120_defconfig
 create mode 100644 include/configs/vcoreiii.h

diff --git a/configs/mscc_luton_defconfig b/configs/mscc_luton_defconfig
new file mode 100644
index 0000000000..47fe12b6ee
--- /dev/null
+++ b/configs/mscc_luton_defconfig
@@ -0,0 +1,66 @@
+CONFIG_MIPS=y
+CONFIG_SYS_TEXT_BASE=0x40000000
+CONFIG_SYS_MALLOC_F_LEN=0x2000
+CONFIG_DEBUG_UART_BOARD_INIT=y
+CONFIG_DEBUG_UART_BASE=0x70100000
+CONFIG_DEBUG_UART_CLOCK=208333333
+CONFIG_ARCH_MSCC=y
+CONFIG_TARGET_LUTON_PCB091=y
+CONFIG_DDRTYPE_MT47H128M8HQ=y
+CONFIG_SYS_LITTLE_ENDIAN=y
+CONFIG_MIPS_BOOT_FDT=y
+CONFIG_DEFAULT_DEVICE_TREE="luton_pcb091"
+CONFIG_DEBUG_UART=y
+CONFIG_FIT=y
+CONFIG_BOOTDELAY=3
+CONFIG_USE_BOOTARGS=y
+CONFIG_BOOTARGS="console=ttyS0,115200"
+CONFIG_LOGLEVEL=7
+CONFIG_DISPLAY_CPUINFO=y
+CONFIG_SYS_PROMPT="pcb091 # "
+# CONFIG_CMD_BDI is not set
+# CONFIG_CMD_CONSOLE is not set
+# CONFIG_CMD_ELF is not set
+# CONFIG_CMD_EXPORTENV is not set
+# CONFIG_CMD_IMPORTENV is not set
+# CONFIG_CMD_CRC32 is not set
+CONFIG_CMD_MD5SUM=y
+CONFIG_CMD_MEMINFO=y
+CONFIG_CMD_MEMTEST=y
+# CONFIG_CMD_FLASH is not set
+CONFIG_CMD_GPIO=y
+CONFIG_CMD_SF=y
+CONFIG_CMD_SPI=y
+CONFIG_CMD_DHCP=y
+# CONFIG_NET_TFTP_VARS is not set
+# CONFIG_CMD_NFS is not set
+CONFIG_CMD_PING=y
+CONFIG_CMD_MTDPARTS=y
+CONFIG_MTDIDS_DEFAULT="nor0=spi_flash"
+CONFIG_MTDPARTS_DEFAULT="mtdparts=spi_flash:512k(UBoot),256k(Env),256k(conf),6m at 1m(linux)"
+# CONFIG_ISO_PARTITION is not set
+CONFIG_OF_EMBED=y
+CONFIG_ENV_IS_IN_SPI_FLASH=y
+CONFIG_NET_RANDOM_ETHADDR=y
+CONFIG_CLK=y
+CONFIG_DM_GPIO=y
+CONFIG_DM_SPI_FLASH=y
+CONFIG_SPI_FLASH=y
+CONFIG_SPI_FLASH_BAR=y
+CONFIG_SPI_FLASH_GIGADEVICE=y
+CONFIG_SPI_FLASH_MACRONIX=y
+CONFIG_SPI_FLASH_SPANSION=y
+CONFIG_SPI_FLASH_STMICRO=y
+CONFIG_SPI_FLASH_WINBOND=y
+CONFIG_SPI_FLASH_MTD=y
+CONFIG_DM_ETH=y
+CONFIG_PINCTRL=y
+CONFIG_PINCONF=y
+CONFIG_DM_SERIAL=y
+CONFIG_DEBUG_UART_SHIFT=2
+CONFIG_SYS_NS16550=y
+CONFIG_SPI=y
+CONFIG_DM_SPI=y
+CONFIG_SOFT_SPI=y
+CONFIG_LZMA=y
+CONFIG_XZ=y
diff --git a/configs/mscc_ocelot_defconfig b/configs/mscc_ocelot_defconfig
new file mode 100644
index 0000000000..eb0566189a
--- /dev/null
+++ b/configs/mscc_ocelot_defconfig
@@ -0,0 +1,57 @@
+CONFIG_MIPS=y
+CONFIG_SYS_TEXT_BASE=0x40000000
+CONFIG_SYS_MALLOC_F_LEN=0x2000
+CONFIG_ARCH_MSCC=y
+CONFIG_TARGET_OCELOT_PCB123=y
+CONFIG_SYS_LITTLE_ENDIAN=y
+CONFIG_DEFAULT_DEVICE_TREE="ocelot_pcb123"
+CONFIG_FIT=y
+CONFIG_BOOTDELAY=3
+CONFIG_USE_BOOTARGS=y
+CONFIG_BOOTARGS="console=ttyS0,115200"
+CONFIG_LOGLEVEL=7
+CONFIG_DISPLAY_CPUINFO=y
+CONFIG_SYS_PROMPT="pcb123 # "
+# CONFIG_CMD_BDI is not set
+# CONFIG_CMD_CONSOLE is not set
+# CONFIG_CMD_ELF is not set
+# CONFIG_CMD_EXPORTENV is not set
+# CONFIG_CMD_IMPORTENV is not set
+# CONFIG_CMD_CRC32 is not set
+CONFIG_CMD_MD5SUM=y
+CONFIG_CMD_MEMINFO=y
+CONFIG_CMD_MEMTEST=y
+# CONFIG_CMD_FLASH is not set
+CONFIG_CMD_GPIO=y
+CONFIG_CMD_SF=y
+CONFIG_CMD_SPI=y
+CONFIG_CMD_DHCP=y
+# CONFIG_NET_TFTP_VARS is not set
+# CONFIG_CMD_NFS is not set
+CONFIG_CMD_PING=y
+CONFIG_CMD_MTDPARTS=y
+CONFIG_MTDIDS_DEFAULT="nor0=spi_flash"
+CONFIG_MTDPARTS_DEFAULT="mtdparts=spi_flash:512k(UBoot),256k(Env),256k(conf),15m(linux),15m(linux.bk)"
+# CONFIG_ISO_PARTITION is not set
+CONFIG_OF_EMBED=y
+CONFIG_ENV_IS_IN_SPI_FLASH=y
+CONFIG_NET_RANDOM_ETHADDR=y
+CONFIG_CLK=y
+CONFIG_DM_GPIO=y
+CONFIG_DM_SPI_FLASH=y
+CONFIG_SPI_FLASH=y
+CONFIG_SPI_FLASH_BAR=y
+CONFIG_SPI_FLASH_GIGADEVICE=y
+CONFIG_SPI_FLASH_MACRONIX=y
+CONFIG_SPI_FLASH_SPANSION=y
+CONFIG_SPI_FLASH_WINBOND=y
+CONFIG_SPI_FLASH_MTD=y
+CONFIG_DM_ETH=y
+CONFIG_PINCTRL=y
+CONFIG_PINCONF=y
+CONFIG_DM_SERIAL=y
+CONFIG_SYS_NS16550=y
+CONFIG_SPI=y
+CONFIG_DM_SPI=y
+CONFIG_DESIGNWARE_SPI=y
+CONFIG_LZMA=y
diff --git a/configs/mscc_ocelot_pcb120_defconfig b/configs/mscc_ocelot_pcb120_defconfig
new file mode 100644
index 0000000000..40cdec45f1
--- /dev/null
+++ b/configs/mscc_ocelot_pcb120_defconfig
@@ -0,0 +1,56 @@
+CONFIG_MIPS=y
+CONFIG_SYS_TEXT_BASE=0x40000000
+CONFIG_SYS_MALLOC_F_LEN=0x2000
+CONFIG_ARCH_MSCC=y
+CONFIG_SYS_LITTLE_ENDIAN=y
+CONFIG_DEFAULT_DEVICE_TREE="ocelot_pcb120"
+CONFIG_FIT=y
+CONFIG_BOOTDELAY=3
+CONFIG_USE_BOOTARGS=y
+CONFIG_BOOTARGS="console=ttyS0,115200"
+CONFIG_LOGLEVEL=7
+CONFIG_DISPLAY_CPUINFO=y
+CONFIG_SYS_PROMPT="pcb120 # "
+# CONFIG_CMD_BDI is not set
+# CONFIG_CMD_CONSOLE is not set
+# CONFIG_CMD_ELF is not set
+# CONFIG_CMD_EXPORTENV is not set
+# CONFIG_CMD_IMPORTENV is not set
+# CONFIG_CMD_CRC32 is not set
+CONFIG_CMD_MD5SUM=y
+CONFIG_CMD_MEMINFO=y
+CONFIG_CMD_MEMTEST=y
+# CONFIG_CMD_FLASH is not set
+CONFIG_CMD_GPIO=y
+CONFIG_CMD_SF=y
+CONFIG_CMD_SPI=y
+CONFIG_CMD_DHCP=y
+# CONFIG_NET_TFTP_VARS is not set
+# CONFIG_CMD_NFS is not set
+CONFIG_CMD_PING=y
+CONFIG_CMD_MTDPARTS=y
+CONFIG_MTDIDS_DEFAULT="nor0=spi_flash"
+CONFIG_MTDPARTS_DEFAULT="mtdparts=spi_flash:512k(UBoot),256k(Env),256k(conf),15m(linux),15m(linux.bk)"
+# CONFIG_ISO_PARTITION is not set
+CONFIG_OF_EMBED=y
+CONFIG_ENV_IS_IN_SPI_FLASH=y
+CONFIG_NET_RANDOM_ETHADDR=y
+CONFIG_CLK=y
+CONFIG_DM_GPIO=y
+CONFIG_DM_SPI_FLASH=y
+CONFIG_SPI_FLASH=y
+CONFIG_SPI_FLASH_BAR=y
+CONFIG_SPI_FLASH_GIGADEVICE=y
+CONFIG_SPI_FLASH_MACRONIX=y
+CONFIG_SPI_FLASH_SPANSION=y
+CONFIG_SPI_FLASH_WINBOND=y
+CONFIG_SPI_FLASH_MTD=y
+CONFIG_DM_ETH=y
+CONFIG_PINCTRL=y
+CONFIG_PINCONF=y
+CONFIG_DM_SERIAL=y
+CONFIG_SYS_NS16550=y
+CONFIG_SPI=y
+CONFIG_DM_SPI=y
+CONFIG_DESIGNWARE_SPI=y
+CONFIG_LZMA=y
diff --git a/include/configs/vcoreiii.h b/include/configs/vcoreiii.h
new file mode 100644
index 0000000000..ce43a27d7d
--- /dev/null
+++ b/include/configs/vcoreiii.h
@@ -0,0 +1,72 @@
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+/*
+ * Copyright (c) 2018 Microsemi Corporation
+ */
+
+#ifndef __VCOREIII_H
+#define __VCOREIII_H
+
+#include <linux/sizes.h>
+
+/* Onboard devices */
+
+#define CONFIG_SYS_MALLOC_LEN		0x80000
+#define CONFIG_SYS_LOAD_ADDR		0x00100000
+#define CONFIG_SYS_INIT_SP_OFFSET       0x400000
+
+#define CPU_CLOCK_RATE			500000000 /* Clock for the MIPS core */
+#ifdef CONFIG_SOC_LUTON
+#define CONFIG_SYS_MIPS_TIMER_FREQ	208333333
+#else
+#define CONFIG_SYS_MIPS_TIMER_FREQ	(CPU_CLOCK_RATE / 2)
+#endif
+#define CONFIG_SYS_NS16550_CLK		CONFIG_SYS_MIPS_TIMER_FREQ
+
+#if defined(CONFIG_ENV_IS_IN_SPI_FLASH) && !defined(CONFIG_ENV_OFFSET)
+#define CONFIG_ENV_OFFSET		(512 * 1024)
+#define CONFIG_ENV_SIZE			(256 * 1024)
+#define CONFIG_ENV_SECT_SIZE		(256 * 1024)
+#endif
+
+#define CONFIG_SYS_SDRAM_BASE		0x80000000
+#if defined(CONFIG_DDRTYPE_H5TQ1G63BFA) || defined(CONFIG_DDRTYPE_MT47H128M8HQ)
+#define CONFIG_SYS_SDRAM_SIZE		(128 * SZ_1M)
+#elif defined(CONFIG_DDRTYPE_MT41J128M16HA) || defined(CONFIG_DDRTYPE_MT41K128M16JT)
+#define CONFIG_SYS_SDRAM_SIZE		(256 * SZ_1M)
+#elif defined(CONFIG_DDRTYPE_H5TQ4G63MFR) || defined(CONFIG_DDRTYPE_MT41K256M16)
+#define CONFIG_SYS_SDRAM_SIZE		(512 * SZ_1M)
+#else
+#error Unknown DDR size - please add!
+#endif
+
+#define CONFIG_CONS_INDEX		1
+
+#define CONFIG_SYS_MEMTEST_START	CONFIG_SYS_SDRAM_BASE
+#define CONFIG_SYS_MEMTEST_END		(CONFIG_SYS_SDRAM_BASE + CONFIG_SYS_SDRAM_SIZE - SZ_1M)
+
+#define CONFIG_SYS_MONITOR_BASE         CONFIG_SYS_TEXT_BASE    /* start of monitor */
+
+#define CONFIG_BOARD_EARLY_INIT_R
+#if defined (CONFIG_MTDIDS_DEFAULT) && defined(CONFIG_MTDPARTS_DEFAULT)
+#define VCOREIII_DEFAULT_MTD_ENV                        \
+        "mtdparts=" CONFIG_MTDPARTS_DEFAULT "\0"        \
+        "mtdids="CONFIG_MTDIDS_DEFAULT "\0"
+#else
+#define VCOREIII_DEFAULT_MTD_ENV    // Go away
+#endif
+
+#define CONFIG_SYS_BOOTM_LEN      (16 << 20)      /* Increase max gunzip size */
+
+#define CONFIG_EXTRA_ENV_SETTINGS                                       \
+    VCOREIII_DEFAULT_MTD_ENV                                            \
+    "loadaddr=0x81000000" "\0"                                          \
+    "spi_image_off=0x00100000" "\0"                                     \
+    "console=ttyS0,115200" "\0"                                         \
+    "setup=setenv bootargs console=${console} ${mtdparts} ${bootargs_extra}" "\0" \
+    "spiboot=run setup; sf probe; sf read ${loadaddr} ${spi_image_off} 0x600000; bootm ${loadaddr}" "\0" \
+    "update=sf probe;mtdparts;dhcp ${loadaddr} u-boot.bin;" \
+    "sf erase UBoot 0x080000;sf write ${loadaddr} UBoot  ${filesize}" "\0" \
+    "initrd_high=0x9000000"                                             \
+    "bootcmd=run spiboot"
+
+#endif				/* __VCOREIII_H */
-- 
2.19.0

^ permalink raw reply related	[flat|nested] 22+ messages in thread

* [U-Boot] [PATCH 6/6] MIPS: bootm: Add support for Vcore III linux kernel
  2018-09-25 13:01 [U-Boot] [PATCH 0/6] Add support for VCore III SoCs found in Microsemi switches Gregory CLEMENT
                   ` (3 preceding siblings ...)
  2018-09-25 13:01 ` [U-Boot] [PATCH 5/6] MSCC: add configuration for Ocelot and Luton based boards Gregory CLEMENT
@ 2018-09-25 13:01 ` Gregory CLEMENT
  2018-09-26 19:40   ` Daniel Schwierzeck
  2018-09-25 15:22 ` [U-Boot] [PATCH 0/6] Add support for VCore III SoCs found in Microsemi switches Gregory CLEMENT
                   ` (2 subsequent siblings)
  7 siblings, 1 reply; 22+ messages in thread
From: Gregory CLEMENT @ 2018-09-25 13:01 UTC (permalink / raw)
  To: u-boot

The kernels built for the Vcore III linux kernel have different
expectation in the way the data were passed.

Unlike with yamon, the command line is expected to be a single string
passed in argv[1]. An other expectation is that the arguments are located
in the cached address space.

However, like yamon, they expect that rd_start and rd_size was passed by
the bootloader in the command line of the kernel, and besides that it
also wait for the root=/dev/ram0.

Signed-off-by: Gregory CLEMENT <gregory.clement@bootlin.com>
---
 arch/mips/lib/bootm.c | 62 +++++++++++++++++++++++++++++--------------
 1 file changed, 42 insertions(+), 20 deletions(-)

diff --git a/arch/mips/lib/bootm.c b/arch/mips/lib/bootm.c
index deca5189e3..417f5ce452 100644
--- a/arch/mips/lib/bootm.c
+++ b/arch/mips/lib/bootm.c
@@ -44,22 +44,38 @@ void arch_lmb_reserve(struct lmb *lmb)
 	lmb_reserve(lmb, sp, gd->ram_top - sp);
 }
 
-static void linux_cmdline_init(void)
+static void linux_cmdline_init(int vcoreiii)
 {
+	if (!vcoreiii) {
+		linux_argv = (char **)UNCACHED_SDRAM(gd->bd->bi_boot_params);
+		linux_argp = (char *)(linux_argv + LINUX_MAX_ARGS);
+	} else {
+		/*
+		 * Vcore III linux kernels expect arguments in the cached
+		 * address space. They also expect the command line being a
+		 * single string in the first argument
+		 */
+		linux_argv = (char **)(gd->bd->bi_boot_params);
+		linux_argp = (char *)(linux_argv + LINUX_MAX_ARGS);
+		linux_argv[1] = linux_argp;
+	}
 	linux_argc = 1;
-	linux_argv = (char **)UNCACHED_SDRAM(gd->bd->bi_boot_params);
 	linux_argv[0] = 0;
-	linux_argp = (char *)(linux_argv + LINUX_MAX_ARGS);
 }
 
-static void linux_cmdline_set(const char *value, size_t len)
+static void linux_cmdline_set(const char *value, size_t len, int vcoreiii)
 {
-	linux_argv[linux_argc] = linux_argp;
 	memcpy(linux_argp, value, len);
-	linux_argp[len] = 0;
-
+	if (!vcoreiii)	{
+		linux_argv[linux_argc] = linux_argp;
+		linux_argp[len] = 0;
+		linux_argc++;
+	} else {
+		linux_argp[len] = ' ';
+		linux_argp[len + 1] = 0;
+		linux_argc = 2;
+	}
 	linux_argp += len + 1;
-	linux_argc++;
 }
 
 static void linux_cmdline_dump(void)
@@ -73,12 +89,10 @@ static void linux_cmdline_dump(void)
 		debug("   arg %03d: %s\n", i, linux_argv[i]);
 }
 
-static void linux_cmdline_legacy(bootm_headers_t *images)
+static void linux_cmdline_legacy(bootm_headers_t *images, int vcoreiii)
 {
 	const char *bootargs, *next, *quote;
-
-	linux_cmdline_init();
-
+	linux_cmdline_init(vcoreiii);
 	bootargs = env_get("bootargs");
 	if (!bootargs)
 		return;
@@ -104,7 +118,7 @@ static void linux_cmdline_legacy(bootm_headers_t *images)
 		if (!next)
 			next = bootargs + strlen(bootargs);
 
-		linux_cmdline_set(bootargs, next - bootargs);
+		linux_cmdline_set(bootargs, next - bootargs, vcoreiii);
 
 		if (*next)
 			next++;
@@ -113,7 +127,7 @@ static void linux_cmdline_legacy(bootm_headers_t *images)
 	}
 }
 
-static void linux_cmdline_append(bootm_headers_t *images)
+static void linux_cmdline_append(bootm_headers_t *images, int vcoreiii)
 {
 	char buf[24];
 	ulong mem, rd_start, rd_size;
@@ -121,7 +135,7 @@ static void linux_cmdline_append(bootm_headers_t *images)
 	/* append mem */
 	mem = gd->ram_size >> 20;
 	sprintf(buf, "mem=%luM", mem);
-	linux_cmdline_set(buf, strlen(buf));
+	linux_cmdline_set(buf, strlen(buf), vcoreiii);
 
 	/* append rd_start and rd_size */
 	rd_start = images->initrd_start;
@@ -129,9 +143,13 @@ static void linux_cmdline_append(bootm_headers_t *images)
 
 	if (rd_size) {
 		sprintf(buf, "rd_start=0x%08lX", rd_start);
-		linux_cmdline_set(buf, strlen(buf));
+		linux_cmdline_set(buf, strlen(buf), vcoreiii);
 		sprintf(buf, "rd_size=0x%lX", rd_size);
-		linux_cmdline_set(buf, strlen(buf));
+		linux_cmdline_set(buf, strlen(buf), vcoreiii);
+		if (vcoreiii) {
+			sprintf(buf, "root=/dev/ram0");
+			linux_cmdline_set(buf, strlen(buf), vcoreiii);
+		}
 	}
 }
 
@@ -276,11 +294,15 @@ static void boot_prep_linux(bootm_headers_t *images)
 		boot_reloc_fdt(images);
 		boot_setup_fdt(images);
 	} else {
-		if (CONFIG_IS_ENABLED(MIPS_BOOT_CMDLINE_LEGACY)) {
-			linux_cmdline_legacy(images);
+		if (CONFIG_IS_ENABLED(SOC_VCOREIII)) {
+			linux_cmdline_legacy(images, 1);
+			linux_cmdline_append(images, 1);
+			linux_cmdline_dump();
+		} else if (CONFIG_IS_ENABLED(MIPS_BOOT_CMDLINE_LEGACY)) {
+			linux_cmdline_legacy(images, 0);
 
 			if (!CONFIG_IS_ENABLED(MIPS_BOOT_ENV_LEGACY))
-				linux_cmdline_append(images);
+				linux_cmdline_append(images, 0);
 
 			linux_cmdline_dump();
 		}
-- 
2.19.0

^ permalink raw reply related	[flat|nested] 22+ messages in thread

* [U-Boot] [PATCH 0/6] Add support for VCore III SoCs found in Microsemi switches
  2018-09-25 13:01 [U-Boot] [PATCH 0/6] Add support for VCore III SoCs found in Microsemi switches Gregory CLEMENT
                   ` (4 preceding siblings ...)
  2018-09-25 13:01 ` [U-Boot] [PATCH 6/6] MIPS: bootm: Add support for Vcore III linux kernel Gregory CLEMENT
@ 2018-09-25 15:22 ` Gregory CLEMENT
  2018-09-25 15:25 ` [U-Boot] [PATCH 2/6] MSCC: add support for VCoreIII SoCs Gregory CLEMENT
       [not found] ` <20180925130108.19211-3-gregory.clement@bootlin.com>
  7 siblings, 0 replies; 22+ messages in thread
From: Gregory CLEMENT @ 2018-09-25 15:22 UTC (permalink / raw)
  To: u-boot

Hi,
 
 On mar., sept. 25 2018, Gregory CLEMENT <gregory.clement@bootlin.com> wrote:

> Hello,
>
> This series add the support of 2 SoCs: Ocelot and Luton from
> Microsemi. Both of them belongs to the same family Vcore III.
>
> We found them on various advanced switches product.
>
> The support for Ocelot already have been submit to Linux, but not yet
> the Luton support.
>
> Besides this series 3 others patches are needed but they are driver
> related:
> DW SPI: Allow to overload the management of the external CS
> gpio: mscc-bitbang-spi: Add a simple gpio driver for bitbgang spi
> pinctrl: mscc: Add gpio and pinctrl driver for MSCC MIPS SoCs (VcoreIII based)
>
> They will be submitted separately.
>
> Thanks,
>
> Gregory
>
>
> Gregory CLEMENT (6):
>   MIPS: move create_tlb() in an proper header: mipsregs.h

>   MSCC: add support for VCoreIII SoCs
This patch didn't reach the mailing because it was too large. Actually,
many defined were not used, so I removed then, and I am going to send
the missing patch now.

Gregory


>   MSCC: add board support for the VCoreIII based evaluation boards
>   MSCC: add device tree for Ocelot and Luton (boards and SoCs)
>   MSCC: add configuration for Ocelot and Luton based boards
>   MIPS: bootm: Add support for Vcore III linux kernel
>
>  arch/mips/Kconfig                             |   6 +
>  arch/mips/Makefile                            |   1 +
>  arch/mips/cpu/cpu.c                           |  10 -
>  arch/mips/dts/luton_pcb091.dts                |  36 +
>  arch/mips/dts/mscc,luton.dtsi                 |  87 ++
>  arch/mips/dts/mscc,ocelot.dtsi                | 132 +++
>  arch/mips/dts/mscc,ocelot_pcb.dtsi            |  37 +
>  arch/mips/dts/ocelot_pcb120.dts               |  12 +
>  arch/mips/dts/ocelot_pcb123.dts               |  12 +
>  arch/mips/include/asm/mipsregs.h              |  11 +
>  arch/mips/lib/bootm.c                         |  62 +-
>  arch/mips/mach-mscc/Kconfig                   | 101 ++
>  arch/mips/mach-mscc/Makefile                  |   6 +
>  arch/mips/mach-mscc/cpu.c                     |  72 ++
>  arch/mips/mach-mscc/dram.c                    |  62 ++
>  arch/mips/mach-mscc/include/ioremap.h         |  49 +
>  arch/mips/mach-mscc/include/mach/cache.h      |  36 +
>  arch/mips/mach-mscc/include/mach/common.h     |  31 +
>  arch/mips/mach-mscc/include/mach/ddr.h        | 753 +++++++++++++++
>  .../mips/mach-mscc/include/mach/luton/luton.h |  37 +
>  .../include/mach/luton/luton_devcpu_gcb.h     |  16 +
>  .../include/mach/luton/luton_icpu_cfg-ref.h   | 884 ++++++++++++++++++
>  .../include/mach/luton/luton_icpu_cfg.h       | 247 +++++
>  .../mach-mscc/include/mach/ocelot/ocelot.h    |  35 +
>  .../include/mach/ocelot/ocelot_devcpu_gcb.h   | 353 +++++++
>  .../include/mach/ocelot/ocelot_icpu_cfg.h     | 884 ++++++++++++++++++
>  arch/mips/mach-mscc/include/mach/tlb.h        |  65 ++
>  arch/mips/mach-mscc/lowlevel_init.S           |  29 +
>  arch/mips/mach-mscc/lowlevel_init_luton.S     |  63 ++
>  arch/mips/mach-mscc/reset.c                   |  37 +
>  board/mscc/common/board.c                     |  29 +
>  board/mscc/luton/Kconfig                      |  14 +
>  board/mscc/luton/Makefile                     |   4 +
>  board/mscc/luton/luton.c                      |  14 +
>  board/mscc/ocelot/Kconfig                     |  24 +
>  board/mscc/ocelot/Makefile                    |   5 +
>  board/mscc/ocelot/ocelot.c                    |  38 +
>  configs/mscc_luton_defconfig                  |  66 ++
>  configs/mscc_ocelot_defconfig                 |  57 ++
>  configs/mscc_ocelot_pcb120_defconfig          |  56 ++
>  include/configs/vcoreiii.h                    |  72 ++
>  41 files changed, 4515 insertions(+), 30 deletions(-)
>  create mode 100644 arch/mips/dts/luton_pcb091.dts
>  create mode 100644 arch/mips/dts/mscc,luton.dtsi
>  create mode 100644 arch/mips/dts/mscc,ocelot.dtsi
>  create mode 100644 arch/mips/dts/mscc,ocelot_pcb.dtsi
>  create mode 100644 arch/mips/dts/ocelot_pcb120.dts
>  create mode 100644 arch/mips/dts/ocelot_pcb123.dts
>  create mode 100644 arch/mips/mach-mscc/Kconfig
>  create mode 100644 arch/mips/mach-mscc/Makefile
>  create mode 100644 arch/mips/mach-mscc/cpu.c
>  create mode 100644 arch/mips/mach-mscc/dram.c
>  create mode 100644 arch/mips/mach-mscc/include/ioremap.h
>  create mode 100644 arch/mips/mach-mscc/include/mach/cache.h
>  create mode 100644 arch/mips/mach-mscc/include/mach/common.h
>  create mode 100644 arch/mips/mach-mscc/include/mach/ddr.h
>  create mode 100644 arch/mips/mach-mscc/include/mach/luton/luton.h
>  create mode 100644 arch/mips/mach-mscc/include/mach/luton/luton_devcpu_gcb.h
>  create mode 100644 arch/mips/mach-mscc/include/mach/luton/luton_icpu_cfg-ref.h
>  create mode 100644 arch/mips/mach-mscc/include/mach/luton/luton_icpu_cfg.h
>  create mode 100644 arch/mips/mach-mscc/include/mach/ocelot/ocelot.h
>  create mode 100644 arch/mips/mach-mscc/include/mach/ocelot/ocelot_devcpu_gcb.h
>  create mode 100644 arch/mips/mach-mscc/include/mach/ocelot/ocelot_icpu_cfg.h
>  create mode 100644 arch/mips/mach-mscc/include/mach/tlb.h
>  create mode 100644 arch/mips/mach-mscc/lowlevel_init.S
>  create mode 100644 arch/mips/mach-mscc/lowlevel_init_luton.S
>  create mode 100644 arch/mips/mach-mscc/reset.c
>  create mode 100644 board/mscc/common/board.c
>  create mode 100644 board/mscc/luton/Kconfig
>  create mode 100644 board/mscc/luton/Makefile
>  create mode 100644 board/mscc/luton/luton.c
>  create mode 100644 board/mscc/ocelot/Kconfig
>  create mode 100644 board/mscc/ocelot/Makefile
>  create mode 100644 board/mscc/ocelot/ocelot.c
>  create mode 100644 configs/mscc_luton_defconfig
>  create mode 100644 configs/mscc_ocelot_defconfig
>  create mode 100644 configs/mscc_ocelot_pcb120_defconfig
>  create mode 100644 include/configs/vcoreiii.h
>
> -- 
> 2.19.0
>

-- 
Gregory Clement, Bootlin
Embedded Linux and Kernel engineering
http://bootlin.com

^ permalink raw reply	[flat|nested] 22+ messages in thread

* [U-Boot] [PATCH 2/6] MSCC: add support for VCoreIII SoCs
  2018-09-25 13:01 [U-Boot] [PATCH 0/6] Add support for VCore III SoCs found in Microsemi switches Gregory CLEMENT
                   ` (5 preceding siblings ...)
  2018-09-25 15:22 ` [U-Boot] [PATCH 0/6] Add support for VCore III SoCs found in Microsemi switches Gregory CLEMENT
@ 2018-09-25 15:25 ` Gregory CLEMENT
       [not found] ` <20180925130108.19211-3-gregory.clement@bootlin.com>
  7 siblings, 0 replies; 22+ messages in thread
From: Gregory CLEMENT @ 2018-09-25 15:25 UTC (permalink / raw)
  To: u-boot

These families of SoCs are found in the Microsemi Switches solution.

Currently the support for two families support is added:
 - Ocelot (VSC7513, VSC7514) already supported in Linux
 - Luton (Luton10: VSC7423, VSC7424, VSC7428 and Luton26: VSC7425,
   VSC7426, VSC7426, VSC7427, VSC7429)

Signed-off-by: Gregory CLEMENT <gregory.clement@bootlin.com>
---
Hi,

Actually this is the second version of this patch.

Compared to the previous version which did not reach the mailing list,
I remove a lot of unused defines in the header.
They can be add later when needed.

Sorry for the noise

Gregory


 arch/mips/Kconfig                             |   6 +
 arch/mips/Makefile                            |   1 +
 arch/mips/mach-mscc/Kconfig                   | 101 +++
 arch/mips/mach-mscc/Makefile                  |   6 +
 arch/mips/mach-mscc/cpu.c                     |  72 ++
 arch/mips/mach-mscc/dram.c                    |  62 ++
 arch/mips/mach-mscc/include/ioremap.h         |  49 ++
 arch/mips/mach-mscc/include/mach/cache.h      |  36 +
 arch/mips/mach-mscc/include/mach/common.h     |  31 +
 arch/mips/mach-mscc/include/mach/ddr.h        | 753 ++++++++++++++++++
 .../mips/mach-mscc/include/mach/luton/luton.h |  37 +
 .../include/mach/luton/luton_devcpu_gcb.h     |  16 +
 .../include/mach/luton/luton_icpu_cfg.h       | 247 ++++++
 .../mach-mscc/include/mach/ocelot/ocelot.h    |  35 +
 .../include/mach/ocelot/ocelot_devcpu_gcb.h   |  49 ++
 .../include/mach/ocelot/ocelot_icpu_cfg.h     | 278 +++++++
 arch/mips/mach-mscc/include/mach/tlb.h        |  65 ++
 arch/mips/mach-mscc/lowlevel_init.S           |  29 +
 arch/mips/mach-mscc/lowlevel_init_luton.S     |  63 ++
 arch/mips/mach-mscc/reset.c                   |  37 +
 20 files changed, 1973 insertions(+)
 create mode 100644 arch/mips/mach-mscc/Kconfig
 create mode 100644 arch/mips/mach-mscc/Makefile
 create mode 100644 arch/mips/mach-mscc/cpu.c
 create mode 100644 arch/mips/mach-mscc/dram.c
 create mode 100644 arch/mips/mach-mscc/include/ioremap.h
 create mode 100644 arch/mips/mach-mscc/include/mach/cache.h
 create mode 100644 arch/mips/mach-mscc/include/mach/common.h
 create mode 100644 arch/mips/mach-mscc/include/mach/ddr.h
 create mode 100644 arch/mips/mach-mscc/include/mach/luton/luton.h
 create mode 100644 arch/mips/mach-mscc/include/mach/luton/luton_devcpu_gcb.h
 create mode 100644 arch/mips/mach-mscc/include/mach/luton/luton_icpu_cfg.h
 create mode 100644 arch/mips/mach-mscc/include/mach/ocelot/ocelot.h
 create mode 100644 arch/mips/mach-mscc/include/mach/ocelot/ocelot_devcpu_gcb.h
 create mode 100644 arch/mips/mach-mscc/include/mach/ocelot/ocelot_icpu_cfg.h
 create mode 100644 arch/mips/mach-mscc/include/mach/tlb.h
 create mode 100644 arch/mips/mach-mscc/lowlevel_init.S
 create mode 100644 arch/mips/mach-mscc/lowlevel_init_luton.S
 create mode 100644 arch/mips/mach-mscc/reset.c

diff --git a/arch/mips/Kconfig b/arch/mips/Kconfig
index 6e5e0ffe65..c4fc3d077b 100644
--- a/arch/mips/Kconfig
+++ b/arch/mips/Kconfig
@@ -58,6 +58,11 @@ config ARCH_ATH79
 	select OF_CONTROL
 	imply CMD_DM
 
+config ARCH_MSCC
+	bool "Support MSCC VCore-III"
+	select OF_CONTROL
+	select DM
+
 config ARCH_BMIPS
 	bool "Support BMIPS SoCs"
 	select CLK
@@ -118,6 +123,7 @@ source "board/imgtec/xilfpga/Kconfig"
 source "board/micronas/vct/Kconfig"
 source "board/qemu-mips/Kconfig"
 source "arch/mips/mach-ath79/Kconfig"
+source "arch/mips/mach-mscc/Kconfig"
 source "arch/mips/mach-bmips/Kconfig"
 source "arch/mips/mach-pic32/Kconfig"
 
diff --git a/arch/mips/Makefile b/arch/mips/Makefile
index a36f5f1fb6..acb1340942 100644
--- a/arch/mips/Makefile
+++ b/arch/mips/Makefile
@@ -14,6 +14,7 @@ libs-y += arch/mips/lib/
 machine-$(CONFIG_ARCH_ATH79) += ath79
 machine-$(CONFIG_ARCH_BMIPS) += bmips
 machine-$(CONFIG_MACH_PIC32) += pic32
+machine-$(CONFIG_ARCH_MSCC) += mscc
 
 machdirs := $(patsubst %,arch/mips/mach-%/,$(machine-y))
 libs-y += $(machdirs)
diff --git a/arch/mips/mach-mscc/Kconfig b/arch/mips/mach-mscc/Kconfig
new file mode 100644
index 0000000000..20148bfe15
--- /dev/null
+++ b/arch/mips/mach-mscc/Kconfig
@@ -0,0 +1,101 @@
+# SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+
+if ARCH_MSCC
+
+config SYS_DCACHE_SIZE
+	default 32768
+
+config SYS_DCACHE_LINE_SIZE
+	default 32
+
+config SYS_ICACHE_SIZE
+	default 32768
+
+config SYS_ICACHE_LINE_SIZE
+	default 32
+
+endif
+
+menu "MSCC VCore-III platforms"
+	depends on ARCH_MSCC
+
+config SOC_VCOREIII
+	select SUPPORTS_LITTLE_ENDIAN
+	select SUPPORTS_BIG_ENDIAN
+	select SUPPORTS_CPU_MIPS32_R1
+	select SUPPORTS_CPU_MIPS32_R2
+	select ROM_EXCEPTION_VECTORS
+	select MIPS_TUNE_24KC
+	bool
+
+config SYS_SOC
+	default "mscc"
+
+config SOC_OCELOT
+	bool
+	select SOC_VCOREIII
+	help
+	  This supports MSCC Ocelot family of SOCs.
+
+config SOC_LUTON
+	bool
+	select SOC_VCOREIII
+	help
+	  This supports MSCC Luton family of SOCs.
+
+config SYS_CONFIG_NAME
+	default "vcoreiii"
+
+choice
+	prompt "Board select"
+
+config TARGET_OCELOT_PCB120
+	bool "MSCC PCB120 Reference Board (aka VSC5635EV)"
+	select SOC_OCELOT
+	help
+	  When selected, CONFIG_DEFAULT_DEVICE_TREE should be set to
+	  ocelot_pcb120
+
+config TARGET_OCELOT_PCB123
+	bool "MSCC PCB123 Reference Board (aka VSC7514EV))"
+	select SOC_OCELOT
+	help
+	  When selected, CONFIG_DEFAULT_DEVICE_TREE should be set to
+	  ocelot_pcb123
+
+config TARGET_LUTON_PCB091
+	bool "MSCC PCB091 Reference Board"
+	select SOC_LUTON
+	select MSCC_BITBANG_SPI_GPIO
+	help
+	  When selected, CONFIG_DEFAULT_DEVICE_TREE should be set to
+	  luton_pcb091
+endchoice
+
+choice
+	prompt "DDR type"
+
+config DDRTYPE_H5TQ4G63MFR
+	bool "Hynix H5TQ4G63MFR-PBC (4Gbit, DDR3-800, 256Mbitx16)"
+
+config DDRTYPE_MT41K256M16
+	bool "Micron MT41K256M16 (4Gbit, DDR3L-800, 256Mbitx16)"
+
+config DDRTYPE_H5TQ1G63BFA
+	bool "Hynix H5TQ1G63BFA (1Gbit DDR3, x16)"
+
+config DDRTYPE_MT41J128M16HA
+	bool "Micron MT41J128M16HA-15E:D (2Gbit DDR3, x16)"
+
+config DDRTYPE_MT41K128M16JT
+	bool "Micron MT41K128M16JT-125 (2Gbit DDR3L, 128Mbitx16)"
+
+config DDRTYPE_MT47H128M8HQ
+	bool "Micron MT47H128M8-3 (1Gbit, DDR-533 at CL4 @ 4.80ns 16Mbisx8x8)"
+
+endchoice
+
+source "board/mscc/ocelot/Kconfig"
+source "board/mscc/luton/Kconfig"
+
+endmenu
diff --git a/arch/mips/mach-mscc/Makefile b/arch/mips/mach-mscc/Makefile
new file mode 100644
index 0000000000..6c60f26ca4
--- /dev/null
+++ b/arch/mips/mach-mscc/Makefile
@@ -0,0 +1,6 @@
+# SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+
+CFLAGS_cpu.o += -finline-limit=64000
+
+obj-y += cpu.o dram.o reset.o lowlevel_init.o
+obj-$(CONFIG_SOC_LUTON) += lowlevel_init_luton.o
diff --git a/arch/mips/mach-mscc/cpu.c b/arch/mips/mach-mscc/cpu.c
new file mode 100644
index 0000000000..3d6dd78c61
--- /dev/null
+++ b/arch/mips/mach-mscc/cpu.c
@@ -0,0 +1,72 @@
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+/*
+ * Copyright (c) 2018 Microsemi Corporation
+ */
+
+#include <common.h>
+
+#include <asm/io.h>
+#include <asm/types.h>
+
+#include <mach/tlb.h>
+#include <mach/ddr.h>
+
+DECLARE_GLOBAL_DATA_PTR;
+
+/* NOTE: lowlevel_init() function does not have access to the
+ * stack. Thus, all called functions must be inlined, and (any) local
+ * variables must be kept in registers.
+ */
+void vcoreiii_tlb_init(void)
+{
+        register int tlbix = 0;
+
+        init_tlb();
+
+        /* 0x70000000 size 32M (0x02000000) */
+        create_tlb(tlbix++, MSCC_IO_ORIGIN1_OFFSET, SZ_16M, MMU_REGIO_RW, MMU_REGIO_RW);
+#ifdef CONFIG_SOC_LUTON
+	create_tlb(tlbix++, MSCC_IO_ORIGIN2_OFFSET, SZ_16M, MMU_REGIO_RW, MMU_REGIO_RW);
+#endif
+        /* 0x40000000 - 0x43ffffff - NON-CACHED! */
+        /* Flash CS0-3, each 16M = 64M total (16 x 4 below )  */
+        create_tlb(tlbix++, MSCC_FLASH_TO,        SZ_16M, MMU_REGIO_RO, MMU_REGIO_RO);
+        create_tlb(tlbix++, MSCC_FLASH_TO+SZ_32M, SZ_16M, MMU_REGIO_RO, MMU_REGIO_RO);
+
+        /* 0x20000000 - up */
+#if CONFIG_SYS_SDRAM_SIZE <= SZ_64M
+        create_tlb(tlbix++, MSCC_DDR_TO,        SZ_64M,  MMU_REGIO_RW, MMU_REGIO_INVAL);
+#elif CONFIG_SYS_SDRAM_SIZE <= SZ_128M
+        create_tlb(tlbix++, MSCC_DDR_TO,        SZ_64M,  MMU_REGIO_RW, MMU_REGIO_RW);
+#elif CONFIG_SYS_SDRAM_SIZE <= SZ_256M
+        create_tlb(tlbix++, MSCC_DDR_TO,       SZ_256M,  MMU_REGIO_RW, MMU_REGIO_INVAL);
+#elif CONFIG_SYS_SDRAM_SIZE <= SZ_512M
+        create_tlb(tlbix++, MSCC_DDR_TO,       SZ_256M,  MMU_REGIO_RW, MMU_REGIO_RW);
+#else  /* 1024M */
+        create_tlb(tlbix++, MSCC_DDR_TO,       SZ_512M,  MMU_REGIO_RW, MMU_REGIO_RW);
+#endif
+}
+
+int mach_cpu_init(void)
+{
+        /* Speed up NOR flash access */
+#ifdef CONFIG_SOC_LUTON
+        writel(ICPU_SPI_MST_CFG_FAST_READ_ENA +
+#else
+	writel(
+#endif
+	       ICPU_SPI_MST_CFG_CS_DESELECT_TIME(0x19) +
+               ICPU_SPI_MST_CFG_CLK_DIV(9), REG_CFG(ICPU_SPI_MST_CFG));
+
+        /* Disable all IRQs - map to destination map 0 */
+        writel(0, REG_CFG(ICPU_INTR_ENA));
+#ifdef CONFIG_SOC_OCELOT
+        writel(~0, REG_CFG(ICPU_DST_INTR_MAP(0)));
+        writel(0, REG_CFG(ICPU_DST_INTR_MAP(1)));
+        writel(0, REG_CFG(ICPU_DST_INTR_MAP(2)));
+        writel(0, REG_CFG(ICPU_DST_INTR_MAP(3)));
+#else
+	writel(ICPU_INTR_IRQ0_ENA_IRQ0_ENA, REG_CFG(ICPU_INTR_IRQ0_ENA));
+#endif
+	return 0;
+}
diff --git a/arch/mips/mach-mscc/dram.c b/arch/mips/mach-mscc/dram.c
new file mode 100644
index 0000000000..2db9001fe9
--- /dev/null
+++ b/arch/mips/mach-mscc/dram.c
@@ -0,0 +1,62 @@
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+/*
+ * Copyright (c) 2018 Microsemi Corporation
+ */
+
+#include <common.h>
+
+#include <asm/io.h>
+#include <asm/types.h>
+
+#include <mach/tlb.h>
+#include <mach/ddr.h>
+
+DECLARE_GLOBAL_DATA_PTR;
+
+int vcoreiii_ddr_init(void)
+{
+        int res;
+        if (!(readl(REG_CFG(ICPU_MEMCTRL_STAT)) &
+              ICPU_MEMCTRL_STAT_INIT_DONE)) {
+                hal_vcoreiii_init_memctl();
+                hal_vcoreiii_wait_memctl();
+                if (hal_vcoreiii_init_dqs() != 0 ||
+                    hal_vcoreiii_train_bytelane(0) != 0
+#ifdef CONFIG_SOC_OCELOT
+		    || hal_vcoreiii_train_bytelane(1) != 0
+#endif
+			)
+                        hal_vcoreiii_ddr_failed();
+        }
+
+#if (CONFIG_SYS_TEXT_BASE != 0x20000000)
+        res = dram_check();
+        if (res == 0)
+                hal_vcoreiii_ddr_verified();
+        else
+                hal_vcoreiii_ddr_failed();
+
+        /* Clear boot-mode and read-back to activate/verify */
+        writel(readl(REG_CFG(ICPU_GENERAL_CTRL))& ~ICPU_GENERAL_CTRL_BOOT_MODE_ENA,
+	       REG_CFG(ICPU_GENERAL_CTRL));
+        readl(REG_CFG(ICPU_GENERAL_CTRL));
+#else
+        res = 0;
+#endif
+        return res;
+}
+
+int print_cpuinfo(void)
+{
+        printf("MSCC VCore-III MIPS 24Kec\n");
+
+	return 0;
+}
+
+int dram_init(void)
+{
+	while (vcoreiii_ddr_init());
+
+        gd->ram_size = CONFIG_SYS_SDRAM_SIZE;
+        return 0;
+}
diff --git a/arch/mips/mach-mscc/include/ioremap.h b/arch/mips/mach-mscc/include/ioremap.h
new file mode 100644
index 0000000000..684f89168c
--- /dev/null
+++ b/arch/mips/mach-mscc/include/ioremap.h
@@ -0,0 +1,49 @@
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+/*
+ * Copyright (c) 2018 Microsemi Corporation
+ */
+
+#ifndef __ASM_MACH_MSCC_IOREMAP_H
+#define __ASM_MACH_MSCC_IOREMAP_H
+
+#include <linux/types.h>
+#include <mach/common.h>
+
+/*
+ * Allow physical addresses to be fixed up to help peripherals located
+ * outside the low 32-bit range -- generic pass-through version.
+ */
+static inline phys_addr_t fixup_bigphys_addr(phys_addr_t phys_addr,
+                                             phys_addr_t size)
+{
+	return phys_addr;
+}
+
+static inline int is_vcoreiii_internal_registers(phys_addr_t offset)
+{
+#if defined(CONFIG_ARCH_MSCC)
+        if ((offset >= MSCC_IO_ORIGIN1_OFFSET && offset < (MSCC_IO_ORIGIN1_OFFSET+MSCC_IO_ORIGIN1_SIZE)) ||
+            (offset >= MSCC_IO_ORIGIN2_OFFSET && offset < (MSCC_IO_ORIGIN2_OFFSET+MSCC_IO_ORIGIN2_SIZE)))
+                return 1;
+#endif
+
+	return 0;
+}
+
+static inline void __iomem *plat_ioremap(phys_addr_t offset, unsigned long size,
+                                         unsigned long flags)
+{
+	if (is_vcoreiii_internal_registers(offset))
+		return (void __iomem *)offset;
+
+	return NULL;
+}
+
+static inline int plat_iounmap(const volatile void __iomem *addr)
+{
+	return is_vcoreiii_internal_registers((unsigned long)addr);
+}
+
+#define _page_cachable_default	_CACHE_CACHABLE_NONCOHERENT
+
+#endif /* __ASM_MACH_MSCC_IOREMAP_H */
diff --git a/arch/mips/mach-mscc/include/mach/cache.h b/arch/mips/mach-mscc/include/mach/cache.h
new file mode 100644
index 0000000000..f3d09014f3
--- /dev/null
+++ b/arch/mips/mach-mscc/include/mach/cache.h
@@ -0,0 +1,36 @@
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+/*
+ * Copyright (c) 2018 Microsemi Corporation
+ */
+#define MIPS32_CACHE_OP(which, op)             (which | (op << 2))
+
+#define MIPS32_WHICH_ICACHE                    0x0
+#define MIPS32_WHICH_DCACHE                    0x1
+
+#define MIPS32_INDEX_INVALIDATE                0x0
+#define MIPS32_INDEX_LOAD_TAG                  0x1
+#define MIPS32_INDEX_STORE_TAG                 0x2
+#define MIPS32_HIT_INVALIDATE                  0x4
+#define MIPS32_ICACHE_FILL                     0x5
+#define MIPS32_DCACHE_HIT_INVALIDATE           0x5
+#define MIPS32_DCACHE_HIT_WRITEBACK            0x6
+#define MIPS32_FETCH_AND_LOCK                  0x7
+
+#define ICACHE_LOAD_LOCK (MIPS32_CACHE_OP(MIPS32_WHICH_ICACHE, MIPS32_FETCH_AND_LOCK))
+
+#define CACHE_LINE_LEN 32
+
+/* Prefetch and lock instructions into cache */
+static inline void icache_lock(void *func, size_t len)
+{
+    int i, lines = ((len - 1) / CACHE_LINE_LEN) + 1;
+    for (i = 0; i < lines; i++) {
+        asm volatile (" cache %0, %1(%2)"
+                      : /* No Output */
+                      : "I" ICACHE_LOAD_LOCK,
+                        "n" (i*CACHE_LINE_LEN),
+                        "r" (func)
+                      : /* No Clobbers */);
+    }
+}
+
diff --git a/arch/mips/mach-mscc/include/mach/common.h b/arch/mips/mach-mscc/include/mach/common.h
new file mode 100644
index 0000000000..7e5c81c925
--- /dev/null
+++ b/arch/mips/mach-mscc/include/mach/common.h
@@ -0,0 +1,31 @@
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+/*
+ * Copyright (c) 2018 Microsemi Corporation
+ */
+
+#ifndef __ASM_MACH_COMMON_H
+#define __ASM_MACH_COMMON_H
+
+// Stick to using register offsets - matching readl()/writel() prototypes
+#define MSCC_IOREG(t,o)      ((void *)MSCC_IOADDR(t,o))
+
+#if defined(CONFIG_SOC_OCELOT)
+#include <mach/ocelot/ocelot.h>
+#include <mach/ocelot/ocelot_devcpu_gcb.h>
+#include <mach/ocelot/ocelot_icpu_cfg.h>
+#elif defined(CONFIG_SOC_LUTON)
+#include <mach/luton/luton.h>
+#include <mach/luton/luton_devcpu_gcb.h>
+#include <mach/luton/luton_icpu_cfg.h>
+#else
+#error Unsupported platform
+#endif
+
+#define MSCC_DDR_TO     0x20000000  /* DDR RAM base offset */
+#define MSCC_MEMCTL1_TO 0x40000000  /* SPI/PI base offset */
+#define MSCC_MEMCTL2_TO 0x50000000  /* SPI/PI base offset */
+#define MSCC_FLASH_TO   MSCC_MEMCTL1_TO /* Flash base offset */
+
+#define VCOREIII_TIMER_DIVIDER 25     // Clock tick ~ 0.1 us
+
+#endif /* __ASM_MACH_COMMON_H */
diff --git a/arch/mips/mach-mscc/include/mach/ddr.h b/arch/mips/mach-mscc/include/mach/ddr.h
new file mode 100644
index 0000000000..aef3facdca
--- /dev/null
+++ b/arch/mips/mach-mscc/include/mach/ddr.h
@@ -0,0 +1,753 @@
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+/*
+ * Copyright (c) 2018 Microsemi Corporation
+ */
+
+#ifndef __ASM_MACH_DDR_H
+#define __ASM_MACH_DDR_H
+
+#include <mach/common.h>
+#include <mach/cache.h>
+#include <asm/reboot.h>
+
+#define MIPS_VCOREIII_MEMORY_DDR3
+#define MIPS_VCOREIII_DDR_SIZE CONFIG_SYS_SDRAM_SIZE
+
+#if defined(CONFIG_DDRTYPE_H5TQ1G63BFA) /* Serval1 Refboard */
+
+/* Hynix H5TQ1G63BFA (1Gbit DDR3, x16) @ 3.20ns */
+#define VC3_MPAR_bank_addr_cnt    3
+#define VC3_MPAR_row_addr_cnt     13
+#define VC3_MPAR_col_addr_cnt     10
+#define VC3_MPAR_tREFI            2437
+#define VC3_MPAR_tRAS_min         12
+#define VC3_MPAR_CL               6
+#define VC3_MPAR_tWTR             4
+#define VC3_MPAR_tRC              16
+#define VC3_MPR_tFAW             16
+#define VC3_MPAR_tRP              5
+#define VC3_MPAR_tRRD             4
+#define VC3_MPAR_tRCD             5
+#define VC3_MPAR_tMRD             4
+#define VC3_MPAR_tRFC             35
+#define VC3_MPAR_CWL              5
+#define VC3_MPAR_tXPR             38
+#define VC3_MPAR_tMOD             12
+#define VC3_MPAR_tDLLK            512
+#define VC3_MPAR_tWR              5
+
+#elif defined(CONFIG_DDRTYPE_MT41J128M16HA) /* Validation board */
+
+/* Micron MT41J128M16HA-15E:D (2Gbit DDR3, x16) @ 3.20ns */
+#define VC3_MPAR_bank_addr_cnt    3
+#define VC3_MPAR_row_addr_cnt     14
+#define VC3_MPAR_col_addr_cnt     10
+#define VC3_MPAR_tREFI            2437
+#define VC3_MPAR_tRAS_min         12
+#define VC3_MPAR_CL               5
+#define VC3_MPAR_tWTR             4
+#define VC3_MPAR_tRC              16
+#define VC3_MPAR_tFAW             16
+#define VC3_MPAR_tRP              5
+#define VC3_MPAR_tRRD             4
+#define VC3_MPAR_tRCD             5
+#define VC3_MPAR_tMRD             4
+#define VC3_MPAR_tRFC             50
+#define VC3_MPAR_CWL              5
+#define VC3_MPAR_tXPR             54
+#define VC3_MPAR_tMOD             12
+#define VC3_MPAR_tDLLK            512
+#define VC3_MPAR_tWR              5
+
+#elif defined(CONFIG_DDRTYPE_MT41K256M16) /* JR2 Validation board */
+
+/* Micron MT41K256M16 (4Gbit, DDR3L-800, 256Mbitx16) @ 3.20ns */
+#define VC3_MPAR_bank_addr_cnt    3
+#define VC3_MPAR_row_addr_cnt     15
+#define VC3_MPAR_col_addr_cnt     10
+#define VC3_MPAR_tREFI            2437
+#define VC3_MPAR_tRAS_min         12
+#define VC3_MPAR_CL               5
+#define VC3_MPAR_tWTR             4
+#define VC3_MPAR_tRC              16
+#define VC3_MPAR_tFAW             16
+#define VC3_MPAR_tRP              5
+#define VC3_MPAR_tRRD             4
+#define VC3_MPAR_tRCD             5
+#define VC3_MPAR_tMRD             4
+#define VC3_MPAR_tRFC             82
+#define VC3_MPAR_CWL              5
+#define VC3_MPAR_tXPR             85
+#define VC3_MPAR_tMOD             12
+#define VC3_MPAR_tDLLK            512
+#define VC3_MPAR_tWR              5
+
+#elif defined(CONFIG_DDRTYPE_H5TQ4G63MFR) /* JR2 Reference board */
+
+/* Hynix H5TQ4G63MFR-PBC (4Gbit, DDR3-800, 256Mbitx16) - 2kb pages @ 3.20ns */
+#define VC3_MPAR_bank_addr_cnt    3
+#define VC3_MPAR_row_addr_cnt     15
+#define VC3_MPAR_col_addr_cnt     10
+#define VC3_MPAR_tREFI            2437
+#define VC3_MPAR_tRAS_min         12
+#define VC3_MPAR_CL               6
+#define VC3_MPAR_tWTR             4
+#define VC3_MPAR_tRC              17
+#define VC3_MPAR_tFAW             16
+#define VC3_MPAR_tRP              5
+#define VC3_MPAR_tRRD             4
+#define VC3_MPAR_tRCD             5
+#define VC3_MPAR_tMRD             4
+#define VC3_MPAR_tRFC             82
+#define VC3_MPAR_CWL              5
+#define VC3_MPAR_tXPR             85
+#define VC3_MPAR_tMOD             12
+#define VC3_MPAR_tDLLK            512
+#define VC3_MPAR_tWR              5
+
+#elif defined(CONFIG_DDRTYPE_MT41K128M16JT)
+
+/* Micron Micron MT41K128M16JT-125 (2Gbit DDR3L, 128Mbitx16) @ 3.20ns */
+#define VC3_MPAR_bank_addr_cnt    3
+#define VC3_MPAR_row_addr_cnt     14
+#define VC3_MPAR_col_addr_cnt     10
+#define VC3_MPAR_tREFI            2437
+#define VC3_MPAR_tRAS_min         12
+#define VC3_MPAR_CL               6
+#define VC3_MPAR_tWTR             4
+#define VC3_MPAR_tRC              16
+#define VC3_MPAR_tFAW             16
+#define VC3_MPAR_tRP              5
+#define VC3_MPAR_tRRD             4
+#define VC3_MPAR_tRCD             5
+#define VC3_MPAR_tMRD             4
+#define VC3_MPAR_tRFC             82
+#define VC3_MPAR_CWL              5
+#define VC3_MPAR_tXPR             85
+#define VC3_MPAR_tMOD             12
+#define VC3_MPAR_tDLLK            512
+#define VC3_MPAR_tWR              5
+
+#elif defined(CONFIG_DDRTYPE_MT47H128M8HQ) /* Luton10/26 Refboards */
+
+/* Micron 1Gb MT47H128M8-3 16Meg x 8 x 8 banks, DDR-533 at CL4 @ 4.80ns */
+#define VC3_MPAR_bank_addr_cnt    3
+#define VC3_MPAR_row_addr_cnt     14
+#define VC3_MPAR_col_addr_cnt     10
+#define VC3_MPAR_tREFI            1625
+#define VC3_MPAR_tRAS_min         9
+#define VC3_MPAR_CL               4
+#define VC3_MPAR_tWTR             2
+#define VC3_MPAR_tRC              12
+#define VC3_MPAR_tFAW             8
+#define VC3_MPAR_tRP              4
+#define VC3_MPAR_tRRD             2
+#define VC3_MPAR_tRCD             4
+
+#define VC3_MPAR_tRPA             4
+#define VC3_MPAR_tRP              4
+
+#define VC3_MPAR_tMRD             2
+#define VC3_MPAR_tRFC             27
+
+#define VC3_MPAR__400_ns_dly      84
+
+#define VC3_MPAR_tWR              4
+#undef MIPS_VCOREIII_MEMORY_DDR3
+#else
+
+#error Unknown DDR system configuration - please add!
+
+#endif
+
+#ifdef CONFIG_SOC_OCELOT
+#define MIPS_VCOREIII_MEMORY_16BIT 1
+#endif
+
+#define MIPS_VCOREIII_MEMORY_SSTL_ODT 7
+#define MIPS_VCOREIII_MEMORY_SSTL_DRIVE 7
+#define VCOREIII_DDR_DQS_MODE_CALIBRATE
+
+#ifdef MIPS_VCOREIII_MEMORY_16BIT
+ #define VC3_MPAR_16BIT       1
+#else
+ #define VC3_MPAR_16BIT       0
+#endif
+
+#ifdef MIPS_VCOREIII_MEMORY_DDR3
+ #define VC3_MPAR_DDR3_MODE    1 /* DDR3 */
+ #define VC3_MPAR_BURST_LENGTH 8 /* Always 8 (1) for DDR3 */
+ #ifdef MIPS_VCOREIII_MEMORY_16BIT
+#define VC3_MPAR_BURST_SIZE   1 /* Always 1 for DDR3/16bit */
+ #else
+  #define VC3_MPAR_BURST_SIZE   0
+ #endif
+#else
+ #define VC3_MPAR_DDR3_MODE    0 /* DDR2 */
+ #ifdef MIPS_VCOREIII_MEMORY_16BIT
+  #define VC3_MPAR_BURST_LENGTH 4 /* in DDR2 16-bit mode, use burstlen 4 */
+ #else
+  #define VC3_MPAR_BURST_LENGTH 8 /* For 8-bit IF we must run burst-8 */
+ #endif
+ #define VC3_MPAR_BURST_SIZE   0 /* Always 0 for DDR2 */
+#endif
+
+#define VC3_MPAR_RL VC3_MPAR_CL
+#if !defined(MIPS_VCOREIII_MEMORY_DDR3)
+#define VC3_MPAR_WL (VC3_MPAR_RL-1)
+#define VC3_MPAR_MD VC3_MPAR_tMRD
+#define VC3_MPAR_ID VC3_MPAR__400_ns_dly
+#define VC3_MPAR_SD VC3_MPAR_tXSRD
+#define VC3_MPAR_OW (VC3_MPAR_WL-2)
+#define VC3_MPAR_OR (VC3_MPAR_WL-3)
+#define VC3_MPAR_RP (VC3_MPAR_bank_addr_cnt < 3 ? VC3_MPAR_tRP : VC3_MPAR_tRPA)
+#define VC3_MPAR_FAW (VC3_MPAR_bank_addr_cnt < 3 ? 1 : VC3_MPAR_tFAW)
+#define VC3_MPAR_BL (VC3_MPAR_BURST_LENGTH == 4 ? 2 : 4)
+#define MSCC_MEMPARM_MR0 \
+	(VC3_MPAR_BURST_LENGTH == 8 ? 3 : 2) | (VC3_MPAR_CL << 4) | ((VC3_MPAR_tWR-1) << 9)
+#define MSCC_MEMPARM_MR1 0x382 /* DLL-on, Full-OD, AL=0, RTT=off, nDQS-on, RDQS-off, out-en */
+#define MSCC_MEMPARM_MR2 0
+#define MSCC_MEMPARM_MR3 0
+#else
+#define VC3_MPAR_WL VC3_MPAR_CWL
+#define VC3_MPAR_MD VC3_MPAR_tMOD
+#define VC3_MPAR_ID VC3_MPAR_tXPR
+#define VC3_MPAR_SD VC3_MPAR_tDLLK
+#define VC3_MPAR_OW 2
+#define VC3_MPAR_OR 2
+#define VC3_MPAR_RP VC3_MPAR_tRP
+#define VC3_MPAR_FAW VC3_MPAR_tFAW
+#define VC3_MPAR_BL 4
+#define MSCC_MEMPARM_MR0 ((VC3_MPAR_RL - 4) << 4) | ((VC3_MPAR_tWR - 4) << 9)
+#define MSCC_MEMPARM_MR1 0x0040 /* ODT_RTT: “0x0040” for 120ohm, and “0x0004” for 60ohm. */
+#define MSCC_MEMPARM_MR2 ((VC3_MPAR_WL - 5) << 3)
+#define MSCC_MEMPARM_MR3 0
+#endif  /* MIPS_VCOREIII_MEMORY_DDR3 */
+
+#define MSCC_MEMPARM_MEMCFG                                             \
+    ((MIPS_VCOREIII_DDR_SIZE > SZ_512M) ?                    \
+     ICPU_MEMCTRL_CFG_DDR_512MBYTE_PLUS : 0) |       \
+    (VC3_MPAR_16BIT ? ICPU_MEMCTRL_CFG_DDR_WIDTH : 0) | \
+    (VC3_MPAR_DDR3_MODE ? ICPU_MEMCTRL_CFG_DDR_MODE : 0) | \
+    (VC3_MPAR_BURST_SIZE ? ICPU_MEMCTRL_CFG_BURST_SIZE : 0) | \
+    (VC3_MPAR_BURST_LENGTH == 8 ? ICPU_MEMCTRL_CFG_BURST_LEN : 0) | \
+    (VC3_MPAR_bank_addr_cnt == 3 ? ICPU_MEMCTRL_CFG_BANK_CNT : 0) | \
+    ICPU_MEMCTRL_CFG_MSB_ROW_ADDR(VC3_MPAR_row_addr_cnt-1) | \
+    ICPU_MEMCTRL_CFG_MSB_COL_ADDR(VC3_MPAR_col_addr_cnt-1)
+
+#define MSCC_MEMPARM_PERIOD                                             \
+    ICPU_MEMCTRL_REF_PERIOD_MAX_PEND_REF(8) |        \
+    ICPU_MEMCTRL_REF_PERIOD_REF_PERIOD(VC3_MPAR_tREFI)
+
+#ifdef CONFIG_SOC_OCELOT
+#define MSCC_MEMPARM_TIMING0                                            \
+    ICPU_MEMCTRL_TIMING0_RD_TO_WR_DLY(VC3_MPAR_RL+VC3_MPAR_BL+1-VC3_MPAR_WL) | \
+    ICPU_MEMCTRL_TIMING0_WR_CS_CHANGE_DLY(VC3_MPAR_BL-1) | \
+    ICPU_MEMCTRL_TIMING0_RD_CS_CHANGE_DLY(VC3_MPAR_BL) | \
+    ICPU_MEMCTRL_TIMING0_RAS_TO_PRECH_DLY(VC3_MPAR_tRAS_min-1) | \
+    ICPU_MEMCTRL_TIMING0_WR_TO_PRECH_DLY(VC3_MPAR_WL + \
+                                                            VC3_MPAR_BL + \
+                                                            VC3_MPAR_tWR - 1) | \
+    ICPU_MEMCTRL_TIMING0_RD_TO_PRECH_DLY(VC3_MPAR_BL-1) | \
+    ICPU_MEMCTRL_TIMING0_WR_DATA_XFR_DLY(VC3_MPAR_WL-1) | \
+    ICPU_MEMCTRL_TIMING0_RD_DATA_XFR_DLY(VC3_MPAR_RL-3)
+
+#define MSCC_MEMPARM_TIMING1                                            \
+    ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_SAME_BANK_DLY(VC3_MPAR_tRC-1) | \
+    ICPU_MEMCTRL_TIMING1_BANK8_FAW_DLY(VC3_MPAR_FAW-1) | \
+    ICPU_MEMCTRL_TIMING1_PRECH_TO_RAS_DLY(VC3_MPAR_RP-1) | \
+    ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_DLY(VC3_MPAR_tRRD-1) | \
+    ICPU_MEMCTRL_TIMING1_RAS_TO_CAS_DLY(VC3_MPAR_tRCD-1) | \
+    ICPU_MEMCTRL_TIMING1_WR_TO_RD_DLY(VC3_MPAR_WL +  \
+                                                         VC3_MPAR_BL +  \
+                                                         VC3_MPAR_tWTR - 1)
+
+#define MSCC_MEMPARM_TIMING2				\
+    ICPU_MEMCTRL_TIMING2_PRECH_ALL_DLY(VC3_MPAR_RP-1) | \
+    ICPU_MEMCTRL_TIMING2_MDSET_DLY(VC3_MPAR_MD-1) |  \
+    ICPU_MEMCTRL_TIMING2_REF_DLY(VC3_MPAR_tRFC-1) |  \
+    ICPU_MEMCTRL_TIMING2_INIT_DLY(VC3_MPAR_ID-1)
+
+#define MSCC_MEMPARM_TIMING3 \
+    ICPU_MEMCTRL_TIMING3_WR_TO_RD_CS_CHANGE_DLY(VC3_MPAR_WL + VC3_MPAR_tWTR - 1) | \
+    ICPU_MEMCTRL_TIMING3_ODT_RD_DLY(VC3_MPAR_OR-1) | \
+    ICPU_MEMCTRL_TIMING3_ODT_WR_DLY(VC3_MPAR_OW-1) | \
+    ICPU_MEMCTRL_TIMING3_LOCAL_ODT_RD_DLY(VC3_MPAR_RL-3)
+
+#else
+#define MSCC_MEMPARM_TIMING0                                            \
+    ICPU_MEMCTRL_TIMING0_RAS_TO_PRECH_DLY(VC3_MPAR_tRAS_min-1) | \
+    ICPU_MEMCTRL_TIMING0_WR_TO_PRECH_DLY(VC3_MPAR_CL + \
+					 (VC3_MPAR_BURST_LENGTH == 8 ? 2 : 0) +	\
+                                                            VC3_MPAR_tWR) | \
+    ICPU_MEMCTRL_TIMING0_RD_TO_PRECH_DLY(VC3_MPAR_BURST_LENGTH == 8 ? 3 : 1) | \
+    ICPU_MEMCTRL_TIMING0_WR_DATA_XFR_DLY(VC3_MPAR_CL-3) | \
+    ICPU_MEMCTRL_TIMING0_RD_DATA_XFR_DLY(VC3_MPAR_CL-3)
+
+#define MSCC_MEMPARM_TIMING1                                            \
+    ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_SAME_BANK_DLY(VC3_MPAR_tRC-1) | \
+    ICPU_MEMCTRL_TIMING1_BANK8_FAW_DLY(VC3_MPAR_tFAW) |   \
+    ICPU_MEMCTRL_TIMING1_PRECH_TO_RAS_DLY(VC3_MPAR_tRP-1) | \
+    ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_DLY(VC3_MPAR_tRRD-1) | \
+    ICPU_MEMCTRL_TIMING1_RAS_TO_CAS_DLY(VC3_MPAR_tRCD-1) | \
+    ICPU_MEMCTRL_TIMING1_WR_TO_RD_DLY(VC3_MPAR_CL +  \
+				      (VC3_MPAR_BURST_LENGTH == 8 ? 2 : 0) + \
+				      VC3_MPAR_tWTR)
+#define MSCC_MEMPARM_TIMING2                                            \
+    ICPU_MEMCTRL_TIMING2_PRECH_ALL_DLY(VC3_MPAR_tRPA-1) | \
+    ICPU_MEMCTRL_TIMING2_MDSET_DLY(VC3_MPAR_tMRD-1) |  \
+    ICPU_MEMCTRL_TIMING2_REF_DLY(VC3_MPAR_tRFC-1) |  \
+    ICPU_MEMCTRL_TIMING2_FOUR_HUNDRED_NS_DLY(VC3_MPAR__400_ns_dly)
+
+#define MSCC_MEMPARM_TIMING3 \
+    ICPU_MEMCTRL_TIMING3_WR_TO_RD_CS_CHANGE_DLY(VC3_MPAR_CL-1) | \
+    ICPU_MEMCTRL_TIMING3_ODT_WR_DLY(VC3_MPAR_CL-1) | \
+    ICPU_MEMCTRL_TIMING3_LOCAL_ODT_RD_DLY(VC3_MPAR_CL-3)
+
+#endif
+
+enum {
+    DDR_TRAIN_OK,
+    DDR_TRAIN_CONTINUE,
+    DDR_TRAIN_ERROR,
+};
+
+/* We actually have very few 'pause' possibilities apart from
+ * these assembly nops (at this very early stage). */
+#define PAUSE() asm volatile("nop; nop; nop; nop; nop; nop; nop; nop")
+
+
+/* NB: Assumes inlining as no stack is available! */
+static inline void set_dly(u32 bytelane, u32 dly)
+{
+    register u32 r = readl(REG_CFG(ICPU_MEMCTRL_DQS_DLY(bytelane)));
+    r &= ~ICPU_MEMCTRL_DQS_DLY_DQS_DLY_M;
+    r |= ICPU_MEMCTRL_DQS_DLY_DQS_DLY(dly);
+    writel(r, REG_CFG(ICPU_MEMCTRL_DQS_DLY(bytelane)));
+}
+
+static inline bool incr_dly(u32 bytelane)
+{
+    register u32 r = readl(REG_CFG(ICPU_MEMCTRL_DQS_DLY(bytelane)));
+    if (ICPU_MEMCTRL_DQS_DLY_DQS_DLY(r) < 31) {
+	    writel(r + 1, REG_CFG(ICPU_MEMCTRL_DQS_DLY(bytelane)));
+	    return true;
+    }
+
+    return false;
+}
+static inline bool adjust_dly(int adjust)
+{
+    register u32 r = readl(REG_CFG(ICPU_MEMCTRL_DQS_DLY(0)));
+    if (ICPU_MEMCTRL_DQS_DLY_DQS_DLY(r) < 31) {
+	    writel(r + adjust, REG_CFG(ICPU_MEMCTRL_DQS_DLY(0)));
+	    return true;
+    }
+
+    return false;
+}
+
+/* NB: Assumes inlining as no stack is available! */
+static inline void center_dly(u32 bytelane, u32 start)
+{
+    register u32 r = readl(REG_CFG(ICPU_MEMCTRL_DQS_DLY(bytelane))) - start;
+    writel(start + (r >> 1), REG_CFG(ICPU_MEMCTRL_DQS_DLY(bytelane)));
+}
+
+static inline void memphy_soft_reset(void)
+{
+        writel(readl(REG_CFG(ICPU_MEMPHY_CFG)) | ICPU_MEMPHY_CFG_PHY_FIFO_RST,
+	       REG_CFG(ICPU_MEMPHY_CFG));
+        PAUSE();
+        writel(readl(REG_CFG(ICPU_MEMPHY_CFG)) & ~ICPU_MEMPHY_CFG_PHY_FIFO_RST,
+	       REG_CFG(ICPU_MEMPHY_CFG));
+        PAUSE();
+}
+#ifdef CONFIG_SOC_OCELOT
+static u8 training_data[] = { 0xfe, 0x11, 0x33, 0x55, 0x77, 0x99, 0xbb, 0xdd };
+
+static inline void sleep_100ns(u32 val)
+{
+        /* Set the timer tick generator to 100 ns */
+        writel(VCOREIII_TIMER_DIVIDER-1, REG_CFG(ICPU_TIMER_TICK_DIV));
+
+        /* Set the timer value */
+        writel(val, REG_CFG(ICPU_TIMER_VALUE(0)));
+
+        /* Enable timer 0 for one-shot */
+        writel(ICPU_TIMER_CTRL_ONE_SHOT_ENA | ICPU_TIMER_CTRL_TIMER_ENA,
+	       REG_CFG(ICPU_TIMER_CTRL(0)));
+
+        /* Wait for timer 0 to reach 0 */
+        while (readl(REG_CFG(ICPU_TIMER_VALUE(0))) != 0)
+                ;
+}
+
+static inline void hal_vcoreiii_ddr_reset_assert(void)
+{
+        /* DDR has reset pin on GPIO 19 toggle Low-High to release */
+        writel(readl(REG_GCB(PERF_GPIO_OE)) | BIT(19), REG_GCB(PERF_GPIO_OE));
+        writel(BIT(19), REG_GCB(PERF_GPIO_OUT_CLR));
+        sleep_100ns(10000);
+}
+
+static inline void hal_vcoreiii_ddr_reset_release(void)
+{
+        /* DDR has reset pin on GPIO 19 toggle Low-High to release */
+        writel(readl(REG_GCB(PERF_GPIO_OE)) | BIT(19), REG_GCB(PERF_GPIO_OE));
+        writel(BIT(19), REG_GCB(PERF_GPIO_OUT_SET));
+        sleep_100ns(10000);
+}
+
+/*
+ * DDR memory sanity checking failed, tally and do hard reset
+ *
+ * NB: Assumes inlining as no stack is available!
+ */
+static inline void hal_vcoreiii_ddr_failed(void)
+{
+        register u32 reset;
+
+        writel(readl(REG_CFG(ICPU_GPR(6))) + 1, REG_CFG(ICPU_GPR(6)));
+
+        writel(readl(REG_GCB(PERF_GPIO_OE)) & ~BIT(19),
+	       REG_GCB(PERF_GPIO_OE));
+
+        /* Jump to reset - does not return */
+        reset = KSEG0ADDR(_machine_restart);
+        icache_lock((void*)reset, 128); // Reset while running from cache
+        asm volatile ("jr %0" : : "r" (reset));
+
+        while(1)
+                ;
+}
+/*
+ * DDR memory sanity checking done, possibly enable ECC.
+ *
+ * NB: Assumes inlining as no stack is available!
+ */
+static inline void hal_vcoreiii_ddr_verified(void)
+{
+#ifdef MIPS_VCOREIII_MEMORY_ECC
+        /* Finally, enable ECC */
+	u32 val = readl(REG_CFG(ICPU_MEMCTRL_CFG));
+
+	val |= ICPU_MEMCTRL_CFG_DDR_ECC_ERR_ENA;
+	val &= ~ICPU_MEMCTRL_CFG_BURST_SIZE;
+
+	writel(val, REG_CFG(ICPU_MEMCTRL_CFG));
+#endif
+
+        /* Reset Status register - sticky bits */
+        writel(readl(REG_CFG(ICPU_MEMCTRL_STAT)),
+	       REG_CFG(ICPU_MEMCTRL_STAT));
+}
+/* NB: Assumes inlining as no stack is available! */
+static inline int look_for(u32 bytelane)
+{
+    register u32 i;
+    /* Reset FIFO in case any previous access failed */
+    for (i = 0; i < sizeof(training_data); i++) {
+        register u32 byte;
+        memphy_soft_reset();
+        /* Reset sticky bits */
+        writel(readl(REG_CFG(ICPU_MEMCTRL_STAT)), REG_CFG(ICPU_MEMCTRL_STAT));
+        /* Read data */
+        byte = ((volatile u8 *) MSCC_DDR_TO)[bytelane + (i * 4)];
+        if (readl(REG_CFG(ICPU_MEMCTRL_STAT)) &
+            (ICPU_MEMCTRL_STAT_RDATA_MASKED|
+             ICPU_MEMCTRL_STAT_RDATA_DUMMY)) {
+		/* Noise on the line */
+            goto read_error;
+        }
+        /* If mismatch, increment DQS - if possible */
+        if (byte != training_data[i]) {
+      read_error:
+            if (!incr_dly(bytelane)) {
+                return DDR_TRAIN_ERROR;
+            }
+            return DDR_TRAIN_CONTINUE;
+        }
+    }
+    return DDR_TRAIN_OK;
+}
+
+
+/* NB: Assumes inlining as no stack is available! */
+static inline int look_past(u32 bytelane)
+{
+    register u32 i;
+    /* Reset FIFO in case any previous access failed */
+    for (i = 0; i < sizeof(training_data); i++) {
+        register u32 byte;
+        memphy_soft_reset();
+        /* Ack sticky bits */
+        writel(readl(REG_CFG(ICPU_MEMCTRL_STAT)), REG_CFG(ICPU_MEMCTRL_STAT));
+        byte = ((volatile u8 *) MSCC_DDR_TO)[bytelane + (i * 4)];
+        if (readl(REG_CFG(ICPU_MEMCTRL_STAT)) &
+            (ICPU_MEMCTRL_STAT_RDATA_MASKED|
+             ICPU_MEMCTRL_STAT_RDATA_DUMMY)) {
+		/* Noise on the line */
+            goto read_error;
+        }
+        /* Bail out when we see first mismatch */
+        if (byte != training_data[i]) {
+      read_error:
+            return DDR_TRAIN_OK;
+        }
+    }
+    /* All data compares OK, increase DQS and retry */
+    if (!incr_dly(bytelane))
+        return DDR_TRAIN_ERROR;
+
+    return DDR_TRAIN_CONTINUE;
+}
+
+static inline int hal_vcoreiii_train_bytelane(u32 bytelane)
+{
+    register int res;
+    register u32 dqs_s;
+
+    set_dly(bytelane, 0);    // Start training at DQS=0
+    while ((res = look_for(bytelane)) == DDR_TRAIN_CONTINUE)
+        ;
+    if(res != DDR_TRAIN_OK)
+        return res;
+
+    dqs_s = readl(REG_CFG(ICPU_MEMCTRL_DQS_DLY(bytelane)));
+    while ((res = look_past(bytelane)) == DDR_TRAIN_CONTINUE)
+        ;
+    if(res != DDR_TRAIN_OK)
+        return res;
+    /* Reset FIFO - for good measure */
+    memphy_soft_reset();
+    /* Adjust to center [dqs_s;cur] */
+    center_dly(bytelane, dqs_s);
+    return DDR_TRAIN_OK;
+}
+/* This algorithm is converted from the TCL training algorithm used
+ * during silicon simulation.
+ * NB: Assumes inlining as no stack is available!
+ */
+static inline int hal_vcoreiii_init_dqs(void)
+{
+#define MAX_DQS 32
+    register u32 i, j;
+    for (i = 0; i < MAX_DQS; i++) {
+        set_dly(0, i);    // Byte-lane 0
+        for (j = 0; j < MAX_DQS; j++) {
+            register  u32 __attribute__ ((unused)) byte;
+            set_dly(1, j);    // Byte-lane 1
+            /* Reset FIFO in case any previous access failed */
+            memphy_soft_reset();
+            writel(readl(REG_CFG(ICPU_MEMCTRL_STAT)),
+		   REG_CFG(ICPU_MEMCTRL_STAT));
+            byte = ((volatile u8 *) MSCC_DDR_TO)[0];
+            byte = ((volatile u8 *) MSCC_DDR_TO)[1];
+            if (readl(REG_CFG(ICPU_MEMCTRL_STAT)) &
+                (ICPU_MEMCTRL_STAT_RDATA_MASKED|
+                 ICPU_MEMCTRL_STAT_RDATA_DUMMY)) {
+            } else {
+                return 0;
+            }
+        }
+    }
+    return -1;
+}
+
+
+static inline int dram_check(void)
+{
+#define DDR ((volatile u32 *) MSCC_DDR_TO)
+        register u32 i;
+
+        for (i = 0; i < 8; i++) {
+                DDR[i] = ~i;
+                if (DDR[i] != ~i) {
+                        return 1;
+                }
+        }
+        return 0;
+}
+#else /* Luton */
+
+static inline void sleep_100ns(u32 val)
+{
+}
+static inline void hal_vcoreiii_ddr_reset_assert(void)
+{
+}
+static inline void hal_vcoreiii_ddr_reset_release(void)
+{
+}
+static inline void hal_vcoreiii_ddr_failed(void)
+{
+	register u32 memphy_cfg = readl(REG_CFG(ICPU_MEMPHY_CFG));
+
+	/* Do a fifo reset and start over */
+	writel( memphy_cfg | ICPU_MEMPHY_CFG_PHY_FIFO_RST,
+		       REG_CFG(ICPU_MEMPHY_CFG));
+	writel( memphy_cfg & ~ICPU_MEMPHY_CFG_PHY_FIFO_RST,
+		       REG_CFG(ICPU_MEMPHY_CFG));
+	writel( memphy_cfg | ICPU_MEMPHY_CFG_PHY_FIFO_RST,
+		       REG_CFG(ICPU_MEMPHY_CFG));
+}
+
+static inline void hal_vcoreiii_ddr_verified(void){}
+
+static inline int look_for(u32 data)
+{
+	register u32 byte = ((volatile u8 *) MSCC_DDR_TO)[0];
+
+	if (data != byte)  {
+		if (!incr_dly(0))
+			return DDR_TRAIN_ERROR;
+		return DDR_TRAIN_CONTINUE;
+	}
+
+	return DDR_TRAIN_OK;
+}
+
+/* This algorithm is converted from the TCL training algorithm used
+ * during silicon simulation.
+ * NB: Assumes inlining as no stack is available!
+ */
+static inline int hal_vcoreiii_train_bytelane(u32 bytelane)
+{
+    register int res;
+
+    set_dly(bytelane, 0);    // Start training at DQS=0
+    while ((res = look_for(0xff)) == DDR_TRAIN_CONTINUE)
+        ;
+    if(res != DDR_TRAIN_OK)
+        return res;
+
+    set_dly(bytelane, 0);    // Start training@DQS=0
+    while ((res = look_for(0x00)) == DDR_TRAIN_CONTINUE)
+        ;
+
+    if(res != DDR_TRAIN_OK)
+        return res;
+
+    adjust_dly(-3);
+
+    return DDR_TRAIN_OK;
+}
+
+static inline int hal_vcoreiii_init_dqs(void)
+{
+	return 0;
+}
+
+static inline int dram_check(void)
+{
+#define DDR ((volatile u32 *) MSCC_DDR_TO)
+        register u32 i;
+
+        for (i = 0; i < 8; i++) {
+                DDR[i] = ~i;
+                if (DDR[i] != ~i) {
+                        return 1;
+                }
+        }
+
+        return 0;
+}
+#endif
+
+/* NB: Called *early* to init memory controller -
+ * assumes inlining as no stack is available! */
+static inline void hal_vcoreiii_init_memctl(void)
+{
+        /* Ensure DDR is in reset */
+        hal_vcoreiii_ddr_reset_assert();
+
+        /* Wait maybe not needed, but ... */
+        PAUSE();
+
+        /* Drop sys ctl memory controller forced reset */
+        writel(readl(REG_CFG(ICPU_RESET)) & ~ICPU_RESET_MEM_RST_FORCE, REG_CFG(ICPU_RESET));
+        PAUSE();
+
+        /* Drop Reset, enable SSTL */
+        writel(ICPU_MEMPHY_CFG_PHY_SSTL_ENA, REG_CFG(ICPU_MEMPHY_CFG));
+        PAUSE();
+
+        /* Start the automatic SSTL output and ODT drive-strength calibration */
+        writel(/* ODT */
+              ICPU_MEMPHY_ZCAL_ZCAL_PROG_ODT(MIPS_VCOREIII_MEMORY_SSTL_ODT) |
+              /* drive strength */
+              ICPU_MEMPHY_ZCAL_ZCAL_PROG(MIPS_VCOREIII_MEMORY_SSTL_DRIVE)   |
+              /* Start calibration process */
+              ICPU_MEMPHY_ZCAL_ZCAL_ENA, REG_CFG(ICPU_MEMPHY_ZCAL));
+
+        while(readl(REG_CFG(ICPU_MEMPHY_ZCAL)) & ICPU_MEMPHY_ZCAL_ZCAL_ENA)
+                ;                       /* Wait for ZCAL to clear */
+#ifdef CONFIG_SOC_OCELOT
+        /* Check no ZCAL_ERR */
+        if (readl(REG_CFG(ICPU_MEMPHY_ZCAL_STAT)) & ICPU_MEMPHY_ZCAL_STAT_ZCAL_ERR) {
+                hal_vcoreiii_ddr_failed();
+        }
+#endif
+        /* Drive CL, CK, ODT */
+        writel(readl(REG_CFG(ICPU_MEMPHY_CFG)) |
+	       ICPU_MEMPHY_CFG_PHY_ODT_OE |
+	       ICPU_MEMPHY_CFG_PHY_CK_OE |
+	       ICPU_MEMPHY_CFG_PHY_CL_OE, REG_CFG(ICPU_MEMPHY_CFG));
+
+        /* Initialize memory controller */
+        writel(MSCC_MEMPARM_MEMCFG, REG_CFG(ICPU_MEMCTRL_CFG));
+        writel(MSCC_MEMPARM_PERIOD, REG_CFG(ICPU_MEMCTRL_REF_PERIOD));
+
+        writel(MSCC_MEMPARM_TIMING0, REG_CFG(ICPU_MEMCTRL_TIMING0));
+        writel(MSCC_MEMPARM_TIMING1, REG_CFG(ICPU_MEMCTRL_TIMING1));
+        writel(MSCC_MEMPARM_TIMING2, REG_CFG(ICPU_MEMCTRL_TIMING2));
+        writel(MSCC_MEMPARM_TIMING3, REG_CFG(ICPU_MEMCTRL_TIMING3));
+        writel(MSCC_MEMPARM_MR0, REG_CFG(ICPU_MEMCTRL_MR0_VAL));
+        writel(MSCC_MEMPARM_MR1, REG_CFG(ICPU_MEMCTRL_MR1_VAL));
+        writel(MSCC_MEMPARM_MR2, REG_CFG(ICPU_MEMCTRL_MR2_VAL));
+        writel(MSCC_MEMPARM_MR3, REG_CFG(ICPU_MEMCTRL_MR3_VAL));
+
+#ifdef CONFIG_SOC_OCELOT
+        /* Termination setup - enable ODT */
+        writel(ICPU_MEMCTRL_TERMRES_CTRL_LOCAL_ODT_RD_ENA |
+               /* Assert ODT0 for any write */
+               ICPU_MEMCTRL_TERMRES_CTRL_ODT_WR_ENA(3),
+	       REG_CFG(ICPU_MEMCTRL_TERMRES_CTRL));
+
+        /* Release Reset from DDR */
+        hal_vcoreiii_ddr_reset_release();
+
+        writel(readl(REG_CFG(ICPU_GPR(7))) + 1, REG_CFG(ICPU_GPR(7)));
+#else /* Luton */
+	/* Termination setup - disable ODT */
+        writel(0, REG_CFG(ICPU_MEMCTRL_TERMRES_CTRL));
+
+#endif
+}
+
+static void inline hal_vcoreiii_wait_memctl(void)
+{
+        /* Now, rip it! */
+        writel(ICPU_MEMCTRL_CTRL_INITIALIZE, REG_CFG(ICPU_MEMCTRL_CTRL));
+
+        while(!(readl(REG_CFG(ICPU_MEMCTRL_STAT)) & ICPU_MEMCTRL_STAT_INIT_DONE))
+                ;
+
+        /* Settle...? */
+        sleep_100ns(10000);
+#ifdef CONFIG_SOC_OCELOT
+        /* Establish data contents in DDR RAM for training */
+        ((volatile u32 *)MSCC_DDR_TO)[0] = 0xcacafefe;
+        ((volatile u32 *)MSCC_DDR_TO)[1] = 0x22221111;
+        ((volatile u32 *)MSCC_DDR_TO)[2] = 0x44443333;
+        ((volatile u32 *)MSCC_DDR_TO)[3] = 0x66665555;
+        ((volatile u32 *)MSCC_DDR_TO)[4] = 0x88887777;
+        ((volatile u32 *)MSCC_DDR_TO)[5] = 0xaaaa9999;
+        ((volatile u32 *)MSCC_DDR_TO)[6] = 0xccccbbbb;
+        ((volatile u32 *)MSCC_DDR_TO)[7] = 0xeeeedddd;
+#else
+	((volatile u32 *)MSCC_DDR_TO)[0] = 0xff;
+#endif
+}
+#endif /* __ASM_MACH_DDR_H */
diff --git a/arch/mips/mach-mscc/include/mach/luton/luton.h b/arch/mips/mach-mscc/include/mach/luton/luton.h
new file mode 100644
index 0000000000..4f761b1bb7
--- /dev/null
+++ b/arch/mips/mach-mscc/include/mach/luton/luton.h
@@ -0,0 +1,37 @@
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+/*
+ * Microsemi Ocelot Switch driver
+ *
+ * Copyright (c) 2018 Microsemi Corporation
+ */
+
+#ifndef _MSCC_OCELOT_H_
+#define _MSCC_OCELOT_H_
+
+#include <linux/bitops.h>
+#include <dm.h>
+
+/*
+ * Target offset base(s)
+ */
+#define MSCC_IO_ORIGIN1_OFFSET 0x60000000
+#define MSCC_IO_ORIGIN1_SIZE   0x01000000
+#define MSCC_IO_ORIGIN2_OFFSET 0x70000000
+#define MSCC_IO_ORIGIN2_SIZE   0x00200000
+#ifndef MSCC_IO_OFFSET1
+#define MSCC_IO_OFFSET1(offset) (MSCC_IO_ORIGIN1_OFFSET + offset)
+#endif
+#ifndef MSCC_IO_OFFSET2
+#define MSCC_IO_OFFSET2(offset) (MSCC_IO_ORIGIN2_OFFSET + offset)
+#endif
+#define BASE_CFG        0x70000000
+#define BASE_UART       0x70100000
+#define BASE_DEVCPU_GCB 0x60070000
+#define BASE_MACRO      0x600a0000
+
+#define REG_OFFSET(t, o) ((volatile unsigned long *)(t + (o)))
+#define REG_CFG(x) REG_OFFSET(BASE_CFG, x)
+#define REG_GCB(x) REG_OFFSET(BASE_DEVCPU_GCB, x)
+#define REG_MACRO(x) REG_OFFSET(BASE_MACRO, x)
+
+#endif
diff --git a/arch/mips/mach-mscc/include/mach/luton/luton_devcpu_gcb.h b/arch/mips/mach-mscc/include/mach/luton/luton_devcpu_gcb.h
new file mode 100644
index 0000000000..0d80c8a534
--- /dev/null
+++ b/arch/mips/mach-mscc/include/mach/luton/luton_devcpu_gcb.h
@@ -0,0 +1,16 @@
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+/*
+ * Copyright (c) 2018 Microsemi Corporation
+ */
+
+#ifndef _MSCC_OCELOT_DEVCPU_GCB_H_
+#define _MSCC_OCELOT_DEVCPU_GCB_H_
+
+#define PERF_GPR                                          0x4
+
+#define PERF_SOFT_RST                                     0x90
+
+#define PERF_SOFT_RST_SOFT_SWC_RST                        BIT(1)
+#define PERF_SOFT_RST_SOFT_CHIP_RST                       BIT(0)
+
+#endif
diff --git a/arch/mips/mach-mscc/include/mach/luton/luton_icpu_cfg.h b/arch/mips/mach-mscc/include/mach/luton/luton_icpu_cfg.h
new file mode 100644
index 0000000000..b0b09f4d21
--- /dev/null
+++ b/arch/mips/mach-mscc/include/mach/luton/luton_icpu_cfg.h
@@ -0,0 +1,247 @@
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+/*
+ * Copyright (c) 2018 Microsemi Corporation
+ */
+
+#ifndef _MSCC_OCELOT_ICPU_CFG_H_
+#define _MSCC_OCELOT_ICPU_CFG_H_
+
+#define ICPU_GPR(x) (0x4 * (x))
+#define ICPU_GPR_RSZ                                      0x4
+
+#define ICPU_RESET                                        0x20
+
+#define ICPU_RESET_CORE_RST_CPU_ONLY                      BIT(3)
+#define ICPU_RESET_CORE_RST_PROTECT                       BIT(2)
+#define ICPU_RESET_CORE_RST_FORCE                         BIT(1)
+#define ICPU_RESET_MEM_RST_FORCE                          BIT(0)
+
+#define ICPU_GENERAL_CTRL                                 0x24
+
+#define ICPU_GENERAL_CTRL_CPU_BUSIF_SLEEP_DIS             BIT(14)
+#define ICPU_GENERAL_CTRL_CPU_BUSIF_WERR_ENA              BIT(13)
+#define ICPU_GENERAL_CTRL_CPU_8051_IROM_ENA               BIT(12)
+#define ICPU_GENERAL_CTRL_CPU_MIPS_DIS                    BIT(11)
+#define ICPU_GENERAL_CTRL_IF_MIIM_SLV_ADDR_SEL            BIT(10)
+#define ICPU_GENERAL_CTRL_IF_MIIM_SLV_ENA                 BIT(9)
+#define ICPU_GENERAL_CTRL_IF_PI_SLV_DONEPOL               BIT(8)
+#define ICPU_GENERAL_CTRL_IF_PI_MST_ENA                   BIT(7)
+#define ICPU_GENERAL_CTRL_IF_PI_SLV_ENA                   BIT(6)
+#define ICPU_GENERAL_CTRL_IF_SI_OWNER(x)                  (((x) << 4) & GENMASK(5, 4))
+#define ICPU_GENERAL_CTRL_IF_SI_OWNER_M                   GENMASK(5, 4)
+#define ICPU_GENERAL_CTRL_IF_SI_OWNER_X(x)                (((x) & GENMASK(5, 4)) >> 4)
+#define ICPU_GENERAL_CTRL_SSI_MST_CONTENTION              BIT(3)
+#define ICPU_GENERAL_CTRL_CPU_BE_ENA                      BIT(2)
+#define ICPU_GENERAL_CTRL_CPU_DIS                         BIT(1)
+#define ICPU_GENERAL_CTRL_BOOT_MODE_ENA                   BIT(0)
+
+#define ICPU_SPI_MST_CFG                                  0x3c
+
+#define ICPU_SPI_MST_CFG_A32B_ENA                         BIT(11)
+#define ICPU_SPI_MST_CFG_FAST_READ_ENA                    BIT(10)
+#define ICPU_SPI_MST_CFG_CS_DESELECT_TIME(x)              (((x) << 5) & GENMASK(9, 5))
+#define ICPU_SPI_MST_CFG_CS_DESELECT_TIME_M               GENMASK(9, 5)
+#define ICPU_SPI_MST_CFG_CS_DESELECT_TIME_X(x)            (((x) & GENMASK(9, 5)) >> 5)
+#define ICPU_SPI_MST_CFG_CLK_DIV(x)                       ((x) & GENMASK(4, 0))
+#define ICPU_SPI_MST_CFG_CLK_DIV_M                        GENMASK(4, 0)
+
+
+#define ICPU_SW_MODE                                      0x64
+
+#define ICPU_SW_MODE_SW_PIN_CTRL_MODE                     BIT(13)
+#define ICPU_SW_MODE_SW_SPI_SCK                           BIT(12)
+#define ICPU_SW_MODE_SW_SPI_SCK_OE                        BIT(11)
+#define ICPU_SW_MODE_SW_SPI_SDO                           BIT(10)
+#define ICPU_SW_MODE_SW_SPI_SDO_OE                        BIT(9)
+#define ICPU_SW_MODE_SW_SPI_CS(x)                         (((x) << 5) & GENMASK(8, 5))
+#define ICPU_SW_MODE_SW_SPI_CS_M                          GENMASK(8, 5)
+#define ICPU_SW_MODE_SW_SPI_CS_X(x)                       (((x) & GENMASK(8, 5)) >> 5)
+#define ICPU_SW_MODE_SW_SPI_CS_OE(x)                      (((x) << 1) & GENMASK(4, 1))
+#define ICPU_SW_MODE_SW_SPI_CS_OE_M                       GENMASK(4, 1)
+#define ICPU_SW_MODE_SW_SPI_CS_OE_X(x)                    (((x) & GENMASK(4, 1)) >> 1)
+#define ICPU_SW_MODE_SW_SPI_SDI                           BIT(0)
+
+#define ICPU_INTR_ENA                                     0x88
+
+#define ICPU_INTR_IRQ0_ENA                                0x98
+#define ICPU_INTR_IRQ0_ENA_IRQ0_ENA                       BIT(0)
+
+#define ICPU_MEMCTRL_CTRL                                 0x234
+
+#define ICPU_MEMCTRL_CTRL_PWR_DOWN                        BIT(3)
+#define ICPU_MEMCTRL_CTRL_MDSET                           BIT(2)
+#define ICPU_MEMCTRL_CTRL_STALL_REF_ENA                   BIT(1)
+#define ICPU_MEMCTRL_CTRL_INITIALIZE                      BIT(0)
+
+#define ICPU_MEMCTRL_CFG                                  0x238
+
+#define ICPU_MEMCTRL_CFG_DDR_512MBYTE_PLUS                BIT(16)
+#define ICPU_MEMCTRL_CFG_DDR_ECC_ERR_ENA                  BIT(15)
+#define ICPU_MEMCTRL_CFG_DDR_ECC_COR_ENA                  BIT(14)
+#define ICPU_MEMCTRL_CFG_DDR_ECC_ENA                      BIT(13)
+#define ICPU_MEMCTRL_CFG_DDR_WIDTH                        BIT(12)
+#define ICPU_MEMCTRL_CFG_DDR_MODE                         BIT(11)
+#define ICPU_MEMCTRL_CFG_BURST_SIZE                       BIT(10)
+#define ICPU_MEMCTRL_CFG_BURST_LEN                        BIT(9)
+#define ICPU_MEMCTRL_CFG_BANK_CNT                         BIT(8)
+#define ICPU_MEMCTRL_CFG_MSB_ROW_ADDR(x)                  (((x) << 4) & GENMASK(7, 4))
+#define ICPU_MEMCTRL_CFG_MSB_ROW_ADDR_M                   GENMASK(7, 4)
+#define ICPU_MEMCTRL_CFG_MSB_ROW_ADDR_X(x)                (((x) & GENMASK(7, 4)) >> 4)
+#define ICPU_MEMCTRL_CFG_MSB_COL_ADDR(x)                  ((x) & GENMASK(3, 0))
+#define ICPU_MEMCTRL_CFG_MSB_COL_ADDR_M                   GENMASK(3, 0)
+
+#define ICPU_MEMCTRL_STAT                                 0x23C
+
+#define ICPU_MEMCTRL_STAT_RDATA_MASKED                    BIT(5)
+#define ICPU_MEMCTRL_STAT_RDATA_DUMMY                     BIT(4)
+#define ICPU_MEMCTRL_STAT_RDATA_ECC_ERR                   BIT(3)
+#define ICPU_MEMCTRL_STAT_RDATA_ECC_COR                   BIT(2)
+#define ICPU_MEMCTRL_STAT_PWR_DOWN_ACK                    BIT(1)
+#define ICPU_MEMCTRL_STAT_INIT_DONE                       BIT(0)
+
+#define ICPU_MEMCTRL_REF_PERIOD                           0x240
+
+#define ICPU_MEMCTRL_REF_PERIOD_MAX_PEND_REF(x)           (((x) << 16) & GENMASK(19, 16))
+#define ICPU_MEMCTRL_REF_PERIOD_MAX_PEND_REF_M            GENMASK(19, 16)
+#define ICPU_MEMCTRL_REF_PERIOD_MAX_PEND_REF_X(x)         (((x) & GENMASK(19, 16)) >> 16)
+#define ICPU_MEMCTRL_REF_PERIOD_REF_PERIOD(x)             ((x) & GENMASK(15, 0))
+#define ICPU_MEMCTRL_REF_PERIOD_REF_PERIOD_M              GENMASK(15, 0)
+
+#define ICPU_MEMCTRL_TIMING0                              0x248
+
+#define ICPU_MEMCTRL_TIMING0_RD_TO_WR_DLY(x)              (((x) << 28) & GENMASK(31, 28))
+#define ICPU_MEMCTRL_TIMING0_RD_TO_WR_DLY_M               GENMASK(31, 28)
+#define ICPU_MEMCTRL_TIMING0_RD_TO_WR_DLY_X(x)            (((x) & GENMASK(31, 28)) >> 28)
+#define ICPU_MEMCTRL_TIMING0_WR_CS_CHANGE_DLY(x)          (((x) << 24) & GENMASK(27, 24))
+#define ICPU_MEMCTRL_TIMING0_WR_CS_CHANGE_DLY_M           GENMASK(27, 24)
+#define ICPU_MEMCTRL_TIMING0_WR_CS_CHANGE_DLY_X(x)        (((x) & GENMASK(27, 24)) >> 24)
+#define ICPU_MEMCTRL_TIMING0_RD_CS_CHANGE_DLY(x)          (((x) << 20) & GENMASK(23, 20))
+#define ICPU_MEMCTRL_TIMING0_RD_CS_CHANGE_DLY_M           GENMASK(23, 20)
+#define ICPU_MEMCTRL_TIMING0_RD_CS_CHANGE_DLY_X(x)        (((x) & GENMASK(23, 20)) >> 20)
+#define ICPU_MEMCTRL_TIMING0_RAS_TO_PRECH_DLY(x)          (((x) << 16) & GENMASK(19, 16))
+#define ICPU_MEMCTRL_TIMING0_RAS_TO_PRECH_DLY_M           GENMASK(19, 16)
+#define ICPU_MEMCTRL_TIMING0_RAS_TO_PRECH_DLY_X(x)        (((x) & GENMASK(19, 16)) >> 16)
+#define ICPU_MEMCTRL_TIMING0_WR_TO_PRECH_DLY(x)           (((x) << 12) & GENMASK(15, 12))
+#define ICPU_MEMCTRL_TIMING0_WR_TO_PRECH_DLY_M            GENMASK(15, 12)
+#define ICPU_MEMCTRL_TIMING0_WR_TO_PRECH_DLY_X(x)         (((x) & GENMASK(15, 12)) >> 12)
+#define ICPU_MEMCTRL_TIMING0_RD_TO_PRECH_DLY(x)           (((x) << 8) & GENMASK(11, 8))
+#define ICPU_MEMCTRL_TIMING0_RD_TO_PRECH_DLY_M            GENMASK(11, 8)
+#define ICPU_MEMCTRL_TIMING0_RD_TO_PRECH_DLY_X(x)         (((x) & GENMASK(11, 8)) >> 8)
+#define ICPU_MEMCTRL_TIMING0_WR_DATA_XFR_DLY(x)           (((x) << 4) & GENMASK(7, 4))
+#define ICPU_MEMCTRL_TIMING0_WR_DATA_XFR_DLY_M            GENMASK(7, 4)
+#define ICPU_MEMCTRL_TIMING0_WR_DATA_XFR_DLY_X(x)         (((x) & GENMASK(7, 4)) >> 4)
+#define ICPU_MEMCTRL_TIMING0_RD_DATA_XFR_DLY(x)           ((x) & GENMASK(3, 0))
+#define ICPU_MEMCTRL_TIMING0_RD_DATA_XFR_DLY_M            GENMASK(3, 0)
+
+#define ICPU_MEMCTRL_TIMING1                              0x24c
+
+#define ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_SAME_BANK_DLY(x)  (((x) << 24) & GENMASK(31, 24))
+#define ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_SAME_BANK_DLY_M   GENMASK(31, 24)
+#define ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_SAME_BANK_DLY_X(x) (((x) & GENMASK(31, 24)) >> 24)
+#define ICPU_MEMCTRL_TIMING1_BANK8_FAW_DLY(x)             (((x) << 16) & GENMASK(23, 16))
+#define ICPU_MEMCTRL_TIMING1_BANK8_FAW_DLY_M              GENMASK(23, 16)
+#define ICPU_MEMCTRL_TIMING1_BANK8_FAW_DLY_X(x)           (((x) & GENMASK(23, 16)) >> 16)
+#define ICPU_MEMCTRL_TIMING1_PRECH_TO_RAS_DLY(x)          (((x) << 12) & GENMASK(15, 12))
+#define ICPU_MEMCTRL_TIMING1_PRECH_TO_RAS_DLY_M           GENMASK(15, 12)
+#define ICPU_MEMCTRL_TIMING1_PRECH_TO_RAS_DLY_X(x)        (((x) & GENMASK(15, 12)) >> 12)
+#define ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_DLY(x)            (((x) << 8) & GENMASK(11, 8))
+#define ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_DLY_M             GENMASK(11, 8)
+#define ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_DLY_X(x)          (((x) & GENMASK(11, 8)) >> 8)
+#define ICPU_MEMCTRL_TIMING1_RAS_TO_CAS_DLY(x)            (((x) << 4) & GENMASK(7, 4))
+#define ICPU_MEMCTRL_TIMING1_RAS_TO_CAS_DLY_M             GENMASK(7, 4)
+#define ICPU_MEMCTRL_TIMING1_RAS_TO_CAS_DLY_X(x)          (((x) & GENMASK(7, 4)) >> 4)
+#define ICPU_MEMCTRL_TIMING1_WR_TO_RD_DLY(x)              ((x) & GENMASK(3, 0))
+#define ICPU_MEMCTRL_TIMING1_WR_TO_RD_DLY_M               GENMASK(3, 0)
+
+#define ICPU_MEMCTRL_TIMING2                              0x250
+
+#define ICPU_MEMCTRL_TIMING2_PRECH_ALL_DLY(x)             (((x) << 28) & GENMASK(31, 28))
+#define ICPU_MEMCTRL_TIMING2_PRECH_ALL_DLY_M              GENMASK(31, 28)
+#define ICPU_MEMCTRL_TIMING2_PRECH_ALL_DLY_X(x)           (((x) & GENMASK(31, 28)) >> 28)
+#define ICPU_MEMCTRL_TIMING2_MDSET_DLY(x)                 (((x) << 24) & GENMASK(27, 24))
+#define ICPU_MEMCTRL_TIMING2_MDSET_DLY_M                  GENMASK(27, 24)
+#define ICPU_MEMCTRL_TIMING2_MDSET_DLY_X(x)               (((x) & GENMASK(27, 24)) >> 24)
+#define ICPU_MEMCTRL_TIMING2_REF_DLY(x)                   (((x) << 16) & GENMASK(23, 16))
+#define ICPU_MEMCTRL_TIMING2_REF_DLY_M                    GENMASK(23, 16)
+#define ICPU_MEMCTRL_TIMING2_REF_DLY_X(x)                 (((x) & GENMASK(23, 16)) >> 16)
+#define ICPU_MEMCTRL_TIMING2_FOUR_HUNDRED_NS_DLY(x)       ((x) & GENMASK(15, 0))
+#define ICPU_MEMCTRL_TIMING2_FOUR_HUNDRED_NS_DLY_M        GENMASK(15, 0)
+
+#define ICPU_MEMCTRL_TIMING3                              0x254
+
+#define ICPU_MEMCTRL_TIMING3_RMW_DLY(x)                   (((x) << 16) & GENMASK(19, 16))
+#define ICPU_MEMCTRL_TIMING3_RMW_DLY_M                    GENMASK(19, 16)
+#define ICPU_MEMCTRL_TIMING3_RMW_DLY_X(x)                 (((x) & GENMASK(19, 16)) >> 16)
+#define ICPU_MEMCTRL_TIMING3_ODT_RD_DLY(x)                (((x) << 12) & GENMASK(15, 12))
+#define ICPU_MEMCTRL_TIMING3_ODT_RD_DLY_M                 GENMASK(15, 12)
+#define ICPU_MEMCTRL_TIMING3_ODT_RD_DLY_X(x)              (((x) & GENMASK(15, 12)) >> 12)
+#define ICPU_MEMCTRL_TIMING3_ODT_WR_DLY(x)                (((x) << 8) & GENMASK(11, 8))
+#define ICPU_MEMCTRL_TIMING3_ODT_WR_DLY_M                 GENMASK(11, 8)
+#define ICPU_MEMCTRL_TIMING3_ODT_WR_DLY_X(x)              (((x) & GENMASK(11, 8)) >> 8)
+#define ICPU_MEMCTRL_TIMING3_LOCAL_ODT_RD_DLY(x)          (((x) << 4) & GENMASK(7, 4))
+#define ICPU_MEMCTRL_TIMING3_LOCAL_ODT_RD_DLY_M           GENMASK(7, 4)
+#define ICPU_MEMCTRL_TIMING3_LOCAL_ODT_RD_DLY_X(x)        (((x) & GENMASK(7, 4)) >> 4)
+#define ICPU_MEMCTRL_TIMING3_WR_TO_RD_CS_CHANGE_DLY(x)    ((x) & GENMASK(3, 0))
+#define ICPU_MEMCTRL_TIMING3_WR_TO_RD_CS_CHANGE_DLY_M     GENMASK(3, 0)
+
+#define ICPU_MEMCTRL_MR0_VAL                              0x258
+
+#define ICPU_MEMCTRL_MR1_VAL                              0x25c
+
+#define ICPU_MEMCTRL_MR2_VAL                              0x260
+
+#define ICPU_MEMCTRL_MR3_VAL                              0x264
+
+#define ICPU_MEMCTRL_TERMRES_CTRL                         0x268
+
+#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_RD_EXT              BIT(11)
+#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_RD_ENA(x)           (((x) << 7) & GENMASK(10, 7))
+#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_RD_ENA_M            GENMASK(10, 7)
+#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_RD_ENA_X(x)         (((x) & GENMASK(10, 7)) >> 7)
+#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_WR_EXT              BIT(6)
+#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_WR_ENA(x)           (((x) << 2) & GENMASK(5, 2))
+#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_WR_ENA_M            GENMASK(5, 2)
+#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_WR_ENA_X(x)         (((x) & GENMASK(5, 2)) >> 2)
+#define ICPU_MEMCTRL_TERMRES_CTRL_LOCAL_ODT_RD_EXT        BIT(1)
+#define ICPU_MEMCTRL_TERMRES_CTRL_LOCAL_ODT_RD_ENA        BIT(0)
+
+#define ICPU_MEMCTRL_DQS_DLY(x) (0x270)
+
+#define ICPU_MEMCTRL_DQS_DLY_TRAIN_DQ_ENA                 BIT(11)
+#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_TRM1(x)              (((x) << 8) & GENMASK(10, 8))
+#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_TRM1_M               GENMASK(10, 8)
+#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_TRM1_X(x)            (((x) & GENMASK(10, 8)) >> 8)
+#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_TRM0(x)              (((x) << 5) & GENMASK(7, 5))
+#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_TRM0_M               GENMASK(7, 5)
+#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_TRM0_X(x)            (((x) & GENMASK(7, 5)) >> 5)
+#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY(x)                   ((x) & GENMASK(4, 0))
+#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_M                    GENMASK(4, 0)
+
+#define ICPU_MEMPHY_CFG                                   0x278
+
+#define ICPU_MEMPHY_CFG_PHY_FLUSH_DIS                     BIT(10)
+#define ICPU_MEMPHY_CFG_PHY_RD_ADJ_DIS                    BIT(9)
+#define ICPU_MEMPHY_CFG_PHY_DQS_EXT                       BIT(8)
+#define ICPU_MEMPHY_CFG_PHY_FIFO_RST                      BIT(7)
+#define ICPU_MEMPHY_CFG_PHY_DLL_BL_RST                    BIT(6)
+#define ICPU_MEMPHY_CFG_PHY_DLL_CL_RST                    BIT(5)
+#define ICPU_MEMPHY_CFG_PHY_ODT_OE                        BIT(4)
+#define ICPU_MEMPHY_CFG_PHY_CK_OE                         BIT(3)
+#define ICPU_MEMPHY_CFG_PHY_CL_OE                         BIT(2)
+#define ICPU_MEMPHY_CFG_PHY_SSTL_ENA                      BIT(1)
+#define ICPU_MEMPHY_CFG_PHY_RST                           BIT(0)
+#define ICPU_MEMPHY_DQ_DLY_TRM                            0x180
+#define ICPU_MEMPHY_DQ_DLY_TRM_RSZ                        0x4
+
+#define ICPU_MEMPHY_ZCAL                                  0x294
+
+#define ICPU_MEMPHY_ZCAL_ZCAL_CLK_SEL                     BIT(9)
+#define ICPU_MEMPHY_ZCAL_ZCAL_PROG_ODT(x)                 (((x) << 5) & GENMASK(8, 5))
+#define ICPU_MEMPHY_ZCAL_ZCAL_PROG_ODT_M                  GENMASK(8, 5)
+#define ICPU_MEMPHY_ZCAL_ZCAL_PROG_ODT_X(x)               (((x) & GENMASK(8, 5)) >> 5)
+#define ICPU_MEMPHY_ZCAL_ZCAL_PROG(x)                     (((x) << 1) & GENMASK(4, 1))
+#define ICPU_MEMPHY_ZCAL_ZCAL_PROG_M                      GENMASK(4, 1)
+#define ICPU_MEMPHY_ZCAL_ZCAL_PROG_X(x)                   (((x) & GENMASK(4, 1)) >> 1)
+#define ICPU_MEMPHY_ZCAL_ZCAL_ENA                         BIT(0)
+
+#endif
diff --git a/arch/mips/mach-mscc/include/mach/ocelot/ocelot.h b/arch/mips/mach-mscc/include/mach/ocelot/ocelot.h
new file mode 100644
index 0000000000..698e6808a4
--- /dev/null
+++ b/arch/mips/mach-mscc/include/mach/ocelot/ocelot.h
@@ -0,0 +1,35 @@
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+/*
+ * Microsemi Ocelot Switch driver
+ *
+ * Copyright (c) 2018 Microsemi Corporation
+ */
+
+#ifndef _MSCC_OCELOT_H_
+#define _MSCC_OCELOT_H_
+
+#include <linux/bitops.h>
+#include <dm.h>
+
+/*
+ * Target offset base(s)
+ */
+#define MSCC_IO_ORIGIN1_OFFSET 0x70000000
+#define MSCC_IO_ORIGIN1_SIZE   0x00200000
+#define MSCC_IO_ORIGIN2_OFFSET 0x71000000
+#define MSCC_IO_ORIGIN2_SIZE   0x01000000
+#ifndef MSCC_IO_OFFSET1
+#define MSCC_IO_OFFSET1(offset) (MSCC_IO_ORIGIN1_OFFSET + offset)
+#endif
+#ifndef MSCC_IO_OFFSET2
+#define MSCC_IO_OFFSET2(offset) (MSCC_IO_ORIGIN2_OFFSET + offset)
+#endif
+#define BASE_CFG        0x70000000
+#define BASE_UART       0x70100000
+#define BASE_DEVCPU_GCB 0x71070000
+
+#define REG_OFFSET(t, o) ((volatile unsigned long *)(t + (o)))
+#define REG_CFG(x) REG_OFFSET(BASE_CFG, x)
+#define REG_GCB(x) REG_OFFSET(BASE_DEVCPU_GCB, x)
+
+#endif
diff --git a/arch/mips/mach-mscc/include/mach/ocelot/ocelot_devcpu_gcb.h b/arch/mips/mach-mscc/include/mach/ocelot/ocelot_devcpu_gcb.h
new file mode 100644
index 0000000000..4bcd0b3c8c
--- /dev/null
+++ b/arch/mips/mach-mscc/include/mach/ocelot/ocelot_devcpu_gcb.h
@@ -0,0 +1,49 @@
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+/*
+ * Copyright (c) 2018 Microsemi Corporation
+ */
+
+#ifndef _MSCC_OCELOT_DEVCPU_GCB_H_
+#define _MSCC_OCELOT_DEVCPU_GCB_H_
+
+
+#define PERF_GPR                                          0x4
+
+#define PERF_SOFT_RST                                     0x8
+
+#define PERF_SOFT_RST_SOFT_NON_CFG_RST                    BIT(2)
+#define PERF_SOFT_RST_SOFT_SWC_RST                        BIT(1)
+#define PERF_SOFT_RST_SOFT_CHIP_RST                       BIT(0)
+
+#define PERF_FEA_STAT                                     0x14
+
+#define PERF_FEA_DIS                                      0x18
+
+#define PERF_SW_INTR                                      0x1c
+
+#define PERF_SW_INTR_SW1_INTR                             BIT(1)
+#define PERF_SW_INTR_SW0_INTR                             BIT(0)
+
+#define PERF_GPIO_OUT_SET                                 0x34
+
+#define PERF_GPIO_OUT_CLR                                 0x38
+
+#define PERF_GPIO_OUT                                     0x3c
+
+#define PERF_GPIO_IN                                      0x40
+
+#define PERF_GPIO_OE                                      0x44
+
+#define PERF_GPIO_INTR                                    0x48
+
+#define PERF_GPIO_INTR_ENA                                0x4c
+
+#define PERF_GPIO_INTR_IDENT                              0x50
+
+#define PERF_GPIO_ALT(x)                                  (0x54 + 4 * (x))
+#define PERF_GPIO_ALT_RSZ                                 0x4
+
+#define PERF_GPIO_SD_MAP                                  0x5c
+#define PERF_GPIO_SD_MAP_RSZ                              0x4
+
+#endif
diff --git a/arch/mips/mach-mscc/include/mach/ocelot/ocelot_icpu_cfg.h b/arch/mips/mach-mscc/include/mach/ocelot/ocelot_icpu_cfg.h
new file mode 100644
index 0000000000..6c354bc475
--- /dev/null
+++ b/arch/mips/mach-mscc/include/mach/ocelot/ocelot_icpu_cfg.h
@@ -0,0 +1,278 @@
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+/*
+ * Copyright (c) 2018 Microsemi Corporation
+ */
+
+#ifndef _MSCC_OCELOT_ICPU_CFG_H_
+#define _MSCC_OCELOT_ICPU_CFG_H_
+
+#define ICPU_GPR(x) (0x4 * (x))
+#define ICPU_GPR_RSZ                                      0x4
+
+#define ICPU_RESET                                        0x20
+
+#define ICPU_RESET_CORE_RST_CPU_ONLY                      BIT(3)
+#define ICPU_RESET_CORE_RST_PROTECT                       BIT(2)
+#define ICPU_RESET_CORE_RST_FORCE                         BIT(1)
+#define ICPU_RESET_MEM_RST_FORCE                          BIT(0)
+
+#define ICPU_GENERAL_CTRL                                 0x24
+
+#define ICPU_GENERAL_CTRL_CPU_BUSIF_SLEEP_DIS             BIT(14)
+#define ICPU_GENERAL_CTRL_CPU_BUSIF_WERR_ENA              BIT(13)
+#define ICPU_GENERAL_CTRL_CPU_8051_IROM_ENA               BIT(12)
+#define ICPU_GENERAL_CTRL_CPU_MIPS_DIS                    BIT(11)
+#define ICPU_GENERAL_CTRL_IF_MIIM_SLV_ADDR_SEL            BIT(10)
+#define ICPU_GENERAL_CTRL_IF_MIIM_SLV_ENA                 BIT(9)
+#define ICPU_GENERAL_CTRL_IF_PI_SLV_DONEPOL               BIT(8)
+#define ICPU_GENERAL_CTRL_IF_PI_MST_ENA                   BIT(7)
+#define ICPU_GENERAL_CTRL_IF_PI_SLV_ENA                   BIT(6)
+#define ICPU_GENERAL_CTRL_IF_SI_OWNER(x)                  (((x) << 4) & GENMASK(5, 4))
+#define ICPU_GENERAL_CTRL_IF_SI_OWNER_M                   GENMASK(5, 4)
+#define ICPU_GENERAL_CTRL_IF_SI_OWNER_X(x)                (((x) & GENMASK(5, 4)) >> 4)
+#define ICPU_GENERAL_CTRL_SSI_MST_CONTENTION              BIT(3)
+#define ICPU_GENERAL_CTRL_CPU_BE_ENA                      BIT(2)
+#define ICPU_GENERAL_CTRL_CPU_DIS                         BIT(1)
+#define ICPU_GENERAL_CTRL_BOOT_MODE_ENA                   BIT(0)
+#define ICPU_SPI_MST_CFG                                  0x3c
+
+#define ICPU_SPI_MST_CFG_A32B_ENA                         BIT(11)
+#define ICPU_SPI_MST_CFG_FAST_READ_ENA                    BIT(10)
+#define ICPU_SPI_MST_CFG_CS_DESELECT_TIME(x)              (((x) << 5) & GENMASK(9, 5))
+#define ICPU_SPI_MST_CFG_CS_DESELECT_TIME_M               GENMASK(9, 5)
+#define ICPU_SPI_MST_CFG_CS_DESELECT_TIME_X(x)            (((x) & GENMASK(9, 5)) >> 5)
+#define ICPU_SPI_MST_CFG_CLK_DIV(x)                       ((x) & GENMASK(4, 0))
+#define ICPU_SPI_MST_CFG_CLK_DIV_M                        GENMASK(4, 0)
+
+#define ICPU_SW_MODE                                      0x50
+
+#define ICPU_SW_MODE_SW_PIN_CTRL_MODE                     BIT(13)
+#define ICPU_SW_MODE_SW_SPI_SCK                           BIT(12)
+#define ICPU_SW_MODE_SW_SPI_SCK_OE                        BIT(11)
+#define ICPU_SW_MODE_SW_SPI_SDO                           BIT(10)
+#define ICPU_SW_MODE_SW_SPI_SDO_OE                        BIT(9)
+#define ICPU_SW_MODE_SW_SPI_CS(x)                         (((x) << 5) & GENMASK(8, 5))
+#define ICPU_SW_MODE_SW_SPI_CS_M                          GENMASK(8, 5)
+#define ICPU_SW_MODE_SW_SPI_CS_X(x)                       (((x) & GENMASK(8, 5)) >> 5)
+#define ICPU_SW_MODE_SW_SPI_CS_OE(x)                      (((x) << 1) & GENMASK(4, 1))
+#define ICPU_SW_MODE_SW_SPI_CS_OE_M                       GENMASK(4, 1)
+#define ICPU_SW_MODE_SW_SPI_CS_OE_X(x)                    (((x) & GENMASK(4, 1)) >> 1)
+#define ICPU_SW_MODE_SW_SPI_SDI                           BIT(0)
+
+#define ICPU_INTR_ENA					  0x88
+
+#define ICPU_DST_INTR_MAP(x)  (0x98 + 0x4 * (x))
+#define ICPU_DST_INTR_MAP_RSZ                             0x4
+
+#define ICPU_DST_INTR_IDENT                               0xa8
+#define ICPU_DST_INTR_IDENT_RSZ                           0x4
+
+#define ICPU_TIMER_TICK_DIV                               0xe8
+#define ICPU_TIMER_VALUE(x) (0xec + 0x4 * (x))
+
+#define ICPU_TIMER_CTRL(x) (0x104 + 0x4 * (x))
+#define ICPU_TIMER_CTRL_MAX_FREQ_ENA			  BIT(3)
+#define ICPU_TIMER_CTRL_ONE_SHOT_ENA			  BIT(2)
+#define ICPU_TIMER_CTRL_TIMER_ENA			  BIT(1)
+#define ICPU_TIMER_CTRL_FORCE_RELOAD			  BIT(0)
+
+#define ICPU_MEMCTRL_CTRL                                 0x110
+#define ICPU_MEMCTRL_CTRL_PWR_DOWN                        BIT(3)
+#define ICPU_MEMCTRL_CTRL_MDSET                           BIT(2)
+#define ICPU_MEMCTRL_CTRL_STALL_REF_ENA                   BIT(1)
+#define ICPU_MEMCTRL_CTRL_INITIALIZE                      BIT(0)
+
+#define ICPU_MEMCTRL_CFG                                  0x114
+
+#define ICPU_MEMCTRL_CFG_DDR_512MBYTE_PLUS                BIT(16)
+#define ICPU_MEMCTRL_CFG_DDR_ECC_ERR_ENA                  BIT(15)
+#define ICPU_MEMCTRL_CFG_DDR_ECC_COR_ENA                  BIT(14)
+#define ICPU_MEMCTRL_CFG_DDR_ECC_ENA                      BIT(13)
+#define ICPU_MEMCTRL_CFG_DDR_WIDTH                        BIT(12)
+#define ICPU_MEMCTRL_CFG_DDR_MODE                         BIT(11)
+#define ICPU_MEMCTRL_CFG_BURST_SIZE                       BIT(10)
+#define ICPU_MEMCTRL_CFG_BURST_LEN                        BIT(9)
+#define ICPU_MEMCTRL_CFG_BANK_CNT                         BIT(8)
+#define ICPU_MEMCTRL_CFG_MSB_ROW_ADDR(x)                  (((x) << 4) & GENMASK(7, 4))
+#define ICPU_MEMCTRL_CFG_MSB_ROW_ADDR_M                   GENMASK(7, 4)
+#define ICPU_MEMCTRL_CFG_MSB_ROW_ADDR_X(x)                (((x) & GENMASK(7, 4)) >> 4)
+#define ICPU_MEMCTRL_CFG_MSB_COL_ADDR(x)                  ((x) & GENMASK(3, 0))
+#define ICPU_MEMCTRL_CFG_MSB_COL_ADDR_M                   GENMASK(3, 0)
+
+#define ICPU_MEMCTRL_STAT                                 0x118
+
+#define ICPU_MEMCTRL_STAT_RDATA_MASKED                    BIT(5)
+#define ICPU_MEMCTRL_STAT_RDATA_DUMMY                     BIT(4)
+#define ICPU_MEMCTRL_STAT_RDATA_ECC_ERR                   BIT(3)
+#define ICPU_MEMCTRL_STAT_RDATA_ECC_COR                   BIT(2)
+#define ICPU_MEMCTRL_STAT_PWR_DOWN_ACK                    BIT(1)
+#define ICPU_MEMCTRL_STAT_INIT_DONE                       BIT(0)
+
+#define ICPU_MEMCTRL_REF_PERIOD                           0x11c
+
+#define ICPU_MEMCTRL_REF_PERIOD_MAX_PEND_REF(x)           (((x) << 16) & GENMASK(19, 16))
+#define ICPU_MEMCTRL_REF_PERIOD_MAX_PEND_REF_M            GENMASK(19, 16)
+#define ICPU_MEMCTRL_REF_PERIOD_MAX_PEND_REF_X(x)         (((x) & GENMASK(19, 16)) >> 16)
+#define ICPU_MEMCTRL_REF_PERIOD_REF_PERIOD(x)             ((x) & GENMASK(15, 0))
+#define ICPU_MEMCTRL_REF_PERIOD_REF_PERIOD_M              GENMASK(15, 0)
+
+#define ICPU_MEMCTRL_TIMING0                              0x124
+
+#define ICPU_MEMCTRL_TIMING0_RD_TO_WR_DLY(x)              (((x) << 28) & GENMASK(31, 28))
+#define ICPU_MEMCTRL_TIMING0_RD_TO_WR_DLY_M               GENMASK(31, 28)
+#define ICPU_MEMCTRL_TIMING0_RD_TO_WR_DLY_X(x)            (((x) & GENMASK(31, 28)) >> 28)
+#define ICPU_MEMCTRL_TIMING0_WR_CS_CHANGE_DLY(x)          (((x) << 24) & GENMASK(27, 24))
+#define ICPU_MEMCTRL_TIMING0_WR_CS_CHANGE_DLY_M           GENMASK(27, 24)
+#define ICPU_MEMCTRL_TIMING0_WR_CS_CHANGE_DLY_X(x)        (((x) & GENMASK(27, 24)) >> 24)
+#define ICPU_MEMCTRL_TIMING0_RD_CS_CHANGE_DLY(x)          (((x) << 20) & GENMASK(23, 20))
+#define ICPU_MEMCTRL_TIMING0_RD_CS_CHANGE_DLY_M           GENMASK(23, 20)
+#define ICPU_MEMCTRL_TIMING0_RD_CS_CHANGE_DLY_X(x)        (((x) & GENMASK(23, 20)) >> 20)
+#define ICPU_MEMCTRL_TIMING0_RAS_TO_PRECH_DLY(x)          (((x) << 16) & GENMASK(19, 16))
+#define ICPU_MEMCTRL_TIMING0_RAS_TO_PRECH_DLY_M           GENMASK(19, 16)
+#define ICPU_MEMCTRL_TIMING0_RAS_TO_PRECH_DLY_X(x)        (((x) & GENMASK(19, 16)) >> 16)
+#define ICPU_MEMCTRL_TIMING0_WR_TO_PRECH_DLY(x)           (((x) << 12) & GENMASK(15, 12))
+#define ICPU_MEMCTRL_TIMING0_WR_TO_PRECH_DLY_M            GENMASK(15, 12)
+#define ICPU_MEMCTRL_TIMING0_WR_TO_PRECH_DLY_X(x)         (((x) & GENMASK(15, 12)) >> 12)
+#define ICPU_MEMCTRL_TIMING0_RD_TO_PRECH_DLY(x)           (((x) << 8) & GENMASK(11, 8))
+#define ICPU_MEMCTRL_TIMING0_RD_TO_PRECH_DLY_M            GENMASK(11, 8)
+#define ICPU_MEMCTRL_TIMING0_RD_TO_PRECH_DLY_X(x)         (((x) & GENMASK(11, 8)) >> 8)
+#define ICPU_MEMCTRL_TIMING0_WR_DATA_XFR_DLY(x)           (((x) << 4) & GENMASK(7, 4))
+#define ICPU_MEMCTRL_TIMING0_WR_DATA_XFR_DLY_M            GENMASK(7, 4)
+#define ICPU_MEMCTRL_TIMING0_WR_DATA_XFR_DLY_X(x)         (((x) & GENMASK(7, 4)) >> 4)
+#define ICPU_MEMCTRL_TIMING0_RD_DATA_XFR_DLY(x)           ((x) & GENMASK(3, 0))
+#define ICPU_MEMCTRL_TIMING0_RD_DATA_XFR_DLY_M            GENMASK(3, 0)
+
+#define ICPU_MEMCTRL_TIMING1                              0x128
+
+#define ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_SAME_BANK_DLY(x)  (((x) << 24) & GENMASK(31, 24))
+#define ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_SAME_BANK_DLY_M   GENMASK(31, 24)
+#define ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_SAME_BANK_DLY_X(x) (((x) & GENMASK(31, 24)) >> 24)
+#define ICPU_MEMCTRL_TIMING1_BANK8_FAW_DLY(x)             (((x) << 16) & GENMASK(23, 16))
+#define ICPU_MEMCTRL_TIMING1_BANK8_FAW_DLY_M              GENMASK(23, 16)
+#define ICPU_MEMCTRL_TIMING1_BANK8_FAW_DLY_X(x)           (((x) & GENMASK(23, 16)) >> 16)
+#define ICPU_MEMCTRL_TIMING1_PRECH_TO_RAS_DLY(x)          (((x) << 12) & GENMASK(15, 12))
+#define ICPU_MEMCTRL_TIMING1_PRECH_TO_RAS_DLY_M           GENMASK(15, 12)
+#define ICPU_MEMCTRL_TIMING1_PRECH_TO_RAS_DLY_X(x)        (((x) & GENMASK(15, 12)) >> 12)
+#define ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_DLY(x)            (((x) << 8) & GENMASK(11, 8))
+#define ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_DLY_M             GENMASK(11, 8)
+#define ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_DLY_X(x)          (((x) & GENMASK(11, 8)) >> 8)
+#define ICPU_MEMCTRL_TIMING1_RAS_TO_CAS_DLY(x)            (((x) << 4) & GENMASK(7, 4))
+#define ICPU_MEMCTRL_TIMING1_RAS_TO_CAS_DLY_M             GENMASK(7, 4)
+#define ICPU_MEMCTRL_TIMING1_RAS_TO_CAS_DLY_X(x)          (((x) & GENMASK(7, 4)) >> 4)
+#define ICPU_MEMCTRL_TIMING1_WR_TO_RD_DLY(x)              ((x) & GENMASK(3, 0))
+#define ICPU_MEMCTRL_TIMING1_WR_TO_RD_DLY_M               GENMASK(3, 0)
+
+#define ICPU_MEMCTRL_TIMING2                              0x12c
+
+#define ICPU_MEMCTRL_TIMING2_PRECH_ALL_DLY(x)             (((x) << 28) & GENMASK(31, 28))
+#define ICPU_MEMCTRL_TIMING2_PRECH_ALL_DLY_M              GENMASK(31, 28)
+#define ICPU_MEMCTRL_TIMING2_PRECH_ALL_DLY_X(x)           (((x) & GENMASK(31, 28)) >> 28)
+#define ICPU_MEMCTRL_TIMING2_MDSET_DLY(x)                 (((x) << 24) & GENMASK(27, 24))
+#define ICPU_MEMCTRL_TIMING2_MDSET_DLY_M                  GENMASK(27, 24)
+#define ICPU_MEMCTRL_TIMING2_MDSET_DLY_X(x)               (((x) & GENMASK(27, 24)) >> 24)
+#define ICPU_MEMCTRL_TIMING2_REF_DLY(x)                   (((x) << 16) & GENMASK(23, 16))
+#define ICPU_MEMCTRL_TIMING2_REF_DLY_M                    GENMASK(23, 16)
+#define ICPU_MEMCTRL_TIMING2_REF_DLY_X(x)                 (((x) & GENMASK(23, 16)) >> 16)
+#define ICPU_MEMCTRL_TIMING2_INIT_DLY(x)                  ((x) & GENMASK(15, 0))
+#define ICPU_MEMCTRL_TIMING2_INIT_DLY_M                   GENMASK(15, 0)
+
+#define ICPU_MEMCTRL_TIMING3                              0x130
+
+#define ICPU_MEMCTRL_TIMING3_RMW_DLY(x)                   (((x) << 16) & GENMASK(19, 16))
+#define ICPU_MEMCTRL_TIMING3_RMW_DLY_M                    GENMASK(19, 16)
+#define ICPU_MEMCTRL_TIMING3_RMW_DLY_X(x)                 (((x) & GENMASK(19, 16)) >> 16)
+#define ICPU_MEMCTRL_TIMING3_ODT_RD_DLY(x)                (((x) << 12) & GENMASK(15, 12))
+#define ICPU_MEMCTRL_TIMING3_ODT_RD_DLY_M                 GENMASK(15, 12)
+#define ICPU_MEMCTRL_TIMING3_ODT_RD_DLY_X(x)              (((x) & GENMASK(15, 12)) >> 12)
+#define ICPU_MEMCTRL_TIMING3_ODT_WR_DLY(x)                (((x) << 8) & GENMASK(11, 8))
+#define ICPU_MEMCTRL_TIMING3_ODT_WR_DLY_M                 GENMASK(11, 8)
+#define ICPU_MEMCTRL_TIMING3_ODT_WR_DLY_X(x)              (((x) & GENMASK(11, 8)) >> 8)
+#define ICPU_MEMCTRL_TIMING3_LOCAL_ODT_RD_DLY(x)          (((x) << 4) & GENMASK(7, 4))
+#define ICPU_MEMCTRL_TIMING3_LOCAL_ODT_RD_DLY_M           GENMASK(7, 4)
+#define ICPU_MEMCTRL_TIMING3_LOCAL_ODT_RD_DLY_X(x)        (((x) & GENMASK(7, 4)) >> 4)
+#define ICPU_MEMCTRL_TIMING3_WR_TO_RD_CS_CHANGE_DLY(x)    ((x) & GENMASK(3, 0))
+#define ICPU_MEMCTRL_TIMING3_WR_TO_RD_CS_CHANGE_DLY_M     GENMASK(3, 0)
+
+#define ICPU_MEMCTRL_MR0_VAL                              0x138
+
+#define ICPU_MEMCTRL_MR1_VAL                              0x13c
+
+#define ICPU_MEMCTRL_MR2_VAL                              0x140
+
+#define ICPU_MEMCTRL_MR3_VAL                              0x144
+
+#define ICPU_MEMCTRL_TERMRES_CTRL                         0x148
+
+#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_RD_EXT              BIT(11)
+#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_RD_ENA(x)           (((x) << 7) & GENMASK(10, 7))
+#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_RD_ENA_M            GENMASK(10, 7)
+#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_RD_ENA_X(x)         (((x) & GENMASK(10, 7)) >> 7)
+#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_WR_EXT              BIT(6)
+#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_WR_ENA(x)           (((x) << 2) & GENMASK(5, 2))
+#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_WR_ENA_M            GENMASK(5, 2)
+#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_WR_ENA_X(x)         (((x) & GENMASK(5, 2)) >> 2)
+#define ICPU_MEMCTRL_TERMRES_CTRL_LOCAL_ODT_RD_EXT        BIT(1)
+#define ICPU_MEMCTRL_TERMRES_CTRL_LOCAL_ODT_RD_ENA        BIT(0)
+
+#define ICPU_MEMCTRL_DQS_DLY(x) (0x150 + 0x4 * (x))
+#define ICPU_MEMCTRL_DQS_DLY_RSZ                          0x4
+
+#define ICPU_MEMCTRL_DQS_DLY_TRAIN_DQ_ENA                 BIT(11)
+#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_TRM1(x)              (((x) << 8) & GENMASK(10, 8))
+#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_TRM1_M               GENMASK(10, 8)
+#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_TRM1_X(x)            (((x) & GENMASK(10, 8)) >> 8)
+#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_TRM0(x)              (((x) << 5) & GENMASK(7, 5))
+#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_TRM0_M               GENMASK(7, 5)
+#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_TRM0_X(x)            (((x) & GENMASK(7, 5)) >> 5)
+#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY(x)                   ((x) & GENMASK(4, 0))
+#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_M                    GENMASK(4, 0)
+
+#define ICPU_MEMPHY_CFG                                   0x160
+
+#define ICPU_MEMPHY_CFG_PHY_FLUSH_DIS                     BIT(10)
+#define ICPU_MEMPHY_CFG_PHY_RD_ADJ_DIS                    BIT(9)
+#define ICPU_MEMPHY_CFG_PHY_DQS_EXT                       BIT(8)
+#define ICPU_MEMPHY_CFG_PHY_FIFO_RST                      BIT(7)
+#define ICPU_MEMPHY_CFG_PHY_DLL_BL_RST                    BIT(6)
+#define ICPU_MEMPHY_CFG_PHY_DLL_CL_RST                    BIT(5)
+#define ICPU_MEMPHY_CFG_PHY_ODT_OE                        BIT(4)
+#define ICPU_MEMPHY_CFG_PHY_CK_OE                         BIT(3)
+#define ICPU_MEMPHY_CFG_PHY_CL_OE                         BIT(2)
+#define ICPU_MEMPHY_CFG_PHY_SSTL_ENA                      BIT(1)
+#define ICPU_MEMPHY_CFG_PHY_RST                           BIT(0)
+
+#define ICPU_MEMPHY_DFT                                   0x164
+
+#define ICPU_MEMPHY_DFT_PHY_DLL_BYPASS                    BIT(0)
+
+#define ICPU_MEMPHY_ZCAL                                  0x188
+
+#define ICPU_MEMPHY_ZCAL_ZCAL_CLK_SEL                     BIT(9)
+#define ICPU_MEMPHY_ZCAL_ZCAL_PROG_ODT(x)                 (((x) << 5) & GENMASK(8, 5))
+#define ICPU_MEMPHY_ZCAL_ZCAL_PROG_ODT_M                  GENMASK(8, 5)
+#define ICPU_MEMPHY_ZCAL_ZCAL_PROG_ODT_X(x)               (((x) & GENMASK(8, 5)) >> 5)
+#define ICPU_MEMPHY_ZCAL_ZCAL_PROG(x)                     (((x) << 1) & GENMASK(4, 1))
+#define ICPU_MEMPHY_ZCAL_ZCAL_PROG_M                      GENMASK(4, 1)
+#define ICPU_MEMPHY_ZCAL_ZCAL_PROG_X(x)                   (((x) & GENMASK(4, 1)) >> 1)
+#define ICPU_MEMPHY_ZCAL_ZCAL_ENA                         BIT(0)
+
+#define ICPU_MEMPHY_ZCAL_STAT                             0x18c
+
+#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_ZCTRL(x)               (((x) << 12) & GENMASK(31, 12))
+#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_ZCTRL_M                GENMASK(31, 12)
+#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_ZCTRL_X(x)             (((x) & GENMASK(31, 12)) >> 12)
+#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_ODTPU(x)          (((x) << 8) & GENMASK(9, 8))
+#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_ODTPU_M           GENMASK(9, 8)
+#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_ODTPU_X(x)        (((x) & GENMASK(9, 8)) >> 8)
+#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_ODTPD(x)          (((x) << 6) & GENMASK(7, 6))
+#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_ODTPD_M           GENMASK(7, 6)
+#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_ODTPD_X(x)        (((x) & GENMASK(7, 6)) >> 6)
+#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_PU(x)             (((x) << 4) & GENMASK(5, 4))
+#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_PU_M              GENMASK(5, 4)
+#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_PU_X(x)           (((x) & GENMASK(5, 4)) >> 4)
+#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_PD(x)             (((x) << 2) & GENMASK(3, 2))
+#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_PD_M              GENMASK(3, 2)
+#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_PD_X(x)           (((x) & GENMASK(3, 2)) >> 2)
+#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_ERR                    BIT(1)
+#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_DONE                   BIT(0)
+#endif
diff --git a/arch/mips/mach-mscc/include/mach/tlb.h b/arch/mips/mach-mscc/include/mach/tlb.h
new file mode 100644
index 0000000000..4e95da28ce
--- /dev/null
+++ b/arch/mips/mach-mscc/include/mach/tlb.h
@@ -0,0 +1,65 @@
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+/*
+ * Copyright (c) 2018 Microsemi Corporation
+ */
+
+#ifndef __ASM_MACH_TLB_H
+#define __ASM_MACH_TLB_H
+
+#include <asm/mipsregs.h>
+#include <mach/common.h>
+#include <linux/sizes.h>
+
+#define TLB_HI_MASK      0xffffe000
+#define TLB_LO_MASK      0x3fffffff /* Masks off Fill bits */
+#define TLB_LO_SHIFT     6          /* PFN Start bit */
+
+#define PAGEMASK_SHIFT   13
+
+#define MMU_PAGE_CACHED   (3 << 3) /* C(5:3) Cache Coherency Attributes */
+#define MMU_PAGE_UNCACHED (2 << 3) /* C(5:3) Cache Coherency Attributes */
+#define MMU_PAGE_DIRTY    BIT(2) /* = Writeable */
+#define MMU_PAGE_VALID    BIT(1)
+#define MMU_PAGE_GLOBAL   BIT(0)
+#define MMU_REGIO_RO_C    (MMU_PAGE_CACHED|MMU_PAGE_VALID|MMU_PAGE_GLOBAL)
+#define MMU_REGIO_RO      (MMU_PAGE_UNCACHED|MMU_PAGE_VALID|MMU_PAGE_GLOBAL)
+#define MMU_REGIO_RW      (MMU_PAGE_DIRTY|MMU_REGIO_RO)
+#define MMU_REGIO_INVAL   (MMU_PAGE_GLOBAL)
+
+#define TLB_COUNT_MASK	  GENMASK(5, 0)
+#define TLB_COUNT_OFF  	  25
+
+static inline u32 get_tlb_count(void)
+{
+        register u32 config1;
+
+	config1 = read_c0_config1();
+	config1 >>= TLB_COUNT_OFF;
+	config1 &= TLB_COUNT_MASK;
+
+        return 1 + config1;
+}
+
+static inline void create_tlb(int index, u32 offset, u32 size, u32 tlb_attrib1,
+			      u32 tlb_attrib2)
+{
+        register u32 tlb_mask, tlb_lo0, tlb_lo1;
+
+        tlb_mask  = ((size >> 12) - 1) << PAGEMASK_SHIFT;
+        tlb_lo0 = tlb_attrib1 | ( offset              >> TLB_LO_SHIFT);
+        tlb_lo1 = tlb_attrib2 | ((offset + size )     >> TLB_LO_SHIFT);
+
+	write_one_tlb(index, tlb_mask, offset & TLB_HI_MASK,
+		      tlb_lo0 & TLB_LO_MASK, tlb_lo1 & TLB_LO_MASK);
+}
+
+static inline void init_tlb(void)
+{
+    register int i, max;
+
+    max = get_tlb_count();
+    for(i = 0; i < max; i++)
+        create_tlb(i, i * SZ_1M, SZ_4K, MMU_REGIO_INVAL, MMU_REGIO_INVAL);
+}
+
+#endif /* __ASM_MACH_TLB_H */
diff --git a/arch/mips/mach-mscc/lowlevel_init.S b/arch/mips/mach-mscc/lowlevel_init.S
new file mode 100644
index 0000000000..87439439f0
--- /dev/null
+++ b/arch/mips/mach-mscc/lowlevel_init.S
@@ -0,0 +1,29 @@
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+/*
+ * Copyright (c) 2018 Microsemi Corporation
+ */
+
+#include <asm/asm.h>
+#include <asm/regdef.h>
+
+    .text
+    .set noreorder
+    .extern     vcoreiii_tlb_init
+#ifdef CONFIG_SOC_LUTON
+    .extern     pll_init
+#endif
+
+LEAF(lowlevel_init)
+	// As we have no stack yet, we can assume the restricted
+        // luxury of the sX-registers without saving them
+	move s0,ra
+
+        jal vcoreiii_tlb_init
+	nop
+#ifdef CONFIG_SOC_LUTON
+        jal pll_init
+	nop
+#endif
+	jr  s0
+	nop
+END(lowlevel_init)
diff --git a/arch/mips/mach-mscc/lowlevel_init_luton.S b/arch/mips/mach-mscc/lowlevel_init_luton.S
new file mode 100644
index 0000000000..5e1b4442d9
--- /dev/null
+++ b/arch/mips/mach-mscc/lowlevel_init_luton.S
@@ -0,0 +1,63 @@
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+/*
+ * Copyright (c) 2018 Microsemi Corporation
+ */
+
+#include <asm/asm.h>
+#include <asm/regdef.h>
+
+#define BASE_MACRO      0x600a0000
+#define REG_OFFSET(t, o) (t + (o*4))
+#define REG_MACRO(x) REG_OFFSET(BASE_MACRO, x)
+#define BIT(nr)			(1 << (nr))
+
+#define MACRO_CTRL_PLL5G_STATUS_PLL5G_STATUS0 REG_MACRO(6)
+#define MACRO_CTRL_PLL5G_STATUS_PLL5G_STATUS0_LOCK_STATUS BIT(0)
+#define MACRO_CTRL_PLL5G_CFG_PLL5G_CFG2 REG_MACRO(2)
+#define MACRO_CTRL_PLL5G_CFG_PLL5G_CFG0 REG_MACRO(0)
+#define MACRO_CTRL_PLL5G_CFG_PLL5G_CFG0_CPU_CLK_DIV (0x3F << 6)
+#define MACRO_CTRL_PLL5G_CFG_PLL5G_CFG0_CPU_CLK_DIV_ENC(x) (x << 6)
+
+    .text
+    .set noreorder
+LEAF(pll_init)
+        # Make sure PLL is locked
+        lw	v0, MACRO_CTRL_PLL5G_STATUS_PLL5G_STATUS0
+        andi	v1, v0, MACRO_CTRL_PLL5G_STATUS_PLL5G_STATUS0_LOCK_STATUS
+        bne	v1, zero, 1f
+        nop
+
+        # Black magic from frontend
+        li	v1, 0x00610400
+        sw	v1, MACRO_CTRL_PLL5G_CFG_PLL5G_CFG2
+
+        li	v1, 0x00610c00
+        sw	v1, MACRO_CTRL_PLL5G_CFG_PLL5G_CFG2
+
+        li	v1, 0x00610800
+        sw	v1, MACRO_CTRL_PLL5G_CFG_PLL5G_CFG2
+
+        li	v1, 0x00610000
+        sw	v1, MACRO_CTRL_PLL5G_CFG_PLL5G_CFG2
+
+        # Wait for lock
+2:      lw	v0, MACRO_CTRL_PLL5G_STATUS_PLL5G_STATUS0
+        andi	v1, v0, MACRO_CTRL_PLL5G_STATUS_PLL5G_STATUS0_LOCK_STATUS
+        # Keep looping if zero (no lock bit yet)
+        beq	v1, zero, 2b
+        nop
+
+        # Setup PLL CPU clock divider for 416MHz
+1:      lw	v0, MACRO_CTRL_PLL5G_CFG_PLL5G_CFG0
+
+        # Keep reserved bits
+        li	v1, ~MACRO_CTRL_PLL5G_CFG_PLL5G_CFG0_CPU_CLK_DIV
+	and	v0, v0, v1
+
+        # Set code 6 ~ 416.66 MHz
+        ori	v0, v0, MACRO_CTRL_PLL5G_CFG_PLL5G_CFG0_CPU_CLK_DIV_ENC(6)
+
+        sw	v0, MACRO_CTRL_PLL5G_CFG_PLL5G_CFG0
+	jr      ra
+	nop
+END(pll_init)
diff --git a/arch/mips/mach-mscc/reset.c b/arch/mips/mach-mscc/reset.c
new file mode 100644
index 0000000000..85768cbdf0
--- /dev/null
+++ b/arch/mips/mach-mscc/reset.c
@@ -0,0 +1,37 @@
+// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
+/*
+ * Copyright (c) 2018 Microsemi Corporation
+ */
+
+#include <common.h>
+
+#include <asm/sections.h>
+#include <asm/io.h>
+
+#include <asm/reboot.h>
+
+void _machine_restart(void)
+{
+        register u32 resetbits = PERF_SOFT_RST_SOFT_CHIP_RST;
+        (void) readl(REG_GCB(PERF_SOFT_RST));
+
+        /*
+         * Make sure VCore is NOT protected from reset
+         */
+        writel(readl(REG_CFG(ICPU_RESET)) & ~ICPU_RESET_CORE_RST_PROTECT,
+	       REG_CFG(ICPU_RESET));
+
+        /*
+         * Change to SPI bitbang for SPI reset workaround...
+         */
+        writel(ICPU_SW_MODE_SW_SPI_CS_OE(1) | ICPU_SW_MODE_SW_SPI_CS(1) |
+	       ICPU_SW_MODE_SW_PIN_CTRL_MODE, REG_CFG(ICPU_SW_MODE));
+
+        /*
+         * Do the global reset
+         */
+        writel(resetbits, REG_GCB(PERF_SOFT_RST));
+
+	while (1)
+		/* NOP */;
+}
-- 
2.19.0

^ permalink raw reply related	[flat|nested] 22+ messages in thread

* [U-Boot] [PATCH 2/6] MSCC: add support for VCoreIII SoCs
       [not found] ` <20180925130108.19211-3-gregory.clement@bootlin.com>
@ 2018-09-26 19:25   ` Daniel Schwierzeck
  2018-09-27 10:14     ` Gregory CLEMENT
  2018-10-09 11:20     ` Gregory CLEMENT
  0 siblings, 2 replies; 22+ messages in thread
From: Daniel Schwierzeck @ 2018-09-26 19:25 UTC (permalink / raw)
  To: u-boot

Hi Gregory,

On 25.09.2018 15:01, Gregory CLEMENT wrote:
> These families of SoCs are found in the Microsemi Switches solution.
> 
> Currently the support for two families support is added:
>  - Ocelot (VSC7513, VSC7514) already supported in Linux
>  - Luton (Luton10: VSC7423, VSC7424, VSC7428 and Luton26: VSC7425,
>    VSC7426, VSC7426, VSC7427, VSC7429)

Is this some polished version of the original vendor U-Boot?
Could you maybe add Ocelot and Luton in separate patches?

> 
> Signed-off-by: Gregory CLEMENT <gregory.clement@bootlin.com>
> ---
>  arch/mips/Kconfig                             |   6 +
>  arch/mips/Makefile                            |   1 +
>  arch/mips/mach-mscc/Kconfig                   | 101 ++
>  arch/mips/mach-mscc/Makefile                  |   6 +
>  arch/mips/mach-mscc/cpu.c                     |  72 ++
>  arch/mips/mach-mscc/dram.c                    |  62 ++
>  arch/mips/mach-mscc/include/ioremap.h         |  49 +
>  arch/mips/mach-mscc/include/mach/cache.h      |  36 +
>  arch/mips/mach-mscc/include/mach/common.h     |  31 +
>  arch/mips/mach-mscc/include/mach/ddr.h        | 753 +++++++++++++++
>  .../mips/mach-mscc/include/mach/luton/luton.h |  37 +
>  .../include/mach/luton/luton_devcpu_gcb.h     |  16 +
>  .../include/mach/luton/luton_icpu_cfg-ref.h   | 884 ++++++++++++++++++
>  .../include/mach/luton/luton_icpu_cfg.h       | 247 +++++
>  .../mach-mscc/include/mach/ocelot/ocelot.h    |  35 +
>  .../include/mach/ocelot/ocelot_devcpu_gcb.h   | 353 +++++++
>  .../include/mach/ocelot/ocelot_icpu_cfg.h     | 884 ++++++++++++++++++
>  arch/mips/mach-mscc/include/mach/tlb.h        |  65 ++
>  arch/mips/mach-mscc/lowlevel_init.S           |  29 +
>  arch/mips/mach-mscc/lowlevel_init_luton.S     |  63 ++
>  arch/mips/mach-mscc/reset.c                   |  37 +
>  21 files changed, 3767 insertions(+)
>  create mode 100644 arch/mips/mach-mscc/Kconfig
>  create mode 100644 arch/mips/mach-mscc/Makefile
>  create mode 100644 arch/mips/mach-mscc/cpu.c
>  create mode 100644 arch/mips/mach-mscc/dram.c
>  create mode 100644 arch/mips/mach-mscc/include/ioremap.h
>  create mode 100644 arch/mips/mach-mscc/include/mach/cache.h
>  create mode 100644 arch/mips/mach-mscc/include/mach/common.h
>  create mode 100644 arch/mips/mach-mscc/include/mach/ddr.h
>  create mode 100644 arch/mips/mach-mscc/include/mach/luton/luton.h
>  create mode 100644 arch/mips/mach-mscc/include/mach/luton/luton_devcpu_gcb.h
>  create mode 100644 arch/mips/mach-mscc/include/mach/luton/luton_icpu_cfg-ref.h
>  create mode 100644 arch/mips/mach-mscc/include/mach/luton/luton_icpu_cfg.h
>  create mode 100644 arch/mips/mach-mscc/include/mach/ocelot/ocelot.h
>  create mode 100644 arch/mips/mach-mscc/include/mach/ocelot/ocelot_devcpu_gcb.h
>  create mode 100644 arch/mips/mach-mscc/include/mach/ocelot/ocelot_icpu_cfg.h
>  create mode 100644 arch/mips/mach-mscc/include/mach/tlb.h
>  create mode 100644 arch/mips/mach-mscc/lowlevel_init.S
>  create mode 100644 arch/mips/mach-mscc/lowlevel_init_luton.S
>  create mode 100644 arch/mips/mach-mscc/reset.c
> 
> diff --git a/arch/mips/Kconfig b/arch/mips/Kconfig
> index 6e5e0ffe65..c4fc3d077b 100644
> --- a/arch/mips/Kconfig
> +++ b/arch/mips/Kconfig
> @@ -58,6 +58,11 @@ config ARCH_ATH79
>  	select OF_CONTROL
>  	imply CMD_DM
>  
> +config ARCH_MSCC
> +	bool "Support MSCC VCore-III"
> +	select OF_CONTROL
> +	select DM
> +
>  config ARCH_BMIPS
>  	bool "Support BMIPS SoCs"
>  	select CLK
> @@ -118,6 +123,7 @@ source "board/imgtec/xilfpga/Kconfig"
>  source "board/micronas/vct/Kconfig"
>  source "board/qemu-mips/Kconfig"
>  source "arch/mips/mach-ath79/Kconfig"
> +source "arch/mips/mach-mscc/Kconfig"
>  source "arch/mips/mach-bmips/Kconfig"
>  source "arch/mips/mach-pic32/Kconfig"
>  
> diff --git a/arch/mips/Makefile b/arch/mips/Makefile
> index a36f5f1fb6..acb1340942 100644
> --- a/arch/mips/Makefile
> +++ b/arch/mips/Makefile
> @@ -14,6 +14,7 @@ libs-y += arch/mips/lib/
>  machine-$(CONFIG_ARCH_ATH79) += ath79
>  machine-$(CONFIG_ARCH_BMIPS) += bmips
>  machine-$(CONFIG_MACH_PIC32) += pic32
> +machine-$(CONFIG_ARCH_MSCC) += mscc
>  
>  machdirs := $(patsubst %,arch/mips/mach-%/,$(machine-y))
>  libs-y += $(machdirs)
> diff --git a/arch/mips/mach-mscc/Kconfig b/arch/mips/mach-mscc/Kconfig
> new file mode 100644
> index 0000000000..20148bfe15
> --- /dev/null
> +++ b/arch/mips/mach-mscc/Kconfig
> @@ -0,0 +1,101 @@
> +# SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +
> +if ARCH_MSCC
> +
> +config SYS_DCACHE_SIZE
> +	default 32768
> +
> +config SYS_DCACHE_LINE_SIZE
> +	default 32
> +
> +config SYS_ICACHE_SIZE
> +	default 32768
> +
> +config SYS_ICACHE_LINE_SIZE
> +	default 32
> +
> +endif

from the code below I assume you have a MIPS24k core? If so you should
use the automatic cache size detection

> +
> +menu "MSCC VCore-III platforms"
> +	depends on ARCH_MSCC
> +
> +config SOC_VCOREIII
> +	select SUPPORTS_LITTLE_ENDIAN
> +	select SUPPORTS_BIG_ENDIAN
> +	select SUPPORTS_CPU_MIPS32_R1
> +	select SUPPORTS_CPU_MIPS32_R2
> +	select ROM_EXCEPTION_VECTORS
> +	select MIPS_TUNE_24KC
> +	bool

sort this alpahetically

> +
> +config SYS_SOC
> +	default "mscc"
> +
> +config SOC_OCELOT
> +	bool
> +	select SOC_VCOREIII
> +	help
> +	  This supports MSCC Ocelot family of SOCs.
> +
> +config SOC_LUTON
> +	bool
> +	select SOC_VCOREIII
> +	help
> +	  This supports MSCC Luton family of SOCs.
> +
> +config SYS_CONFIG_NAME
> +	default "vcoreiii"
> +
> +choice
> +	prompt "Board select"
> +
> +config TARGET_OCELOT_PCB120
> +	bool "MSCC PCB120 Reference Board (aka VSC5635EV)"
> +	select SOC_OCELOT
> +	help
> +	  When selected, CONFIG_DEFAULT_DEVICE_TREE should be set to
> +	  ocelot_pcb120
> +
> +config TARGET_OCELOT_PCB123
> +	bool "MSCC PCB123 Reference Board (aka VSC7514EV))"
> +	select SOC_OCELOT
> +	help
> +	  When selected, CONFIG_DEFAULT_DEVICE_TREE should be set to
> +	  ocelot_pcb123
> +
> +config TARGET_LUTON_PCB091
> +	bool "MSCC PCB091 Reference Board"
> +	select SOC_LUTON
> +	select MSCC_BITBANG_SPI_GPIO
> +	help
> +	  When selected, CONFIG_DEFAULT_DEVICE_TREE should be set to
> +	  luton_pcb091
> +endchoice
> +
> +choice
> +	prompt "DDR type"
> +
> +config DDRTYPE_H5TQ4G63MFR
> +	bool "Hynix H5TQ4G63MFR-PBC (4Gbit, DDR3-800, 256Mbitx16)"
> +
> +config DDRTYPE_MT41K256M16
> +	bool "Micron MT41K256M16 (4Gbit, DDR3L-800, 256Mbitx16)"
> +
> +config DDRTYPE_H5TQ1G63BFA
> +	bool "Hynix H5TQ1G63BFA (1Gbit DDR3, x16)"
> +
> +config DDRTYPE_MT41J128M16HA
> +	bool "Micron MT41J128M16HA-15E:D (2Gbit DDR3, x16)"
> +
> +config DDRTYPE_MT41K128M16JT
> +	bool "Micron MT41K128M16JT-125 (2Gbit DDR3L, 128Mbitx16)"
> +
> +config DDRTYPE_MT47H128M8HQ
> +	bool "Micron MT47H128M8-3 (1Gbit, DDR-533 at CL4 @ 4.80ns 16Mbisx8x8)"
> +
> +endchoice
> +
> +source "board/mscc/ocelot/Kconfig"
> +source "board/mscc/luton/Kconfig"
> +
> +endmenu
> diff --git a/arch/mips/mach-mscc/Makefile b/arch/mips/mach-mscc/Makefile
> new file mode 100644
> index 0000000000..6c60f26ca4
> --- /dev/null
> +++ b/arch/mips/mach-mscc/Makefile
> @@ -0,0 +1,6 @@
> +# SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +
> +CFLAGS_cpu.o += -finline-limit=64000
> +
> +obj-y += cpu.o dram.o reset.o lowlevel_init.o
> +obj-$(CONFIG_SOC_LUTON) += lowlevel_init_luton.o
> diff --git a/arch/mips/mach-mscc/cpu.c b/arch/mips/mach-mscc/cpu.c
> new file mode 100644
> index 0000000000..3d6dd78c61
> --- /dev/null
> +++ b/arch/mips/mach-mscc/cpu.c
> @@ -0,0 +1,72 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +/*
> + * Copyright (c) 2018 Microsemi Corporation
> + */
> +
> +#include <common.h>
> +
> +#include <asm/io.h>
> +#include <asm/types.h>
> +
> +#include <mach/tlb.h>
> +#include <mach/ddr.h>
> +
> +DECLARE_GLOBAL_DATA_PTR;
> +
> +/* NOTE: lowlevel_init() function does not have access to the
> + * stack. Thus, all called functions must be inlined, and (any) local
> + * variables must be kept in registers.
> + */
> +void vcoreiii_tlb_init(void)
> +{
> +        register int tlbix = 0;
> +
> +        init_tlb();
> +
> +        /* 0x70000000 size 32M (0x02000000) */
> +        create_tlb(tlbix++, MSCC_IO_ORIGIN1_OFFSET, SZ_16M, MMU_REGIO_RW, MMU_REGIO_RW);
> +#ifdef CONFIG_SOC_LUTON
> +	create_tlb(tlbix++, MSCC_IO_ORIGIN2_OFFSET, SZ_16M, MMU_REGIO_RW, MMU_REGIO_RW);
> +#endif
> +        /* 0x40000000 - 0x43ffffff - NON-CACHED! */
> +        /* Flash CS0-3, each 16M = 64M total (16 x 4 below )  */
> +        create_tlb(tlbix++, MSCC_FLASH_TO,        SZ_16M, MMU_REGIO_RO, MMU_REGIO_RO);
> +        create_tlb(tlbix++, MSCC_FLASH_TO+SZ_32M, SZ_16M, MMU_REGIO_RO, MMU_REGIO_RO);
> +
> +        /* 0x20000000 - up */
> +#if CONFIG_SYS_SDRAM_SIZE <= SZ_64M
> +        create_tlb(tlbix++, MSCC_DDR_TO,        SZ_64M,  MMU_REGIO_RW, MMU_REGIO_INVAL);
> +#elif CONFIG_SYS_SDRAM_SIZE <= SZ_128M
> +        create_tlb(tlbix++, MSCC_DDR_TO,        SZ_64M,  MMU_REGIO_RW, MMU_REGIO_RW);
> +#elif CONFIG_SYS_SDRAM_SIZE <= SZ_256M
> +        create_tlb(tlbix++, MSCC_DDR_TO,       SZ_256M,  MMU_REGIO_RW, MMU_REGIO_INVAL);
> +#elif CONFIG_SYS_SDRAM_SIZE <= SZ_512M
> +        create_tlb(tlbix++, MSCC_DDR_TO,       SZ_256M,  MMU_REGIO_RW, MMU_REGIO_RW);
> +#else  /* 1024M */
> +        create_tlb(tlbix++, MSCC_DDR_TO,       SZ_512M,  MMU_REGIO_RW, MMU_REGIO_RW);
> +#endif

can't you leave that to the kernel? U-Boot is only running in kernel
mode and doesn't need MMU mappings.

> +}
> +
> +int mach_cpu_init(void)
> +{
> +        /* Speed up NOR flash access */
> +#ifdef CONFIG_SOC_LUTON
> +        writel(ICPU_SPI_MST_CFG_FAST_READ_ENA +
> +#else
> +	writel(
> +#endif
> +	       ICPU_SPI_MST_CFG_CS_DESELECT_TIME(0x19) +
> +               ICPU_SPI_MST_CFG_CLK_DIV(9), REG_CFG(ICPU_SPI_MST_CFG));
> +
> +        /* Disable all IRQs - map to destination map 0 */
> +        writel(0, REG_CFG(ICPU_INTR_ENA));
> +#ifdef CONFIG_SOC_OCELOT
> +        writel(~0, REG_CFG(ICPU_DST_INTR_MAP(0)));
> +        writel(0, REG_CFG(ICPU_DST_INTR_MAP(1)));
> +        writel(0, REG_CFG(ICPU_DST_INTR_MAP(2)));
> +        writel(0, REG_CFG(ICPU_DST_INTR_MAP(3)));
> +#else
> +	writel(ICPU_INTR_IRQ0_ENA_IRQ0_ENA, REG_CFG(ICPU_INTR_IRQ0_ENA));
> +#endif

do you really need to disable interrupts after a cold or warm boot?

> +	return 0;
> +}
> diff --git a/arch/mips/mach-mscc/dram.c b/arch/mips/mach-mscc/dram.c
> new file mode 100644
> index 0000000000..2db9001fe9
> --- /dev/null
> +++ b/arch/mips/mach-mscc/dram.c
> @@ -0,0 +1,62 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +/*
> + * Copyright (c) 2018 Microsemi Corporation
> + */
> +
> +#include <common.h>
> +
> +#include <asm/io.h>
> +#include <asm/types.h>
> +
> +#include <mach/tlb.h>
> +#include <mach/ddr.h>
> +
> +DECLARE_GLOBAL_DATA_PTR;
> +
> +int vcoreiii_ddr_init(void)
> +{
> +        int res;
> +        if (!(readl(REG_CFG(ICPU_MEMCTRL_STAT)) &
> +              ICPU_MEMCTRL_STAT_INIT_DONE)) {
> +                hal_vcoreiii_init_memctl();
> +                hal_vcoreiii_wait_memctl();
> +                if (hal_vcoreiii_init_dqs() != 0 ||
> +                    hal_vcoreiii_train_bytelane(0) != 0
> +#ifdef CONFIG_SOC_OCELOT
> +		    || hal_vcoreiii_train_bytelane(1) != 0
> +#endif
> +			)
> +                        hal_vcoreiii_ddr_failed();
> +        }
> +
> +#if (CONFIG_SYS_TEXT_BASE != 0x20000000)
> +        res = dram_check();
> +        if (res == 0)
> +                hal_vcoreiii_ddr_verified();
> +        else
> +                hal_vcoreiii_ddr_failed();
> +
> +        /* Clear boot-mode and read-back to activate/verify */
> +        writel(readl(REG_CFG(ICPU_GENERAL_CTRL))& ~ICPU_GENERAL_CTRL_BOOT_MODE_ENA,
> +	       REG_CFG(ICPU_GENERAL_CTRL));

clrbits_32()?

> +        readl(REG_CFG(ICPU_GENERAL_CTRL));
> +#else
> +        res = 0;
> +#endif
> +        return res;
> +}
> +
> +int print_cpuinfo(void)
> +{
> +        printf("MSCC VCore-III MIPS 24Kec\n");
> +
> +	return 0;
> +}
> +
> +int dram_init(void)
> +{
> +	while (vcoreiii_ddr_init());
> +
> +        gd->ram_size = CONFIG_SYS_SDRAM_SIZE;
> +        return 0;
> +}
> diff --git a/arch/mips/mach-mscc/include/ioremap.h b/arch/mips/mach-mscc/include/ioremap.h
> new file mode 100644
> index 0000000000..684f89168c
> --- /dev/null
> +++ b/arch/mips/mach-mscc/include/ioremap.h
> @@ -0,0 +1,49 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +/*
> + * Copyright (c) 2018 Microsemi Corporation
> + */
> +
> +#ifndef __ASM_MACH_MSCC_IOREMAP_H
> +#define __ASM_MACH_MSCC_IOREMAP_H
> +
> +#include <linux/types.h>
> +#include <mach/common.h>
> +
> +/*
> + * Allow physical addresses to be fixed up to help peripherals located
> + * outside the low 32-bit range -- generic pass-through version.
> + */
> +static inline phys_addr_t fixup_bigphys_addr(phys_addr_t phys_addr,
> +                                             phys_addr_t size)
> +{
> +	return phys_addr;
> +}
> +
> +static inline int is_vcoreiii_internal_registers(phys_addr_t offset)
> +{
> +#if defined(CONFIG_ARCH_MSCC)
> +        if ((offset >= MSCC_IO_ORIGIN1_OFFSET && offset < (MSCC_IO_ORIGIN1_OFFSET+MSCC_IO_ORIGIN1_SIZE)) ||
> +            (offset >= MSCC_IO_ORIGIN2_OFFSET && offset < (MSCC_IO_ORIGIN2_OFFSET+MSCC_IO_ORIGIN2_SIZE)))
> +                return 1;
> +#endif
> +
> +	return 0;
> +}
> +
> +static inline void __iomem *plat_ioremap(phys_addr_t offset, unsigned long size,
> +                                         unsigned long flags)
> +{
> +	if (is_vcoreiii_internal_registers(offset))
> +		return (void __iomem *)offset;
> +
> +	return NULL;
> +}
> +
> +static inline int plat_iounmap(const volatile void __iomem *addr)
> +{
> +	return is_vcoreiii_internal_registers((unsigned long)addr);
> +}
> +
> +#define _page_cachable_default	_CACHE_CACHABLE_NONCOHERENT
> +
> +#endif /* __ASM_MACH_MSCC_IOREMAP_H */
> diff --git a/arch/mips/mach-mscc/include/mach/cache.h b/arch/mips/mach-mscc/include/mach/cache.h
> new file mode 100644
> index 0000000000..f3d09014f3
> --- /dev/null
> +++ b/arch/mips/mach-mscc/include/mach/cache.h
> @@ -0,0 +1,36 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +/*
> + * Copyright (c) 2018 Microsemi Corporation
> + */
> +#define MIPS32_CACHE_OP(which, op)             (which | (op << 2))
> +
> +#define MIPS32_WHICH_ICACHE                    0x0
> +#define MIPS32_WHICH_DCACHE                    0x1
> +
> +#define MIPS32_INDEX_INVALIDATE                0x0
> +#define MIPS32_INDEX_LOAD_TAG                  0x1
> +#define MIPS32_INDEX_STORE_TAG                 0x2
> +#define MIPS32_HIT_INVALIDATE                  0x4
> +#define MIPS32_ICACHE_FILL                     0x5
> +#define MIPS32_DCACHE_HIT_INVALIDATE           0x5
> +#define MIPS32_DCACHE_HIT_WRITEBACK            0x6
> +#define MIPS32_FETCH_AND_LOCK                  0x7
> +
> +#define ICACHE_LOAD_LOCK (MIPS32_CACHE_OP(MIPS32_WHICH_ICACHE, MIPS32_FETCH_AND_LOCK))
> +
> +#define CACHE_LINE_LEN 32

you can use ARCH_DMA_MINALIGN for this

> +
> +/* Prefetch and lock instructions into cache */
> +static inline void icache_lock(void *func, size_t len)
> +{
> +    int i, lines = ((len - 1) / CACHE_LINE_LEN) + 1;
> +    for (i = 0; i < lines; i++) {
> +        asm volatile (" cache %0, %1(%2)"
> +                      : /* No Output */
> +                      : "I" ICACHE_LOAD_LOCK,
> +                        "n" (i*CACHE_LINE_LEN),
> +                        "r" (func)
> +                      : /* No Clobbers */);
> +    }
> +}

could you try to implement this in a generic way in
arch/mips/lib/cache.c or arch/mips/include/asm/cacheops.h?

> +
> diff --git a/arch/mips/mach-mscc/include/mach/common.h b/arch/mips/mach-mscc/include/mach/common.h
> new file mode 100644
> index 0000000000..7e5c81c925
> --- /dev/null
> +++ b/arch/mips/mach-mscc/include/mach/common.h
> @@ -0,0 +1,31 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +/*
> + * Copyright (c) 2018 Microsemi Corporation
> + */
> +
> +#ifndef __ASM_MACH_COMMON_H
> +#define __ASM_MACH_COMMON_H
> +
> +// Stick to using register offsets - matching readl()/writel() prototypes
> +#define MSCC_IOREG(t,o)      ((void *)MSCC_IOADDR(t,o))
> +
> +#if defined(CONFIG_SOC_OCELOT)
> +#include <mach/ocelot/ocelot.h>
> +#include <mach/ocelot/ocelot_devcpu_gcb.h>
> +#include <mach/ocelot/ocelot_icpu_cfg.h>
> +#elif defined(CONFIG_SOC_LUTON)
> +#include <mach/luton/luton.h>
> +#include <mach/luton/luton_devcpu_gcb.h>
> +#include <mach/luton/luton_icpu_cfg.h>
> +#else
> +#error Unsupported platform
> +#endif
> +
> +#define MSCC_DDR_TO     0x20000000  /* DDR RAM base offset */
> +#define MSCC_MEMCTL1_TO 0x40000000  /* SPI/PI base offset */
> +#define MSCC_MEMCTL2_TO 0x50000000  /* SPI/PI base offset */
> +#define MSCC_FLASH_TO   MSCC_MEMCTL1_TO /* Flash base offset */
> +
> +#define VCOREIII_TIMER_DIVIDER 25     // Clock tick ~ 0.1 us
> +
> +#endif /* __ASM_MACH_COMMON_H */
> diff --git a/arch/mips/mach-mscc/include/mach/ddr.h b/arch/mips/mach-mscc/include/mach/ddr.h
> new file mode 100644
> index 0000000000..aef3facdca
> --- /dev/null
> +++ b/arch/mips/mach-mscc/include/mach/ddr.h
> @@ -0,0 +1,753 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +/*
> + * Copyright (c) 2018 Microsemi Corporation
> + */
> +
> +#ifndef __ASM_MACH_DDR_H
> +#define __ASM_MACH_DDR_H
> +
> +#include <mach/common.h>
> +#include <mach/cache.h>
> +#include <asm/reboot.h>
> +
> +#define MIPS_VCOREIII_MEMORY_DDR3
> +#define MIPS_VCOREIII_DDR_SIZE CONFIG_SYS_SDRAM_SIZE
> +
> +#if defined(CONFIG_DDRTYPE_H5TQ1G63BFA) /* Serval1 Refboard */
> +
> +/* Hynix H5TQ1G63BFA (1Gbit DDR3, x16) @ 3.20ns */
> +#define VC3_MPAR_bank_addr_cnt    3
> +#define VC3_MPAR_row_addr_cnt     13
> +#define VC3_MPAR_col_addr_cnt     10
> +#define VC3_MPAR_tREFI            2437
> +#define VC3_MPAR_tRAS_min         12
> +#define VC3_MPAR_CL               6
> +#define VC3_MPAR_tWTR             4
> +#define VC3_MPAR_tRC              16
> +#define VC3_MPR_tFAW             16
> +#define VC3_MPAR_tRP              5
> +#define VC3_MPAR_tRRD             4
> +#define VC3_MPAR_tRCD             5
> +#define VC3_MPAR_tMRD             4
> +#define VC3_MPAR_tRFC             35
> +#define VC3_MPAR_CWL              5
> +#define VC3_MPAR_tXPR             38
> +#define VC3_MPAR_tMOD             12
> +#define VC3_MPAR_tDLLK            512
> +#define VC3_MPAR_tWR              5
> +
> +#elif defined(CONFIG_DDRTYPE_MT41J128M16HA) /* Validation board */
> +
> +/* Micron MT41J128M16HA-15E:D (2Gbit DDR3, x16) @ 3.20ns */
> +#define VC3_MPAR_bank_addr_cnt    3
> +#define VC3_MPAR_row_addr_cnt     14
> +#define VC3_MPAR_col_addr_cnt     10
> +#define VC3_MPAR_tREFI            2437
> +#define VC3_MPAR_tRAS_min         12
> +#define VC3_MPAR_CL               5
> +#define VC3_MPAR_tWTR             4
> +#define VC3_MPAR_tRC              16
> +#define VC3_MPAR_tFAW             16
> +#define VC3_MPAR_tRP              5
> +#define VC3_MPAR_tRRD             4
> +#define VC3_MPAR_tRCD             5
> +#define VC3_MPAR_tMRD             4
> +#define VC3_MPAR_tRFC             50
> +#define VC3_MPAR_CWL              5
> +#define VC3_MPAR_tXPR             54
> +#define VC3_MPAR_tMOD             12
> +#define VC3_MPAR_tDLLK            512
> +#define VC3_MPAR_tWR              5
> +
> +#elif defined(CONFIG_DDRTYPE_MT41K256M16) /* JR2 Validation board */
> +
> +/* Micron MT41K256M16 (4Gbit, DDR3L-800, 256Mbitx16) @ 3.20ns */
> +#define VC3_MPAR_bank_addr_cnt    3
> +#define VC3_MPAR_row_addr_cnt     15
> +#define VC3_MPAR_col_addr_cnt     10
> +#define VC3_MPAR_tREFI            2437
> +#define VC3_MPAR_tRAS_min         12
> +#define VC3_MPAR_CL               5
> +#define VC3_MPAR_tWTR             4
> +#define VC3_MPAR_tRC              16
> +#define VC3_MPAR_tFAW             16
> +#define VC3_MPAR_tRP              5
> +#define VC3_MPAR_tRRD             4
> +#define VC3_MPAR_tRCD             5
> +#define VC3_MPAR_tMRD             4
> +#define VC3_MPAR_tRFC             82
> +#define VC3_MPAR_CWL              5
> +#define VC3_MPAR_tXPR             85
> +#define VC3_MPAR_tMOD             12
> +#define VC3_MPAR_tDLLK            512
> +#define VC3_MPAR_tWR              5
> +
> +#elif defined(CONFIG_DDRTYPE_H5TQ4G63MFR) /* JR2 Reference board */
> +
> +/* Hynix H5TQ4G63MFR-PBC (4Gbit, DDR3-800, 256Mbitx16) - 2kb pages @ 3.20ns */
> +#define VC3_MPAR_bank_addr_cnt    3
> +#define VC3_MPAR_row_addr_cnt     15
> +#define VC3_MPAR_col_addr_cnt     10
> +#define VC3_MPAR_tREFI            2437
> +#define VC3_MPAR_tRAS_min         12
> +#define VC3_MPAR_CL               6
> +#define VC3_MPAR_tWTR             4
> +#define VC3_MPAR_tRC              17
> +#define VC3_MPAR_tFAW             16
> +#define VC3_MPAR_tRP              5
> +#define VC3_MPAR_tRRD             4
> +#define VC3_MPAR_tRCD             5
> +#define VC3_MPAR_tMRD             4
> +#define VC3_MPAR_tRFC             82
> +#define VC3_MPAR_CWL              5
> +#define VC3_MPAR_tXPR             85
> +#define VC3_MPAR_tMOD             12
> +#define VC3_MPAR_tDLLK            512
> +#define VC3_MPAR_tWR              5
> +
> +#elif defined(CONFIG_DDRTYPE_MT41K128M16JT)
> +
> +/* Micron Micron MT41K128M16JT-125 (2Gbit DDR3L, 128Mbitx16) @ 3.20ns */
> +#define VC3_MPAR_bank_addr_cnt    3
> +#define VC3_MPAR_row_addr_cnt     14
> +#define VC3_MPAR_col_addr_cnt     10
> +#define VC3_MPAR_tREFI            2437
> +#define VC3_MPAR_tRAS_min         12
> +#define VC3_MPAR_CL               6
> +#define VC3_MPAR_tWTR             4
> +#define VC3_MPAR_tRC              16
> +#define VC3_MPAR_tFAW             16
> +#define VC3_MPAR_tRP              5
> +#define VC3_MPAR_tRRD             4
> +#define VC3_MPAR_tRCD             5
> +#define VC3_MPAR_tMRD             4
> +#define VC3_MPAR_tRFC             82
> +#define VC3_MPAR_CWL              5
> +#define VC3_MPAR_tXPR             85
> +#define VC3_MPAR_tMOD             12
> +#define VC3_MPAR_tDLLK            512
> +#define VC3_MPAR_tWR              5
> +
> +#elif defined(CONFIG_DDRTYPE_MT47H128M8HQ) /* Luton10/26 Refboards */
> +
> +/* Micron 1Gb MT47H128M8-3 16Meg x 8 x 8 banks, DDR-533 at CL4 @ 4.80ns */
> +#define VC3_MPAR_bank_addr_cnt    3
> +#define VC3_MPAR_row_addr_cnt     14
> +#define VC3_MPAR_col_addr_cnt     10
> +#define VC3_MPAR_tREFI            1625
> +#define VC3_MPAR_tRAS_min         9
> +#define VC3_MPAR_CL               4
> +#define VC3_MPAR_tWTR             2
> +#define VC3_MPAR_tRC              12
> +#define VC3_MPAR_tFAW             8
> +#define VC3_MPAR_tRP              4
> +#define VC3_MPAR_tRRD             2
> +#define VC3_MPAR_tRCD             4
> +
> +#define VC3_MPAR_tRPA             4
> +#define VC3_MPAR_tRP              4
> +
> +#define VC3_MPAR_tMRD             2
> +#define VC3_MPAR_tRFC             27
> +
> +#define VC3_MPAR__400_ns_dly      84
> +
> +#define VC3_MPAR_tWR              4
> +#undef MIPS_VCOREIII_MEMORY_DDR3
> +#else
> +
> +#error Unknown DDR system configuration - please add!
> +
> +#endif
> +
> +#ifdef CONFIG_SOC_OCELOT
> +#define MIPS_VCOREIII_MEMORY_16BIT 1
> +#endif
> +
> +#define MIPS_VCOREIII_MEMORY_SSTL_ODT 7
> +#define MIPS_VCOREIII_MEMORY_SSTL_DRIVE 7
> +#define VCOREIII_DDR_DQS_MODE_CALIBRATE
> +
> +#ifdef MIPS_VCOREIII_MEMORY_16BIT
> + #define VC3_MPAR_16BIT       1
> +#else
> + #define VC3_MPAR_16BIT       0
> +#endif
> +
> +#ifdef MIPS_VCOREIII_MEMORY_DDR3
> + #define VC3_MPAR_DDR3_MODE    1 /* DDR3 */
> + #define VC3_MPAR_BURST_LENGTH 8 /* Always 8 (1) for DDR3 */
> + #ifdef MIPS_VCOREIII_MEMORY_16BIT
> +#define VC3_MPAR_BURST_SIZE   1 /* Always 1 for DDR3/16bit */
> + #else
> +  #define VC3_MPAR_BURST_SIZE   0
> + #endif
> +#else
> + #define VC3_MPAR_DDR3_MODE    0 /* DDR2 */
> + #ifdef MIPS_VCOREIII_MEMORY_16BIT
> +  #define VC3_MPAR_BURST_LENGTH 4 /* in DDR2 16-bit mode, use burstlen 4 */
> + #else
> +  #define VC3_MPAR_BURST_LENGTH 8 /* For 8-bit IF we must run burst-8 */
> + #endif
> + #define VC3_MPAR_BURST_SIZE   0 /* Always 0 for DDR2 */
> +#endif
> +
> +#define VC3_MPAR_RL VC3_MPAR_CL
> +#if !defined(MIPS_VCOREIII_MEMORY_DDR3)
> +#define VC3_MPAR_WL (VC3_MPAR_RL-1)
> +#define VC3_MPAR_MD VC3_MPAR_tMRD
> +#define VC3_MPAR_ID VC3_MPAR__400_ns_dly
> +#define VC3_MPAR_SD VC3_MPAR_tXSRD
> +#define VC3_MPAR_OW (VC3_MPAR_WL-2)
> +#define VC3_MPAR_OR (VC3_MPAR_WL-3)
> +#define VC3_MPAR_RP (VC3_MPAR_bank_addr_cnt < 3 ? VC3_MPAR_tRP : VC3_MPAR_tRPA)
> +#define VC3_MPAR_FAW (VC3_MPAR_bank_addr_cnt < 3 ? 1 : VC3_MPAR_tFAW)
> +#define VC3_MPAR_BL (VC3_MPAR_BURST_LENGTH == 4 ? 2 : 4)
> +#define MSCC_MEMPARM_MR0 \
> +	(VC3_MPAR_BURST_LENGTH == 8 ? 3 : 2) | (VC3_MPAR_CL << 4) | ((VC3_MPAR_tWR-1) << 9)
> +#define MSCC_MEMPARM_MR1 0x382 /* DLL-on, Full-OD, AL=0, RTT=off, nDQS-on, RDQS-off, out-en */
> +#define MSCC_MEMPARM_MR2 0
> +#define MSCC_MEMPARM_MR3 0
> +#else
> +#define VC3_MPAR_WL VC3_MPAR_CWL
> +#define VC3_MPAR_MD VC3_MPAR_tMOD
> +#define VC3_MPAR_ID VC3_MPAR_tXPR
> +#define VC3_MPAR_SD VC3_MPAR_tDLLK
> +#define VC3_MPAR_OW 2
> +#define VC3_MPAR_OR 2
> +#define VC3_MPAR_RP VC3_MPAR_tRP
> +#define VC3_MPAR_FAW VC3_MPAR_tFAW
> +#define VC3_MPAR_BL 4
> +#define MSCC_MEMPARM_MR0 ((VC3_MPAR_RL - 4) << 4) | ((VC3_MPAR_tWR - 4) << 9)
> +#define MSCC_MEMPARM_MR1 0x0040 /* ODT_RTT: “0x0040” for 120ohm, and “0x0004” for 60ohm. */
> +#define MSCC_MEMPARM_MR2 ((VC3_MPAR_WL - 5) << 3)
> +#define MSCC_MEMPARM_MR3 0
> +#endif  /* MIPS_VCOREIII_MEMORY_DDR3 */
> +
> +#define MSCC_MEMPARM_MEMCFG                                             \
> +    ((MIPS_VCOREIII_DDR_SIZE > SZ_512M) ?                    \
> +     ICPU_MEMCTRL_CFG_DDR_512MBYTE_PLUS : 0) |       \
> +    (VC3_MPAR_16BIT ? ICPU_MEMCTRL_CFG_DDR_WIDTH : 0) | \
> +    (VC3_MPAR_DDR3_MODE ? ICPU_MEMCTRL_CFG_DDR_MODE : 0) | \
> +    (VC3_MPAR_BURST_SIZE ? ICPU_MEMCTRL_CFG_BURST_SIZE : 0) | \
> +    (VC3_MPAR_BURST_LENGTH == 8 ? ICPU_MEMCTRL_CFG_BURST_LEN : 0) | \
> +    (VC3_MPAR_bank_addr_cnt == 3 ? ICPU_MEMCTRL_CFG_BANK_CNT : 0) | \
> +    ICPU_MEMCTRL_CFG_MSB_ROW_ADDR(VC3_MPAR_row_addr_cnt-1) | \
> +    ICPU_MEMCTRL_CFG_MSB_COL_ADDR(VC3_MPAR_col_addr_cnt-1)
> +
> +#define MSCC_MEMPARM_PERIOD                                             \
> +    ICPU_MEMCTRL_REF_PERIOD_MAX_PEND_REF(8) |        \
> +    ICPU_MEMCTRL_REF_PERIOD_REF_PERIOD(VC3_MPAR_tREFI)
> +
> +#ifdef CONFIG_SOC_OCELOT
> +#define MSCC_MEMPARM_TIMING0                                            \
> +    ICPU_MEMCTRL_TIMING0_RD_TO_WR_DLY(VC3_MPAR_RL+VC3_MPAR_BL+1-VC3_MPAR_WL) | \
> +    ICPU_MEMCTRL_TIMING0_WR_CS_CHANGE_DLY(VC3_MPAR_BL-1) | \
> +    ICPU_MEMCTRL_TIMING0_RD_CS_CHANGE_DLY(VC3_MPAR_BL) | \
> +    ICPU_MEMCTRL_TIMING0_RAS_TO_PRECH_DLY(VC3_MPAR_tRAS_min-1) | \
> +    ICPU_MEMCTRL_TIMING0_WR_TO_PRECH_DLY(VC3_MPAR_WL + \
> +                                                            VC3_MPAR_BL + \
> +                                                            VC3_MPAR_tWR - 1) | \
> +    ICPU_MEMCTRL_TIMING0_RD_TO_PRECH_DLY(VC3_MPAR_BL-1) | \
> +    ICPU_MEMCTRL_TIMING0_WR_DATA_XFR_DLY(VC3_MPAR_WL-1) | \
> +    ICPU_MEMCTRL_TIMING0_RD_DATA_XFR_DLY(VC3_MPAR_RL-3)
> +
> +#define MSCC_MEMPARM_TIMING1                                            \
> +    ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_SAME_BANK_DLY(VC3_MPAR_tRC-1) | \
> +    ICPU_MEMCTRL_TIMING1_BANK8_FAW_DLY(VC3_MPAR_FAW-1) | \
> +    ICPU_MEMCTRL_TIMING1_PRECH_TO_RAS_DLY(VC3_MPAR_RP-1) | \
> +    ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_DLY(VC3_MPAR_tRRD-1) | \
> +    ICPU_MEMCTRL_TIMING1_RAS_TO_CAS_DLY(VC3_MPAR_tRCD-1) | \
> +    ICPU_MEMCTRL_TIMING1_WR_TO_RD_DLY(VC3_MPAR_WL +  \
> +                                                         VC3_MPAR_BL +  \
> +                                                         VC3_MPAR_tWTR - 1)
> +
> +#define MSCC_MEMPARM_TIMING2				\
> +    ICPU_MEMCTRL_TIMING2_PRECH_ALL_DLY(VC3_MPAR_RP-1) | \
> +    ICPU_MEMCTRL_TIMING2_MDSET_DLY(VC3_MPAR_MD-1) |  \
> +    ICPU_MEMCTRL_TIMING2_REF_DLY(VC3_MPAR_tRFC-1) |  \
> +    ICPU_MEMCTRL_TIMING2_INIT_DLY(VC3_MPAR_ID-1)
> +
> +#define MSCC_MEMPARM_TIMING3 \
> +    ICPU_MEMCTRL_TIMING3_WR_TO_RD_CS_CHANGE_DLY(VC3_MPAR_WL + VC3_MPAR_tWTR - 1) | \
> +    ICPU_MEMCTRL_TIMING3_ODT_RD_DLY(VC3_MPAR_OR-1) | \
> +    ICPU_MEMCTRL_TIMING3_ODT_WR_DLY(VC3_MPAR_OW-1) | \
> +    ICPU_MEMCTRL_TIMING3_LOCAL_ODT_RD_DLY(VC3_MPAR_RL-3)
> +
> +#else
> +#define MSCC_MEMPARM_TIMING0                                            \
> +    ICPU_MEMCTRL_TIMING0_RAS_TO_PRECH_DLY(VC3_MPAR_tRAS_min-1) | \
> +    ICPU_MEMCTRL_TIMING0_WR_TO_PRECH_DLY(VC3_MPAR_CL + \
> +					 (VC3_MPAR_BURST_LENGTH == 8 ? 2 : 0) +	\
> +                                                            VC3_MPAR_tWR) | \
> +    ICPU_MEMCTRL_TIMING0_RD_TO_PRECH_DLY(VC3_MPAR_BURST_LENGTH == 8 ? 3 : 1) | \
> +    ICPU_MEMCTRL_TIMING0_WR_DATA_XFR_DLY(VC3_MPAR_CL-3) | \
> +    ICPU_MEMCTRL_TIMING0_RD_DATA_XFR_DLY(VC3_MPAR_CL-3)
> +
> +#define MSCC_MEMPARM_TIMING1                                            \
> +    ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_SAME_BANK_DLY(VC3_MPAR_tRC-1) | \
> +    ICPU_MEMCTRL_TIMING1_BANK8_FAW_DLY(VC3_MPAR_tFAW) |   \
> +    ICPU_MEMCTRL_TIMING1_PRECH_TO_RAS_DLY(VC3_MPAR_tRP-1) | \
> +    ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_DLY(VC3_MPAR_tRRD-1) | \
> +    ICPU_MEMCTRL_TIMING1_RAS_TO_CAS_DLY(VC3_MPAR_tRCD-1) | \
> +    ICPU_MEMCTRL_TIMING1_WR_TO_RD_DLY(VC3_MPAR_CL +  \
> +				      (VC3_MPAR_BURST_LENGTH == 8 ? 2 : 0) + \
> +				      VC3_MPAR_tWTR)
> +#define MSCC_MEMPARM_TIMING2                                            \
> +    ICPU_MEMCTRL_TIMING2_PRECH_ALL_DLY(VC3_MPAR_tRPA-1) | \
> +    ICPU_MEMCTRL_TIMING2_MDSET_DLY(VC3_MPAR_tMRD-1) |  \
> +    ICPU_MEMCTRL_TIMING2_REF_DLY(VC3_MPAR_tRFC-1) |  \
> +    ICPU_MEMCTRL_TIMING2_FOUR_HUNDRED_NS_DLY(VC3_MPAR__400_ns_dly)
> +
> +#define MSCC_MEMPARM_TIMING3 \
> +    ICPU_MEMCTRL_TIMING3_WR_TO_RD_CS_CHANGE_DLY(VC3_MPAR_CL-1) | \
> +    ICPU_MEMCTRL_TIMING3_ODT_WR_DLY(VC3_MPAR_CL-1) | \
> +    ICPU_MEMCTRL_TIMING3_LOCAL_ODT_RD_DLY(VC3_MPAR_CL-3)
> +
> +#endif
> +
> +enum {
> +    DDR_TRAIN_OK,
> +    DDR_TRAIN_CONTINUE,
> +    DDR_TRAIN_ERROR,
> +};
> +
> +/* We actually have very few 'pause' possibilities apart from
> + * these assembly nops (at this very early stage). */
> +#define PAUSE() asm volatile("nop; nop; nop; nop; nop; nop; nop; nop")
> +
> +
> +/* NB: Assumes inlining as no stack is available! */
> +static inline void set_dly(u32 bytelane, u32 dly)
> +{
> +    register u32 r = readl(REG_CFG(ICPU_MEMCTRL_DQS_DLY(bytelane)));
> +    r &= ~ICPU_MEMCTRL_DQS_DLY_DQS_DLY_M;
> +    r |= ICPU_MEMCTRL_DQS_DLY_DQS_DLY(dly);
> +    writel(r, REG_CFG(ICPU_MEMCTRL_DQS_DLY(bytelane)));
> +}
> +
> +static inline bool incr_dly(u32 bytelane)
> +{
> +    register u32 r = readl(REG_CFG(ICPU_MEMCTRL_DQS_DLY(bytelane)));
> +    if (ICPU_MEMCTRL_DQS_DLY_DQS_DLY(r) < 31) {
> +	    writel(r + 1, REG_CFG(ICPU_MEMCTRL_DQS_DLY(bytelane)));
> +	    return true;
> +    }
> +
> +    return false;
> +}
> +static inline bool adjust_dly(int adjust)
> +{
> +    register u32 r = readl(REG_CFG(ICPU_MEMCTRL_DQS_DLY(0)));
> +    if (ICPU_MEMCTRL_DQS_DLY_DQS_DLY(r) < 31) {
> +	    writel(r + adjust, REG_CFG(ICPU_MEMCTRL_DQS_DLY(0)));
> +	    return true;
> +    }
> +
> +    return false;
> +}
> +
> +/* NB: Assumes inlining as no stack is available! */
> +static inline void center_dly(u32 bytelane, u32 start)
> +{
> +    register u32 r = readl(REG_CFG(ICPU_MEMCTRL_DQS_DLY(bytelane))) - start;
> +    writel(start + (r >> 1), REG_CFG(ICPU_MEMCTRL_DQS_DLY(bytelane)));
> +}
> +
> +static inline void memphy_soft_reset(void)
> +{
> +        writel(readl(REG_CFG(ICPU_MEMPHY_CFG)) | ICPU_MEMPHY_CFG_PHY_FIFO_RST,
> +	       REG_CFG(ICPU_MEMPHY_CFG));
> +        PAUSE();
> +        writel(readl(REG_CFG(ICPU_MEMPHY_CFG)) & ~ICPU_MEMPHY_CFG_PHY_FIFO_RST,
> +	       REG_CFG(ICPU_MEMPHY_CFG));
> +        PAUSE();
> +}
> +#ifdef CONFIG_SOC_OCELOT
> +static u8 training_data[] = { 0xfe, 0x11, 0x33, 0x55, 0x77, 0x99, 0xbb, 0xdd };
> +
> +static inline void sleep_100ns(u32 val)
> +{
> +        /* Set the timer tick generator to 100 ns */
> +        writel(VCOREIII_TIMER_DIVIDER-1, REG_CFG(ICPU_TIMER_TICK_DIV));
> +
> +        /* Set the timer value */
> +        writel(val, REG_CFG(ICPU_TIMER_VALUE(0)));
> +
> +        /* Enable timer 0 for one-shot */
> +        writel(ICPU_TIMER_CTRL_ONE_SHOT_ENA | ICPU_TIMER_CTRL_TIMER_ENA,
> +	       REG_CFG(ICPU_TIMER_CTRL(0)));
> +
> +        /* Wait for timer 0 to reach 0 */
> +        while (readl(REG_CFG(ICPU_TIMER_VALUE(0))) != 0)
> +                ;
> +}
> +
> +static inline void hal_vcoreiii_ddr_reset_assert(void)
> +{
> +        /* DDR has reset pin on GPIO 19 toggle Low-High to release */
> +        writel(readl(REG_GCB(PERF_GPIO_OE)) | BIT(19), REG_GCB(PERF_GPIO_OE));
> +        writel(BIT(19), REG_GCB(PERF_GPIO_OUT_CLR));
> +        sleep_100ns(10000);
> +}
> +
> +static inline void hal_vcoreiii_ddr_reset_release(void)
> +{
> +        /* DDR has reset pin on GPIO 19 toggle Low-High to release */
> +        writel(readl(REG_GCB(PERF_GPIO_OE)) | BIT(19), REG_GCB(PERF_GPIO_OE));
> +        writel(BIT(19), REG_GCB(PERF_GPIO_OUT_SET));
> +        sleep_100ns(10000);
> +}
> +
> +/*
> + * DDR memory sanity checking failed, tally and do hard reset
> + *
> + * NB: Assumes inlining as no stack is available!
> + */
> +static inline void hal_vcoreiii_ddr_failed(void)
> +{
> +        register u32 reset;
> +
> +        writel(readl(REG_CFG(ICPU_GPR(6))) + 1, REG_CFG(ICPU_GPR(6)));
> +
> +        writel(readl(REG_GCB(PERF_GPIO_OE)) & ~BIT(19),
> +	       REG_GCB(PERF_GPIO_OE));
> +
> +        /* Jump to reset - does not return */
> +        reset = KSEG0ADDR(_machine_restart);
> +        icache_lock((void*)reset, 128); // Reset while running from cache
> +        asm volatile ("jr %0" : : "r" (reset));
> +
> +        while(1)
> +                ;

can't you just use panic() or hang()?

> +}
> +/*
> + * DDR memory sanity checking done, possibly enable ECC.
> + *
> + * NB: Assumes inlining as no stack is available!
> + */
> +static inline void hal_vcoreiii_ddr_verified(void)
> +{
> +#ifdef MIPS_VCOREIII_MEMORY_ECC
> +        /* Finally, enable ECC */
> +	u32 val = readl(REG_CFG(ICPU_MEMCTRL_CFG));

shouldn't it "register u32 val" like in the other functions?

> +
> +	val |= ICPU_MEMCTRL_CFG_DDR_ECC_ERR_ENA;
> +	val &= ~ICPU_MEMCTRL_CFG_BURST_SIZE;
> +
> +	writel(val, REG_CFG(ICPU_MEMCTRL_CFG));
> +#endif
> +
> +        /* Reset Status register - sticky bits */
> +        writel(readl(REG_CFG(ICPU_MEMCTRL_STAT)),
> +	       REG_CFG(ICPU_MEMCTRL_STAT));
> +}
> +/* NB: Assumes inlining as no stack is available! */
> +static inline int look_for(u32 bytelane)
> +{
> +    register u32 i;
> +    /* Reset FIFO in case any previous access failed */
> +    for (i = 0; i < sizeof(training_data); i++) {
> +        register u32 byte;
> +        memphy_soft_reset();
> +        /* Reset sticky bits */
> +        writel(readl(REG_CFG(ICPU_MEMCTRL_STAT)), REG_CFG(ICPU_MEMCTRL_STAT));
> +        /* Read data */
> +        byte = ((volatile u8 *) MSCC_DDR_TO)[bytelane + (i * 4)];
> +        if (readl(REG_CFG(ICPU_MEMCTRL_STAT)) &
> +            (ICPU_MEMCTRL_STAT_RDATA_MASKED|
> +             ICPU_MEMCTRL_STAT_RDATA_DUMMY)) {
> +		/* Noise on the line */
> +            goto read_error;
> +        }
> +        /* If mismatch, increment DQS - if possible */
> +        if (byte != training_data[i]) {
> +      read_error:
> +            if (!incr_dly(bytelane)) {
> +                return DDR_TRAIN_ERROR;
> +            }
> +            return DDR_TRAIN_CONTINUE;
> +        }
> +    }
> +    return DDR_TRAIN_OK;
> +}
> +
> +
> +/* NB: Assumes inlining as no stack is available! */
> +static inline int look_past(u32 bytelane)
> +{
> +    register u32 i;
> +    /* Reset FIFO in case any previous access failed */
> +    for (i = 0; i < sizeof(training_data); i++) {
> +        register u32 byte;
> +        memphy_soft_reset();
> +        /* Ack sticky bits */
> +        writel(readl(REG_CFG(ICPU_MEMCTRL_STAT)), REG_CFG(ICPU_MEMCTRL_STAT));
> +        byte = ((volatile u8 *) MSCC_DDR_TO)[bytelane + (i * 4)];
> +        if (readl(REG_CFG(ICPU_MEMCTRL_STAT)) &
> +            (ICPU_MEMCTRL_STAT_RDATA_MASKED|
> +             ICPU_MEMCTRL_STAT_RDATA_DUMMY)) {
> +		/* Noise on the line */
> +            goto read_error;
> +        }
> +        /* Bail out when we see first mismatch */
> +        if (byte != training_data[i]) {
> +      read_error:
> +            return DDR_TRAIN_OK;
> +        }
> +    }
> +    /* All data compares OK, increase DQS and retry */
> +    if (!incr_dly(bytelane))
> +        return DDR_TRAIN_ERROR;
> +
> +    return DDR_TRAIN_CONTINUE;
> +}
> +
> +static inline int hal_vcoreiii_train_bytelane(u32 bytelane)
> +{
> +    register int res;
> +    register u32 dqs_s;
> +
> +    set_dly(bytelane, 0);    // Start training at DQS=0
> +    while ((res = look_for(bytelane)) == DDR_TRAIN_CONTINUE)
> +        ;
> +    if(res != DDR_TRAIN_OK)
> +        return res;
> +
> +    dqs_s = readl(REG_CFG(ICPU_MEMCTRL_DQS_DLY(bytelane)));
> +    while ((res = look_past(bytelane)) == DDR_TRAIN_CONTINUE)
> +        ;
> +    if(res != DDR_TRAIN_OK)
> +        return res;
> +    /* Reset FIFO - for good measure */
> +    memphy_soft_reset();
> +    /* Adjust to center [dqs_s;cur] */
> +    center_dly(bytelane, dqs_s);
> +    return DDR_TRAIN_OK;
> +}
> +/* This algorithm is converted from the TCL training algorithm used
> + * during silicon simulation.
> + * NB: Assumes inlining as no stack is available!
> + */
> +static inline int hal_vcoreiii_init_dqs(void)
> +{
> +#define MAX_DQS 32
> +    register u32 i, j;
> +    for (i = 0; i < MAX_DQS; i++) {
> +        set_dly(0, i);    // Byte-lane 0
> +        for (j = 0; j < MAX_DQS; j++) {
> +            register  u32 __attribute__ ((unused)) byte;
> +            set_dly(1, j);    // Byte-lane 1
> +            /* Reset FIFO in case any previous access failed */
> +            memphy_soft_reset();
> +            writel(readl(REG_CFG(ICPU_MEMCTRL_STAT)),
> +		   REG_CFG(ICPU_MEMCTRL_STAT));
> +            byte = ((volatile u8 *) MSCC_DDR_TO)[0];
> +            byte = ((volatile u8 *) MSCC_DDR_TO)[1];
> +            if (readl(REG_CFG(ICPU_MEMCTRL_STAT)) &
> +                (ICPU_MEMCTRL_STAT_RDATA_MASKED|
> +                 ICPU_MEMCTRL_STAT_RDATA_DUMMY)) {
> +            } else {
> +                return 0;
> +            }
> +        }
> +    }
> +    return -1;
> +}
> +
> +
> +static inline int dram_check(void)
> +{
> +#define DDR ((volatile u32 *) MSCC_DDR_TO)
> +        register u32 i;
> +
> +        for (i = 0; i < 8; i++) {
> +                DDR[i] = ~i;
> +                if (DDR[i] != ~i) {
> +                        return 1;
> +                }
> +        }
> +        return 0;
> +}
> +#else /* Luton */
> +
> +static inline void sleep_100ns(u32 val)
> +{
> +}
> +static inline void hal_vcoreiii_ddr_reset_assert(void)
> +{
> +}
> +static inline void hal_vcoreiii_ddr_reset_release(void)
> +{
> +}
> +static inline void hal_vcoreiii_ddr_failed(void)
> +{
> +	register u32 memphy_cfg = readl(REG_CFG(ICPU_MEMPHY_CFG));
> +
> +	/* Do a fifo reset and start over */
> +	writel( memphy_cfg | ICPU_MEMPHY_CFG_PHY_FIFO_RST,
> +		       REG_CFG(ICPU_MEMPHY_CFG));
> +	writel( memphy_cfg & ~ICPU_MEMPHY_CFG_PHY_FIFO_RST,
> +		       REG_CFG(ICPU_MEMPHY_CFG));
> +	writel( memphy_cfg | ICPU_MEMPHY_CFG_PHY_FIFO_RST,
> +		       REG_CFG(ICPU_MEMPHY_CFG));
> +}
> +
> +static inline void hal_vcoreiii_ddr_verified(void){}
> +
> +static inline int look_for(u32 data)
> +{
> +	register u32 byte = ((volatile u8 *) MSCC_DDR_TO)[0];
> +
> +	if (data != byte)  {
> +		if (!incr_dly(0))
> +			return DDR_TRAIN_ERROR;
> +		return DDR_TRAIN_CONTINUE;
> +	}
> +
> +	return DDR_TRAIN_OK;
> +}
> +
> +/* This algorithm is converted from the TCL training algorithm used
> + * during silicon simulation.
> + * NB: Assumes inlining as no stack is available!
> + */
> +static inline int hal_vcoreiii_train_bytelane(u32 bytelane)
> +{
> +    register int res;
> +
> +    set_dly(bytelane, 0);    // Start training at DQS=0
> +    while ((res = look_for(0xff)) == DDR_TRAIN_CONTINUE)
> +        ;
> +    if(res != DDR_TRAIN_OK)
> +        return res;
> +
> +    set_dly(bytelane, 0);    // Start training at DQS=0
> +    while ((res = look_for(0x00)) == DDR_TRAIN_CONTINUE)
> +        ;
> +
> +    if(res != DDR_TRAIN_OK)
> +        return res;
> +
> +    adjust_dly(-3);
> +
> +    return DDR_TRAIN_OK;
> +}
> +
> +static inline int hal_vcoreiii_init_dqs(void)
> +{
> +	return 0;
> +}
> +
> +static inline int dram_check(void)
> +{
> +#define DDR ((volatile u32 *) MSCC_DDR_TO)
> +        register u32 i;
> +
> +        for (i = 0; i < 8; i++) {
> +                DDR[i] = ~i;
> +                if (DDR[i] != ~i) {
> +                        return 1;
> +                }
> +        }
> +
> +        return 0;
> +}
> +#endif
> +
> +/* NB: Called *early* to init memory controller -
> + * assumes inlining as no stack is available! */
> +static inline void hal_vcoreiii_init_memctl(void)
> +{
> +        /* Ensure DDR is in reset */
> +        hal_vcoreiii_ddr_reset_assert();
> +
> +        /* Wait maybe not needed, but ... */
> +        PAUSE();
> +
> +        /* Drop sys ctl memory controller forced reset */
> +        writel(readl(REG_CFG(ICPU_RESET)) & ~ICPU_RESET_MEM_RST_FORCE, REG_CFG(ICPU_RESET));
> +        PAUSE();
> +
> +        /* Drop Reset, enable SSTL */
> +        writel(ICPU_MEMPHY_CFG_PHY_SSTL_ENA, REG_CFG(ICPU_MEMPHY_CFG));
> +        PAUSE();
> +
> +        /* Start the automatic SSTL output and ODT drive-strength calibration */
> +        writel(/* ODT */
> +              ICPU_MEMPHY_ZCAL_ZCAL_PROG_ODT(MIPS_VCOREIII_MEMORY_SSTL_ODT) |
> +              /* drive strength */
> +              ICPU_MEMPHY_ZCAL_ZCAL_PROG(MIPS_VCOREIII_MEMORY_SSTL_DRIVE)   |
> +              /* Start calibration process */
> +              ICPU_MEMPHY_ZCAL_ZCAL_ENA, REG_CFG(ICPU_MEMPHY_ZCAL));
> +
> +        while(readl(REG_CFG(ICPU_MEMPHY_ZCAL)) & ICPU_MEMPHY_ZCAL_ZCAL_ENA)
> +                ;                       /* Wait for ZCAL to clear */
> +#ifdef CONFIG_SOC_OCELOT
> +        /* Check no ZCAL_ERR */
> +        if (readl(REG_CFG(ICPU_MEMPHY_ZCAL_STAT)) & ICPU_MEMPHY_ZCAL_STAT_ZCAL_ERR) {
> +                hal_vcoreiii_ddr_failed();
> +        }
> +#endif
> +        /* Drive CL, CK, ODT */
> +        writel(readl(REG_CFG(ICPU_MEMPHY_CFG)) |
> +	       ICPU_MEMPHY_CFG_PHY_ODT_OE |
> +	       ICPU_MEMPHY_CFG_PHY_CK_OE |
> +	       ICPU_MEMPHY_CFG_PHY_CL_OE, REG_CFG(ICPU_MEMPHY_CFG));
> +
> +        /* Initialize memory controller */
> +        writel(MSCC_MEMPARM_MEMCFG, REG_CFG(ICPU_MEMCTRL_CFG));
> +        writel(MSCC_MEMPARM_PERIOD, REG_CFG(ICPU_MEMCTRL_REF_PERIOD));
> +
> +        writel(MSCC_MEMPARM_TIMING0, REG_CFG(ICPU_MEMCTRL_TIMING0));
> +        writel(MSCC_MEMPARM_TIMING1, REG_CFG(ICPU_MEMCTRL_TIMING1));
> +        writel(MSCC_MEMPARM_TIMING2, REG_CFG(ICPU_MEMCTRL_TIMING2));
> +        writel(MSCC_MEMPARM_TIMING3, REG_CFG(ICPU_MEMCTRL_TIMING3));
> +        writel(MSCC_MEMPARM_MR0, REG_CFG(ICPU_MEMCTRL_MR0_VAL));
> +        writel(MSCC_MEMPARM_MR1, REG_CFG(ICPU_MEMCTRL_MR1_VAL));
> +        writel(MSCC_MEMPARM_MR2, REG_CFG(ICPU_MEMCTRL_MR2_VAL));
> +        writel(MSCC_MEMPARM_MR3, REG_CFG(ICPU_MEMCTRL_MR3_VAL));
> +
> +#ifdef CONFIG_SOC_OCELOT
> +        /* Termination setup - enable ODT */
> +        writel(ICPU_MEMCTRL_TERMRES_CTRL_LOCAL_ODT_RD_ENA |
> +               /* Assert ODT0 for any write */
> +               ICPU_MEMCTRL_TERMRES_CTRL_ODT_WR_ENA(3),
> +	       REG_CFG(ICPU_MEMCTRL_TERMRES_CTRL));
> +
> +        /* Release Reset from DDR */
> +        hal_vcoreiii_ddr_reset_release();
> +
> +        writel(readl(REG_CFG(ICPU_GPR(7))) + 1, REG_CFG(ICPU_GPR(7)));
> +#else /* Luton */
> +	/* Termination setup - disable ODT */
> +        writel(0, REG_CFG(ICPU_MEMCTRL_TERMRES_CTRL));
> +
> +#endif
> +}
> +
> +static void inline hal_vcoreiii_wait_memctl(void)
> +{
> +        /* Now, rip it! */
> +        writel(ICPU_MEMCTRL_CTRL_INITIALIZE, REG_CFG(ICPU_MEMCTRL_CTRL));
> +
> +        while(!(readl(REG_CFG(ICPU_MEMCTRL_STAT)) & ICPU_MEMCTRL_STAT_INIT_DONE))
> +                ;
> +
> +        /* Settle...? */
> +        sleep_100ns(10000);
> +#ifdef CONFIG_SOC_OCELOT
> +        /* Establish data contents in DDR RAM for training */
> +        ((volatile u32 *)MSCC_DDR_TO)[0] = 0xcacafefe;
> +        ((volatile u32 *)MSCC_DDR_TO)[1] = 0x22221111;
> +        ((volatile u32 *)MSCC_DDR_TO)[2] = 0x44443333;
> +        ((volatile u32 *)MSCC_DDR_TO)[3] = 0x66665555;
> +        ((volatile u32 *)MSCC_DDR_TO)[4] = 0x88887777;
> +        ((volatile u32 *)MSCC_DDR_TO)[5] = 0xaaaa9999;
> +        ((volatile u32 *)MSCC_DDR_TO)[6] = 0xccccbbbb;
> +        ((volatile u32 *)MSCC_DDR_TO)[7] = 0xeeeedddd;
> +#else
> +	((volatile u32 *)MSCC_DDR_TO)[0] = 0xff;
> +#endif

use writel() or at least __raw_writel()

> +}
> +#endif /* __ASM_MACH_DDR_H */
> diff --git a/arch/mips/mach-mscc/include/mach/luton/luton.h b/arch/mips/mach-mscc/include/mach/luton/luton.h
> new file mode 100644
> index 0000000000..4f761b1bb7
> --- /dev/null
> +++ b/arch/mips/mach-mscc/include/mach/luton/luton.h
> @@ -0,0 +1,37 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +/*
> + * Microsemi Ocelot Switch driver
> + *
> + * Copyright (c) 2018 Microsemi Corporation
> + */
> +
> +#ifndef _MSCC_OCELOT_H_
> +#define _MSCC_OCELOT_H_
> +
> +#include <linux/bitops.h>
> +#include <dm.h>
> +
> +/*
> + * Target offset base(s)
> + */
> +#define MSCC_IO_ORIGIN1_OFFSET 0x60000000
> +#define MSCC_IO_ORIGIN1_SIZE   0x01000000
> +#define MSCC_IO_ORIGIN2_OFFSET 0x70000000
> +#define MSCC_IO_ORIGIN2_SIZE   0x00200000
> +#ifndef MSCC_IO_OFFSET1
> +#define MSCC_IO_OFFSET1(offset) (MSCC_IO_ORIGIN1_OFFSET + offset)
> +#endif
> +#ifndef MSCC_IO_OFFSET2
> +#define MSCC_IO_OFFSET2(offset) (MSCC_IO_ORIGIN2_OFFSET + offset)
> +#endif
> +#define BASE_CFG        0x70000000
> +#define BASE_UART       0x70100000
> +#define BASE_DEVCPU_GCB 0x60070000
> +#define BASE_MACRO      0x600a0000
> +
> +#define REG_OFFSET(t, o) ((volatile unsigned long *)(t + (o)))
> +#define REG_CFG(x) REG_OFFSET(BASE_CFG, x)
> +#define REG_GCB(x) REG_OFFSET(BASE_DEVCPU_GCB, x)
> +#define REG_MACRO(x) REG_OFFSET(BASE_MACRO, x)

No header files with offsets please except when needed for ASM code.
This should come from device-tree.

> +
> +#endif
> diff --git a/arch/mips/mach-mscc/include/mach/luton/luton_devcpu_gcb.h b/arch/mips/mach-mscc/include/mach/luton/luton_devcpu_gcb.h
> new file mode 100644
> index 0000000000..0d80c8a534
> --- /dev/null
> +++ b/arch/mips/mach-mscc/include/mach/luton/luton_devcpu_gcb.h
> @@ -0,0 +1,16 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +/*
> + * Copyright (c) 2018 Microsemi Corporation
> + */
> +
> +#ifndef _MSCC_OCELOT_DEVCPU_GCB_H_
> +#define _MSCC_OCELOT_DEVCPU_GCB_H_
> +
> +#define PERF_GPR                                          0x4
> +
> +#define PERF_SOFT_RST                                     0x90
> +
> +#define PERF_SOFT_RST_SOFT_SWC_RST                        BIT(1)
> +#define PERF_SOFT_RST_SOFT_CHIP_RST                       BIT(0)
> +
> +#endif
> diff --git a/arch/mips/mach-mscc/include/mach/luton/luton_icpu_cfg-ref.h b/arch/mips/mach-mscc/include/mach/luton/luton_icpu_cfg-ref.h
> new file mode 100644
> index 0000000000..5a5fe079e1
> --- /dev/null
> +++ b/arch/mips/mach-mscc/include/mach/luton/luton_icpu_cfg-ref.h
> @@ -0,0 +1,884 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +/*
> + * Copyright (c) 2018 Microsemi Corporation
> + */
> +
> +#ifndef _MSCC_OCELOT_ICPU_CFG_H_
> +#define _MSCC_OCELOT_ICPU_CFG_H_
> +
> +#define ICPU_GPR(x) (0x4 * (x))
> +#define ICPU_GPR_RSZ                                      0x4
> +
> +#define ICPU_RESET                                        0x20
> +
> +#define ICPU_RESET_CORE_RST_CPU_ONLY                      BIT(3)
> +#define ICPU_RESET_CORE_RST_PROTECT                       BIT(2)
> +#define ICPU_RESET_CORE_RST_FORCE                         BIT(1)
> +#define ICPU_RESET_MEM_RST_FORCE                          BIT(0)

No header files with thousand of register definitions please. Only
define what you need per driver.

> +
> +#define ICPU_GENERAL_CTRL                                 0x24
> +
> +#define ICPU_GENERAL_CTRL_CPU_BUSIF_SLEEP_DIS             BIT(14)
> +#define ICPU_GENERAL_CTRL_CPU_BUSIF_WERR_ENA              BIT(13)
> +#define ICPU_GENERAL_CTRL_CPU_8051_IROM_ENA               BIT(12)
> +#define ICPU_GENERAL_CTRL_CPU_MIPS_DIS                    BIT(11)
> +#define ICPU_GENERAL_CTRL_IF_MIIM_SLV_ADDR_SEL            BIT(10)
> +#define ICPU_GENERAL_CTRL_IF_MIIM_SLV_ENA                 BIT(9)
> +#define ICPU_GENERAL_CTRL_IF_PI_SLV_DONEPOL               BIT(8)
> +#define ICPU_GENERAL_CTRL_IF_PI_MST_ENA                   BIT(7)
> +#define ICPU_GENERAL_CTRL_IF_PI_SLV_ENA                   BIT(6)
> +#define ICPU_GENERAL_CTRL_IF_SI_OWNER(x)                  (((x) << 4) & GENMASK(5, 4))
> +#define ICPU_GENERAL_CTRL_IF_SI_OWNER_M                   GENMASK(5, 4)
> +#define ICPU_GENERAL_CTRL_IF_SI_OWNER_X(x)                (((x) & GENMASK(5, 4)) >> 4)
> +#define ICPU_GENERAL_CTRL_SSI_MST_CONTENTION              BIT(3)
> +#define ICPU_GENERAL_CTRL_CPU_BE_ENA                      BIT(2)
> +#define ICPU_GENERAL_CTRL_CPU_DIS                         BIT(1)
> +#define ICPU_GENERAL_CTRL_BOOT_MODE_ENA                   BIT(0)
> +
> +#define ICPU_GENERAL_STAT                                 0x28
> +
> +#define ICPU_GENERAL_STAT_PI_SLV_WR_ERR                   BIT(9)
> +#define ICPU_GENERAL_STAT_PI_SLV_RD_ERR                   BIT(8)
> +#define ICPU_GENERAL_STAT_VCORE_CFG(x)                    (((x) << 4) & GENMASK(7, 4))
> +#define ICPU_GENERAL_STAT_VCORE_CFG_M                     GENMASK(7, 4)
> +#define ICPU_GENERAL_STAT_VCORE_CFG_X(x)                  (((x) & GENMASK(7, 4)) >> 4)
> +#define ICPU_GENERAL_STAT_REG_IF_ERR(x)                   (((x) << 1) & GENMASK(3, 1))
> +#define ICPU_GENERAL_STAT_REG_IF_ERR_M                    GENMASK(3, 1)
> +#define ICPU_GENERAL_STAT_REG_IF_ERR_X(x)                 (((x) & GENMASK(3, 1)) >> 1)
> +#define ICPU_GENERAL_STAT_CPU_SLEEP                       BIT(0)
> +
> +#define ICPU_PI_MST_CFG                                   0x2c
> +
> +#define ICPU_PI_MST_CFG_ATE_MODE_DIS                      BIT(7)
> +#define ICPU_PI_MST_CFG_CLK_POL                           BIT(6)
> +#define ICPU_PI_MST_CFG_TRISTATE_CTRL                     BIT(5)
> +#define ICPU_PI_MST_CFG_CLK_DIV(x)                        ((x) & GENMASK(4, 0))
> +#define ICPU_PI_MST_CFG_CLK_DIV_M                         GENMASK(4, 0)
> +
> +#define ICPU_PI_MST_CTRL                                  0x30
> +
> +#define ICPU_PI_MST_CTRL_DEVICE_PACED_XFER_ENA            BIT(22)
> +#define ICPU_PI_MST_CTRL_DEVICE_PACED_TIMEOUT_ENA         BIT(21)
> +#define ICPU_PI_MST_CTRL_DEVICE_PACED_TIMEOUT(x)          (((x) << 18) & GENMASK(20, 18))
> +#define ICPU_PI_MST_CTRL_DEVICE_PACED_TIMEOUT_M           GENMASK(20, 18)
> +#define ICPU_PI_MST_CTRL_DEVICE_PACED_TIMEOUT_X(x)        (((x) & GENMASK(20, 18)) >> 18)
> +#define ICPU_PI_MST_CTRL_CS_TRISTATE_CTRL                 BIT(17)
> +#define ICPU_PI_MST_CTRL_DONE_POL                         BIT(16)
> +#define ICPU_PI_MST_CTRL_SMPL_ON_DONE                     BIT(15)
> +#define ICPU_PI_MST_CTRL_WAITCC(x)                        (((x) << 7) & GENMASK(14, 7))
> +#define ICPU_PI_MST_CTRL_WAITCC_M                         GENMASK(14, 7)
> +#define ICPU_PI_MST_CTRL_WAITCC_X(x)                      (((x) & GENMASK(14, 7)) >> 7)
> +#define ICPU_PI_MST_CTRL_CSCC(x)                          (((x) << 5) & GENMASK(6, 5))
> +#define ICPU_PI_MST_CTRL_CSCC_M                           GENMASK(6, 5)
> +#define ICPU_PI_MST_CTRL_CSCC_X(x)                        (((x) & GENMASK(6, 5)) >> 5)
> +#define ICPU_PI_MST_CTRL_OECC(x)                          (((x) << 3) & GENMASK(4, 3))
> +#define ICPU_PI_MST_CTRL_OECC_M                           GENMASK(4, 3)
> +#define ICPU_PI_MST_CTRL_OECC_X(x)                        (((x) & GENMASK(4, 3)) >> 3)
> +#define ICPU_PI_MST_CTRL_HLDCC(x)                         ((x) & GENMASK(2, 0))
> +#define ICPU_PI_MST_CTRL_HLDCC_M                          GENMASK(2, 0)
> +
> +#define ICPU_PI_MST_STATUS                                0x34
> +
> +#define ICPU_PI_MST_STATUS_TIMEOUT_ERR_STICKY             BIT(0)
> +
> +#define ICPU_PI_SLV_CFG                                   0x38
> +
> +#define ICPU_PI_SLV_CFG_DONEPOL_VAL                       BIT(24)
> +#define ICPU_PI_SLV_CFG_DONEPOL_SET                       BIT(23)
> +#define ICPU_PI_SLV_CFG_BIGENDIAN                         BIT(22)
> +#define ICPU_PI_SLV_CFG_DONEPARK(x)                       (((x) << 16) & GENMASK(21, 16))
> +#define ICPU_PI_SLV_CFG_DONEPARK_M                        GENMASK(21, 16)
> +#define ICPU_PI_SLV_CFG_DONEPARK_X(x)                     (((x) & GENMASK(21, 16)) >> 16)
> +#define ICPU_PI_SLV_CFG_DONEWAIT(x)                       (((x) << 8) & GENMASK(15, 8))
> +#define ICPU_PI_SLV_CFG_DONEWAIT_M                        GENMASK(15, 8)
> +#define ICPU_PI_SLV_CFG_DONEWAIT_X(x)                     (((x) & GENMASK(15, 8)) >> 8)
> +#define ICPU_PI_SLV_CFG_CSWAIT(x)                         ((x) & GENMASK(7, 0))
> +#define ICPU_PI_SLV_CFG_CSWAIT_M                          GENMASK(7, 0)
> +
> +#define ICPU_SPI_MST_CFG                                  0x3c
> +
> +#define ICPU_SPI_MST_CFG_A32B_ENA                         BIT(11)
> +#define ICPU_SPI_MST_CFG_FAST_READ_ENA                    BIT(10)
> +#define ICPU_SPI_MST_CFG_CS_DESELECT_TIME(x)              (((x) << 5) & GENMASK(9, 5))
> +#define ICPU_SPI_MST_CFG_CS_DESELECT_TIME_M               GENMASK(9, 5)
> +#define ICPU_SPI_MST_CFG_CS_DESELECT_TIME_X(x)            (((x) & GENMASK(9, 5)) >> 5)
> +#define ICPU_SPI_MST_CFG_CLK_DIV(x)                       ((x) & GENMASK(4, 0))
> +#define ICPU_SPI_MST_CFG_CLK_DIV_M                        GENMASK(4, 0)
> +
> +#define ICPU_SPI_MST_STATUS                               0x40
> +#define ICPU_SPI_MST_STATUS_RSZ                           0x4
> +
> +#define ICPU_SPI_MST_STATUS_UNSUP_ERR                     BIT(0)
> +
> +#define ICPU_SW_MODE                                      0x50
> +
> +#define ICPU_SW_MODE_SW_PIN_CTRL_MODE                     BIT(13)
> +#define ICPU_SW_MODE_SW_SPI_SCK                           BIT(12)
> +#define ICPU_SW_MODE_SW_SPI_SCK_OE                        BIT(11)
> +#define ICPU_SW_MODE_SW_SPI_SDO                           BIT(10)
> +#define ICPU_SW_MODE_SW_SPI_SDO_OE                        BIT(9)
> +#define ICPU_SW_MODE_SW_SPI_CS(x)                         (((x) << 5) & GENMASK(8, 5))
> +#define ICPU_SW_MODE_SW_SPI_CS_M                          GENMASK(8, 5)
> +#define ICPU_SW_MODE_SW_SPI_CS_X(x)                       (((x) & GENMASK(8, 5)) >> 5)
> +#define ICPU_SW_MODE_SW_SPI_CS_OE(x)                      (((x) << 1) & GENMASK(4, 1))
> +#define ICPU_SW_MODE_SW_SPI_CS_OE_M                       GENMASK(4, 1)
> +#define ICPU_SW_MODE_SW_SPI_CS_OE_X(x)                    (((x) & GENMASK(4, 1)) >> 1)
> +#define ICPU_SW_MODE_SW_SPI_SDI                           BIT(0)
> +
> +#define ICPU_MPU8051_CFG                                  0x54
> +
> +#define ICPU_MPU8051_CFG_UART_SYS_ENA                     BIT(0)
> +
> +#define ICPU_MPU8051_STAT                                 0x58
> +
> +#define ICPU_MPU8051_STAT_MPU8051_SBA_ERR                 BIT(9)
> +#define ICPU_MPU8051_STAT_MPU8051_STOP                    BIT(8)
> +#define ICPU_MPU8051_STAT_MPU8051_GPR(x)                  ((x) & GENMASK(7, 0))
> +#define ICPU_MPU8051_STAT_MPU8051_GPR_M                   GENMASK(7, 0)
> +
> +#define ICPU_MPU8051_MMAP                                 0x5c
> +
> +#define ICPU_MPU8051_MMAP_MSADDR_CODE_HIGH                BIT(7)
> +#define ICPU_MPU8051_MMAP_MSADDR_CODE_LOW                 BIT(6)
> +#define ICPU_MPU8051_MMAP_MSADDR_DATA_HIGH                BIT(5)
> +#define ICPU_MPU8051_MMAP_MSADDR_DATA_LOW                 BIT(4)
> +#define ICPU_MPU8051_MMAP_MAP_CODE_HIGH                   BIT(3)
> +#define ICPU_MPU8051_MMAP_MAP_CODE_LOW                    BIT(2)
> +#define ICPU_MPU8051_MMAP_MAP_DATA_HIGH                   BIT(1)
> +#define ICPU_MPU8051_MMAP_MAP_DATA_LOW                    BIT(0)
> +
> +#define ICPU_MEMACC_CTRL                                  0x60
> +
> +#define ICPU_MEMACC_CTRL_MEMACC_EXAMINE                   BIT(1)
> +#define ICPU_MEMACC_CTRL_MEMACC_DO                        BIT(0)
> +
> +#define ICPU_MEMACC                                       0x64
> +
> +#define ICPU_MEMACC_MEMACC_STOP(x)                        (((x) << 18) & GENMASK(31, 18))
> +#define ICPU_MEMACC_MEMACC_STOP_M                         GENMASK(31, 18)
> +#define ICPU_MEMACC_MEMACC_STOP_X(x)                      (((x) & GENMASK(31, 18)) >> 18)
> +#define ICPU_MEMACC_MEMACC_START(x)                       (((x) << 2) & GENMASK(15, 2))
> +#define ICPU_MEMACC_MEMACC_START_M                        GENMASK(15, 2)
> +#define ICPU_MEMACC_MEMACC_START_X(x)                     (((x) & GENMASK(15, 2)) >> 2)
> +
> +#define ICPU_MEMACC_SBA                                   0x68
> +
> +#define ICPU_MPU8051_IROM                                 0x6c
> +
> +#define ICPU_INTR_RAW                                     0x70
> +
> +#define ICPU_INTR_TRIGGER                                 0x74
> +#define ICPU_INTR_TRIGGER_RSZ                             0x4
> +
> +#define ICPU_INTR_FORCE                                   0x7c
> +
> +#define ICPU_INTR_STICKY                                  0x80
> +
> +#define ICPU_INTR_BYPASS                                  0x84
> +
> +#define ICPU_INTR_ENA                                     0x88
> +
> +#define ICPU_INTR_ENA_CLR                                 0x8c
> +
> +#define ICPU_INTR_ENA_SET                                 0x90
> +
> +#define ICPU_INTR_IDENT                                   0x94
> +
> +#define ICPU_DST_INTR_MAP(x)  (0x98 + 0x4 * (x))
> +#define ICPU_DST_INTR_MAP_RSZ                             0x4
> +
> +#define ICPU_DST_INTR_IDENT                               0xa8
> +#define ICPU_DST_INTR_IDENT_RSZ                           0x4
> +
> +#define ICPU_EXT_SRC_INTR_POL                             0xb8
> +
> +#define ICPU_EXT_DST_INTR_POL                             0xbc
> +
> +#define ICPU_EXT_DST_INTR_DRV                             0xc0
> +
> +#define ICPU_DEV_INTR_POL                                 0xc4
> +
> +#define ICPU_DEV_INTR_RAW                                 0xc8
> +
> +#define ICPU_DEV_INTR_TRIGGER                             0xcc
> +#define ICPU_DEV_INTR_TRIGGER_RSZ                         0x4
> +
> +#define ICPU_DEV_INTR_STICKY                              0xd4
> +
> +#define ICPU_DEV_INTR_BYPASS                              0xd8
> +
> +#define ICPU_DEV_INTR_ENA                                 0xdc
> +
> +#define ICPU_DEV_INTR_IDENT                               0xe0
> +
> +#define ICPU_WDT                                          0xe4
> +
> +#define ICPU_WDT_WDT_STATUS                               BIT(9)
> +#define ICPU_WDT_WDT_ENABLE                               BIT(8)
> +#define ICPU_WDT_WDT_LOCK(x)                              ((x) & GENMASK(7, 0))
> +#define ICPU_WDT_WDT_LOCK_M                               GENMASK(7, 0)
> +
> +#define ICPU_TIMER_TICK_DIV                               0xe8
> +
> +#define ICPU_TIMER_VALUE(x) (0xec + 0x4 * (x))
> +#define ICPU_TIMER_VALUE_RSZ                              0x4
> +
> +#define ICPU_TIMER_RELOAD_VALUE                           0xf8
> +#define ICPU_TIMER_RELOAD_VALUE_RSZ                       0x4
> +
> +#define ICPU_TIMER_CTRL(x) (0x104 + 0x4 * (x))
> +#define ICPU_TIMER_CTRL_RSZ                               0x4
> +
> +#define ICPU_TIMER_CTRL_MAX_FREQ_ENA                      BIT(3)
> +#define ICPU_TIMER_CTRL_ONE_SHOT_ENA                      BIT(2)
> +#define ICPU_TIMER_CTRL_TIMER_ENA                         BIT(1)
> +#define ICPU_TIMER_CTRL_FORCE_RELOAD                      BIT(0)
> +
> +#define ICPU_MEMCTRL_CTRL                                 0x110
> +
> +#define ICPU_MEMCTRL_CTRL_PWR_DOWN                        BIT(3)
> +#define ICPU_MEMCTRL_CTRL_MDSET                           BIT(2)
> +#define ICPU_MEMCTRL_CTRL_STALL_REF_ENA                   BIT(1)
> +#define ICPU_MEMCTRL_CTRL_INITIALIZE                      BIT(0)
> +
> +#define ICPU_MEMCTRL_CFG                                  0x114
> +
> +#define ICPU_MEMCTRL_CFG_DDR_512MBYTE_PLUS                BIT(16)
> +#define ICPU_MEMCTRL_CFG_DDR_ECC_ERR_ENA                  BIT(15)
> +#define ICPU_MEMCTRL_CFG_DDR_ECC_COR_ENA                  BIT(14)
> +#define ICPU_MEMCTRL_CFG_DDR_ECC_ENA                      BIT(13)
> +#define ICPU_MEMCTRL_CFG_DDR_WIDTH                        BIT(12)
> +#define ICPU_MEMCTRL_CFG_DDR_MODE                         BIT(11)
> +#define ICPU_MEMCTRL_CFG_BURST_SIZE                       BIT(10)
> +#define ICPU_MEMCTRL_CFG_BURST_LEN                        BIT(9)
> +#define ICPU_MEMCTRL_CFG_BANK_CNT                         BIT(8)
> +#define ICPU_MEMCTRL_CFG_MSB_ROW_ADDR(x)                  (((x) << 4) & GENMASK(7, 4))
> +#define ICPU_MEMCTRL_CFG_MSB_ROW_ADDR_M                   GENMASK(7, 4)
> +#define ICPU_MEMCTRL_CFG_MSB_ROW_ADDR_X(x)                (((x) & GENMASK(7, 4)) >> 4)
> +#define ICPU_MEMCTRL_CFG_MSB_COL_ADDR(x)                  ((x) & GENMASK(3, 0))
> +#define ICPU_MEMCTRL_CFG_MSB_COL_ADDR_M                   GENMASK(3, 0)
> +
> +#define ICPU_MEMCTRL_STAT                                 0x118
> +
> +#define ICPU_MEMCTRL_STAT_RDATA_MASKED                    BIT(5)
> +#define ICPU_MEMCTRL_STAT_RDATA_DUMMY                     BIT(4)
> +#define ICPU_MEMCTRL_STAT_RDATA_ECC_ERR                   BIT(3)
> +#define ICPU_MEMCTRL_STAT_RDATA_ECC_COR                   BIT(2)
> +#define ICPU_MEMCTRL_STAT_PWR_DOWN_ACK                    BIT(1)
> +#define ICPU_MEMCTRL_STAT_INIT_DONE                       BIT(0)
> +
> +#define ICPU_MEMCTRL_REF_PERIOD                           0x11c
> +
> +#define ICPU_MEMCTRL_REF_PERIOD_MAX_PEND_REF(x)           (((x) << 16) & GENMASK(19, 16))
> +#define ICPU_MEMCTRL_REF_PERIOD_MAX_PEND_REF_M            GENMASK(19, 16)
> +#define ICPU_MEMCTRL_REF_PERIOD_MAX_PEND_REF_X(x)         (((x) & GENMASK(19, 16)) >> 16)
> +#define ICPU_MEMCTRL_REF_PERIOD_REF_PERIOD(x)             ((x) & GENMASK(15, 0))
> +#define ICPU_MEMCTRL_REF_PERIOD_REF_PERIOD_M              GENMASK(15, 0)
> +
> +#define ICPU_MEMCTRL_ZQCAL                                0x120
> +
> +#define ICPU_MEMCTRL_ZQCAL_ZQCAL_LONG                     BIT(1)
> +#define ICPU_MEMCTRL_ZQCAL_ZQCAL_SHORT                    BIT(0)
> +
> +#define ICPU_MEMCTRL_TIMING0                              0x124
> +
> +#define ICPU_MEMCTRL_TIMING0_RD_TO_WR_DLY(x)              (((x) << 28) & GENMASK(31, 28))
> +#define ICPU_MEMCTRL_TIMING0_RD_TO_WR_DLY_M               GENMASK(31, 28)
> +#define ICPU_MEMCTRL_TIMING0_RD_TO_WR_DLY_X(x)            (((x) & GENMASK(31, 28)) >> 28)
> +#define ICPU_MEMCTRL_TIMING0_WR_CS_CHANGE_DLY(x)          (((x) << 24) & GENMASK(27, 24))
> +#define ICPU_MEMCTRL_TIMING0_WR_CS_CHANGE_DLY_M           GENMASK(27, 24)
> +#define ICPU_MEMCTRL_TIMING0_WR_CS_CHANGE_DLY_X(x)        (((x) & GENMASK(27, 24)) >> 24)
> +#define ICPU_MEMCTRL_TIMING0_RD_CS_CHANGE_DLY(x)          (((x) << 20) & GENMASK(23, 20))
> +#define ICPU_MEMCTRL_TIMING0_RD_CS_CHANGE_DLY_M           GENMASK(23, 20)
> +#define ICPU_MEMCTRL_TIMING0_RD_CS_CHANGE_DLY_X(x)        (((x) & GENMASK(23, 20)) >> 20)
> +#define ICPU_MEMCTRL_TIMING0_RAS_TO_PRECH_DLY(x)          (((x) << 16) & GENMASK(19, 16))
> +#define ICPU_MEMCTRL_TIMING0_RAS_TO_PRECH_DLY_M           GENMASK(19, 16)
> +#define ICPU_MEMCTRL_TIMING0_RAS_TO_PRECH_DLY_X(x)        (((x) & GENMASK(19, 16)) >> 16)
> +#define ICPU_MEMCTRL_TIMING0_WR_TO_PRECH_DLY(x)           (((x) << 12) & GENMASK(15, 12))
> +#define ICPU_MEMCTRL_TIMING0_WR_TO_PRECH_DLY_M            GENMASK(15, 12)
> +#define ICPU_MEMCTRL_TIMING0_WR_TO_PRECH_DLY_X(x)         (((x) & GENMASK(15, 12)) >> 12)
> +#define ICPU_MEMCTRL_TIMING0_RD_TO_PRECH_DLY(x)           (((x) << 8) & GENMASK(11, 8))
> +#define ICPU_MEMCTRL_TIMING0_RD_TO_PRECH_DLY_M            GENMASK(11, 8)
> +#define ICPU_MEMCTRL_TIMING0_RD_TO_PRECH_DLY_X(x)         (((x) & GENMASK(11, 8)) >> 8)
> +#define ICPU_MEMCTRL_TIMING0_WR_DATA_XFR_DLY(x)           (((x) << 4) & GENMASK(7, 4))
> +#define ICPU_MEMCTRL_TIMING0_WR_DATA_XFR_DLY_M            GENMASK(7, 4)
> +#define ICPU_MEMCTRL_TIMING0_WR_DATA_XFR_DLY_X(x)         (((x) & GENMASK(7, 4)) >> 4)
> +#define ICPU_MEMCTRL_TIMING0_RD_DATA_XFR_DLY(x)           ((x) & GENMASK(3, 0))
> +#define ICPU_MEMCTRL_TIMING0_RD_DATA_XFR_DLY_M            GENMASK(3, 0)
> +
> +#define ICPU_MEMCTRL_TIMING1                              0x128
> +
> +#define ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_SAME_BANK_DLY(x)  (((x) << 24) & GENMASK(31, 24))
> +#define ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_SAME_BANK_DLY_M   GENMASK(31, 24)
> +#define ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_SAME_BANK_DLY_X(x) (((x) & GENMASK(31, 24)) >> 24)
> +#define ICPU_MEMCTRL_TIMING1_BANK8_FAW_DLY(x)             (((x) << 16) & GENMASK(23, 16))
> +#define ICPU_MEMCTRL_TIMING1_BANK8_FAW_DLY_M              GENMASK(23, 16)
> +#define ICPU_MEMCTRL_TIMING1_BANK8_FAW_DLY_X(x)           (((x) & GENMASK(23, 16)) >> 16)
> +#define ICPU_MEMCTRL_TIMING1_PRECH_TO_RAS_DLY(x)          (((x) << 12) & GENMASK(15, 12))
> +#define ICPU_MEMCTRL_TIMING1_PRECH_TO_RAS_DLY_M           GENMASK(15, 12)
> +#define ICPU_MEMCTRL_TIMING1_PRECH_TO_RAS_DLY_X(x)        (((x) & GENMASK(15, 12)) >> 12)
> +#define ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_DLY(x)            (((x) << 8) & GENMASK(11, 8))
> +#define ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_DLY_M             GENMASK(11, 8)
> +#define ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_DLY_X(x)          (((x) & GENMASK(11, 8)) >> 8)
> +#define ICPU_MEMCTRL_TIMING1_RAS_TO_CAS_DLY(x)            (((x) << 4) & GENMASK(7, 4))
> +#define ICPU_MEMCTRL_TIMING1_RAS_TO_CAS_DLY_M             GENMASK(7, 4)
> +#define ICPU_MEMCTRL_TIMING1_RAS_TO_CAS_DLY_X(x)          (((x) & GENMASK(7, 4)) >> 4)
> +#define ICPU_MEMCTRL_TIMING1_WR_TO_RD_DLY(x)              ((x) & GENMASK(3, 0))
> +#define ICPU_MEMCTRL_TIMING1_WR_TO_RD_DLY_M               GENMASK(3, 0)
> +
> +#define ICPU_MEMCTRL_TIMING2                              0x12c
> +
> +#define ICPU_MEMCTRL_TIMING2_PRECH_ALL_DLY(x)             (((x) << 28) & GENMASK(31, 28))
> +#define ICPU_MEMCTRL_TIMING2_PRECH_ALL_DLY_M              GENMASK(31, 28)
> +#define ICPU_MEMCTRL_TIMING2_PRECH_ALL_DLY_X(x)           (((x) & GENMASK(31, 28)) >> 28)
> +#define ICPU_MEMCTRL_TIMING2_MDSET_DLY(x)                 (((x) << 24) & GENMASK(27, 24))
> +#define ICPU_MEMCTRL_TIMING2_MDSET_DLY_M                  GENMASK(27, 24)
> +#define ICPU_MEMCTRL_TIMING2_MDSET_DLY_X(x)               (((x) & GENMASK(27, 24)) >> 24)
> +#define ICPU_MEMCTRL_TIMING2_REF_DLY(x)                   (((x) << 16) & GENMASK(23, 16))
> +#define ICPU_MEMCTRL_TIMING2_REF_DLY_M                    GENMASK(23, 16)
> +#define ICPU_MEMCTRL_TIMING2_REF_DLY_X(x)                 (((x) & GENMASK(23, 16)) >> 16)
> +#define ICPU_MEMCTRL_TIMING2_INIT_DLY(x)                  ((x) & GENMASK(15, 0))
> +#define ICPU_MEMCTRL_TIMING2_INIT_DLY_M                   GENMASK(15, 0)
> +
> +#define ICPU_MEMCTRL_TIMING3                              0x130
> +
> +#define ICPU_MEMCTRL_TIMING3_RMW_DLY(x)                   (((x) << 16) & GENMASK(19, 16))
> +#define ICPU_MEMCTRL_TIMING3_RMW_DLY_M                    GENMASK(19, 16)
> +#define ICPU_MEMCTRL_TIMING3_RMW_DLY_X(x)                 (((x) & GENMASK(19, 16)) >> 16)
> +#define ICPU_MEMCTRL_TIMING3_ODT_RD_DLY(x)                (((x) << 12) & GENMASK(15, 12))
> +#define ICPU_MEMCTRL_TIMING3_ODT_RD_DLY_M                 GENMASK(15, 12)
> +#define ICPU_MEMCTRL_TIMING3_ODT_RD_DLY_X(x)              (((x) & GENMASK(15, 12)) >> 12)
> +#define ICPU_MEMCTRL_TIMING3_ODT_WR_DLY(x)                (((x) << 8) & GENMASK(11, 8))
> +#define ICPU_MEMCTRL_TIMING3_ODT_WR_DLY_M                 GENMASK(11, 8)
> +#define ICPU_MEMCTRL_TIMING3_ODT_WR_DLY_X(x)              (((x) & GENMASK(11, 8)) >> 8)
> +#define ICPU_MEMCTRL_TIMING3_LOCAL_ODT_RD_DLY(x)          (((x) << 4) & GENMASK(7, 4))
> +#define ICPU_MEMCTRL_TIMING3_LOCAL_ODT_RD_DLY_M           GENMASK(7, 4)
> +#define ICPU_MEMCTRL_TIMING3_LOCAL_ODT_RD_DLY_X(x)        (((x) & GENMASK(7, 4)) >> 4)
> +#define ICPU_MEMCTRL_TIMING3_WR_TO_RD_CS_CHANGE_DLY(x)    ((x) & GENMASK(3, 0))
> +#define ICPU_MEMCTRL_TIMING3_WR_TO_RD_CS_CHANGE_DLY_M     GENMASK(3, 0)
> +
> +#define ICPU_MEMCTRL_TIMING4                              0x134
> +
> +#define ICPU_MEMCTRL_TIMING4_ZQCAL_INIT_DLY(x)            (((x) << 20) & GENMASK(31, 20))
> +#define ICPU_MEMCTRL_TIMING4_ZQCAL_INIT_DLY_M             GENMASK(31, 20)
> +#define ICPU_MEMCTRL_TIMING4_ZQCAL_INIT_DLY_X(x)          (((x) & GENMASK(31, 20)) >> 20)
> +#define ICPU_MEMCTRL_TIMING4_ZQCAL_LONG_DLY(x)            (((x) << 8) & GENMASK(19, 8))
> +#define ICPU_MEMCTRL_TIMING4_ZQCAL_LONG_DLY_M             GENMASK(19, 8)
> +#define ICPU_MEMCTRL_TIMING4_ZQCAL_LONG_DLY_X(x)          (((x) & GENMASK(19, 8)) >> 8)
> +#define ICPU_MEMCTRL_TIMING4_ZQCAL_SHORT_DLY(x)           ((x) & GENMASK(7, 0))
> +#define ICPU_MEMCTRL_TIMING4_ZQCAL_SHORT_DLY_M            GENMASK(7, 0)
> +
> +#define ICPU_MEMCTRL_MR0_VAL                              0x138
> +
> +#define ICPU_MEMCTRL_MR1_VAL                              0x13c
> +
> +#define ICPU_MEMCTRL_MR2_VAL                              0x140
> +
> +#define ICPU_MEMCTRL_MR3_VAL                              0x144
> +
> +#define ICPU_MEMCTRL_TERMRES_CTRL                         0x148
> +
> +#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_RD_EXT              BIT(11)
> +#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_RD_ENA(x)           (((x) << 7) & GENMASK(10, 7))
> +#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_RD_ENA_M            GENMASK(10, 7)
> +#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_RD_ENA_X(x)         (((x) & GENMASK(10, 7)) >> 7)
> +#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_WR_EXT              BIT(6)
> +#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_WR_ENA(x)           (((x) << 2) & GENMASK(5, 2))
> +#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_WR_ENA_M            GENMASK(5, 2)
> +#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_WR_ENA_X(x)         (((x) & GENMASK(5, 2)) >> 2)
> +#define ICPU_MEMCTRL_TERMRES_CTRL_LOCAL_ODT_RD_EXT        BIT(1)
> +#define ICPU_MEMCTRL_TERMRES_CTRL_LOCAL_ODT_RD_ENA        BIT(0)
> +
> +#define ICPU_MEMCTRL_DFT                                  0x14c
> +
> +#define ICPU_MEMCTRL_DFT_DDRDFT_LBW                       BIT(7)
> +#define ICPU_MEMCTRL_DFT_DDRDFT_GATE_ENA                  BIT(6)
> +#define ICPU_MEMCTRL_DFT_DDRDFT_TERM_ENA                  BIT(5)
> +#define ICPU_MEMCTRL_DFT_DDRDFT_A10                       BIT(4)
> +#define ICPU_MEMCTRL_DFT_DDRDFT_STAT                      BIT(3)
> +#define ICPU_MEMCTRL_DFT_DDRDFT_MODE(x)                   (((x) << 1) & GENMASK(2, 1))
> +#define ICPU_MEMCTRL_DFT_DDRDFT_MODE_M                    GENMASK(2, 1)
> +#define ICPU_MEMCTRL_DFT_DDRDFT_MODE_X(x)                 (((x) & GENMASK(2, 1)) >> 1)
> +#define ICPU_MEMCTRL_DFT_DDRDFT_ENA                       BIT(0)
> +
> +#define ICPU_MEMCTRL_DQS_DLY(x) (0x150 + 0x4 * (x))
> +#define ICPU_MEMCTRL_DQS_DLY_RSZ                          0x4
> +
> +#define ICPU_MEMCTRL_DQS_DLY_TRAIN_DQ_ENA                 BIT(11)
> +#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_TRM1(x)              (((x) << 8) & GENMASK(10, 8))
> +#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_TRM1_M               GENMASK(10, 8)
> +#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_TRM1_X(x)            (((x) & GENMASK(10, 8)) >> 8)
> +#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_TRM0(x)              (((x) << 5) & GENMASK(7, 5))
> +#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_TRM0_M               GENMASK(7, 5)
> +#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_TRM0_X(x)            (((x) & GENMASK(7, 5)) >> 5)
> +#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY(x)                   ((x) & GENMASK(4, 0))
> +#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_M                    GENMASK(4, 0)
> +
> +#define ICPU_MEMCTRL_DQS_AUTO                             0x158
> +#define ICPU_MEMCTRL_DQS_AUTO_RSZ                         0x4
> +
> +#define ICPU_MEMCTRL_DQS_AUTO_DQS_DRIFT(x)                (((x) << 6) & GENMASK(7, 6))
> +#define ICPU_MEMCTRL_DQS_AUTO_DQS_DRIFT_M                 GENMASK(7, 6)
> +#define ICPU_MEMCTRL_DQS_AUTO_DQS_DRIFT_X(x)              (((x) & GENMASK(7, 6)) >> 6)
> +#define ICPU_MEMCTRL_DQS_AUTO_DQS_OVERFLOW                BIT(5)
> +#define ICPU_MEMCTRL_DQS_AUTO_DQS_UNDERFLOW               BIT(4)
> +#define ICPU_MEMCTRL_DQS_AUTO_DQS_AUTO_SRC                BIT(3)
> +#define ICPU_MEMCTRL_DQS_AUTO_DQS_AUTO_UP                 BIT(2)
> +#define ICPU_MEMCTRL_DQS_AUTO_DQS_AUTO_DOWN               BIT(1)
> +#define ICPU_MEMCTRL_DQS_AUTO_DQS_AUTO_ENA                BIT(0)
> +
> +#define ICPU_MEMPHY_CFG                                   0x160
> +
> +#define ICPU_MEMPHY_CFG_PHY_FLUSH_DIS                     BIT(10)
> +#define ICPU_MEMPHY_CFG_PHY_RD_ADJ_DIS                    BIT(9)
> +#define ICPU_MEMPHY_CFG_PHY_DQS_EXT                       BIT(8)
> +#define ICPU_MEMPHY_CFG_PHY_FIFO_RST                      BIT(7)
> +#define ICPU_MEMPHY_CFG_PHY_DLL_BL_RST                    BIT(6)
> +#define ICPU_MEMPHY_CFG_PHY_DLL_CL_RST                    BIT(5)
> +#define ICPU_MEMPHY_CFG_PHY_ODT_OE                        BIT(4)
> +#define ICPU_MEMPHY_CFG_PHY_CK_OE                         BIT(3)
> +#define ICPU_MEMPHY_CFG_PHY_CL_OE                         BIT(2)
> +#define ICPU_MEMPHY_CFG_PHY_SSTL_ENA                      BIT(1)
> +#define ICPU_MEMPHY_CFG_PHY_RST                           BIT(0)
> +
> +#define ICPU_MEMPHY_DFT                                   0x164
> +
> +#define ICPU_MEMPHY_DFT_PHY_DLL_BYPASS                    BIT(0)
> +
> +#define ICPU_MEMPHY_DLLCFG0                               0x168
> +#define ICPU_MEMPHY_DLLCFG0_RSZ                           0x4
> +
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_RES6(x)                (((x) << 30) & GENMASK(31, 30))
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_RES6_M                 GENMASK(31, 30)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_RES6_X(x)              (((x) & GENMASK(31, 30)) >> 30)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_LOCK_DET_EN            BIT(29)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_RES5(x)                (((x) << 27) & GENMASK(28, 27))
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_RES5_M                 GENMASK(28, 27)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_RES5_X(x)              (((x) & GENMASK(28, 27)) >> 27)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_BIAS_TRM3(x)           (((x) << 24) & GENMASK(26, 24))
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_BIAS_TRM3_M            GENMASK(26, 24)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_BIAS_TRM3_X(x)         (((x) & GENMASK(26, 24)) >> 24)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_RES4                   BIT(23)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_BIAS_TRM2(x)           (((x) << 20) & GENMASK(22, 20))
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_BIAS_TRM2_M            GENMASK(22, 20)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_BIAS_TRM2_X(x)         (((x) & GENMASK(22, 20)) >> 20)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_RES3                   BIT(19)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_BIAS_TRM1(x)           (((x) << 16) & GENMASK(18, 16))
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_BIAS_TRM1_M            GENMASK(18, 16)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_BIAS_TRM1_X(x)         (((x) & GENMASK(18, 16)) >> 16)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_RES2                   BIT(15)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_BIAS_TRM0(x)           (((x) << 12) & GENMASK(14, 12))
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_BIAS_TRM0_M            GENMASK(14, 12)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_BIAS_TRM0_X(x)         (((x) & GENMASK(14, 12)) >> 12)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_RES1                   BIT(11)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_TEST_CTRL_A(x)         (((x) << 9) & GENMASK(10, 9))
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_TEST_CTRL_A_M          GENMASK(10, 9)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_TEST_CTRL_A_X(x)       (((x) & GENMASK(10, 9)) >> 9)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_TEST_CTRL_D(x)         (((x) << 6) & GENMASK(8, 6))
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_TEST_CTRL_D_M          GENMASK(8, 6)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_TEST_CTRL_D_X(x)       (((x) & GENMASK(8, 6)) >> 6)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_TEST_CTRL_EN           BIT(5)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_IPUMP_TRM(x)           (((x) << 2) & GENMASK(4, 2))
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_IPUMP_TRM_M            GENMASK(4, 2)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_IPUMP_TRM_X(x)         (((x) & GENMASK(4, 2)) >> 2)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_RES0(x)                ((x) & GENMASK(1, 0))
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_RES0_M                 GENMASK(1, 0)
> +
> +#define ICPU_MEMPHY_DLLCFG1                               0x174
> +#define ICPU_MEMPHY_DLLCFG1_RSZ                           0x4
> +
> +#define ICPU_MEMPHY_DLLCFG1_DLLCFG_RES9                   BIT(19)
> +#define ICPU_MEMPHY_DLLCFG1_DLLCFG_TEST_HIZB_A            BIT(18)
> +#define ICPU_MEMPHY_DLLCFG1_DLLCFG_RES8(x)                (((x) << 12) & GENMASK(17, 12))
> +#define ICPU_MEMPHY_DLLCFG1_DLLCFG_RES8_M                 GENMASK(17, 12)
> +#define ICPU_MEMPHY_DLLCFG1_DLLCFG_RES8_X(x)              (((x) & GENMASK(17, 12)) >> 12)
> +#define ICPU_MEMPHY_DLLCFG1_DLLCFG_FF_TRM(x)              (((x) << 9) & GENMASK(11, 9))
> +#define ICPU_MEMPHY_DLLCFG1_DLLCFG_FF_TRM_M               GENMASK(11, 9)
> +#define ICPU_MEMPHY_DLLCFG1_DLLCFG_FF_TRM_X(x)            (((x) & GENMASK(11, 9)) >> 9)
> +#define ICPU_MEMPHY_DLLCFG1_DLLCFG_FB_TRM(x)              (((x) << 6) & GENMASK(8, 6))
> +#define ICPU_MEMPHY_DLLCFG1_DLLCFG_FB_TRM_M               GENMASK(8, 6)
> +#define ICPU_MEMPHY_DLLCFG1_DLLCFG_FB_TRM_X(x)            (((x) & GENMASK(8, 6)) >> 6)
> +#define ICPU_MEMPHY_DLLCFG1_DLLCFG_RES7(x)                ((x) & GENMASK(5, 0))
> +#define ICPU_MEMPHY_DLLCFG1_DLLCFG_RES7_M                 GENMASK(5, 0)
> +
> +#define ICPU_MEMPHY_DQ_DLY_TRM                            0x180
> +#define ICPU_MEMPHY_DQ_DLY_TRM_RSZ                        0x4
> +
> +#define ICPU_MEMPHY_ZCAL                                  0x188
> +
> +#define ICPU_MEMPHY_ZCAL_ZCAL_CLK_SEL                     BIT(9)
> +#define ICPU_MEMPHY_ZCAL_ZCAL_PROG_ODT(x)                 (((x) << 5) & GENMASK(8, 5))
> +#define ICPU_MEMPHY_ZCAL_ZCAL_PROG_ODT_M                  GENMASK(8, 5)
> +#define ICPU_MEMPHY_ZCAL_ZCAL_PROG_ODT_X(x)               (((x) & GENMASK(8, 5)) >> 5)
> +#define ICPU_MEMPHY_ZCAL_ZCAL_PROG(x)                     (((x) << 1) & GENMASK(4, 1))
> +#define ICPU_MEMPHY_ZCAL_ZCAL_PROG_M                      GENMASK(4, 1)
> +#define ICPU_MEMPHY_ZCAL_ZCAL_PROG_X(x)                   (((x) & GENMASK(4, 1)) >> 1)
> +#define ICPU_MEMPHY_ZCAL_ZCAL_ENA                         BIT(0)
> +
> +#define ICPU_MEMPHY_ZCAL_STAT                             0x18c
> +
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_ZCTRL(x)               (((x) << 12) & GENMASK(31, 12))
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_ZCTRL_M                GENMASK(31, 12)
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_ZCTRL_X(x)             (((x) & GENMASK(31, 12)) >> 12)
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_ODTPU(x)          (((x) << 8) & GENMASK(9, 8))
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_ODTPU_M           GENMASK(9, 8)
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_ODTPU_X(x)        (((x) & GENMASK(9, 8)) >> 8)
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_ODTPD(x)          (((x) << 6) & GENMASK(7, 6))
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_ODTPD_M           GENMASK(7, 6)
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_ODTPD_X(x)        (((x) & GENMASK(7, 6)) >> 6)
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_PU(x)             (((x) << 4) & GENMASK(5, 4))
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_PU_M              GENMASK(5, 4)
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_PU_X(x)           (((x) & GENMASK(5, 4)) >> 4)
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_PD(x)             (((x) << 2) & GENMASK(3, 2))
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_PD_M              GENMASK(3, 2)
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_PD_X(x)           (((x) & GENMASK(3, 2)) >> 2)
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_ERR                    BIT(1)
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_DONE                   BIT(0)
> +
> +#define ICPU_MEMPHY_ZCAL_OVR                              0x190
> +
> +#define ICPU_MEMPHY_ZCAL_OVR_ZCAL_OVR_DATA(x)             (((x) << 12) & GENMASK(31, 12))
> +#define ICPU_MEMPHY_ZCAL_OVR_ZCAL_OVR_DATA_M              GENMASK(31, 12)
> +#define ICPU_MEMPHY_ZCAL_OVR_ZCAL_OVR_DATA_X(x)           (((x) & GENMASK(31, 12)) >> 12)
> +#define ICPU_MEMPHY_ZCAL_OVR_ZCAL_ENACLR_DIS              BIT(2)
> +#define ICPU_MEMPHY_ZCAL_OVR_ZCAL_ZCOMP                   BIT(1)
> +#define ICPU_MEMPHY_ZCAL_OVR_ZCAL_OVR_ENA                 BIT(0)
> +
> +#define ICPU_MEMPHY_ZCAL_FORCE                            0x194
> +
> +#define ICPU_MEMPHY_ZCAL_FORCE_ZCAL_FORCE_ZCAL(x)         (((x) << 2) & GENMASK(3, 2))
> +#define ICPU_MEMPHY_ZCAL_FORCE_ZCAL_FORCE_ZCAL_M          GENMASK(3, 2)
> +#define ICPU_MEMPHY_ZCAL_FORCE_ZCAL_FORCE_ZCAL_X(x)       (((x) & GENMASK(3, 2)) >> 2)
> +#define ICPU_MEMPHY_ZCAL_FORCE_ZCAL_FORCE_ZQ_OFF          BIT(1)
> +#define ICPU_MEMPHY_ZCAL_FORCE_ZCAL_FORCE_ENA             BIT(0)
> +
> +#define ICPU_TWI_CONFIG                                   0x198
> +
> +#define ICPU_TWI_CONFIG_TWI_CNT_RELOAD(x)                 (((x) << 1) & GENMASK(8, 1))
> +#define ICPU_TWI_CONFIG_TWI_CNT_RELOAD_M                  GENMASK(8, 1)
> +#define ICPU_TWI_CONFIG_TWI_CNT_RELOAD_X(x)               (((x) & GENMASK(8, 1)) >> 1)
> +#define ICPU_TWI_CONFIG_TWI_DELAY_ENABLE                  BIT(0)
> +
> +#define ICPU_TWI_SPIKE_FILTER_CFG                         0x19c
> +
> +#define ICPU_FDMA_DCB_LLP                                 0x1a0
> +#define ICPU_FDMA_DCB_LLP_RSZ                             0x4
> +
> +#define ICPU_FDMA_DCB_DATAP                               0x1c8
> +#define ICPU_FDMA_DCB_DATAP_RSZ                           0x4
> +
> +#define ICPU_FDMA_DCB_DATAL                               0x1f0
> +#define ICPU_FDMA_DCB_DATAL_RSZ                           0x4
> +
> +#define ICPU_FDMA_DCB_DATAL_TOKEN                         BIT(17)
> +#define ICPU_FDMA_DCB_DATAL_DATAL(x)                      ((x) & GENMASK(15, 0))
> +#define ICPU_FDMA_DCB_DATAL_DATAL_M                       GENMASK(15, 0)
> +
> +#define ICPU_FDMA_DCB_STAT                                0x218
> +#define ICPU_FDMA_DCB_STAT_RSZ                            0x4
> +
> +#define ICPU_FDMA_DCB_STAT_BLOCKO(x)                      (((x) << 20) & GENMASK(31, 20))
> +#define ICPU_FDMA_DCB_STAT_BLOCKO_M                       GENMASK(31, 20)
> +#define ICPU_FDMA_DCB_STAT_BLOCKO_X(x)                    (((x) & GENMASK(31, 20)) >> 20)
> +#define ICPU_FDMA_DCB_STAT_PD                             BIT(19)
> +#define ICPU_FDMA_DCB_STAT_ABORT                          BIT(18)
> +#define ICPU_FDMA_DCB_STAT_EOF                            BIT(17)
> +#define ICPU_FDMA_DCB_STAT_SOF                            BIT(16)
> +#define ICPU_FDMA_DCB_STAT_BLOCKL(x)                      ((x) & GENMASK(15, 0))
> +#define ICPU_FDMA_DCB_STAT_BLOCKL_M                       GENMASK(15, 0)
> +
> +#define ICPU_FDMA_DCB_LLP_PREV                            0x240
> +#define ICPU_FDMA_DCB_LLP_PREV_RSZ                        0x4
> +
> +#define ICPU_FDMA_CH_STAT                                 0x268
> +
> +#define ICPU_FDMA_CH_SAFE                                 0x26c
> +
> +#define ICPU_FDMA_CH_ACTIVATE                             0x270
> +
> +#define ICPU_FDMA_CH_DISABLE                              0x274
> +
> +#define ICPU_FDMA_CH_FORCEDIS                             0x278
> +
> +#define ICPU_FDMA_CH_CNT                                  0x27c
> +#define ICPU_FDMA_CH_CNT_RSZ                              0x4
> +
> +#define ICPU_FDMA_CH_CNT_CH_CNT_FRM(x)                    (((x) << 16) & GENMASK(31, 16))
> +#define ICPU_FDMA_CH_CNT_CH_CNT_FRM_M                     GENMASK(31, 16)
> +#define ICPU_FDMA_CH_CNT_CH_CNT_FRM_X(x)                  (((x) & GENMASK(31, 16)) >> 16)
> +#define ICPU_FDMA_CH_CNT_CH_CNT_DCB(x)                    (((x) << 8) & GENMASK(15, 8))
> +#define ICPU_FDMA_CH_CNT_CH_CNT_DCB_M                     GENMASK(15, 8)
> +#define ICPU_FDMA_CH_CNT_CH_CNT_DCB_X(x)                  (((x) & GENMASK(15, 8)) >> 8)
> +#define ICPU_FDMA_CH_CNT_CH_CNT_SIG(x)                    ((x) & GENMASK(7, 0))
> +#define ICPU_FDMA_CH_CNT_CH_CNT_SIG_M                     GENMASK(7, 0)
> +
> +#define ICPU_FDMA_CH_INJ_CNT                              0x2a4
> +#define ICPU_FDMA_CH_INJ_CNT_RSZ                          0x4
> +
> +#define ICPU_FDMA_CH_INJ_TICK_RLD                         0x2c4
> +#define ICPU_FDMA_CH_INJ_TICK_RLD_RSZ                     0x4
> +
> +#define ICPU_FDMA_CH_INJ_TICK_CNT                         0x2e4
> +#define ICPU_FDMA_CH_INJ_TICK_CNT_RSZ                     0x4
> +
> +#define ICPU_FDMA_EVT_ERR                                 0x304
> +
> +#define ICPU_FDMA_EVT_ERR_CODE                            0x308
> +
> +#define ICPU_FDMA_INTR_LLP                                0x30c
> +
> +#define ICPU_FDMA_INTR_LLP_ENA                            0x310
> +
> +#define ICPU_FDMA_INTR_FRM                                0x314
> +
> +#define ICPU_FDMA_INTR_FRM_ENA                            0x318
> +
> +#define ICPU_FDMA_INTR_SIG                                0x31c
> +
> +#define ICPU_FDMA_INTR_SIG_ENA                            0x320
> +
> +#define ICPU_FDMA_INTR_ENA                                0x324
> +
> +#define ICPU_FDMA_INTR_IDENT                              0x328
> +
> +#define ICPU_FDMA_CH_CFG                                  0x32c
> +#define ICPU_FDMA_CH_CFG_RSZ                              0x4
> +
> +#define ICPU_FDMA_CH_CFG_STAT_IN_DATA_ENA                 BIT(7)
> +#define ICPU_FDMA_CH_CFG_CH_INJ_GRP                       BIT(6)
> +#define ICPU_FDMA_CH_CFG_CH_PRIO(x)                       (((x) << 2) & GENMASK(5, 2))
> +#define ICPU_FDMA_CH_CFG_CH_PRIO_M                        GENMASK(5, 2)
> +#define ICPU_FDMA_CH_CFG_CH_PRIO_X(x)                     (((x) & GENMASK(5, 2)) >> 2)
> +#define ICPU_FDMA_CH_CFG_DONE_STOP_ENA                    BIT(1)
> +#define ICPU_FDMA_CH_CFG_DONEEOF_STOP_ENA                 BIT(0)
> +
> +#define ICPU_FDMA_GCFG                                    0x354
> +
> +#define ICPU_FDMA_GCFG_FRM_AT_OFF                         BIT(12)
> +#define ICPU_FDMA_GCFG_INJ_RF_WM(x)                       (((x) << 7) & GENMASK(11, 7))
> +#define ICPU_FDMA_GCFG_INJ_RF_WM_M                        GENMASK(11, 7)
> +#define ICPU_FDMA_GCFG_INJ_RF_WM_X(x)                     (((x) & GENMASK(11, 7)) >> 7)
> +#define ICPU_FDMA_GCFG_XTR_RF_WM(x)                       (((x) << 3) & GENMASK(6, 3))
> +#define ICPU_FDMA_GCFG_XTR_RF_WM_M                        GENMASK(6, 3)
> +#define ICPU_FDMA_GCFG_XTR_RF_WM_X(x)                     (((x) & GENMASK(6, 3)) >> 3)
> +#define ICPU_FDMA_GCFG_XTR_AVAIL_EXT_DIS                  BIT(2)
> +#define ICPU_FDMA_GCFG_XTR_PRIO_BP_DIS                    BIT(1)
> +#define ICPU_FDMA_GCFG_PD_IGNORE                          BIT(0)
> +
> +#define ICPU_FDMA_GSTAT                                   0x358
> +
> +#define ICPU_FDMA_GSTAT_INJ_RF_HIGH(x)                    (((x) << 5) & GENMASK(10, 5))
> +#define ICPU_FDMA_GSTAT_INJ_RF_HIGH_M                     GENMASK(10, 5)
> +#define ICPU_FDMA_GSTAT_INJ_RF_HIGH_X(x)                  (((x) & GENMASK(10, 5)) >> 5)
> +#define ICPU_FDMA_GSTAT_XTR_RF_HIGH(x)                    ((x) & GENMASK(4, 0))
> +#define ICPU_FDMA_GSTAT_XTR_RF_HIGH_M                     GENMASK(4, 0)
> +
> +#define ICPU_FDMA_IDLECNT                                 0x35c
> +
> +#define ICPU_FDMA_CONST                                   0x360
> +
> +#define ICPU_FDMA_CONST_CH_INJ_CNT(x)                     (((x) << 8) & GENMASK(15, 8))
> +#define ICPU_FDMA_CONST_CH_INJ_CNT_M                      GENMASK(15, 8)
> +#define ICPU_FDMA_CONST_CH_INJ_CNT_X(x)                   (((x) & GENMASK(15, 8)) >> 8)
> +#define ICPU_FDMA_CONST_CH_XTR_CNT(x)                     ((x) & GENMASK(7, 0))
> +#define ICPU_FDMA_CONST_CH_XTR_CNT_M                      GENMASK(7, 0)
> +
> +#define ICPU_PCIE_CTRL                                    0x364
> +
> +#define ICPU_PCIE_CTRL_POWERUP                            BIT(0)
> +
> +#define ICPU_PCIE_CFG                                     0x368
> +
> +#define ICPU_PCIE_CFG_CG_DIS                              BIT(5)
> +#define ICPU_PCIE_CFG_MEM_CG_DIS                          BIT(4)
> +#define ICPU_PCIE_CFG_CONF_REQ_RETRY_ENA                  BIT(3)
> +#define ICPU_PCIE_CFG_PCIE_BAR_WR_ENA                     BIT(2)
> +#define ICPU_PCIE_CFG_LTSSM_DIS                           BIT(1)
> +#define ICPU_PCIE_CFG_MEM_RING_CORE_ENA                   BIT(0)
> +
> +#define ICPU_PCIE_STAT                                    0x36c
> +
> +#define ICPU_PCIE_STAT_SLV_ERROR_REPLY                    BIT(12)
> +#define ICPU_PCIE_STAT_LTSSM_STATE(x)                     (((x) << 6) & GENMASK(11, 6))
> +#define ICPU_PCIE_STAT_LTSSM_STATE_M                      GENMASK(11, 6)
> +#define ICPU_PCIE_STAT_LTSSM_STATE_X(x)                   (((x) & GENMASK(11, 6)) >> 6)
> +#define ICPU_PCIE_STAT_LINK_STATE(x)                      (((x) << 3) & GENMASK(5, 3))
> +#define ICPU_PCIE_STAT_LINK_STATE_M                       GENMASK(5, 3)
> +#define ICPU_PCIE_STAT_LINK_STATE_X(x)                    (((x) & GENMASK(5, 3)) >> 3)
> +#define ICPU_PCIE_STAT_PM_STATE(x)                        ((x) & GENMASK(2, 0))
> +#define ICPU_PCIE_STAT_PM_STATE_M                         GENMASK(2, 0)
> +
> +#define ICPU_PCIE_AUX_CFG                                 0x370
> +
> +#define ICPU_PCIE_AUX_CFG_AUX_POWER_VAL                   BIT(0)
> +
> +#define ICPU_PCIE_DBG_STAT                                0x374
> +
> +#define ICPU_PCIE_DBG_STAT_TBI_RX_CE                      BIT(14)
> +#define ICPU_PCIE_DBG_STAT_TBI_RX_LOS                     BIT(13)
> +#define ICPU_PCIE_DBG_STAT_TBI_RX_SDET                    BIT(12)
> +#define ICPU_PCIE_DBG_STAT_TBI_RX_DATA(x)                 (((x) << 2) & GENMASK(11, 2))
> +#define ICPU_PCIE_DBG_STAT_TBI_RX_DATA_M                  GENMASK(11, 2)
> +#define ICPU_PCIE_DBG_STAT_TBI_RX_DATA_X(x)               (((x) & GENMASK(11, 2)) >> 2)
> +#define ICPU_PCIE_DBG_STAT_PM_L2_EXIT                     BIT(1)
> +#define ICPU_PCIE_DBG_STAT_DATA_LINK_LAYER_UP             BIT(0)
> +
> +#define ICPU_PCIEMST_REPLY_INFO                           0x378
> +
> +#define ICPU_PCIEMST_BAR1_OFFSET                          0x37c
> +
> +#define ICPU_PCIEMST_BAR1_MASK                            0x380
> +
> +#define ICPU_PCIEMST_BAR2_OFFSET                          0x384
> +
> +#define ICPU_PCIEMST_BAR2_MASK                            0x388
> +
> +#define ICPU_PCIESLV_FDMA                                 0x38c
> +
> +#define ICPU_PCIESLV_FDMA_FDMA_TC(x)                      (((x) << 4) & GENMASK(6, 4))
> +#define ICPU_PCIESLV_FDMA_FDMA_TC_M                       GENMASK(6, 4)
> +#define ICPU_PCIESLV_FDMA_FDMA_TC_X(x)                    (((x) & GENMASK(6, 4)) >> 4)
> +#define ICPU_PCIESLV_FDMA_FDMA_ATTR(x)                    (((x) << 2) & GENMASK(3, 2))
> +#define ICPU_PCIESLV_FDMA_FDMA_ATTR_M                     GENMASK(3, 2)
> +#define ICPU_PCIESLV_FDMA_FDMA_ATTR_X(x)                  (((x) & GENMASK(3, 2)) >> 2)
> +#define ICPU_PCIESLV_FDMA_FDMA_OFFSET(x)                  ((x) & GENMASK(1, 0))
> +#define ICPU_PCIESLV_FDMA_FDMA_OFFSET_M                   GENMASK(1, 0)
> +
> +#define ICPU_PCIESLV_SBA                                  0x390
> +
> +#define ICPU_PCIESLV_SBA_SBA_BE(x)                        (((x) << 24) & GENMASK(27, 24))
> +#define ICPU_PCIESLV_SBA_SBA_BE_M                         GENMASK(27, 24)
> +#define ICPU_PCIESLV_SBA_SBA_BE_X(x)                      (((x) & GENMASK(27, 24)) >> 24)
> +#define ICPU_PCIESLV_SBA_SBA_RESERVED1                    BIT(23)
> +#define ICPU_PCIESLV_SBA_SBA_MSG_CODE(x)                  (((x) << 15) & GENMASK(22, 15))
> +#define ICPU_PCIESLV_SBA_SBA_MSG_CODE_M                   GENMASK(22, 15)
> +#define ICPU_PCIESLV_SBA_SBA_MSG_CODE_X(x)                (((x) & GENMASK(22, 15)) >> 15)
> +#define ICPU_PCIESLV_SBA_SBA_TC(x)                        (((x) << 12) & GENMASK(14, 12))
> +#define ICPU_PCIESLV_SBA_SBA_TC_M                         GENMASK(14, 12)
> +#define ICPU_PCIESLV_SBA_SBA_TC_X(x)                      (((x) & GENMASK(14, 12)) >> 12)
> +#define ICPU_PCIESLV_SBA_SBA_ATTR(x)                      (((x) << 10) & GENMASK(11, 10))
> +#define ICPU_PCIESLV_SBA_SBA_ATTR_M                       GENMASK(11, 10)
> +#define ICPU_PCIESLV_SBA_SBA_ATTR_X(x)                    (((x) & GENMASK(11, 10)) >> 10)
> +#define ICPU_PCIESLV_SBA_SBA_TD                           BIT(9)
> +#define ICPU_PCIESLV_SBA_SBA_EP                           BIT(8)
> +#define ICPU_PCIESLV_SBA_SBA_RESERVED0                    BIT(7)
> +#define ICPU_PCIESLV_SBA_SBA_TYPE(x)                      (((x) << 2) & GENMASK(6, 2))
> +#define ICPU_PCIESLV_SBA_SBA_TYPE_M                       GENMASK(6, 2)
> +#define ICPU_PCIESLV_SBA_SBA_TYPE_X(x)                    (((x) & GENMASK(6, 2)) >> 2)
> +#define ICPU_PCIESLV_SBA_SBA_OFFSET(x)                    ((x) & GENMASK(1, 0))
> +#define ICPU_PCIESLV_SBA_SBA_OFFSET_M                     GENMASK(1, 0)
> +
> +#define ICPU_PCIEPCS_CFG                                  0x394
> +
> +#define ICPU_PCIEPCS_CFG_TXRX_DETECT                      BIT(22)
> +#define ICPU_PCIEPCS_CFG_SDETCOM_PERM                     BIT(21)
> +#define ICPU_PCIEPCS_CFG_SDETCOM_DIS                      BIT(20)
> +#define ICPU_PCIEPCS_CFG_BEACON_FORCE                     BIT(19)
> +#define ICPU_PCIEPCS_CFG_RXRST_FORCE                      BIT(18)
> +#define ICPU_PCIEPCS_CFG_RXRST_VAL                        BIT(17)
> +#define ICPU_PCIEPCS_CFG_TXRST_FORCE                      BIT(16)
> +#define ICPU_PCIEPCS_CFG_TXRST_VAL                        BIT(15)
> +#define ICPU_PCIEPCS_CFG_RXSDET_XOR                       BIT(14)
> +#define ICPU_PCIEPCS_CFG_RXSDET_FORCE                     BIT(13)
> +#define ICPU_PCIEPCS_CFG_RXINV_ENA                        BIT(12)
> +#define ICPU_PCIEPCS_CFG_RXSWAP_ENA                       BIT(11)
> +#define ICPU_PCIEPCS_CFG_TXSWAP_ENA                       BIT(10)
> +#define ICPU_PCIEPCS_CFG_IDLE_DATA_DIS                    BIT(9)
> +#define ICPU_PCIEPCS_CFG_IDLE_DIS                         BIT(8)
> +#define ICPU_PCIEPCS_CFG_IDLE_DLY(x)                      (((x) << 5) & GENMASK(7, 5))
> +#define ICPU_PCIEPCS_CFG_IDLE_DLY_M                       GENMASK(7, 5)
> +#define ICPU_PCIEPCS_CFG_IDLE_DLY_X(x)                    (((x) & GENMASK(7, 5)) >> 5)
> +#define ICPU_PCIEPCS_CFG_RXLP_FORCE                       BIT(4)
> +#define ICPU_PCIEPCS_CFG_TXLP_FORCE                       BIT(3)
> +#define ICPU_PCIEPCS_CFG_WAKE_POL                         BIT(2)
> +#define ICPU_PCIEPCS_CFG_WAKE_OE                          BIT(1)
> +#define ICPU_PCIEPCS_CFG_BEACON_DIS                       BIT(0)
> +
> +#define ICPU_PCIEPCS_BEACON                               0x398
> +
> +#define ICPU_PCIEPCS_BEACON_BEACON_VAL(x)                 (((x) << 16) & GENMASK(25, 16))
> +#define ICPU_PCIEPCS_BEACON_BEACON_VAL_M                  GENMASK(25, 16)
> +#define ICPU_PCIEPCS_BEACON_BEACON_VAL_X(x)               (((x) & GENMASK(25, 16)) >> 16)
> +#define ICPU_PCIEPCS_BEACON_BEACON_MAX_DIS                BIT(15)
> +#define ICPU_PCIEPCS_BEACON_BEACON_MAX_DLY(x)             ((x) & GENMASK(14, 0))
> +#define ICPU_PCIEPCS_BEACON_BEACON_MAX_DLY_M              GENMASK(14, 0)
> +
> +#define ICPU_PCIE_INTR                                    0x39c
> +
> +#define ICPU_PCIE_INTR_INTR_LTSSM_STATE                   BIT(4)
> +#define ICPU_PCIE_INTR_INTR_LINK_STATE                    BIT(3)
> +#define ICPU_PCIE_INTR_INTR_BAR1_WR                       BIT(2)
> +#define ICPU_PCIE_INTR_INTR_BAR1_RD                       BIT(1)
> +#define ICPU_PCIE_INTR_INTR_PM_STATE                      BIT(0)
> +
> +#define ICPU_PCIE_INTR_ENA                                0x3a0
> +
> +#define ICPU_PCIE_INTR_ENA_INTR_LTSSM_STATE_ENA           BIT(4)
> +#define ICPU_PCIE_INTR_ENA_INTR_LINK_STATE_ENA            BIT(3)
> +#define ICPU_PCIE_INTR_ENA_INTR_BAR1_WR_ENA               BIT(2)
> +#define ICPU_PCIE_INTR_ENA_INTR_BAR1_RD_ENA               BIT(1)
> +#define ICPU_PCIE_INTR_ENA_INTR_PM_STATE_ENA              BIT(0)
> +
> +#define ICPU_PCIE_INTR_IDENT                              0x3a4
> +
> +#define ICPU_PCIE_INTR_IDENT_INTR_LTSSM_STATE_IDENT       BIT(4)
> +#define ICPU_PCIE_INTR_IDENT_INTR_LINK_STATE_IDENT        BIT(3)
> +#define ICPU_PCIE_INTR_IDENT_INTR_BAR1_WR_IDENT           BIT(2)
> +#define ICPU_PCIE_INTR_IDENT_INTR_BAR1_RD_IDENT           BIT(1)
> +#define ICPU_PCIE_INTR_IDENT_INTR_PM_STATE_IDENT          BIT(0)
> +
> +#define ICPU_PCIE_INTR_COMMON_CFG                         0x3a8
> +
> +#define ICPU_PCIE_INTR_COMMON_CFG_WAKEUP_ON_INTR_DIS      BIT(2)
> +#define ICPU_PCIE_INTR_COMMON_CFG_LEGACY_MODE_INTR_SEL    BIT(1)
> +#define ICPU_PCIE_INTR_COMMON_CFG_PCIE_INTR_ENA           BIT(0)
> +
> +#define ICPU_PCIE_INTR_CFG                                0x3ac
> +#define ICPU_PCIE_INTR_CFG_RSZ                            0x4
> +
> +#define ICPU_PCIE_INTR_CFG_FUNCTION_NUMBER(x)             (((x) << 15) & GENMASK(17, 15))
> +#define ICPU_PCIE_INTR_CFG_FUNCTION_NUMBER_M              GENMASK(17, 15)
> +#define ICPU_PCIE_INTR_CFG_FUNCTION_NUMBER_X(x)           (((x) & GENMASK(17, 15)) >> 15)
> +#define ICPU_PCIE_INTR_CFG_TRAFFIC_CLASS(x)               (((x) << 12) & GENMASK(14, 12))
> +#define ICPU_PCIE_INTR_CFG_TRAFFIC_CLASS_M                GENMASK(14, 12)
> +#define ICPU_PCIE_INTR_CFG_TRAFFIC_CLASS_X(x)             (((x) & GENMASK(14, 12)) >> 12)
> +#define ICPU_PCIE_INTR_CFG_FALLING_VECTOR_VAL(x)          (((x) << 7) & GENMASK(11, 7))
> +#define ICPU_PCIE_INTR_CFG_FALLING_VECTOR_VAL_M           GENMASK(11, 7)
> +#define ICPU_PCIE_INTR_CFG_FALLING_VECTOR_VAL_X(x)        (((x) & GENMASK(11, 7)) >> 7)
> +#define ICPU_PCIE_INTR_CFG_RISING_VECTOR_VAL(x)           (((x) << 2) & GENMASK(6, 2))
> +#define ICPU_PCIE_INTR_CFG_RISING_VECTOR_VAL_M            GENMASK(6, 2)
> +#define ICPU_PCIE_INTR_CFG_RISING_VECTOR_VAL_X(x)         (((x) & GENMASK(6, 2)) >> 2)
> +#define ICPU_PCIE_INTR_CFG_INTR_FALLING_ENA               BIT(1)
> +#define ICPU_PCIE_INTR_CFG_INTR_RISING_ENA                BIT(0)
> +
> +#define ICPU_PCIE_INTR_STAT                               0x3b4
> +#define ICPU_PCIE_INTR_STAT_RSZ                           0x4
> +
> +#define ICPU_PCIE_INTR_STAT_INTR_PENDING_FALLING          BIT(1)
> +#define ICPU_PCIE_INTR_STAT_INTR_PENDING_RISING           BIT(0)
> +
> +#define ICPU_MANUAL_XTR                                   0x4000
> +
> +#define ICPU_MANUAL_INJ                                   0x8000
> +
> +#define ICPU_MANUAL_CFG                                   0xc000
> +
> +#define ICPU_MANUAL_CFG_XTR_FLUSH_DIS                     BIT(4)
> +#define ICPU_MANUAL_CFG_INJ_SWAP_ENA                      BIT(3)
> +#define ICPU_MANUAL_CFG_XTR_SWAP_ENA                      BIT(2)
> +#define ICPU_MANUAL_CFG_INJ_ENA                           BIT(1)
> +#define ICPU_MANUAL_CFG_XTR_ENA                           BIT(0)
> +
> +#define ICPU_MANUAL_INTR                                  0xc004
> +
> +#define ICPU_MANUAL_INTR_INTR_INJ_RDY                     BIT(2)
> +#define ICPU_MANUAL_INTR_INTR_XTR_ANY_RDY                 BIT(1)
> +#define ICPU_MANUAL_INTR_INTR_XTR_SOF_RDY                 BIT(0)
> +
> +#define ICPU_MANUAL_INTR_ENA                              0xc008
> +
> +#define ICPU_MANUAL_INTR_ENA_INTR_INJ_RDY_ENA             BIT(2)
> +#define ICPU_MANUAL_INTR_ENA_INTR_XTR_ANY_RDY_ENA         BIT(1)
> +#define ICPU_MANUAL_INTR_ENA_INTR_XTR_SOF_RDY_ENA         BIT(0)
> +
> +#endif
> diff --git a/arch/mips/mach-mscc/include/mach/luton/luton_icpu_cfg.h b/arch/mips/mach-mscc/include/mach/luton/luton_icpu_cfg.h
> new file mode 100644
> index 0000000000..b0b09f4d21
> --- /dev/null
> +++ b/arch/mips/mach-mscc/include/mach/luton/luton_icpu_cfg.h
> @@ -0,0 +1,247 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +/*
> + * Copyright (c) 2018 Microsemi Corporation
> + */
> +
> +#ifndef _MSCC_OCELOT_ICPU_CFG_H_
> +#define _MSCC_OCELOT_ICPU_CFG_H_
> +
> +#define ICPU_GPR(x) (0x4 * (x))
> +#define ICPU_GPR_RSZ                                      0x4
> +
> +#define ICPU_RESET                                        0x20
> +
> +#define ICPU_RESET_CORE_RST_CPU_ONLY                      BIT(3)
> +#define ICPU_RESET_CORE_RST_PROTECT                       BIT(2)
> +#define ICPU_RESET_CORE_RST_FORCE                         BIT(1)
> +#define ICPU_RESET_MEM_RST_FORCE                          BIT(0)
> +
> +#define ICPU_GENERAL_CTRL                                 0x24
> +
> +#define ICPU_GENERAL_CTRL_CPU_BUSIF_SLEEP_DIS             BIT(14)
> +#define ICPU_GENERAL_CTRL_CPU_BUSIF_WERR_ENA              BIT(13)
> +#define ICPU_GENERAL_CTRL_CPU_8051_IROM_ENA               BIT(12)
> +#define ICPU_GENERAL_CTRL_CPU_MIPS_DIS                    BIT(11)
> +#define ICPU_GENERAL_CTRL_IF_MIIM_SLV_ADDR_SEL            BIT(10)
> +#define ICPU_GENERAL_CTRL_IF_MIIM_SLV_ENA                 BIT(9)
> +#define ICPU_GENERAL_CTRL_IF_PI_SLV_DONEPOL               BIT(8)
> +#define ICPU_GENERAL_CTRL_IF_PI_MST_ENA                   BIT(7)
> +#define ICPU_GENERAL_CTRL_IF_PI_SLV_ENA                   BIT(6)
> +#define ICPU_GENERAL_CTRL_IF_SI_OWNER(x)                  (((x) << 4) & GENMASK(5, 4))
> +#define ICPU_GENERAL_CTRL_IF_SI_OWNER_M                   GENMASK(5, 4)
> +#define ICPU_GENERAL_CTRL_IF_SI_OWNER_X(x)                (((x) & GENMASK(5, 4)) >> 4)
> +#define ICPU_GENERAL_CTRL_SSI_MST_CONTENTION              BIT(3)
> +#define ICPU_GENERAL_CTRL_CPU_BE_ENA                      BIT(2)
> +#define ICPU_GENERAL_CTRL_CPU_DIS                         BIT(1)
> +#define ICPU_GENERAL_CTRL_BOOT_MODE_ENA                   BIT(0)
> +
> +#define ICPU_SPI_MST_CFG                                  0x3c
> +
> +#define ICPU_SPI_MST_CFG_A32B_ENA                         BIT(11)
> +#define ICPU_SPI_MST_CFG_FAST_READ_ENA                    BIT(10)
> +#define ICPU_SPI_MST_CFG_CS_DESELECT_TIME(x)              (((x) << 5) & GENMASK(9, 5))
> +#define ICPU_SPI_MST_CFG_CS_DESELECT_TIME_M               GENMASK(9, 5)
> +#define ICPU_SPI_MST_CFG_CS_DESELECT_TIME_X(x)            (((x) & GENMASK(9, 5)) >> 5)
> +#define ICPU_SPI_MST_CFG_CLK_DIV(x)                       ((x) & GENMASK(4, 0))
> +#define ICPU_SPI_MST_CFG_CLK_DIV_M                        GENMASK(4, 0)
> +
> +
> +#define ICPU_SW_MODE                                      0x64
> +
> +#define ICPU_SW_MODE_SW_PIN_CTRL_MODE                     BIT(13)
> +#define ICPU_SW_MODE_SW_SPI_SCK                           BIT(12)
> +#define ICPU_SW_MODE_SW_SPI_SCK_OE                        BIT(11)
> +#define ICPU_SW_MODE_SW_SPI_SDO                           BIT(10)
> +#define ICPU_SW_MODE_SW_SPI_SDO_OE                        BIT(9)
> +#define ICPU_SW_MODE_SW_SPI_CS(x)                         (((x) << 5) & GENMASK(8, 5))
> +#define ICPU_SW_MODE_SW_SPI_CS_M                          GENMASK(8, 5)
> +#define ICPU_SW_MODE_SW_SPI_CS_X(x)                       (((x) & GENMASK(8, 5)) >> 5)
> +#define ICPU_SW_MODE_SW_SPI_CS_OE(x)                      (((x) << 1) & GENMASK(4, 1))
> +#define ICPU_SW_MODE_SW_SPI_CS_OE_M                       GENMASK(4, 1)
> +#define ICPU_SW_MODE_SW_SPI_CS_OE_X(x)                    (((x) & GENMASK(4, 1)) >> 1)
> +#define ICPU_SW_MODE_SW_SPI_SDI                           BIT(0)
> +
> +#define ICPU_INTR_ENA                                     0x88
> +
> +#define ICPU_INTR_IRQ0_ENA                                0x98
> +#define ICPU_INTR_IRQ0_ENA_IRQ0_ENA                       BIT(0)
> +
> +#define ICPU_MEMCTRL_CTRL                                 0x234
> +
> +#define ICPU_MEMCTRL_CTRL_PWR_DOWN                        BIT(3)
> +#define ICPU_MEMCTRL_CTRL_MDSET                           BIT(2)
> +#define ICPU_MEMCTRL_CTRL_STALL_REF_ENA                   BIT(1)
> +#define ICPU_MEMCTRL_CTRL_INITIALIZE                      BIT(0)
> +
> +#define ICPU_MEMCTRL_CFG                                  0x238
> +
> +#define ICPU_MEMCTRL_CFG_DDR_512MBYTE_PLUS                BIT(16)
> +#define ICPU_MEMCTRL_CFG_DDR_ECC_ERR_ENA                  BIT(15)
> +#define ICPU_MEMCTRL_CFG_DDR_ECC_COR_ENA                  BIT(14)
> +#define ICPU_MEMCTRL_CFG_DDR_ECC_ENA                      BIT(13)
> +#define ICPU_MEMCTRL_CFG_DDR_WIDTH                        BIT(12)
> +#define ICPU_MEMCTRL_CFG_DDR_MODE                         BIT(11)
> +#define ICPU_MEMCTRL_CFG_BURST_SIZE                       BIT(10)
> +#define ICPU_MEMCTRL_CFG_BURST_LEN                        BIT(9)
> +#define ICPU_MEMCTRL_CFG_BANK_CNT                         BIT(8)
> +#define ICPU_MEMCTRL_CFG_MSB_ROW_ADDR(x)                  (((x) << 4) & GENMASK(7, 4))
> +#define ICPU_MEMCTRL_CFG_MSB_ROW_ADDR_M                   GENMASK(7, 4)
> +#define ICPU_MEMCTRL_CFG_MSB_ROW_ADDR_X(x)                (((x) & GENMASK(7, 4)) >> 4)
> +#define ICPU_MEMCTRL_CFG_MSB_COL_ADDR(x)                  ((x) & GENMASK(3, 0))
> +#define ICPU_MEMCTRL_CFG_MSB_COL_ADDR_M                   GENMASK(3, 0)
> +
> +#define ICPU_MEMCTRL_STAT                                 0x23C
> +
> +#define ICPU_MEMCTRL_STAT_RDATA_MASKED                    BIT(5)
> +#define ICPU_MEMCTRL_STAT_RDATA_DUMMY                     BIT(4)
> +#define ICPU_MEMCTRL_STAT_RDATA_ECC_ERR                   BIT(3)
> +#define ICPU_MEMCTRL_STAT_RDATA_ECC_COR                   BIT(2)
> +#define ICPU_MEMCTRL_STAT_PWR_DOWN_ACK                    BIT(1)
> +#define ICPU_MEMCTRL_STAT_INIT_DONE                       BIT(0)
> +
> +#define ICPU_MEMCTRL_REF_PERIOD                           0x240
> +
> +#define ICPU_MEMCTRL_REF_PERIOD_MAX_PEND_REF(x)           (((x) << 16) & GENMASK(19, 16))
> +#define ICPU_MEMCTRL_REF_PERIOD_MAX_PEND_REF_M            GENMASK(19, 16)
> +#define ICPU_MEMCTRL_REF_PERIOD_MAX_PEND_REF_X(x)         (((x) & GENMASK(19, 16)) >> 16)
> +#define ICPU_MEMCTRL_REF_PERIOD_REF_PERIOD(x)             ((x) & GENMASK(15, 0))
> +#define ICPU_MEMCTRL_REF_PERIOD_REF_PERIOD_M              GENMASK(15, 0)
> +
> +#define ICPU_MEMCTRL_TIMING0                              0x248
> +
> +#define ICPU_MEMCTRL_TIMING0_RD_TO_WR_DLY(x)              (((x) << 28) & GENMASK(31, 28))
> +#define ICPU_MEMCTRL_TIMING0_RD_TO_WR_DLY_M               GENMASK(31, 28)
> +#define ICPU_MEMCTRL_TIMING0_RD_TO_WR_DLY_X(x)            (((x) & GENMASK(31, 28)) >> 28)
> +#define ICPU_MEMCTRL_TIMING0_WR_CS_CHANGE_DLY(x)          (((x) << 24) & GENMASK(27, 24))
> +#define ICPU_MEMCTRL_TIMING0_WR_CS_CHANGE_DLY_M           GENMASK(27, 24)
> +#define ICPU_MEMCTRL_TIMING0_WR_CS_CHANGE_DLY_X(x)        (((x) & GENMASK(27, 24)) >> 24)
> +#define ICPU_MEMCTRL_TIMING0_RD_CS_CHANGE_DLY(x)          (((x) << 20) & GENMASK(23, 20))
> +#define ICPU_MEMCTRL_TIMING0_RD_CS_CHANGE_DLY_M           GENMASK(23, 20)
> +#define ICPU_MEMCTRL_TIMING0_RD_CS_CHANGE_DLY_X(x)        (((x) & GENMASK(23, 20)) >> 20)
> +#define ICPU_MEMCTRL_TIMING0_RAS_TO_PRECH_DLY(x)          (((x) << 16) & GENMASK(19, 16))
> +#define ICPU_MEMCTRL_TIMING0_RAS_TO_PRECH_DLY_M           GENMASK(19, 16)
> +#define ICPU_MEMCTRL_TIMING0_RAS_TO_PRECH_DLY_X(x)        (((x) & GENMASK(19, 16)) >> 16)
> +#define ICPU_MEMCTRL_TIMING0_WR_TO_PRECH_DLY(x)           (((x) << 12) & GENMASK(15, 12))
> +#define ICPU_MEMCTRL_TIMING0_WR_TO_PRECH_DLY_M            GENMASK(15, 12)
> +#define ICPU_MEMCTRL_TIMING0_WR_TO_PRECH_DLY_X(x)         (((x) & GENMASK(15, 12)) >> 12)
> +#define ICPU_MEMCTRL_TIMING0_RD_TO_PRECH_DLY(x)           (((x) << 8) & GENMASK(11, 8))
> +#define ICPU_MEMCTRL_TIMING0_RD_TO_PRECH_DLY_M            GENMASK(11, 8)
> +#define ICPU_MEMCTRL_TIMING0_RD_TO_PRECH_DLY_X(x)         (((x) & GENMASK(11, 8)) >> 8)
> +#define ICPU_MEMCTRL_TIMING0_WR_DATA_XFR_DLY(x)           (((x) << 4) & GENMASK(7, 4))
> +#define ICPU_MEMCTRL_TIMING0_WR_DATA_XFR_DLY_M            GENMASK(7, 4)
> +#define ICPU_MEMCTRL_TIMING0_WR_DATA_XFR_DLY_X(x)         (((x) & GENMASK(7, 4)) >> 4)
> +#define ICPU_MEMCTRL_TIMING0_RD_DATA_XFR_DLY(x)           ((x) & GENMASK(3, 0))
> +#define ICPU_MEMCTRL_TIMING0_RD_DATA_XFR_DLY_M            GENMASK(3, 0)
> +
> +#define ICPU_MEMCTRL_TIMING1                              0x24c
> +
> +#define ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_SAME_BANK_DLY(x)  (((x) << 24) & GENMASK(31, 24))
> +#define ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_SAME_BANK_DLY_M   GENMASK(31, 24)
> +#define ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_SAME_BANK_DLY_X(x) (((x) & GENMASK(31, 24)) >> 24)
> +#define ICPU_MEMCTRL_TIMING1_BANK8_FAW_DLY(x)             (((x) << 16) & GENMASK(23, 16))
> +#define ICPU_MEMCTRL_TIMING1_BANK8_FAW_DLY_M              GENMASK(23, 16)
> +#define ICPU_MEMCTRL_TIMING1_BANK8_FAW_DLY_X(x)           (((x) & GENMASK(23, 16)) >> 16)
> +#define ICPU_MEMCTRL_TIMING1_PRECH_TO_RAS_DLY(x)          (((x) << 12) & GENMASK(15, 12))
> +#define ICPU_MEMCTRL_TIMING1_PRECH_TO_RAS_DLY_M           GENMASK(15, 12)
> +#define ICPU_MEMCTRL_TIMING1_PRECH_TO_RAS_DLY_X(x)        (((x) & GENMASK(15, 12)) >> 12)
> +#define ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_DLY(x)            (((x) << 8) & GENMASK(11, 8))
> +#define ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_DLY_M             GENMASK(11, 8)
> +#define ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_DLY_X(x)          (((x) & GENMASK(11, 8)) >> 8)
> +#define ICPU_MEMCTRL_TIMING1_RAS_TO_CAS_DLY(x)            (((x) << 4) & GENMASK(7, 4))
> +#define ICPU_MEMCTRL_TIMING1_RAS_TO_CAS_DLY_M             GENMASK(7, 4)
> +#define ICPU_MEMCTRL_TIMING1_RAS_TO_CAS_DLY_X(x)          (((x) & GENMASK(7, 4)) >> 4)
> +#define ICPU_MEMCTRL_TIMING1_WR_TO_RD_DLY(x)              ((x) & GENMASK(3, 0))
> +#define ICPU_MEMCTRL_TIMING1_WR_TO_RD_DLY_M               GENMASK(3, 0)
> +
> +#define ICPU_MEMCTRL_TIMING2                              0x250
> +
> +#define ICPU_MEMCTRL_TIMING2_PRECH_ALL_DLY(x)             (((x) << 28) & GENMASK(31, 28))
> +#define ICPU_MEMCTRL_TIMING2_PRECH_ALL_DLY_M              GENMASK(31, 28)
> +#define ICPU_MEMCTRL_TIMING2_PRECH_ALL_DLY_X(x)           (((x) & GENMASK(31, 28)) >> 28)
> +#define ICPU_MEMCTRL_TIMING2_MDSET_DLY(x)                 (((x) << 24) & GENMASK(27, 24))
> +#define ICPU_MEMCTRL_TIMING2_MDSET_DLY_M                  GENMASK(27, 24)
> +#define ICPU_MEMCTRL_TIMING2_MDSET_DLY_X(x)               (((x) & GENMASK(27, 24)) >> 24)
> +#define ICPU_MEMCTRL_TIMING2_REF_DLY(x)                   (((x) << 16) & GENMASK(23, 16))
> +#define ICPU_MEMCTRL_TIMING2_REF_DLY_M                    GENMASK(23, 16)
> +#define ICPU_MEMCTRL_TIMING2_REF_DLY_X(x)                 (((x) & GENMASK(23, 16)) >> 16)
> +#define ICPU_MEMCTRL_TIMING2_FOUR_HUNDRED_NS_DLY(x)       ((x) & GENMASK(15, 0))
> +#define ICPU_MEMCTRL_TIMING2_FOUR_HUNDRED_NS_DLY_M        GENMASK(15, 0)
> +
> +#define ICPU_MEMCTRL_TIMING3                              0x254
> +
> +#define ICPU_MEMCTRL_TIMING3_RMW_DLY(x)                   (((x) << 16) & GENMASK(19, 16))
> +#define ICPU_MEMCTRL_TIMING3_RMW_DLY_M                    GENMASK(19, 16)
> +#define ICPU_MEMCTRL_TIMING3_RMW_DLY_X(x)                 (((x) & GENMASK(19, 16)) >> 16)
> +#define ICPU_MEMCTRL_TIMING3_ODT_RD_DLY(x)                (((x) << 12) & GENMASK(15, 12))
> +#define ICPU_MEMCTRL_TIMING3_ODT_RD_DLY_M                 GENMASK(15, 12)
> +#define ICPU_MEMCTRL_TIMING3_ODT_RD_DLY_X(x)              (((x) & GENMASK(15, 12)) >> 12)
> +#define ICPU_MEMCTRL_TIMING3_ODT_WR_DLY(x)                (((x) << 8) & GENMASK(11, 8))
> +#define ICPU_MEMCTRL_TIMING3_ODT_WR_DLY_M                 GENMASK(11, 8)
> +#define ICPU_MEMCTRL_TIMING3_ODT_WR_DLY_X(x)              (((x) & GENMASK(11, 8)) >> 8)
> +#define ICPU_MEMCTRL_TIMING3_LOCAL_ODT_RD_DLY(x)          (((x) << 4) & GENMASK(7, 4))
> +#define ICPU_MEMCTRL_TIMING3_LOCAL_ODT_RD_DLY_M           GENMASK(7, 4)
> +#define ICPU_MEMCTRL_TIMING3_LOCAL_ODT_RD_DLY_X(x)        (((x) & GENMASK(7, 4)) >> 4)
> +#define ICPU_MEMCTRL_TIMING3_WR_TO_RD_CS_CHANGE_DLY(x)    ((x) & GENMASK(3, 0))
> +#define ICPU_MEMCTRL_TIMING3_WR_TO_RD_CS_CHANGE_DLY_M     GENMASK(3, 0)
> +
> +#define ICPU_MEMCTRL_MR0_VAL                              0x258
> +
> +#define ICPU_MEMCTRL_MR1_VAL                              0x25c
> +
> +#define ICPU_MEMCTRL_MR2_VAL                              0x260
> +
> +#define ICPU_MEMCTRL_MR3_VAL                              0x264
> +
> +#define ICPU_MEMCTRL_TERMRES_CTRL                         0x268
> +
> +#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_RD_EXT              BIT(11)
> +#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_RD_ENA(x)           (((x) << 7) & GENMASK(10, 7))
> +#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_RD_ENA_M            GENMASK(10, 7)
> +#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_RD_ENA_X(x)         (((x) & GENMASK(10, 7)) >> 7)
> +#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_WR_EXT              BIT(6)
> +#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_WR_ENA(x)           (((x) << 2) & GENMASK(5, 2))
> +#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_WR_ENA_M            GENMASK(5, 2)
> +#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_WR_ENA_X(x)         (((x) & GENMASK(5, 2)) >> 2)
> +#define ICPU_MEMCTRL_TERMRES_CTRL_LOCAL_ODT_RD_EXT        BIT(1)
> +#define ICPU_MEMCTRL_TERMRES_CTRL_LOCAL_ODT_RD_ENA        BIT(0)
> +
> +#define ICPU_MEMCTRL_DQS_DLY(x) (0x270)
> +
> +#define ICPU_MEMCTRL_DQS_DLY_TRAIN_DQ_ENA                 BIT(11)
> +#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_TRM1(x)              (((x) << 8) & GENMASK(10, 8))
> +#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_TRM1_M               GENMASK(10, 8)
> +#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_TRM1_X(x)            (((x) & GENMASK(10, 8)) >> 8)
> +#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_TRM0(x)              (((x) << 5) & GENMASK(7, 5))
> +#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_TRM0_M               GENMASK(7, 5)
> +#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_TRM0_X(x)            (((x) & GENMASK(7, 5)) >> 5)
> +#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY(x)                   ((x) & GENMASK(4, 0))
> +#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_M                    GENMASK(4, 0)
> +
> +#define ICPU_MEMPHY_CFG                                   0x278
> +
> +#define ICPU_MEMPHY_CFG_PHY_FLUSH_DIS                     BIT(10)
> +#define ICPU_MEMPHY_CFG_PHY_RD_ADJ_DIS                    BIT(9)
> +#define ICPU_MEMPHY_CFG_PHY_DQS_EXT                       BIT(8)
> +#define ICPU_MEMPHY_CFG_PHY_FIFO_RST                      BIT(7)
> +#define ICPU_MEMPHY_CFG_PHY_DLL_BL_RST                    BIT(6)
> +#define ICPU_MEMPHY_CFG_PHY_DLL_CL_RST                    BIT(5)
> +#define ICPU_MEMPHY_CFG_PHY_ODT_OE                        BIT(4)
> +#define ICPU_MEMPHY_CFG_PHY_CK_OE                         BIT(3)
> +#define ICPU_MEMPHY_CFG_PHY_CL_OE                         BIT(2)
> +#define ICPU_MEMPHY_CFG_PHY_SSTL_ENA                      BIT(1)
> +#define ICPU_MEMPHY_CFG_PHY_RST                           BIT(0)
> +#define ICPU_MEMPHY_DQ_DLY_TRM                            0x180
> +#define ICPU_MEMPHY_DQ_DLY_TRM_RSZ                        0x4
> +
> +#define ICPU_MEMPHY_ZCAL                                  0x294
> +
> +#define ICPU_MEMPHY_ZCAL_ZCAL_CLK_SEL                     BIT(9)
> +#define ICPU_MEMPHY_ZCAL_ZCAL_PROG_ODT(x)                 (((x) << 5) & GENMASK(8, 5))
> +#define ICPU_MEMPHY_ZCAL_ZCAL_PROG_ODT_M                  GENMASK(8, 5)
> +#define ICPU_MEMPHY_ZCAL_ZCAL_PROG_ODT_X(x)               (((x) & GENMASK(8, 5)) >> 5)
> +#define ICPU_MEMPHY_ZCAL_ZCAL_PROG(x)                     (((x) << 1) & GENMASK(4, 1))
> +#define ICPU_MEMPHY_ZCAL_ZCAL_PROG_M                      GENMASK(4, 1)
> +#define ICPU_MEMPHY_ZCAL_ZCAL_PROG_X(x)                   (((x) & GENMASK(4, 1)) >> 1)
> +#define ICPU_MEMPHY_ZCAL_ZCAL_ENA                         BIT(0)
> +
> +#endif
> diff --git a/arch/mips/mach-mscc/include/mach/ocelot/ocelot.h b/arch/mips/mach-mscc/include/mach/ocelot/ocelot.h
> new file mode 100644
> index 0000000000..698e6808a4
> --- /dev/null
> +++ b/arch/mips/mach-mscc/include/mach/ocelot/ocelot.h
> @@ -0,0 +1,35 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +/*
> + * Microsemi Ocelot Switch driver
> + *
> + * Copyright (c) 2018 Microsemi Corporation
> + */
> +
> +#ifndef _MSCC_OCELOT_H_
> +#define _MSCC_OCELOT_H_
> +
> +#include <linux/bitops.h>
> +#include <dm.h>
> +
> +/*
> + * Target offset base(s)
> + */
> +#define MSCC_IO_ORIGIN1_OFFSET 0x70000000
> +#define MSCC_IO_ORIGIN1_SIZE   0x00200000
> +#define MSCC_IO_ORIGIN2_OFFSET 0x71000000
> +#define MSCC_IO_ORIGIN2_SIZE   0x01000000
> +#ifndef MSCC_IO_OFFSET1
> +#define MSCC_IO_OFFSET1(offset) (MSCC_IO_ORIGIN1_OFFSET + offset)
> +#endif
> +#ifndef MSCC_IO_OFFSET2
> +#define MSCC_IO_OFFSET2(offset) (MSCC_IO_ORIGIN2_OFFSET + offset)
> +#endif
> +#define BASE_CFG        0x70000000
> +#define BASE_UART       0x70100000
> +#define BASE_DEVCPU_GCB 0x71070000
> +
> +#define REG_OFFSET(t, o) ((volatile unsigned long *)(t + (o)))
> +#define REG_CFG(x) REG_OFFSET(BASE_CFG, x)
> +#define REG_GCB(x) REG_OFFSET(BASE_DEVCPU_GCB, x)
> +
> +#endif
> diff --git a/arch/mips/mach-mscc/include/mach/ocelot/ocelot_devcpu_gcb.h b/arch/mips/mach-mscc/include/mach/ocelot/ocelot_devcpu_gcb.h
> new file mode 100644
> index 0000000000..19f707a478
> --- /dev/null
> +++ b/arch/mips/mach-mscc/include/mach/ocelot/ocelot_devcpu_gcb.h
> @@ -0,0 +1,353 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +/*
> + * Copyright (c) 2018 Microsemi Corporation
> + */
> +
> +#ifndef _MSCC_OCELOT_DEVCPU_GCB_H_
> +#define _MSCC_OCELOT_DEVCPU_GCB_H_
> +
> +#define PERF_CHIP_ID                                      0x0
> +
> +#define PERF_CHIP_ID_REV_ID(x)                            (((x) << 28) & GENMASK(31, 28))
> +#define PERF_CHIP_ID_REV_ID_M                             GENMASK(31, 28)
> +#define PERF_CHIP_ID_REV_ID_X(x)                          (((x) & GENMASK(31, 28)) >> 28)
> +#define PERF_CHIP_ID_PART_ID(x)                           (((x) << 12) & GENMASK(27, 12))
> +#define PERF_CHIP_ID_PART_ID_M                            GENMASK(27, 12)
> +#define PERF_CHIP_ID_PART_ID_X(x)                         (((x) & GENMASK(27, 12)) >> 12)
> +#define PERF_CHIP_ID_MFG_ID(x)                            (((x) << 1) & GENMASK(11, 1))
> +#define PERF_CHIP_ID_MFG_ID_M                             GENMASK(11, 1)
> +#define PERF_CHIP_ID_MFG_ID_X(x)                          (((x) & GENMASK(11, 1)) >> 1)
> +#define PERF_CHIP_ID_ONE                                  BIT(0)
> +
> +#define PERF_GPR                                          0x4
> +
> +#define PERF_SOFT_RST                                     0x8
> +
> +#define PERF_SOFT_RST_SOFT_NON_CFG_RST                    BIT(2)
> +#define PERF_SOFT_RST_SOFT_SWC_RST                        BIT(1)
> +#define PERF_SOFT_RST_SOFT_CHIP_RST                       BIT(0)
> +
> +#define PERF_HW_CFG                                       0xc
> +
> +#define PERF_HW_CFG_DFT_STAT_ENA                          BIT(0)
> +
> +#define PERF_HW_STAT                                      0x10
> +
> +#define PERF_HW_STAT_PLL0_CONF(x)                         (((x) << 1) & GENMASK(3, 1))
> +#define PERF_HW_STAT_PLL0_CONF_M                          GENMASK(3, 1)
> +#define PERF_HW_STAT_PLL0_CONF_X(x)                       (((x) & GENMASK(3, 1)) >> 1)
> +#define PERF_HW_STAT_MEM_FAIL                             BIT(0)
> +
> +#define PERF_FEA_STAT                                     0x14
> +
> +#define PERF_FEA_DIS                                      0x18
> +
> +#define PERF_SW_INTR                                      0x1c
> +
> +#define PERF_SW_INTR_SW1_INTR                             BIT(1)
> +#define PERF_SW_INTR_SW0_INTR                             BIT(0)
> +
> +#define PERF_VA_CTRL                                      0x20
> +
> +#define PERF_VA_CTRL_VA_SIZE(x)                           (((x) << 4) & GENMASK(5, 4))
> +#define PERF_VA_CTRL_VA_SIZE_M                            GENMASK(5, 4)
> +#define PERF_VA_CTRL_VA_SIZE_X(x)                         (((x) & GENMASK(5, 4)) >> 4)
> +#define PERF_VA_CTRL_VA_ERR(x)                            (((x) << 2) & GENMASK(3, 2))
> +#define PERF_VA_CTRL_VA_ERR_M                             GENMASK(3, 2)
> +#define PERF_VA_CTRL_VA_ERR_X(x)                          (((x) & GENMASK(3, 2)) >> 2)
> +#define PERF_VA_CTRL_VA_BUSY_RD                           BIT(1)
> +#define PERF_VA_CTRL_VA_BUSY                              BIT(0)
> +
> +#define PERF_VA_ADDR                                      0x24
> +
> +#define PERF_VA_DATA                                      0x28
> +
> +#define PERF_VA_DATA_INCR                                 0x2c
> +
> +#define PERF_VA_DATA_INERT                                0x30
> +
> +#define PERF_GPIO_OUT_SET                                 0x34
> +
> +#define PERF_GPIO_OUT_CLR                                 0x38
> +
> +#define PERF_GPIO_OUT                                     0x3c
> +
> +#define PERF_GPIO_IN                                      0x40
> +
> +#define PERF_GPIO_OE                                      0x44
> +
> +#define PERF_GPIO_INTR                                    0x48
> +
> +#define PERF_GPIO_INTR_ENA                                0x4c
> +
> +#define PERF_GPIO_INTR_IDENT                              0x50
> +
> +#define PERF_GPIO_ALT(x)                                  (0x54 + 4 * (x))
> +#define PERF_GPIO_ALT_RSZ                                 0x4
> +
> +#define PERF_GPIO_SD_MAP                                  0x5c
> +#define PERF_GPIO_SD_MAP_RSZ                              0x4
> +
> +#define PERF_MII_STATUS                                   0x9c
> +#define PERF_MII_STATUS_GSZ                               0x24
> +
> +#define PERF_MII_STATUS_MIIM_SCAN_COMPLETE                BIT(4)
> +#define PERF_MII_STATUS_MIIM_STAT_BUSY                    BIT(3)
> +#define PERF_MII_STATUS_MIIM_STAT_OPR_PEND                BIT(2)
> +#define PERF_MII_STATUS_MIIM_STAT_PENDING_RD              BIT(1)
> +#define PERF_MII_STATUS_MIIM_STAT_PENDING_WR              BIT(0)
> +
> +#define PERF_MII_CFG_7226                                 0xa0
> +#define PERF_MII_CFG_7226_GSZ                             0x24
> +
> +#define PERF_MII_CFG_7226_MIIM_7226_CFG_FIELD             BIT(9)
> +
> +#define PERF_MII_CMD                                      0xa4
> +#define PERF_MII_CMD_GSZ                                  0x24
> +
> +#define PERF_MII_CMD_MIIM_CMD_VLD                         BIT(31)
> +#define PERF_MII_CMD_MIIM_CMD_PHYAD(x)                    (((x) << 25) & GENMASK(29, 25))
> +#define PERF_MII_CMD_MIIM_CMD_PHYAD_M                     GENMASK(29, 25)
> +#define PERF_MII_CMD_MIIM_CMD_PHYAD_X(x)                  (((x) & GENMASK(29, 25)) >> 25)
> +#define PERF_MII_CMD_MIIM_CMD_REGAD(x)                    (((x) << 20) & GENMASK(24, 20))
> +#define PERF_MII_CMD_MIIM_CMD_REGAD_M                     GENMASK(24, 20)
> +#define PERF_MII_CMD_MIIM_CMD_REGAD_X(x)                  (((x) & GENMASK(24, 20)) >> 20)
> +#define PERF_MII_CMD_MIIM_CMD_WRDATA(x)                   (((x) << 4) & GENMASK(19, 4))
> +#define PERF_MII_CMD_MIIM_CMD_WRDATA_M                    GENMASK(19, 4)
> +#define PERF_MII_CMD_MIIM_CMD_WRDATA_X(x)                 (((x) & GENMASK(19, 4)) >> 4)
> +#define PERF_MII_CMD_MIIM_CMD_SINGLE_SCAN                 BIT(3)
> +#define PERF_MII_CMD_MIIM_CMD_OPR_FIELD(x)                (((x) << 1) & GENMASK(2, 1))
> +#define PERF_MII_CMD_MIIM_CMD_OPR_FIELD_M                 GENMASK(2, 1)
> +#define PERF_MII_CMD_MIIM_CMD_OPR_FIELD_X(x)              (((x) & GENMASK(2, 1)) >> 1)
> +#define PERF_MII_CMD_MIIM_CMD_SCAN                        BIT(0)
> +
> +#define PERF_MII_DATA                                     0xa8
> +#define PERF_MII_DATA_GSZ                                 0x24
> +
> +#define PERF_MII_DATA_MIIM_DATA_SUCCESS(x)                (((x) << 16) & GENMASK(17, 16))
> +#define PERF_MII_DATA_MIIM_DATA_SUCCESS_M                 GENMASK(17, 16)
> +#define PERF_MII_DATA_MIIM_DATA_SUCCESS_X(x)              (((x) & GENMASK(17, 16)) >> 16)
> +#define PERF_MII_DATA_MIIM_DATA_RDDATA(x)                 ((x) & GENMASK(15, 0))
> +#define PERF_MII_DATA_MIIM_DATA_RDDATA_M                  GENMASK(15, 0)
> +
> +#define PERF_MII_CFG                                      0xac
> +#define PERF_MII_CFG_GSZ                                  0x24
> +
> +#define PERF_MII_CFG_DEADLOCK_FIX_DIS                     BIT(11)
> +#define PERF_MII_CFG_MIIM_ST_CFG_FIELD(x)                 (((x) << 9) & GENMASK(10, 9))
> +#define PERF_MII_CFG_MIIM_ST_CFG_FIELD_M                  GENMASK(10, 9)
> +#define PERF_MII_CFG_MIIM_ST_CFG_FIELD_X(x)               (((x) & GENMASK(10, 9)) >> 9)
> +#define PERF_MII_CFG_MIIM_CFG_DBG                         BIT(8)
> +#define PERF_MII_CFG_MIIM_CFG_PRESCALE(x)                 ((x) & GENMASK(7, 0))
> +#define PERF_MII_CFG_MIIM_CFG_PRESCALE_M                  GENMASK(7, 0)
> +
> +#define PERF_MII_SCAN_0                                   0xb0
> +#define PERF_MII_SCAN_0_GSZ                               0x24
> +
> +#define PERF_MII_SCAN_0_MIIM_SCAN_PHYADHI(x)              (((x) << 5) & GENMASK(9, 5))
> +#define PERF_MII_SCAN_0_MIIM_SCAN_PHYADHI_M               GENMASK(9, 5)
> +#define PERF_MII_SCAN_0_MIIM_SCAN_PHYADHI_X(x)            (((x) & GENMASK(9, 5)) >> 5)
> +#define PERF_MII_SCAN_0_MIIM_SCAN_PHYADLO(x)              ((x) & GENMASK(4, 0))
> +#define PERF_MII_SCAN_0_MIIM_SCAN_PHYADLO_M               GENMASK(4, 0)
> +
> +#define PERF_MII_SCAN_1                                   0xb4
> +#define PERF_MII_SCAN_1_GSZ                               0x24
> +
> +#define PERF_MII_SCAN_1_MIIM_SCAN_MASK(x)                 (((x) << 16) & GENMASK(31, 16))
> +#define PERF_MII_SCAN_1_MIIM_SCAN_MASK_M                  GENMASK(31, 16)
> +#define PERF_MII_SCAN_1_MIIM_SCAN_MASK_X(x)               (((x) & GENMASK(31, 16)) >> 16)
> +#define PERF_MII_SCAN_1_MIIM_SCAN_EXPECT(x)               ((x) & GENMASK(15, 0))
> +#define PERF_MII_SCAN_1_MIIM_SCAN_EXPECT_M                GENMASK(15, 0)
> +
> +#define PERF_MII_SCAN_RES                                 0xb8
> +#define PERF_MII_SCAN_RES_GSZ                             0x24
> +
> +#define PERF_MII_SCAN_RES_VLD                             0xbc
> +#define PERF_MII_SCAN_RES_VLD_GSZ                         0x24
> +
> +#define PERF_MII_SCAN_RES_STICKY                          0xe4
> +#define PERF_MII_SCAN_RES_STICKY_RSZ                      0x4
> +
> +#define PERF_MII_SLAVE_CFG                                0xec
> +
> +#define PERF_MII_SLAVE_CFG_SPIKE_FILTER_CFG(x)            (((x) << 1) & GENMASK(5, 1))
> +#define PERF_MII_SLAVE_CFG_SPIKE_FILTER_CFG_M             GENMASK(5, 1)
> +#define PERF_MII_SLAVE_CFG_SPIKE_FILTER_CFG_X(x)          (((x) & GENMASK(5, 1)) >> 1)
> +#define PERF_MII_SLAVE_CFG_SPIKE_FILTER_ENA               BIT(0)
> +
> +#define PERF_PHY_CFG                                      0xf0
> +
> +#define PERF_PHY_CFG_PHY_COMA                             BIT(12)
> +#define PERF_PHY_CFG_PHY_ADDR(x)                          (((x) << 9) & GENMASK(11, 9))
> +#define PERF_PHY_CFG_PHY_ADDR_M                           GENMASK(11, 9)
> +#define PERF_PHY_CFG_PHY_ADDR_X(x)                        (((x) & GENMASK(11, 9)) >> 9)
> +#define PERF_PHY_CFG_PHY_RESET(x)                         (((x) << 5) & GENMASK(8, 5))
> +#define PERF_PHY_CFG_PHY_RESET_M                          GENMASK(8, 5)
> +#define PERF_PHY_CFG_PHY_RESET_X(x)                       (((x) & GENMASK(8, 5)) >> 5)
> +#define PERF_PHY_CFG_PHY_COMMON_RESET                     BIT(4)
> +#define PERF_PHY_CFG_PHY_ENA(x)                           ((x) & GENMASK(3, 0))
> +#define PERF_PHY_CFG_PHY_ENA_M                            GENMASK(3, 0)
> +
> +#define PERF_PHY_STAT                                     0xf4
> +
> +#define PERF_PHY_STAT_PHY_COMA_OE                         BIT(22)
> +#define PERF_PHY_STAT_PHY_COMA_O                          BIT(21)
> +#define PERF_PHY_STAT_FAST_LINK_STATUS(x)                 (((x) << 17) & GENMASK(20, 17))
> +#define PERF_PHY_STAT_FAST_LINK_STATUS_M                  GENMASK(20, 17)
> +#define PERF_PHY_STAT_FAST_LINK_STATUS_X(x)               (((x) & GENMASK(20, 17)) >> 17)
> +#define PERF_PHY_STAT_LINK_STAT_DUPLEX(x)                 (((x) << 13) & GENMASK(16, 13))
> +#define PERF_PHY_STAT_LINK_STAT_DUPLEX_M                  GENMASK(16, 13)
> +#define PERF_PHY_STAT_LINK_STAT_DUPLEX_X(x)               (((x) & GENMASK(16, 13)) >> 13)
> +#define PERF_PHY_STAT_LINK_STAT_SPEED_1000(x)             (((x) << 9) & GENMASK(12, 9))
> +#define PERF_PHY_STAT_LINK_STAT_SPEED_1000_M              GENMASK(12, 9)
> +#define PERF_PHY_STAT_LINK_STAT_SPEED_1000_X(x)           (((x) & GENMASK(12, 9)) >> 9)
> +#define PERF_PHY_STAT_LINK_STAT_SPEED_100(x)              (((x) << 5) & GENMASK(8, 5))
> +#define PERF_PHY_STAT_LINK_STAT_SPEED_100_M               GENMASK(8, 5)
> +#define PERF_PHY_STAT_LINK_STAT_SPEED_100_X(x)            (((x) & GENMASK(8, 5)) >> 5)
> +#define PERF_PHY_STAT_LINK_STAT_SPEED_10(x)               (((x) << 1) & GENMASK(4, 1))
> +#define PERF_PHY_STAT_LINK_STAT_SPEED_10_M                GENMASK(4, 1)
> +#define PERF_PHY_STAT_LINK_STAT_SPEED_10_X(x)             (((x) & GENMASK(4, 1)) >> 1)
> +#define PERF_PHY_STAT_SUPERVISOR_COMPLETE                 BIT(0)
> +
> +#define PERF_SIO_INPUT_DATA                               0xf8
> +#define PERF_SIO_INPUT_DATA_RSZ                           0x4
> +
> +#define PERF_SIO_CFG                                      0x108
> +
> +#define PERF_SIO_CFG_SIO_PWM_WINDOW(x)                    (((x) << 24) & GENMASK(31, 24))
> +#define PERF_SIO_CFG_SIO_PWM_WINDOW_M                     GENMASK(31, 24)
> +#define PERF_SIO_CFG_SIO_PWM_WINDOW_X(x)                  (((x) & GENMASK(31, 24)) >> 24)
> +#define PERF_SIO_CFG_SIO_REDUCED_GAP                      BIT(23)
> +#define PERF_SIO_CFG_SIO_BMODE_1(x)                       (((x) << 21) & GENMASK(22, 21))
> +#define PERF_SIO_CFG_SIO_BMODE_1_M                        GENMASK(22, 21)
> +#define PERF_SIO_CFG_SIO_BMODE_1_X(x)                     (((x) & GENMASK(22, 21)) >> 21)
> +#define PERF_SIO_CFG_SIO_BMODE_0(x)                       (((x) << 19) & GENMASK(20, 19))
> +#define PERF_SIO_CFG_SIO_BMODE_0_M                        GENMASK(20, 19)
> +#define PERF_SIO_CFG_SIO_BMODE_0_X(x)                     (((x) & GENMASK(20, 19)) >> 19)
> +#define PERF_SIO_CFG_SIO_BLINK_RESET                      BIT(18)
> +#define PERF_SIO_CFG_SIO_BURST_GAP_DIS                    BIT(17)
> +#define PERF_SIO_CFG_SIO_BURST_GAP(x)                     (((x) << 12) & GENMASK(16, 12))
> +#define PERF_SIO_CFG_SIO_BURST_GAP_M                      GENMASK(16, 12)
> +#define PERF_SIO_CFG_SIO_BURST_GAP_X(x)                   (((x) & GENMASK(16, 12)) >> 12)
> +#define PERF_SIO_CFG_SIO_SINGLE_SHOT                      BIT(11)
> +#define PERF_SIO_CFG_SIO_AUTO_REPEAT                      BIT(10)
> +#define PERF_SIO_CFG_SIO_LD_POLARITY                      BIT(9)
> +#define PERF_SIO_CFG_SIO_PORT_WIDTH(x)                    (((x) << 7) & GENMASK(8, 7))
> +#define PERF_SIO_CFG_SIO_PORT_WIDTH_M                     GENMASK(8, 7)
> +#define PERF_SIO_CFG_SIO_PORT_WIDTH_X(x)                  (((x) & GENMASK(8, 7)) >> 7)
> +#define PERF_SIO_CFG_SIO_REVERSE_OUTPUT                   BIT(6)
> +#define PERF_SIO_CFG_SIO_REVERSE_INPUT                    BIT(5)
> +#define PERF_SIO_CFG_SIO_GPIO_INTR_ENA(x)                 (((x) << 1) & GENMASK(4, 1))
> +#define PERF_SIO_CFG_SIO_GPIO_INTR_ENA_M                  GENMASK(4, 1)
> +#define PERF_SIO_CFG_SIO_GPIO_INTR_ENA_X(x)               (((x) & GENMASK(4, 1)) >> 1)
> +#define PERF_SIO_CFG_SIO_MASTER_INTR_ENA                  BIT(0)
> +
> +#define PERF_SIO_CLOCK                                    0x10c
> +
> +#define PERF_SIO_CLOCK_SIO_CLK_FREQ(x)                    (((x) << 8) & GENMASK(19, 8))
> +#define PERF_SIO_CLOCK_SIO_CLK_FREQ_M                     GENMASK(19, 8)
> +#define PERF_SIO_CLOCK_SIO_CLK_FREQ_X(x)                  (((x) & GENMASK(19, 8)) >> 8)
> +#define PERF_SIO_CLOCK_SYS_CLK_PERIOD(x)                  ((x) & GENMASK(7, 0))
> +#define PERF_SIO_CLOCK_SYS_CLK_PERIOD_M                   GENMASK(7, 0)
> +
> +#define PERF_SIO_PORT_CFG                                 0x110
> +#define PERF_SIO_PORT_CFG_RSZ                             0x4
> +
> +#define PERF_SIO_PORT_CFG_BIT_SOURCE(x)                   (((x) << 12) & GENMASK(23, 12))
> +#define PERF_SIO_PORT_CFG_BIT_SOURCE_M                    GENMASK(23, 12)
> +#define PERF_SIO_PORT_CFG_BIT_SOURCE_X(x)                 (((x) & GENMASK(23, 12)) >> 12)
> +#define PERF_SIO_PORT_CFG_PWM_SOURCE(x)                   (((x) << 4) & GENMASK(11, 4))
> +#define PERF_SIO_PORT_CFG_PWM_SOURCE_M                    GENMASK(11, 4)
> +#define PERF_SIO_PORT_CFG_PWM_SOURCE_X(x)                 (((x) & GENMASK(11, 4)) >> 4)
> +#define PERF_SIO_PORT_CFG_BIT_POLARITY(x)                 ((x) & GENMASK(3, 0))
> +#define PERF_SIO_PORT_CFG_BIT_POLARITY_M                  GENMASK(3, 0)
> +
> +#define PERF_SIO_PORT_ENA                                 0x190
> +
> +#define PERF_SIO_PWM_CFG                                  0x194
> +#define PERF_SIO_PWM_CFG_RSZ                              0x4
> +
> +#define PERF_SIO_INTR_POL                                 0x1a0
> +#define PERF_SIO_INTR_POL_RSZ                             0x4
> +
> +#define PERF_SIO_INTR_RAW                                 0x1b0
> +#define PERF_SIO_INTR_RAW_RSZ                             0x4
> +
> +#define PERF_SIO_INTR_TRIGGER0                            0x1c0
> +#define PERF_SIO_INTR_TRIGGER0_RSZ                        0x4
> +
> +#define PERF_SIO_INTR_TRIGGER1                            0x1d0
> +#define PERF_SIO_INTR_TRIGGER1_RSZ                        0x4
> +
> +#define PERF_SIO_INTR                                     0x1e0
> +#define PERF_SIO_INTR_RSZ                                 0x4
> +
> +#define PERF_SIO_INTR_ENA                                 0x1f0
> +
> +#define PERF_SIO_INTR_IDENT                               0x1f4
> +#define PERF_SIO_INTR_IDENT_RSZ                           0x4
> +
> +#define PERF_FAN_CFG                                      0x204
> +
> +#define PERF_FAN_CFG_DUTY_CYCLE(x)                        (((x) << 16) & GENMASK(23, 16))
> +#define PERF_FAN_CFG_DUTY_CYCLE_M                         GENMASK(23, 16)
> +#define PERF_FAN_CFG_DUTY_CYCLE_X(x)                      (((x) & GENMASK(23, 16)) >> 16)
> +#define PERF_FAN_CFG_CLK_CYCLES_10US(x)                   (((x) << 4) & GENMASK(15, 4))
> +#define PERF_FAN_CFG_CLK_CYCLES_10US_M                    GENMASK(15, 4)
> +#define PERF_FAN_CFG_CLK_CYCLES_10US_X(x)                 (((x) & GENMASK(15, 4)) >> 4)
> +#define PERF_FAN_CFG_INV_POL                              BIT(3)
> +#define PERF_FAN_CFG_GATE_ENA                             BIT(2)
> +#define PERF_FAN_CFG_PWM_OPEN_COL_ENA                     BIT(1)
> +#define PERF_FAN_CFG_FAN_STAT_CFG                         BIT(0)
> +
> +#define PERF_PWM_FREQ                                     0x208
> +
> +#define PERF_FAN_CNT                                      0x20c
> +
> +#define PERF_MEMITGR_CTRL                                 0x210
> +
> +#define PERF_MEMITGR_CTRL_ACTIVATE                        BIT(0)
> +
> +#define PERF_MEMITGR_STAT                                 0x214
> +
> +#define PERF_MEMITGR_STAT_INDICATION_OVF                  BIT(5)
> +#define PERF_MEMITGR_STAT_INDICATION                      BIT(4)
> +#define PERF_MEMITGR_STAT_MODE_LISTEN                     BIT(3)
> +#define PERF_MEMITGR_STAT_MODE_DETECT                     BIT(2)
> +#define PERF_MEMITGR_STAT_MODE_IDLE                       BIT(1)
> +#define PERF_MEMITGR_STAT_MODE_BUSY                       BIT(0)
> +
> +#define PERF_MEMITGR_INFO                                 0x218
> +
> +#define PERF_MEMITGR_INFO_MEM_ERR                         BIT(31)
> +#define PERF_MEMITGR_INFO_MEM_COR                         BIT(30)
> +#define PERF_MEMITGR_INFO_MEM_ERR_OVF                     BIT(29)
> +#define PERF_MEMITGR_INFO_MEM_COR_OVF                     BIT(28)
> +#define PERF_MEMITGR_INFO_MEM_ADDR(x)                     ((x) & GENMASK(27, 0))
> +#define PERF_MEMITGR_INFO_MEM_ADDR_M                      GENMASK(27, 0)
> +
> +#define PERF_MEMITGR_IDX                                  0x21c
> +
> +#define PERF_MEMITGR_DIV                                  0x220
> +
> +#define PERF_MEMITGR_DBG                                  0x224
> +
> +#define PERF_MEMITGR_DBG_MEM_DIV_SENSE                    BIT(9)
> +#define PERF_MEMITGR_DBG_FORCE_INTR                       BIT(8)
> +#define PERF_MEMITGR_DBG_SYNC_IN                          BIT(7)
> +#define PERF_MEMITGR_DBG_ENA_IN                           BIT(6)
> +#define PERF_MEMITGR_DBG_DATA_IN                          BIT(5)
> +#define PERF_MEMITGR_DBG_INTR_IN                          BIT(4)
> +#define PERF_MEMITGR_DBG_SYNC_OUT                         BIT(3)
> +#define PERF_MEMITGR_DBG_ENA_OUT                          BIT(2)
> +#define PERF_MEMITGR_DBG_FORCE_ENA                        BIT(1)
> +#define PERF_MEMITGR_DBG_DETECT_ENA                       BIT(0)
> +
> +#define PERF_VRAP_ACCESS_STAT                             0x228
> +
> +#define PERF_VRAP_ACCESS_STAT_FRM_RECV_STICKY             BIT(3)
> +#define PERF_VRAP_ACCESS_STAT_CMD_INVALID_STICKY          BIT(2)
> +#define PERF_VRAP_ACCESS_STAT_FRM_INVALID_STICKY          BIT(1)
> +#define PERF_VRAP_ACCESS_STAT_REPLY_ABORT_STICKY          BIT(0)
> +
> +#endif
> diff --git a/arch/mips/mach-mscc/include/mach/ocelot/ocelot_icpu_cfg.h b/arch/mips/mach-mscc/include/mach/ocelot/ocelot_icpu_cfg.h
> new file mode 100644
> index 0000000000..5a5fe079e1
> --- /dev/null
> +++ b/arch/mips/mach-mscc/include/mach/ocelot/ocelot_icpu_cfg.h
> @@ -0,0 +1,884 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +/*
> + * Copyright (c) 2018 Microsemi Corporation
> + */
> +
> +#ifndef _MSCC_OCELOT_ICPU_CFG_H_
> +#define _MSCC_OCELOT_ICPU_CFG_H_
> +
> +#define ICPU_GPR(x) (0x4 * (x))
> +#define ICPU_GPR_RSZ                                      0x4
> +
> +#define ICPU_RESET                                        0x20
> +
> +#define ICPU_RESET_CORE_RST_CPU_ONLY                      BIT(3)
> +#define ICPU_RESET_CORE_RST_PROTECT                       BIT(2)
> +#define ICPU_RESET_CORE_RST_FORCE                         BIT(1)
> +#define ICPU_RESET_MEM_RST_FORCE                          BIT(0)
> +
> +#define ICPU_GENERAL_CTRL                                 0x24
> +
> +#define ICPU_GENERAL_CTRL_CPU_BUSIF_SLEEP_DIS             BIT(14)
> +#define ICPU_GENERAL_CTRL_CPU_BUSIF_WERR_ENA              BIT(13)
> +#define ICPU_GENERAL_CTRL_CPU_8051_IROM_ENA               BIT(12)
> +#define ICPU_GENERAL_CTRL_CPU_MIPS_DIS                    BIT(11)
> +#define ICPU_GENERAL_CTRL_IF_MIIM_SLV_ADDR_SEL            BIT(10)
> +#define ICPU_GENERAL_CTRL_IF_MIIM_SLV_ENA                 BIT(9)
> +#define ICPU_GENERAL_CTRL_IF_PI_SLV_DONEPOL               BIT(8)
> +#define ICPU_GENERAL_CTRL_IF_PI_MST_ENA                   BIT(7)
> +#define ICPU_GENERAL_CTRL_IF_PI_SLV_ENA                   BIT(6)
> +#define ICPU_GENERAL_CTRL_IF_SI_OWNER(x)                  (((x) << 4) & GENMASK(5, 4))
> +#define ICPU_GENERAL_CTRL_IF_SI_OWNER_M                   GENMASK(5, 4)
> +#define ICPU_GENERAL_CTRL_IF_SI_OWNER_X(x)                (((x) & GENMASK(5, 4)) >> 4)
> +#define ICPU_GENERAL_CTRL_SSI_MST_CONTENTION              BIT(3)
> +#define ICPU_GENERAL_CTRL_CPU_BE_ENA                      BIT(2)
> +#define ICPU_GENERAL_CTRL_CPU_DIS                         BIT(1)
> +#define ICPU_GENERAL_CTRL_BOOT_MODE_ENA                   BIT(0)
> +
> +#define ICPU_GENERAL_STAT                                 0x28
> +
> +#define ICPU_GENERAL_STAT_PI_SLV_WR_ERR                   BIT(9)
> +#define ICPU_GENERAL_STAT_PI_SLV_RD_ERR                   BIT(8)
> +#define ICPU_GENERAL_STAT_VCORE_CFG(x)                    (((x) << 4) & GENMASK(7, 4))
> +#define ICPU_GENERAL_STAT_VCORE_CFG_M                     GENMASK(7, 4)
> +#define ICPU_GENERAL_STAT_VCORE_CFG_X(x)                  (((x) & GENMASK(7, 4)) >> 4)
> +#define ICPU_GENERAL_STAT_REG_IF_ERR(x)                   (((x) << 1) & GENMASK(3, 1))
> +#define ICPU_GENERAL_STAT_REG_IF_ERR_M                    GENMASK(3, 1)
> +#define ICPU_GENERAL_STAT_REG_IF_ERR_X(x)                 (((x) & GENMASK(3, 1)) >> 1)
> +#define ICPU_GENERAL_STAT_CPU_SLEEP                       BIT(0)
> +
> +#define ICPU_PI_MST_CFG                                   0x2c
> +
> +#define ICPU_PI_MST_CFG_ATE_MODE_DIS                      BIT(7)
> +#define ICPU_PI_MST_CFG_CLK_POL                           BIT(6)
> +#define ICPU_PI_MST_CFG_TRISTATE_CTRL                     BIT(5)
> +#define ICPU_PI_MST_CFG_CLK_DIV(x)                        ((x) & GENMASK(4, 0))
> +#define ICPU_PI_MST_CFG_CLK_DIV_M                         GENMASK(4, 0)
> +
> +#define ICPU_PI_MST_CTRL                                  0x30
> +
> +#define ICPU_PI_MST_CTRL_DEVICE_PACED_XFER_ENA            BIT(22)
> +#define ICPU_PI_MST_CTRL_DEVICE_PACED_TIMEOUT_ENA         BIT(21)
> +#define ICPU_PI_MST_CTRL_DEVICE_PACED_TIMEOUT(x)          (((x) << 18) & GENMASK(20, 18))
> +#define ICPU_PI_MST_CTRL_DEVICE_PACED_TIMEOUT_M           GENMASK(20, 18)
> +#define ICPU_PI_MST_CTRL_DEVICE_PACED_TIMEOUT_X(x)        (((x) & GENMASK(20, 18)) >> 18)
> +#define ICPU_PI_MST_CTRL_CS_TRISTATE_CTRL                 BIT(17)
> +#define ICPU_PI_MST_CTRL_DONE_POL                         BIT(16)
> +#define ICPU_PI_MST_CTRL_SMPL_ON_DONE                     BIT(15)
> +#define ICPU_PI_MST_CTRL_WAITCC(x)                        (((x) << 7) & GENMASK(14, 7))
> +#define ICPU_PI_MST_CTRL_WAITCC_M                         GENMASK(14, 7)
> +#define ICPU_PI_MST_CTRL_WAITCC_X(x)                      (((x) & GENMASK(14, 7)) >> 7)
> +#define ICPU_PI_MST_CTRL_CSCC(x)                          (((x) << 5) & GENMASK(6, 5))
> +#define ICPU_PI_MST_CTRL_CSCC_M                           GENMASK(6, 5)
> +#define ICPU_PI_MST_CTRL_CSCC_X(x)                        (((x) & GENMASK(6, 5)) >> 5)
> +#define ICPU_PI_MST_CTRL_OECC(x)                          (((x) << 3) & GENMASK(4, 3))
> +#define ICPU_PI_MST_CTRL_OECC_M                           GENMASK(4, 3)
> +#define ICPU_PI_MST_CTRL_OECC_X(x)                        (((x) & GENMASK(4, 3)) >> 3)
> +#define ICPU_PI_MST_CTRL_HLDCC(x)                         ((x) & GENMASK(2, 0))
> +#define ICPU_PI_MST_CTRL_HLDCC_M                          GENMASK(2, 0)
> +
> +#define ICPU_PI_MST_STATUS                                0x34
> +
> +#define ICPU_PI_MST_STATUS_TIMEOUT_ERR_STICKY             BIT(0)
> +
> +#define ICPU_PI_SLV_CFG                                   0x38
> +
> +#define ICPU_PI_SLV_CFG_DONEPOL_VAL                       BIT(24)
> +#define ICPU_PI_SLV_CFG_DONEPOL_SET                       BIT(23)
> +#define ICPU_PI_SLV_CFG_BIGENDIAN                         BIT(22)
> +#define ICPU_PI_SLV_CFG_DONEPARK(x)                       (((x) << 16) & GENMASK(21, 16))
> +#define ICPU_PI_SLV_CFG_DONEPARK_M                        GENMASK(21, 16)
> +#define ICPU_PI_SLV_CFG_DONEPARK_X(x)                     (((x) & GENMASK(21, 16)) >> 16)
> +#define ICPU_PI_SLV_CFG_DONEWAIT(x)                       (((x) << 8) & GENMASK(15, 8))
> +#define ICPU_PI_SLV_CFG_DONEWAIT_M                        GENMASK(15, 8)
> +#define ICPU_PI_SLV_CFG_DONEWAIT_X(x)                     (((x) & GENMASK(15, 8)) >> 8)
> +#define ICPU_PI_SLV_CFG_CSWAIT(x)                         ((x) & GENMASK(7, 0))
> +#define ICPU_PI_SLV_CFG_CSWAIT_M                          GENMASK(7, 0)
> +
> +#define ICPU_SPI_MST_CFG                                  0x3c
> +
> +#define ICPU_SPI_MST_CFG_A32B_ENA                         BIT(11)
> +#define ICPU_SPI_MST_CFG_FAST_READ_ENA                    BIT(10)
> +#define ICPU_SPI_MST_CFG_CS_DESELECT_TIME(x)              (((x) << 5) & GENMASK(9, 5))
> +#define ICPU_SPI_MST_CFG_CS_DESELECT_TIME_M               GENMASK(9, 5)
> +#define ICPU_SPI_MST_CFG_CS_DESELECT_TIME_X(x)            (((x) & GENMASK(9, 5)) >> 5)
> +#define ICPU_SPI_MST_CFG_CLK_DIV(x)                       ((x) & GENMASK(4, 0))
> +#define ICPU_SPI_MST_CFG_CLK_DIV_M                        GENMASK(4, 0)
> +
> +#define ICPU_SPI_MST_STATUS                               0x40
> +#define ICPU_SPI_MST_STATUS_RSZ                           0x4
> +
> +#define ICPU_SPI_MST_STATUS_UNSUP_ERR                     BIT(0)
> +
> +#define ICPU_SW_MODE                                      0x50
> +
> +#define ICPU_SW_MODE_SW_PIN_CTRL_MODE                     BIT(13)
> +#define ICPU_SW_MODE_SW_SPI_SCK                           BIT(12)
> +#define ICPU_SW_MODE_SW_SPI_SCK_OE                        BIT(11)
> +#define ICPU_SW_MODE_SW_SPI_SDO                           BIT(10)
> +#define ICPU_SW_MODE_SW_SPI_SDO_OE                        BIT(9)
> +#define ICPU_SW_MODE_SW_SPI_CS(x)                         (((x) << 5) & GENMASK(8, 5))
> +#define ICPU_SW_MODE_SW_SPI_CS_M                          GENMASK(8, 5)
> +#define ICPU_SW_MODE_SW_SPI_CS_X(x)                       (((x) & GENMASK(8, 5)) >> 5)
> +#define ICPU_SW_MODE_SW_SPI_CS_OE(x)                      (((x) << 1) & GENMASK(4, 1))
> +#define ICPU_SW_MODE_SW_SPI_CS_OE_M                       GENMASK(4, 1)
> +#define ICPU_SW_MODE_SW_SPI_CS_OE_X(x)                    (((x) & GENMASK(4, 1)) >> 1)
> +#define ICPU_SW_MODE_SW_SPI_SDI                           BIT(0)
> +
> +#define ICPU_MPU8051_CFG                                  0x54
> +
> +#define ICPU_MPU8051_CFG_UART_SYS_ENA                     BIT(0)
> +
> +#define ICPU_MPU8051_STAT                                 0x58
> +
> +#define ICPU_MPU8051_STAT_MPU8051_SBA_ERR                 BIT(9)
> +#define ICPU_MPU8051_STAT_MPU8051_STOP                    BIT(8)
> +#define ICPU_MPU8051_STAT_MPU8051_GPR(x)                  ((x) & GENMASK(7, 0))
> +#define ICPU_MPU8051_STAT_MPU8051_GPR_M                   GENMASK(7, 0)
> +
> +#define ICPU_MPU8051_MMAP                                 0x5c
> +
> +#define ICPU_MPU8051_MMAP_MSADDR_CODE_HIGH                BIT(7)
> +#define ICPU_MPU8051_MMAP_MSADDR_CODE_LOW                 BIT(6)
> +#define ICPU_MPU8051_MMAP_MSADDR_DATA_HIGH                BIT(5)
> +#define ICPU_MPU8051_MMAP_MSADDR_DATA_LOW                 BIT(4)
> +#define ICPU_MPU8051_MMAP_MAP_CODE_HIGH                   BIT(3)
> +#define ICPU_MPU8051_MMAP_MAP_CODE_LOW                    BIT(2)
> +#define ICPU_MPU8051_MMAP_MAP_DATA_HIGH                   BIT(1)
> +#define ICPU_MPU8051_MMAP_MAP_DATA_LOW                    BIT(0)
> +
> +#define ICPU_MEMACC_CTRL                                  0x60
> +
> +#define ICPU_MEMACC_CTRL_MEMACC_EXAMINE                   BIT(1)
> +#define ICPU_MEMACC_CTRL_MEMACC_DO                        BIT(0)
> +
> +#define ICPU_MEMACC                                       0x64
> +
> +#define ICPU_MEMACC_MEMACC_STOP(x)                        (((x) << 18) & GENMASK(31, 18))
> +#define ICPU_MEMACC_MEMACC_STOP_M                         GENMASK(31, 18)
> +#define ICPU_MEMACC_MEMACC_STOP_X(x)                      (((x) & GENMASK(31, 18)) >> 18)
> +#define ICPU_MEMACC_MEMACC_START(x)                       (((x) << 2) & GENMASK(15, 2))
> +#define ICPU_MEMACC_MEMACC_START_M                        GENMASK(15, 2)
> +#define ICPU_MEMACC_MEMACC_START_X(x)                     (((x) & GENMASK(15, 2)) >> 2)
> +
> +#define ICPU_MEMACC_SBA                                   0x68
> +
> +#define ICPU_MPU8051_IROM                                 0x6c
> +
> +#define ICPU_INTR_RAW                                     0x70
> +
> +#define ICPU_INTR_TRIGGER                                 0x74
> +#define ICPU_INTR_TRIGGER_RSZ                             0x4
> +
> +#define ICPU_INTR_FORCE                                   0x7c
> +
> +#define ICPU_INTR_STICKY                                  0x80
> +
> +#define ICPU_INTR_BYPASS                                  0x84
> +
> +#define ICPU_INTR_ENA                                     0x88
> +
> +#define ICPU_INTR_ENA_CLR                                 0x8c
> +
> +#define ICPU_INTR_ENA_SET                                 0x90
> +
> +#define ICPU_INTR_IDENT                                   0x94
> +
> +#define ICPU_DST_INTR_MAP(x)  (0x98 + 0x4 * (x))
> +#define ICPU_DST_INTR_MAP_RSZ                             0x4
> +
> +#define ICPU_DST_INTR_IDENT                               0xa8
> +#define ICPU_DST_INTR_IDENT_RSZ                           0x4
> +
> +#define ICPU_EXT_SRC_INTR_POL                             0xb8
> +
> +#define ICPU_EXT_DST_INTR_POL                             0xbc
> +
> +#define ICPU_EXT_DST_INTR_DRV                             0xc0
> +
> +#define ICPU_DEV_INTR_POL                                 0xc4
> +
> +#define ICPU_DEV_INTR_RAW                                 0xc8
> +
> +#define ICPU_DEV_INTR_TRIGGER                             0xcc
> +#define ICPU_DEV_INTR_TRIGGER_RSZ                         0x4
> +
> +#define ICPU_DEV_INTR_STICKY                              0xd4
> +
> +#define ICPU_DEV_INTR_BYPASS                              0xd8
> +
> +#define ICPU_DEV_INTR_ENA                                 0xdc
> +
> +#define ICPU_DEV_INTR_IDENT                               0xe0
> +
> +#define ICPU_WDT                                          0xe4
> +
> +#define ICPU_WDT_WDT_STATUS                               BIT(9)
> +#define ICPU_WDT_WDT_ENABLE                               BIT(8)
> +#define ICPU_WDT_WDT_LOCK(x)                              ((x) & GENMASK(7, 0))
> +#define ICPU_WDT_WDT_LOCK_M                               GENMASK(7, 0)
> +
> +#define ICPU_TIMER_TICK_DIV                               0xe8
> +
> +#define ICPU_TIMER_VALUE(x) (0xec + 0x4 * (x))
> +#define ICPU_TIMER_VALUE_RSZ                              0x4
> +
> +#define ICPU_TIMER_RELOAD_VALUE                           0xf8
> +#define ICPU_TIMER_RELOAD_VALUE_RSZ                       0x4
> +
> +#define ICPU_TIMER_CTRL(x) (0x104 + 0x4 * (x))
> +#define ICPU_TIMER_CTRL_RSZ                               0x4
> +
> +#define ICPU_TIMER_CTRL_MAX_FREQ_ENA                      BIT(3)
> +#define ICPU_TIMER_CTRL_ONE_SHOT_ENA                      BIT(2)
> +#define ICPU_TIMER_CTRL_TIMER_ENA                         BIT(1)
> +#define ICPU_TIMER_CTRL_FORCE_RELOAD                      BIT(0)
> +
> +#define ICPU_MEMCTRL_CTRL                                 0x110
> +
> +#define ICPU_MEMCTRL_CTRL_PWR_DOWN                        BIT(3)
> +#define ICPU_MEMCTRL_CTRL_MDSET                           BIT(2)
> +#define ICPU_MEMCTRL_CTRL_STALL_REF_ENA                   BIT(1)
> +#define ICPU_MEMCTRL_CTRL_INITIALIZE                      BIT(0)
> +
> +#define ICPU_MEMCTRL_CFG                                  0x114
> +
> +#define ICPU_MEMCTRL_CFG_DDR_512MBYTE_PLUS                BIT(16)
> +#define ICPU_MEMCTRL_CFG_DDR_ECC_ERR_ENA                  BIT(15)
> +#define ICPU_MEMCTRL_CFG_DDR_ECC_COR_ENA                  BIT(14)
> +#define ICPU_MEMCTRL_CFG_DDR_ECC_ENA                      BIT(13)
> +#define ICPU_MEMCTRL_CFG_DDR_WIDTH                        BIT(12)
> +#define ICPU_MEMCTRL_CFG_DDR_MODE                         BIT(11)
> +#define ICPU_MEMCTRL_CFG_BURST_SIZE                       BIT(10)
> +#define ICPU_MEMCTRL_CFG_BURST_LEN                        BIT(9)
> +#define ICPU_MEMCTRL_CFG_BANK_CNT                         BIT(8)
> +#define ICPU_MEMCTRL_CFG_MSB_ROW_ADDR(x)                  (((x) << 4) & GENMASK(7, 4))
> +#define ICPU_MEMCTRL_CFG_MSB_ROW_ADDR_M                   GENMASK(7, 4)
> +#define ICPU_MEMCTRL_CFG_MSB_ROW_ADDR_X(x)                (((x) & GENMASK(7, 4)) >> 4)
> +#define ICPU_MEMCTRL_CFG_MSB_COL_ADDR(x)                  ((x) & GENMASK(3, 0))
> +#define ICPU_MEMCTRL_CFG_MSB_COL_ADDR_M                   GENMASK(3, 0)
> +
> +#define ICPU_MEMCTRL_STAT                                 0x118
> +
> +#define ICPU_MEMCTRL_STAT_RDATA_MASKED                    BIT(5)
> +#define ICPU_MEMCTRL_STAT_RDATA_DUMMY                     BIT(4)
> +#define ICPU_MEMCTRL_STAT_RDATA_ECC_ERR                   BIT(3)
> +#define ICPU_MEMCTRL_STAT_RDATA_ECC_COR                   BIT(2)
> +#define ICPU_MEMCTRL_STAT_PWR_DOWN_ACK                    BIT(1)
> +#define ICPU_MEMCTRL_STAT_INIT_DONE                       BIT(0)
> +
> +#define ICPU_MEMCTRL_REF_PERIOD                           0x11c
> +
> +#define ICPU_MEMCTRL_REF_PERIOD_MAX_PEND_REF(x)           (((x) << 16) & GENMASK(19, 16))
> +#define ICPU_MEMCTRL_REF_PERIOD_MAX_PEND_REF_M            GENMASK(19, 16)
> +#define ICPU_MEMCTRL_REF_PERIOD_MAX_PEND_REF_X(x)         (((x) & GENMASK(19, 16)) >> 16)
> +#define ICPU_MEMCTRL_REF_PERIOD_REF_PERIOD(x)             ((x) & GENMASK(15, 0))
> +#define ICPU_MEMCTRL_REF_PERIOD_REF_PERIOD_M              GENMASK(15, 0)
> +
> +#define ICPU_MEMCTRL_ZQCAL                                0x120
> +
> +#define ICPU_MEMCTRL_ZQCAL_ZQCAL_LONG                     BIT(1)
> +#define ICPU_MEMCTRL_ZQCAL_ZQCAL_SHORT                    BIT(0)
> +
> +#define ICPU_MEMCTRL_TIMING0                              0x124
> +
> +#define ICPU_MEMCTRL_TIMING0_RD_TO_WR_DLY(x)              (((x) << 28) & GENMASK(31, 28))
> +#define ICPU_MEMCTRL_TIMING0_RD_TO_WR_DLY_M               GENMASK(31, 28)
> +#define ICPU_MEMCTRL_TIMING0_RD_TO_WR_DLY_X(x)            (((x) & GENMASK(31, 28)) >> 28)
> +#define ICPU_MEMCTRL_TIMING0_WR_CS_CHANGE_DLY(x)          (((x) << 24) & GENMASK(27, 24))
> +#define ICPU_MEMCTRL_TIMING0_WR_CS_CHANGE_DLY_M           GENMASK(27, 24)
> +#define ICPU_MEMCTRL_TIMING0_WR_CS_CHANGE_DLY_X(x)        (((x) & GENMASK(27, 24)) >> 24)
> +#define ICPU_MEMCTRL_TIMING0_RD_CS_CHANGE_DLY(x)          (((x) << 20) & GENMASK(23, 20))
> +#define ICPU_MEMCTRL_TIMING0_RD_CS_CHANGE_DLY_M           GENMASK(23, 20)
> +#define ICPU_MEMCTRL_TIMING0_RD_CS_CHANGE_DLY_X(x)        (((x) & GENMASK(23, 20)) >> 20)
> +#define ICPU_MEMCTRL_TIMING0_RAS_TO_PRECH_DLY(x)          (((x) << 16) & GENMASK(19, 16))
> +#define ICPU_MEMCTRL_TIMING0_RAS_TO_PRECH_DLY_M           GENMASK(19, 16)
> +#define ICPU_MEMCTRL_TIMING0_RAS_TO_PRECH_DLY_X(x)        (((x) & GENMASK(19, 16)) >> 16)
> +#define ICPU_MEMCTRL_TIMING0_WR_TO_PRECH_DLY(x)           (((x) << 12) & GENMASK(15, 12))
> +#define ICPU_MEMCTRL_TIMING0_WR_TO_PRECH_DLY_M            GENMASK(15, 12)
> +#define ICPU_MEMCTRL_TIMING0_WR_TO_PRECH_DLY_X(x)         (((x) & GENMASK(15, 12)) >> 12)
> +#define ICPU_MEMCTRL_TIMING0_RD_TO_PRECH_DLY(x)           (((x) << 8) & GENMASK(11, 8))
> +#define ICPU_MEMCTRL_TIMING0_RD_TO_PRECH_DLY_M            GENMASK(11, 8)
> +#define ICPU_MEMCTRL_TIMING0_RD_TO_PRECH_DLY_X(x)         (((x) & GENMASK(11, 8)) >> 8)
> +#define ICPU_MEMCTRL_TIMING0_WR_DATA_XFR_DLY(x)           (((x) << 4) & GENMASK(7, 4))
> +#define ICPU_MEMCTRL_TIMING0_WR_DATA_XFR_DLY_M            GENMASK(7, 4)
> +#define ICPU_MEMCTRL_TIMING0_WR_DATA_XFR_DLY_X(x)         (((x) & GENMASK(7, 4)) >> 4)
> +#define ICPU_MEMCTRL_TIMING0_RD_DATA_XFR_DLY(x)           ((x) & GENMASK(3, 0))
> +#define ICPU_MEMCTRL_TIMING0_RD_DATA_XFR_DLY_M            GENMASK(3, 0)
> +
> +#define ICPU_MEMCTRL_TIMING1                              0x128
> +
> +#define ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_SAME_BANK_DLY(x)  (((x) << 24) & GENMASK(31, 24))
> +#define ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_SAME_BANK_DLY_M   GENMASK(31, 24)
> +#define ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_SAME_BANK_DLY_X(x) (((x) & GENMASK(31, 24)) >> 24)
> +#define ICPU_MEMCTRL_TIMING1_BANK8_FAW_DLY(x)             (((x) << 16) & GENMASK(23, 16))
> +#define ICPU_MEMCTRL_TIMING1_BANK8_FAW_DLY_M              GENMASK(23, 16)
> +#define ICPU_MEMCTRL_TIMING1_BANK8_FAW_DLY_X(x)           (((x) & GENMASK(23, 16)) >> 16)
> +#define ICPU_MEMCTRL_TIMING1_PRECH_TO_RAS_DLY(x)          (((x) << 12) & GENMASK(15, 12))
> +#define ICPU_MEMCTRL_TIMING1_PRECH_TO_RAS_DLY_M           GENMASK(15, 12)
> +#define ICPU_MEMCTRL_TIMING1_PRECH_TO_RAS_DLY_X(x)        (((x) & GENMASK(15, 12)) >> 12)
> +#define ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_DLY(x)            (((x) << 8) & GENMASK(11, 8))
> +#define ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_DLY_M             GENMASK(11, 8)
> +#define ICPU_MEMCTRL_TIMING1_RAS_TO_RAS_DLY_X(x)          (((x) & GENMASK(11, 8)) >> 8)
> +#define ICPU_MEMCTRL_TIMING1_RAS_TO_CAS_DLY(x)            (((x) << 4) & GENMASK(7, 4))
> +#define ICPU_MEMCTRL_TIMING1_RAS_TO_CAS_DLY_M             GENMASK(7, 4)
> +#define ICPU_MEMCTRL_TIMING1_RAS_TO_CAS_DLY_X(x)          (((x) & GENMASK(7, 4)) >> 4)
> +#define ICPU_MEMCTRL_TIMING1_WR_TO_RD_DLY(x)              ((x) & GENMASK(3, 0))
> +#define ICPU_MEMCTRL_TIMING1_WR_TO_RD_DLY_M               GENMASK(3, 0)
> +
> +#define ICPU_MEMCTRL_TIMING2                              0x12c
> +
> +#define ICPU_MEMCTRL_TIMING2_PRECH_ALL_DLY(x)             (((x) << 28) & GENMASK(31, 28))
> +#define ICPU_MEMCTRL_TIMING2_PRECH_ALL_DLY_M              GENMASK(31, 28)
> +#define ICPU_MEMCTRL_TIMING2_PRECH_ALL_DLY_X(x)           (((x) & GENMASK(31, 28)) >> 28)
> +#define ICPU_MEMCTRL_TIMING2_MDSET_DLY(x)                 (((x) << 24) & GENMASK(27, 24))
> +#define ICPU_MEMCTRL_TIMING2_MDSET_DLY_M                  GENMASK(27, 24)
> +#define ICPU_MEMCTRL_TIMING2_MDSET_DLY_X(x)               (((x) & GENMASK(27, 24)) >> 24)
> +#define ICPU_MEMCTRL_TIMING2_REF_DLY(x)                   (((x) << 16) & GENMASK(23, 16))
> +#define ICPU_MEMCTRL_TIMING2_REF_DLY_M                    GENMASK(23, 16)
> +#define ICPU_MEMCTRL_TIMING2_REF_DLY_X(x)                 (((x) & GENMASK(23, 16)) >> 16)
> +#define ICPU_MEMCTRL_TIMING2_INIT_DLY(x)                  ((x) & GENMASK(15, 0))
> +#define ICPU_MEMCTRL_TIMING2_INIT_DLY_M                   GENMASK(15, 0)
> +
> +#define ICPU_MEMCTRL_TIMING3                              0x130
> +
> +#define ICPU_MEMCTRL_TIMING3_RMW_DLY(x)                   (((x) << 16) & GENMASK(19, 16))
> +#define ICPU_MEMCTRL_TIMING3_RMW_DLY_M                    GENMASK(19, 16)
> +#define ICPU_MEMCTRL_TIMING3_RMW_DLY_X(x)                 (((x) & GENMASK(19, 16)) >> 16)
> +#define ICPU_MEMCTRL_TIMING3_ODT_RD_DLY(x)                (((x) << 12) & GENMASK(15, 12))
> +#define ICPU_MEMCTRL_TIMING3_ODT_RD_DLY_M                 GENMASK(15, 12)
> +#define ICPU_MEMCTRL_TIMING3_ODT_RD_DLY_X(x)              (((x) & GENMASK(15, 12)) >> 12)
> +#define ICPU_MEMCTRL_TIMING3_ODT_WR_DLY(x)                (((x) << 8) & GENMASK(11, 8))
> +#define ICPU_MEMCTRL_TIMING3_ODT_WR_DLY_M                 GENMASK(11, 8)
> +#define ICPU_MEMCTRL_TIMING3_ODT_WR_DLY_X(x)              (((x) & GENMASK(11, 8)) >> 8)
> +#define ICPU_MEMCTRL_TIMING3_LOCAL_ODT_RD_DLY(x)          (((x) << 4) & GENMASK(7, 4))
> +#define ICPU_MEMCTRL_TIMING3_LOCAL_ODT_RD_DLY_M           GENMASK(7, 4)
> +#define ICPU_MEMCTRL_TIMING3_LOCAL_ODT_RD_DLY_X(x)        (((x) & GENMASK(7, 4)) >> 4)
> +#define ICPU_MEMCTRL_TIMING3_WR_TO_RD_CS_CHANGE_DLY(x)    ((x) & GENMASK(3, 0))
> +#define ICPU_MEMCTRL_TIMING3_WR_TO_RD_CS_CHANGE_DLY_M     GENMASK(3, 0)
> +
> +#define ICPU_MEMCTRL_TIMING4                              0x134
> +
> +#define ICPU_MEMCTRL_TIMING4_ZQCAL_INIT_DLY(x)            (((x) << 20) & GENMASK(31, 20))
> +#define ICPU_MEMCTRL_TIMING4_ZQCAL_INIT_DLY_M             GENMASK(31, 20)
> +#define ICPU_MEMCTRL_TIMING4_ZQCAL_INIT_DLY_X(x)          (((x) & GENMASK(31, 20)) >> 20)
> +#define ICPU_MEMCTRL_TIMING4_ZQCAL_LONG_DLY(x)            (((x) << 8) & GENMASK(19, 8))
> +#define ICPU_MEMCTRL_TIMING4_ZQCAL_LONG_DLY_M             GENMASK(19, 8)
> +#define ICPU_MEMCTRL_TIMING4_ZQCAL_LONG_DLY_X(x)          (((x) & GENMASK(19, 8)) >> 8)
> +#define ICPU_MEMCTRL_TIMING4_ZQCAL_SHORT_DLY(x)           ((x) & GENMASK(7, 0))
> +#define ICPU_MEMCTRL_TIMING4_ZQCAL_SHORT_DLY_M            GENMASK(7, 0)
> +
> +#define ICPU_MEMCTRL_MR0_VAL                              0x138
> +
> +#define ICPU_MEMCTRL_MR1_VAL                              0x13c
> +
> +#define ICPU_MEMCTRL_MR2_VAL                              0x140
> +
> +#define ICPU_MEMCTRL_MR3_VAL                              0x144
> +
> +#define ICPU_MEMCTRL_TERMRES_CTRL                         0x148
> +
> +#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_RD_EXT              BIT(11)
> +#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_RD_ENA(x)           (((x) << 7) & GENMASK(10, 7))
> +#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_RD_ENA_M            GENMASK(10, 7)
> +#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_RD_ENA_X(x)         (((x) & GENMASK(10, 7)) >> 7)
> +#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_WR_EXT              BIT(6)
> +#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_WR_ENA(x)           (((x) << 2) & GENMASK(5, 2))
> +#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_WR_ENA_M            GENMASK(5, 2)
> +#define ICPU_MEMCTRL_TERMRES_CTRL_ODT_WR_ENA_X(x)         (((x) & GENMASK(5, 2)) >> 2)
> +#define ICPU_MEMCTRL_TERMRES_CTRL_LOCAL_ODT_RD_EXT        BIT(1)
> +#define ICPU_MEMCTRL_TERMRES_CTRL_LOCAL_ODT_RD_ENA        BIT(0)
> +
> +#define ICPU_MEMCTRL_DFT                                  0x14c
> +
> +#define ICPU_MEMCTRL_DFT_DDRDFT_LBW                       BIT(7)
> +#define ICPU_MEMCTRL_DFT_DDRDFT_GATE_ENA                  BIT(6)
> +#define ICPU_MEMCTRL_DFT_DDRDFT_TERM_ENA                  BIT(5)
> +#define ICPU_MEMCTRL_DFT_DDRDFT_A10                       BIT(4)
> +#define ICPU_MEMCTRL_DFT_DDRDFT_STAT                      BIT(3)
> +#define ICPU_MEMCTRL_DFT_DDRDFT_MODE(x)                   (((x) << 1) & GENMASK(2, 1))
> +#define ICPU_MEMCTRL_DFT_DDRDFT_MODE_M                    GENMASK(2, 1)
> +#define ICPU_MEMCTRL_DFT_DDRDFT_MODE_X(x)                 (((x) & GENMASK(2, 1)) >> 1)
> +#define ICPU_MEMCTRL_DFT_DDRDFT_ENA                       BIT(0)
> +
> +#define ICPU_MEMCTRL_DQS_DLY(x) (0x150 + 0x4 * (x))
> +#define ICPU_MEMCTRL_DQS_DLY_RSZ                          0x4
> +
> +#define ICPU_MEMCTRL_DQS_DLY_TRAIN_DQ_ENA                 BIT(11)
> +#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_TRM1(x)              (((x) << 8) & GENMASK(10, 8))
> +#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_TRM1_M               GENMASK(10, 8)
> +#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_TRM1_X(x)            (((x) & GENMASK(10, 8)) >> 8)
> +#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_TRM0(x)              (((x) << 5) & GENMASK(7, 5))
> +#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_TRM0_M               GENMASK(7, 5)
> +#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_TRM0_X(x)            (((x) & GENMASK(7, 5)) >> 5)
> +#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY(x)                   ((x) & GENMASK(4, 0))
> +#define ICPU_MEMCTRL_DQS_DLY_DQS_DLY_M                    GENMASK(4, 0)
> +
> +#define ICPU_MEMCTRL_DQS_AUTO                             0x158
> +#define ICPU_MEMCTRL_DQS_AUTO_RSZ                         0x4
> +
> +#define ICPU_MEMCTRL_DQS_AUTO_DQS_DRIFT(x)                (((x) << 6) & GENMASK(7, 6))
> +#define ICPU_MEMCTRL_DQS_AUTO_DQS_DRIFT_M                 GENMASK(7, 6)
> +#define ICPU_MEMCTRL_DQS_AUTO_DQS_DRIFT_X(x)              (((x) & GENMASK(7, 6)) >> 6)
> +#define ICPU_MEMCTRL_DQS_AUTO_DQS_OVERFLOW                BIT(5)
> +#define ICPU_MEMCTRL_DQS_AUTO_DQS_UNDERFLOW               BIT(4)
> +#define ICPU_MEMCTRL_DQS_AUTO_DQS_AUTO_SRC                BIT(3)
> +#define ICPU_MEMCTRL_DQS_AUTO_DQS_AUTO_UP                 BIT(2)
> +#define ICPU_MEMCTRL_DQS_AUTO_DQS_AUTO_DOWN               BIT(1)
> +#define ICPU_MEMCTRL_DQS_AUTO_DQS_AUTO_ENA                BIT(0)
> +
> +#define ICPU_MEMPHY_CFG                                   0x160
> +
> +#define ICPU_MEMPHY_CFG_PHY_FLUSH_DIS                     BIT(10)
> +#define ICPU_MEMPHY_CFG_PHY_RD_ADJ_DIS                    BIT(9)
> +#define ICPU_MEMPHY_CFG_PHY_DQS_EXT                       BIT(8)
> +#define ICPU_MEMPHY_CFG_PHY_FIFO_RST                      BIT(7)
> +#define ICPU_MEMPHY_CFG_PHY_DLL_BL_RST                    BIT(6)
> +#define ICPU_MEMPHY_CFG_PHY_DLL_CL_RST                    BIT(5)
> +#define ICPU_MEMPHY_CFG_PHY_ODT_OE                        BIT(4)
> +#define ICPU_MEMPHY_CFG_PHY_CK_OE                         BIT(3)
> +#define ICPU_MEMPHY_CFG_PHY_CL_OE                         BIT(2)
> +#define ICPU_MEMPHY_CFG_PHY_SSTL_ENA                      BIT(1)
> +#define ICPU_MEMPHY_CFG_PHY_RST                           BIT(0)
> +
> +#define ICPU_MEMPHY_DFT                                   0x164
> +
> +#define ICPU_MEMPHY_DFT_PHY_DLL_BYPASS                    BIT(0)
> +
> +#define ICPU_MEMPHY_DLLCFG0                               0x168
> +#define ICPU_MEMPHY_DLLCFG0_RSZ                           0x4
> +
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_RES6(x)                (((x) << 30) & GENMASK(31, 30))
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_RES6_M                 GENMASK(31, 30)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_RES6_X(x)              (((x) & GENMASK(31, 30)) >> 30)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_LOCK_DET_EN            BIT(29)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_RES5(x)                (((x) << 27) & GENMASK(28, 27))
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_RES5_M                 GENMASK(28, 27)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_RES5_X(x)              (((x) & GENMASK(28, 27)) >> 27)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_BIAS_TRM3(x)           (((x) << 24) & GENMASK(26, 24))
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_BIAS_TRM3_M            GENMASK(26, 24)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_BIAS_TRM3_X(x)         (((x) & GENMASK(26, 24)) >> 24)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_RES4                   BIT(23)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_BIAS_TRM2(x)           (((x) << 20) & GENMASK(22, 20))
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_BIAS_TRM2_M            GENMASK(22, 20)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_BIAS_TRM2_X(x)         (((x) & GENMASK(22, 20)) >> 20)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_RES3                   BIT(19)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_BIAS_TRM1(x)           (((x) << 16) & GENMASK(18, 16))
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_BIAS_TRM1_M            GENMASK(18, 16)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_BIAS_TRM1_X(x)         (((x) & GENMASK(18, 16)) >> 16)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_RES2                   BIT(15)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_BIAS_TRM0(x)           (((x) << 12) & GENMASK(14, 12))
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_BIAS_TRM0_M            GENMASK(14, 12)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_BIAS_TRM0_X(x)         (((x) & GENMASK(14, 12)) >> 12)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_RES1                   BIT(11)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_TEST_CTRL_A(x)         (((x) << 9) & GENMASK(10, 9))
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_TEST_CTRL_A_M          GENMASK(10, 9)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_TEST_CTRL_A_X(x)       (((x) & GENMASK(10, 9)) >> 9)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_TEST_CTRL_D(x)         (((x) << 6) & GENMASK(8, 6))
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_TEST_CTRL_D_M          GENMASK(8, 6)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_TEST_CTRL_D_X(x)       (((x) & GENMASK(8, 6)) >> 6)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_TEST_CTRL_EN           BIT(5)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_IPUMP_TRM(x)           (((x) << 2) & GENMASK(4, 2))
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_IPUMP_TRM_M            GENMASK(4, 2)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_IPUMP_TRM_X(x)         (((x) & GENMASK(4, 2)) >> 2)
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_RES0(x)                ((x) & GENMASK(1, 0))
> +#define ICPU_MEMPHY_DLLCFG0_DLLCFG_RES0_M                 GENMASK(1, 0)
> +
> +#define ICPU_MEMPHY_DLLCFG1                               0x174
> +#define ICPU_MEMPHY_DLLCFG1_RSZ                           0x4
> +
> +#define ICPU_MEMPHY_DLLCFG1_DLLCFG_RES9                   BIT(19)
> +#define ICPU_MEMPHY_DLLCFG1_DLLCFG_TEST_HIZB_A            BIT(18)
> +#define ICPU_MEMPHY_DLLCFG1_DLLCFG_RES8(x)                (((x) << 12) & GENMASK(17, 12))
> +#define ICPU_MEMPHY_DLLCFG1_DLLCFG_RES8_M                 GENMASK(17, 12)
> +#define ICPU_MEMPHY_DLLCFG1_DLLCFG_RES8_X(x)              (((x) & GENMASK(17, 12)) >> 12)
> +#define ICPU_MEMPHY_DLLCFG1_DLLCFG_FF_TRM(x)              (((x) << 9) & GENMASK(11, 9))
> +#define ICPU_MEMPHY_DLLCFG1_DLLCFG_FF_TRM_M               GENMASK(11, 9)
> +#define ICPU_MEMPHY_DLLCFG1_DLLCFG_FF_TRM_X(x)            (((x) & GENMASK(11, 9)) >> 9)
> +#define ICPU_MEMPHY_DLLCFG1_DLLCFG_FB_TRM(x)              (((x) << 6) & GENMASK(8, 6))
> +#define ICPU_MEMPHY_DLLCFG1_DLLCFG_FB_TRM_M               GENMASK(8, 6)
> +#define ICPU_MEMPHY_DLLCFG1_DLLCFG_FB_TRM_X(x)            (((x) & GENMASK(8, 6)) >> 6)
> +#define ICPU_MEMPHY_DLLCFG1_DLLCFG_RES7(x)                ((x) & GENMASK(5, 0))
> +#define ICPU_MEMPHY_DLLCFG1_DLLCFG_RES7_M                 GENMASK(5, 0)
> +
> +#define ICPU_MEMPHY_DQ_DLY_TRM                            0x180
> +#define ICPU_MEMPHY_DQ_DLY_TRM_RSZ                        0x4
> +
> +#define ICPU_MEMPHY_ZCAL                                  0x188
> +
> +#define ICPU_MEMPHY_ZCAL_ZCAL_CLK_SEL                     BIT(9)
> +#define ICPU_MEMPHY_ZCAL_ZCAL_PROG_ODT(x)                 (((x) << 5) & GENMASK(8, 5))
> +#define ICPU_MEMPHY_ZCAL_ZCAL_PROG_ODT_M                  GENMASK(8, 5)
> +#define ICPU_MEMPHY_ZCAL_ZCAL_PROG_ODT_X(x)               (((x) & GENMASK(8, 5)) >> 5)
> +#define ICPU_MEMPHY_ZCAL_ZCAL_PROG(x)                     (((x) << 1) & GENMASK(4, 1))
> +#define ICPU_MEMPHY_ZCAL_ZCAL_PROG_M                      GENMASK(4, 1)
> +#define ICPU_MEMPHY_ZCAL_ZCAL_PROG_X(x)                   (((x) & GENMASK(4, 1)) >> 1)
> +#define ICPU_MEMPHY_ZCAL_ZCAL_ENA                         BIT(0)
> +
> +#define ICPU_MEMPHY_ZCAL_STAT                             0x18c
> +
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_ZCTRL(x)               (((x) << 12) & GENMASK(31, 12))
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_ZCTRL_M                GENMASK(31, 12)
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_ZCTRL_X(x)             (((x) & GENMASK(31, 12)) >> 12)
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_ODTPU(x)          (((x) << 8) & GENMASK(9, 8))
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_ODTPU_M           GENMASK(9, 8)
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_ODTPU_X(x)        (((x) & GENMASK(9, 8)) >> 8)
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_ODTPD(x)          (((x) << 6) & GENMASK(7, 6))
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_ODTPD_M           GENMASK(7, 6)
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_ODTPD_X(x)        (((x) & GENMASK(7, 6)) >> 6)
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_PU(x)             (((x) << 4) & GENMASK(5, 4))
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_PU_M              GENMASK(5, 4)
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_PU_X(x)           (((x) & GENMASK(5, 4)) >> 4)
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_PD(x)             (((x) << 2) & GENMASK(3, 2))
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_PD_M              GENMASK(3, 2)
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_STAT_PD_X(x)           (((x) & GENMASK(3, 2)) >> 2)
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_ERR                    BIT(1)
> +#define ICPU_MEMPHY_ZCAL_STAT_ZCAL_DONE                   BIT(0)
> +
> +#define ICPU_MEMPHY_ZCAL_OVR                              0x190
> +
> +#define ICPU_MEMPHY_ZCAL_OVR_ZCAL_OVR_DATA(x)             (((x) << 12) & GENMASK(31, 12))
> +#define ICPU_MEMPHY_ZCAL_OVR_ZCAL_OVR_DATA_M              GENMASK(31, 12)
> +#define ICPU_MEMPHY_ZCAL_OVR_ZCAL_OVR_DATA_X(x)           (((x) & GENMASK(31, 12)) >> 12)
> +#define ICPU_MEMPHY_ZCAL_OVR_ZCAL_ENACLR_DIS              BIT(2)
> +#define ICPU_MEMPHY_ZCAL_OVR_ZCAL_ZCOMP                   BIT(1)
> +#define ICPU_MEMPHY_ZCAL_OVR_ZCAL_OVR_ENA                 BIT(0)
> +
> +#define ICPU_MEMPHY_ZCAL_FORCE                            0x194
> +
> +#define ICPU_MEMPHY_ZCAL_FORCE_ZCAL_FORCE_ZCAL(x)         (((x) << 2) & GENMASK(3, 2))
> +#define ICPU_MEMPHY_ZCAL_FORCE_ZCAL_FORCE_ZCAL_M          GENMASK(3, 2)
> +#define ICPU_MEMPHY_ZCAL_FORCE_ZCAL_FORCE_ZCAL_X(x)       (((x) & GENMASK(3, 2)) >> 2)
> +#define ICPU_MEMPHY_ZCAL_FORCE_ZCAL_FORCE_ZQ_OFF          BIT(1)
> +#define ICPU_MEMPHY_ZCAL_FORCE_ZCAL_FORCE_ENA             BIT(0)
> +
> +#define ICPU_TWI_CONFIG                                   0x198
> +
> +#define ICPU_TWI_CONFIG_TWI_CNT_RELOAD(x)                 (((x) << 1) & GENMASK(8, 1))
> +#define ICPU_TWI_CONFIG_TWI_CNT_RELOAD_M                  GENMASK(8, 1)
> +#define ICPU_TWI_CONFIG_TWI_CNT_RELOAD_X(x)               (((x) & GENMASK(8, 1)) >> 1)
> +#define ICPU_TWI_CONFIG_TWI_DELAY_ENABLE                  BIT(0)
> +
> +#define ICPU_TWI_SPIKE_FILTER_CFG                         0x19c
> +
> +#define ICPU_FDMA_DCB_LLP                                 0x1a0
> +#define ICPU_FDMA_DCB_LLP_RSZ                             0x4
> +
> +#define ICPU_FDMA_DCB_DATAP                               0x1c8
> +#define ICPU_FDMA_DCB_DATAP_RSZ                           0x4
> +
> +#define ICPU_FDMA_DCB_DATAL                               0x1f0
> +#define ICPU_FDMA_DCB_DATAL_RSZ                           0x4
> +
> +#define ICPU_FDMA_DCB_DATAL_TOKEN                         BIT(17)
> +#define ICPU_FDMA_DCB_DATAL_DATAL(x)                      ((x) & GENMASK(15, 0))
> +#define ICPU_FDMA_DCB_DATAL_DATAL_M                       GENMASK(15, 0)
> +
> +#define ICPU_FDMA_DCB_STAT                                0x218
> +#define ICPU_FDMA_DCB_STAT_RSZ                            0x4
> +
> +#define ICPU_FDMA_DCB_STAT_BLOCKO(x)                      (((x) << 20) & GENMASK(31, 20))
> +#define ICPU_FDMA_DCB_STAT_BLOCKO_M                       GENMASK(31, 20)
> +#define ICPU_FDMA_DCB_STAT_BLOCKO_X(x)                    (((x) & GENMASK(31, 20)) >> 20)
> +#define ICPU_FDMA_DCB_STAT_PD                             BIT(19)
> +#define ICPU_FDMA_DCB_STAT_ABORT                          BIT(18)
> +#define ICPU_FDMA_DCB_STAT_EOF                            BIT(17)
> +#define ICPU_FDMA_DCB_STAT_SOF                            BIT(16)
> +#define ICPU_FDMA_DCB_STAT_BLOCKL(x)                      ((x) & GENMASK(15, 0))
> +#define ICPU_FDMA_DCB_STAT_BLOCKL_M                       GENMASK(15, 0)
> +
> +#define ICPU_FDMA_DCB_LLP_PREV                            0x240
> +#define ICPU_FDMA_DCB_LLP_PREV_RSZ                        0x4
> +
> +#define ICPU_FDMA_CH_STAT                                 0x268
> +
> +#define ICPU_FDMA_CH_SAFE                                 0x26c
> +
> +#define ICPU_FDMA_CH_ACTIVATE                             0x270
> +
> +#define ICPU_FDMA_CH_DISABLE                              0x274
> +
> +#define ICPU_FDMA_CH_FORCEDIS                             0x278
> +
> +#define ICPU_FDMA_CH_CNT                                  0x27c
> +#define ICPU_FDMA_CH_CNT_RSZ                              0x4
> +
> +#define ICPU_FDMA_CH_CNT_CH_CNT_FRM(x)                    (((x) << 16) & GENMASK(31, 16))
> +#define ICPU_FDMA_CH_CNT_CH_CNT_FRM_M                     GENMASK(31, 16)
> +#define ICPU_FDMA_CH_CNT_CH_CNT_FRM_X(x)                  (((x) & GENMASK(31, 16)) >> 16)
> +#define ICPU_FDMA_CH_CNT_CH_CNT_DCB(x)                    (((x) << 8) & GENMASK(15, 8))
> +#define ICPU_FDMA_CH_CNT_CH_CNT_DCB_M                     GENMASK(15, 8)
> +#define ICPU_FDMA_CH_CNT_CH_CNT_DCB_X(x)                  (((x) & GENMASK(15, 8)) >> 8)
> +#define ICPU_FDMA_CH_CNT_CH_CNT_SIG(x)                    ((x) & GENMASK(7, 0))
> +#define ICPU_FDMA_CH_CNT_CH_CNT_SIG_M                     GENMASK(7, 0)
> +
> +#define ICPU_FDMA_CH_INJ_CNT                              0x2a4
> +#define ICPU_FDMA_CH_INJ_CNT_RSZ                          0x4
> +
> +#define ICPU_FDMA_CH_INJ_TICK_RLD                         0x2c4
> +#define ICPU_FDMA_CH_INJ_TICK_RLD_RSZ                     0x4
> +
> +#define ICPU_FDMA_CH_INJ_TICK_CNT                         0x2e4
> +#define ICPU_FDMA_CH_INJ_TICK_CNT_RSZ                     0x4
> +
> +#define ICPU_FDMA_EVT_ERR                                 0x304
> +
> +#define ICPU_FDMA_EVT_ERR_CODE                            0x308
> +
> +#define ICPU_FDMA_INTR_LLP                                0x30c
> +
> +#define ICPU_FDMA_INTR_LLP_ENA                            0x310
> +
> +#define ICPU_FDMA_INTR_FRM                                0x314
> +
> +#define ICPU_FDMA_INTR_FRM_ENA                            0x318
> +
> +#define ICPU_FDMA_INTR_SIG                                0x31c
> +
> +#define ICPU_FDMA_INTR_SIG_ENA                            0x320
> +
> +#define ICPU_FDMA_INTR_ENA                                0x324
> +
> +#define ICPU_FDMA_INTR_IDENT                              0x328
> +
> +#define ICPU_FDMA_CH_CFG                                  0x32c
> +#define ICPU_FDMA_CH_CFG_RSZ                              0x4
> +
> +#define ICPU_FDMA_CH_CFG_STAT_IN_DATA_ENA                 BIT(7)
> +#define ICPU_FDMA_CH_CFG_CH_INJ_GRP                       BIT(6)
> +#define ICPU_FDMA_CH_CFG_CH_PRIO(x)                       (((x) << 2) & GENMASK(5, 2))
> +#define ICPU_FDMA_CH_CFG_CH_PRIO_M                        GENMASK(5, 2)
> +#define ICPU_FDMA_CH_CFG_CH_PRIO_X(x)                     (((x) & GENMASK(5, 2)) >> 2)
> +#define ICPU_FDMA_CH_CFG_DONE_STOP_ENA                    BIT(1)
> +#define ICPU_FDMA_CH_CFG_DONEEOF_STOP_ENA                 BIT(0)
> +
> +#define ICPU_FDMA_GCFG                                    0x354
> +
> +#define ICPU_FDMA_GCFG_FRM_AT_OFF                         BIT(12)
> +#define ICPU_FDMA_GCFG_INJ_RF_WM(x)                       (((x) << 7) & GENMASK(11, 7))
> +#define ICPU_FDMA_GCFG_INJ_RF_WM_M                        GENMASK(11, 7)
> +#define ICPU_FDMA_GCFG_INJ_RF_WM_X(x)                     (((x) & GENMASK(11, 7)) >> 7)
> +#define ICPU_FDMA_GCFG_XTR_RF_WM(x)                       (((x) << 3) & GENMASK(6, 3))
> +#define ICPU_FDMA_GCFG_XTR_RF_WM_M                        GENMASK(6, 3)
> +#define ICPU_FDMA_GCFG_XTR_RF_WM_X(x)                     (((x) & GENMASK(6, 3)) >> 3)
> +#define ICPU_FDMA_GCFG_XTR_AVAIL_EXT_DIS                  BIT(2)
> +#define ICPU_FDMA_GCFG_XTR_PRIO_BP_DIS                    BIT(1)
> +#define ICPU_FDMA_GCFG_PD_IGNORE                          BIT(0)
> +
> +#define ICPU_FDMA_GSTAT                                   0x358
> +
> +#define ICPU_FDMA_GSTAT_INJ_RF_HIGH(x)                    (((x) << 5) & GENMASK(10, 5))
> +#define ICPU_FDMA_GSTAT_INJ_RF_HIGH_M                     GENMASK(10, 5)
> +#define ICPU_FDMA_GSTAT_INJ_RF_HIGH_X(x)                  (((x) & GENMASK(10, 5)) >> 5)
> +#define ICPU_FDMA_GSTAT_XTR_RF_HIGH(x)                    ((x) & GENMASK(4, 0))
> +#define ICPU_FDMA_GSTAT_XTR_RF_HIGH_M                     GENMASK(4, 0)
> +
> +#define ICPU_FDMA_IDLECNT                                 0x35c
> +
> +#define ICPU_FDMA_CONST                                   0x360
> +
> +#define ICPU_FDMA_CONST_CH_INJ_CNT(x)                     (((x) << 8) & GENMASK(15, 8))
> +#define ICPU_FDMA_CONST_CH_INJ_CNT_M                      GENMASK(15, 8)
> +#define ICPU_FDMA_CONST_CH_INJ_CNT_X(x)                   (((x) & GENMASK(15, 8)) >> 8)
> +#define ICPU_FDMA_CONST_CH_XTR_CNT(x)                     ((x) & GENMASK(7, 0))
> +#define ICPU_FDMA_CONST_CH_XTR_CNT_M                      GENMASK(7, 0)
> +
> +#define ICPU_PCIE_CTRL                                    0x364
> +
> +#define ICPU_PCIE_CTRL_POWERUP                            BIT(0)
> +
> +#define ICPU_PCIE_CFG                                     0x368
> +
> +#define ICPU_PCIE_CFG_CG_DIS                              BIT(5)
> +#define ICPU_PCIE_CFG_MEM_CG_DIS                          BIT(4)
> +#define ICPU_PCIE_CFG_CONF_REQ_RETRY_ENA                  BIT(3)
> +#define ICPU_PCIE_CFG_PCIE_BAR_WR_ENA                     BIT(2)
> +#define ICPU_PCIE_CFG_LTSSM_DIS                           BIT(1)
> +#define ICPU_PCIE_CFG_MEM_RING_CORE_ENA                   BIT(0)
> +
> +#define ICPU_PCIE_STAT                                    0x36c
> +
> +#define ICPU_PCIE_STAT_SLV_ERROR_REPLY                    BIT(12)
> +#define ICPU_PCIE_STAT_LTSSM_STATE(x)                     (((x) << 6) & GENMASK(11, 6))
> +#define ICPU_PCIE_STAT_LTSSM_STATE_M                      GENMASK(11, 6)
> +#define ICPU_PCIE_STAT_LTSSM_STATE_X(x)                   (((x) & GENMASK(11, 6)) >> 6)
> +#define ICPU_PCIE_STAT_LINK_STATE(x)                      (((x) << 3) & GENMASK(5, 3))
> +#define ICPU_PCIE_STAT_LINK_STATE_M                       GENMASK(5, 3)
> +#define ICPU_PCIE_STAT_LINK_STATE_X(x)                    (((x) & GENMASK(5, 3)) >> 3)
> +#define ICPU_PCIE_STAT_PM_STATE(x)                        ((x) & GENMASK(2, 0))
> +#define ICPU_PCIE_STAT_PM_STATE_M                         GENMASK(2, 0)
> +
> +#define ICPU_PCIE_AUX_CFG                                 0x370
> +
> +#define ICPU_PCIE_AUX_CFG_AUX_POWER_VAL                   BIT(0)
> +
> +#define ICPU_PCIE_DBG_STAT                                0x374
> +
> +#define ICPU_PCIE_DBG_STAT_TBI_RX_CE                      BIT(14)
> +#define ICPU_PCIE_DBG_STAT_TBI_RX_LOS                     BIT(13)
> +#define ICPU_PCIE_DBG_STAT_TBI_RX_SDET                    BIT(12)
> +#define ICPU_PCIE_DBG_STAT_TBI_RX_DATA(x)                 (((x) << 2) & GENMASK(11, 2))
> +#define ICPU_PCIE_DBG_STAT_TBI_RX_DATA_M                  GENMASK(11, 2)
> +#define ICPU_PCIE_DBG_STAT_TBI_RX_DATA_X(x)               (((x) & GENMASK(11, 2)) >> 2)
> +#define ICPU_PCIE_DBG_STAT_PM_L2_EXIT                     BIT(1)
> +#define ICPU_PCIE_DBG_STAT_DATA_LINK_LAYER_UP             BIT(0)
> +
> +#define ICPU_PCIEMST_REPLY_INFO                           0x378
> +
> +#define ICPU_PCIEMST_BAR1_OFFSET                          0x37c
> +
> +#define ICPU_PCIEMST_BAR1_MASK                            0x380
> +
> +#define ICPU_PCIEMST_BAR2_OFFSET                          0x384
> +
> +#define ICPU_PCIEMST_BAR2_MASK                            0x388
> +
> +#define ICPU_PCIESLV_FDMA                                 0x38c
> +
> +#define ICPU_PCIESLV_FDMA_FDMA_TC(x)                      (((x) << 4) & GENMASK(6, 4))
> +#define ICPU_PCIESLV_FDMA_FDMA_TC_M                       GENMASK(6, 4)
> +#define ICPU_PCIESLV_FDMA_FDMA_TC_X(x)                    (((x) & GENMASK(6, 4)) >> 4)
> +#define ICPU_PCIESLV_FDMA_FDMA_ATTR(x)                    (((x) << 2) & GENMASK(3, 2))
> +#define ICPU_PCIESLV_FDMA_FDMA_ATTR_M                     GENMASK(3, 2)
> +#define ICPU_PCIESLV_FDMA_FDMA_ATTR_X(x)                  (((x) & GENMASK(3, 2)) >> 2)
> +#define ICPU_PCIESLV_FDMA_FDMA_OFFSET(x)                  ((x) & GENMASK(1, 0))
> +#define ICPU_PCIESLV_FDMA_FDMA_OFFSET_M                   GENMASK(1, 0)
> +
> +#define ICPU_PCIESLV_SBA                                  0x390
> +
> +#define ICPU_PCIESLV_SBA_SBA_BE(x)                        (((x) << 24) & GENMASK(27, 24))
> +#define ICPU_PCIESLV_SBA_SBA_BE_M                         GENMASK(27, 24)
> +#define ICPU_PCIESLV_SBA_SBA_BE_X(x)                      (((x) & GENMASK(27, 24)) >> 24)
> +#define ICPU_PCIESLV_SBA_SBA_RESERVED1                    BIT(23)
> +#define ICPU_PCIESLV_SBA_SBA_MSG_CODE(x)                  (((x) << 15) & GENMASK(22, 15))
> +#define ICPU_PCIESLV_SBA_SBA_MSG_CODE_M                   GENMASK(22, 15)
> +#define ICPU_PCIESLV_SBA_SBA_MSG_CODE_X(x)                (((x) & GENMASK(22, 15)) >> 15)
> +#define ICPU_PCIESLV_SBA_SBA_TC(x)                        (((x) << 12) & GENMASK(14, 12))
> +#define ICPU_PCIESLV_SBA_SBA_TC_M                         GENMASK(14, 12)
> +#define ICPU_PCIESLV_SBA_SBA_TC_X(x)                      (((x) & GENMASK(14, 12)) >> 12)
> +#define ICPU_PCIESLV_SBA_SBA_ATTR(x)                      (((x) << 10) & GENMASK(11, 10))
> +#define ICPU_PCIESLV_SBA_SBA_ATTR_M                       GENMASK(11, 10)
> +#define ICPU_PCIESLV_SBA_SBA_ATTR_X(x)                    (((x) & GENMASK(11, 10)) >> 10)
> +#define ICPU_PCIESLV_SBA_SBA_TD                           BIT(9)
> +#define ICPU_PCIESLV_SBA_SBA_EP                           BIT(8)
> +#define ICPU_PCIESLV_SBA_SBA_RESERVED0                    BIT(7)
> +#define ICPU_PCIESLV_SBA_SBA_TYPE(x)                      (((x) << 2) & GENMASK(6, 2))
> +#define ICPU_PCIESLV_SBA_SBA_TYPE_M                       GENMASK(6, 2)
> +#define ICPU_PCIESLV_SBA_SBA_TYPE_X(x)                    (((x) & GENMASK(6, 2)) >> 2)
> +#define ICPU_PCIESLV_SBA_SBA_OFFSET(x)                    ((x) & GENMASK(1, 0))
> +#define ICPU_PCIESLV_SBA_SBA_OFFSET_M                     GENMASK(1, 0)
> +
> +#define ICPU_PCIEPCS_CFG                                  0x394
> +
> +#define ICPU_PCIEPCS_CFG_TXRX_DETECT                      BIT(22)
> +#define ICPU_PCIEPCS_CFG_SDETCOM_PERM                     BIT(21)
> +#define ICPU_PCIEPCS_CFG_SDETCOM_DIS                      BIT(20)
> +#define ICPU_PCIEPCS_CFG_BEACON_FORCE                     BIT(19)
> +#define ICPU_PCIEPCS_CFG_RXRST_FORCE                      BIT(18)
> +#define ICPU_PCIEPCS_CFG_RXRST_VAL                        BIT(17)
> +#define ICPU_PCIEPCS_CFG_TXRST_FORCE                      BIT(16)
> +#define ICPU_PCIEPCS_CFG_TXRST_VAL                        BIT(15)
> +#define ICPU_PCIEPCS_CFG_RXSDET_XOR                       BIT(14)
> +#define ICPU_PCIEPCS_CFG_RXSDET_FORCE                     BIT(13)
> +#define ICPU_PCIEPCS_CFG_RXINV_ENA                        BIT(12)
> +#define ICPU_PCIEPCS_CFG_RXSWAP_ENA                       BIT(11)
> +#define ICPU_PCIEPCS_CFG_TXSWAP_ENA                       BIT(10)
> +#define ICPU_PCIEPCS_CFG_IDLE_DATA_DIS                    BIT(9)
> +#define ICPU_PCIEPCS_CFG_IDLE_DIS                         BIT(8)
> +#define ICPU_PCIEPCS_CFG_IDLE_DLY(x)                      (((x) << 5) & GENMASK(7, 5))
> +#define ICPU_PCIEPCS_CFG_IDLE_DLY_M                       GENMASK(7, 5)
> +#define ICPU_PCIEPCS_CFG_IDLE_DLY_X(x)                    (((x) & GENMASK(7, 5)) >> 5)
> +#define ICPU_PCIEPCS_CFG_RXLP_FORCE                       BIT(4)
> +#define ICPU_PCIEPCS_CFG_TXLP_FORCE                       BIT(3)
> +#define ICPU_PCIEPCS_CFG_WAKE_POL                         BIT(2)
> +#define ICPU_PCIEPCS_CFG_WAKE_OE                          BIT(1)
> +#define ICPU_PCIEPCS_CFG_BEACON_DIS                       BIT(0)
> +
> +#define ICPU_PCIEPCS_BEACON                               0x398
> +
> +#define ICPU_PCIEPCS_BEACON_BEACON_VAL(x)                 (((x) << 16) & GENMASK(25, 16))
> +#define ICPU_PCIEPCS_BEACON_BEACON_VAL_M                  GENMASK(25, 16)
> +#define ICPU_PCIEPCS_BEACON_BEACON_VAL_X(x)               (((x) & GENMASK(25, 16)) >> 16)
> +#define ICPU_PCIEPCS_BEACON_BEACON_MAX_DIS                BIT(15)
> +#define ICPU_PCIEPCS_BEACON_BEACON_MAX_DLY(x)             ((x) & GENMASK(14, 0))
> +#define ICPU_PCIEPCS_BEACON_BEACON_MAX_DLY_M              GENMASK(14, 0)
> +
> +#define ICPU_PCIE_INTR                                    0x39c
> +
> +#define ICPU_PCIE_INTR_INTR_LTSSM_STATE                   BIT(4)
> +#define ICPU_PCIE_INTR_INTR_LINK_STATE                    BIT(3)
> +#define ICPU_PCIE_INTR_INTR_BAR1_WR                       BIT(2)
> +#define ICPU_PCIE_INTR_INTR_BAR1_RD                       BIT(1)
> +#define ICPU_PCIE_INTR_INTR_PM_STATE                      BIT(0)
> +
> +#define ICPU_PCIE_INTR_ENA                                0x3a0
> +
> +#define ICPU_PCIE_INTR_ENA_INTR_LTSSM_STATE_ENA           BIT(4)
> +#define ICPU_PCIE_INTR_ENA_INTR_LINK_STATE_ENA            BIT(3)
> +#define ICPU_PCIE_INTR_ENA_INTR_BAR1_WR_ENA               BIT(2)
> +#define ICPU_PCIE_INTR_ENA_INTR_BAR1_RD_ENA               BIT(1)
> +#define ICPU_PCIE_INTR_ENA_INTR_PM_STATE_ENA              BIT(0)
> +
> +#define ICPU_PCIE_INTR_IDENT                              0x3a4
> +
> +#define ICPU_PCIE_INTR_IDENT_INTR_LTSSM_STATE_IDENT       BIT(4)
> +#define ICPU_PCIE_INTR_IDENT_INTR_LINK_STATE_IDENT        BIT(3)
> +#define ICPU_PCIE_INTR_IDENT_INTR_BAR1_WR_IDENT           BIT(2)
> +#define ICPU_PCIE_INTR_IDENT_INTR_BAR1_RD_IDENT           BIT(1)
> +#define ICPU_PCIE_INTR_IDENT_INTR_PM_STATE_IDENT          BIT(0)
> +
> +#define ICPU_PCIE_INTR_COMMON_CFG                         0x3a8
> +
> +#define ICPU_PCIE_INTR_COMMON_CFG_WAKEUP_ON_INTR_DIS      BIT(2)
> +#define ICPU_PCIE_INTR_COMMON_CFG_LEGACY_MODE_INTR_SEL    BIT(1)
> +#define ICPU_PCIE_INTR_COMMON_CFG_PCIE_INTR_ENA           BIT(0)
> +
> +#define ICPU_PCIE_INTR_CFG                                0x3ac
> +#define ICPU_PCIE_INTR_CFG_RSZ                            0x4
> +
> +#define ICPU_PCIE_INTR_CFG_FUNCTION_NUMBER(x)             (((x) << 15) & GENMASK(17, 15))
> +#define ICPU_PCIE_INTR_CFG_FUNCTION_NUMBER_M              GENMASK(17, 15)
> +#define ICPU_PCIE_INTR_CFG_FUNCTION_NUMBER_X(x)           (((x) & GENMASK(17, 15)) >> 15)
> +#define ICPU_PCIE_INTR_CFG_TRAFFIC_CLASS(x)               (((x) << 12) & GENMASK(14, 12))
> +#define ICPU_PCIE_INTR_CFG_TRAFFIC_CLASS_M                GENMASK(14, 12)
> +#define ICPU_PCIE_INTR_CFG_TRAFFIC_CLASS_X(x)             (((x) & GENMASK(14, 12)) >> 12)
> +#define ICPU_PCIE_INTR_CFG_FALLING_VECTOR_VAL(x)          (((x) << 7) & GENMASK(11, 7))
> +#define ICPU_PCIE_INTR_CFG_FALLING_VECTOR_VAL_M           GENMASK(11, 7)
> +#define ICPU_PCIE_INTR_CFG_FALLING_VECTOR_VAL_X(x)        (((x) & GENMASK(11, 7)) >> 7)
> +#define ICPU_PCIE_INTR_CFG_RISING_VECTOR_VAL(x)           (((x) << 2) & GENMASK(6, 2))
> +#define ICPU_PCIE_INTR_CFG_RISING_VECTOR_VAL_M            GENMASK(6, 2)
> +#define ICPU_PCIE_INTR_CFG_RISING_VECTOR_VAL_X(x)         (((x) & GENMASK(6, 2)) >> 2)
> +#define ICPU_PCIE_INTR_CFG_INTR_FALLING_ENA               BIT(1)
> +#define ICPU_PCIE_INTR_CFG_INTR_RISING_ENA                BIT(0)
> +
> +#define ICPU_PCIE_INTR_STAT                               0x3b4
> +#define ICPU_PCIE_INTR_STAT_RSZ                           0x4
> +
> +#define ICPU_PCIE_INTR_STAT_INTR_PENDING_FALLING          BIT(1)
> +#define ICPU_PCIE_INTR_STAT_INTR_PENDING_RISING           BIT(0)
> +
> +#define ICPU_MANUAL_XTR                                   0x4000
> +
> +#define ICPU_MANUAL_INJ                                   0x8000
> +
> +#define ICPU_MANUAL_CFG                                   0xc000
> +
> +#define ICPU_MANUAL_CFG_XTR_FLUSH_DIS                     BIT(4)
> +#define ICPU_MANUAL_CFG_INJ_SWAP_ENA                      BIT(3)
> +#define ICPU_MANUAL_CFG_XTR_SWAP_ENA                      BIT(2)
> +#define ICPU_MANUAL_CFG_INJ_ENA                           BIT(1)
> +#define ICPU_MANUAL_CFG_XTR_ENA                           BIT(0)
> +
> +#define ICPU_MANUAL_INTR                                  0xc004
> +
> +#define ICPU_MANUAL_INTR_INTR_INJ_RDY                     BIT(2)
> +#define ICPU_MANUAL_INTR_INTR_XTR_ANY_RDY                 BIT(1)
> +#define ICPU_MANUAL_INTR_INTR_XTR_SOF_RDY                 BIT(0)
> +
> +#define ICPU_MANUAL_INTR_ENA                              0xc008
> +
> +#define ICPU_MANUAL_INTR_ENA_INTR_INJ_RDY_ENA             BIT(2)
> +#define ICPU_MANUAL_INTR_ENA_INTR_XTR_ANY_RDY_ENA         BIT(1)
> +#define ICPU_MANUAL_INTR_ENA_INTR_XTR_SOF_RDY_ENA         BIT(0)
> +
> +#endif
> diff --git a/arch/mips/mach-mscc/include/mach/tlb.h b/arch/mips/mach-mscc/include/mach/tlb.h
> new file mode 100644
> index 0000000000..4e95da28ce
> --- /dev/null
> +++ b/arch/mips/mach-mscc/include/mach/tlb.h
> @@ -0,0 +1,65 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +/*
> + * Copyright (c) 2018 Microsemi Corporation
> + */
> +
> +#ifndef __ASM_MACH_TLB_H
> +#define __ASM_MACH_TLB_H
> +
> +#include <asm/mipsregs.h>
> +#include <mach/common.h>
> +#include <linux/sizes.h>
> +
> +#define TLB_HI_MASK      0xffffe000
> +#define TLB_LO_MASK      0x3fffffff /* Masks off Fill bits */
> +#define TLB_LO_SHIFT     6          /* PFN Start bit */
> +
> +#define PAGEMASK_SHIFT   13
> +
> +#define MMU_PAGE_CACHED   (3 << 3) /* C(5:3) Cache Coherency Attributes */
> +#define MMU_PAGE_UNCACHED (2 << 3) /* C(5:3) Cache Coherency Attributes */
> +#define MMU_PAGE_DIRTY    BIT(2) /* = Writeable */
> +#define MMU_PAGE_VALID    BIT(1)
> +#define MMU_PAGE_GLOBAL   BIT(0)
> +#define MMU_REGIO_RO_C    (MMU_PAGE_CACHED|MMU_PAGE_VALID|MMU_PAGE_GLOBAL)
> +#define MMU_REGIO_RO      (MMU_PAGE_UNCACHED|MMU_PAGE_VALID|MMU_PAGE_GLOBAL)
> +#define MMU_REGIO_RW      (MMU_PAGE_DIRTY|MMU_REGIO_RO)
> +#define MMU_REGIO_INVAL   (MMU_PAGE_GLOBAL)
> +
> +#define TLB_COUNT_MASK	  GENMASK(5, 0)
> +#define TLB_COUNT_OFF  	  25
> +
> +static inline u32 get_tlb_count(void)
> +{
> +        register u32 config1;
> +
> +	config1 = read_c0_config1();
> +	config1 >>= TLB_COUNT_OFF;
> +	config1 &= TLB_COUNT_MASK;
> +
> +        return 1 + config1;
> +}
> +
> +static inline void create_tlb(int index, u32 offset, u32 size, u32 tlb_attrib1,
> +			      u32 tlb_attrib2)
> +{
> +        register u32 tlb_mask, tlb_lo0, tlb_lo1;
> +
> +        tlb_mask  = ((size >> 12) - 1) << PAGEMASK_SHIFT;
> +        tlb_lo0 = tlb_attrib1 | ( offset              >> TLB_LO_SHIFT);
> +        tlb_lo1 = tlb_attrib2 | ((offset + size )     >> TLB_LO_SHIFT);
> +
> +	write_one_tlb(index, tlb_mask, offset & TLB_HI_MASK,
> +		      tlb_lo0 & TLB_LO_MASK, tlb_lo1 & TLB_LO_MASK);
> +}
> +
> +static inline void init_tlb(void)
> +{
> +    register int i, max;
> +
> +    max = get_tlb_count();
> +    for(i = 0; i < max; i++)
> +        create_tlb(i, i * SZ_1M, SZ_4K, MMU_REGIO_INVAL, MMU_REGIO_INVAL);
> +}

again can't you leave the setup of MMU mappings to the kernel?

> +
> +#endif /* __ASM_MACH_TLB_H */
> diff --git a/arch/mips/mach-mscc/lowlevel_init.S b/arch/mips/mach-mscc/lowlevel_init.S
> new file mode 100644
> index 0000000000..87439439f0
> --- /dev/null
> +++ b/arch/mips/mach-mscc/lowlevel_init.S
> @@ -0,0 +1,29 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +/*
> + * Copyright (c) 2018 Microsemi Corporation
> + */
> +
> +#include <asm/asm.h>
> +#include <asm/regdef.h>
> +
> +    .text

don't set .text in ASM files. The LEAF() and NODE() macros are hacked to
place the code in .text.FUNCNAME to allow section garbage collect.

> +    .set noreorder
> +    .extern     vcoreiii_tlb_init
> +#ifdef CONFIG_SOC_LUTON
> +    .extern     pll_init
> +#endif
> +
> +LEAF(lowlevel_init)
> +	// As we have no stack yet, we can assume the restricted
> +        // luxury of the sX-registers without saving them
> +	move s0,ra

various coding style issues like C++ comments and wrong indentation

> +
> +        jal vcoreiii_tlb_init
> +	nop
> +#ifdef CONFIG_SOC_LUTON
> +        jal pll_init
> +	nop
> +#endif
> +	jr  s0
> +	nop

please indent instructions in the delay slot by one space

> +END(lowlevel_init)
> diff --git a/arch/mips/mach-mscc/lowlevel_init_luton.S b/arch/mips/mach-mscc/lowlevel_init_luton.S
> new file mode 100644
> index 0000000000..5e1b4442d9
> --- /dev/null
> +++ b/arch/mips/mach-mscc/lowlevel_init_luton.S
> @@ -0,0 +1,63 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +/*
> + * Copyright (c) 2018 Microsemi Corporation
> + */
> +
> +#include <asm/asm.h>
> +#include <asm/regdef.h>
> +
> +#define BASE_MACRO      0x600a0000
> +#define REG_OFFSET(t, o) (t + (o*4))
> +#define REG_MACRO(x) REG_OFFSET(BASE_MACRO, x)
> +#define BIT(nr)			(1 << (nr))
> +
> +#define MACRO_CTRL_PLL5G_STATUS_PLL5G_STATUS0 REG_MACRO(6)
> +#define MACRO_CTRL_PLL5G_STATUS_PLL5G_STATUS0_LOCK_STATUS BIT(0)
> +#define MACRO_CTRL_PLL5G_CFG_PLL5G_CFG2 REG_MACRO(2)
> +#define MACRO_CTRL_PLL5G_CFG_PLL5G_CFG0 REG_MACRO(0)
> +#define MACRO_CTRL_PLL5G_CFG_PLL5G_CFG0_CPU_CLK_DIV (0x3F << 6)
> +#define MACRO_CTRL_PLL5G_CFG_PLL5G_CFG0_CPU_CLK_DIV_ENC(x) (x << 6)
> +
> +    .text
> +    .set noreorder
> +LEAF(pll_init)
> +        # Make sure PLL is locked
> +        lw	v0, MACRO_CTRL_PLL5G_STATUS_PLL5G_STATUS0
> +        andi	v1, v0, MACRO_CTRL_PLL5G_STATUS_PLL5G_STATUS0_LOCK_STATUS
> +        bne	v1, zero, 1f
> +        nop
> +
> +        # Black magic from frontend
> +        li	v1, 0x00610400
> +        sw	v1, MACRO_CTRL_PLL5G_CFG_PLL5G_CFG2
> +
> +        li	v1, 0x00610c00
> +        sw	v1, MACRO_CTRL_PLL5G_CFG_PLL5G_CFG2
> +
> +        li	v1, 0x00610800
> +        sw	v1, MACRO_CTRL_PLL5G_CFG_PLL5G_CFG2
> +
> +        li	v1, 0x00610000
> +        sw	v1, MACRO_CTRL_PLL5G_CFG_PLL5G_CFG2
> +
> +        # Wait for lock
> +2:      lw	v0, MACRO_CTRL_PLL5G_STATUS_PLL5G_STATUS0
> +        andi	v1, v0, MACRO_CTRL_PLL5G_STATUS_PLL5G_STATUS0_LOCK_STATUS
> +        # Keep looping if zero (no lock bit yet)
> +        beq	v1, zero, 2b
> +        nop
> +
> +        # Setup PLL CPU clock divider for 416MHz
> +1:      lw	v0, MACRO_CTRL_PLL5G_CFG_PLL5G_CFG0
> +
> +        # Keep reserved bits
> +        li	v1, ~MACRO_CTRL_PLL5G_CFG_PLL5G_CFG0_CPU_CLK_DIV
> +	and	v0, v0, v1
> +
> +        # Set code 6 ~ 416.66 MHz
> +        ori	v0, v0, MACRO_CTRL_PLL5G_CFG_PLL5G_CFG0_CPU_CLK_DIV_ENC(6)
> +
> +        sw	v0, MACRO_CTRL_PLL5G_CFG_PLL5G_CFG0
> +	jr      ra
> +	nop
> +END(pll_init)
> diff --git a/arch/mips/mach-mscc/reset.c b/arch/mips/mach-mscc/reset.c
> new file mode 100644
> index 0000000000..85768cbdf0
> --- /dev/null
> +++ b/arch/mips/mach-mscc/reset.c
> @@ -0,0 +1,37 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +/*
> + * Copyright (c) 2018 Microsemi Corporation
> + */
> +
> +#include <common.h>
> +
> +#include <asm/sections.h>
> +#include <asm/io.h>
> +
> +#include <asm/reboot.h>
> +
> +void _machine_restart(void)
> +{
> +        register u32 resetbits = PERF_SOFT_RST_SOFT_CHIP_RST;
> +        (void) readl(REG_GCB(PERF_SOFT_RST));
> +
> +        /*
> +         * Make sure VCore is NOT protected from reset
> +         */
> +        writel(readl(REG_CFG(ICPU_RESET)) & ~ICPU_RESET_CORE_RST_PROTECT,
> +	       REG_CFG(ICPU_RESET));
> +
> +        /*
> +         * Change to SPI bitbang for SPI reset workaround...
> +         */
> +        writel(ICPU_SW_MODE_SW_SPI_CS_OE(1) | ICPU_SW_MODE_SW_SPI_CS(1) |
> +	       ICPU_SW_MODE_SW_PIN_CTRL_MODE, REG_CFG(ICPU_SW_MODE));
> +
> +        /*
> +         * Do the global reset
> +         */
> +        writel(resetbits, REG_GCB(PERF_SOFT_RST));
> +
> +	while (1)
> +		/* NOP */;
> +}
> 

-- 
- Daniel

-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 833 bytes
Desc: OpenPGP digital signature
URL: <http://lists.denx.de/pipermail/u-boot/attachments/20180926/3d51ca2a/attachment.sig>

^ permalink raw reply	[flat|nested] 22+ messages in thread

* [U-Boot] [PATCH 3/6] MSCC: add board support for the VCoreIII based evaluation boards
  2018-09-25 13:01 ` [U-Boot] [PATCH 3/6] MSCC: add board support for the VCoreIII based evaluation boards Gregory CLEMENT
@ 2018-09-26 19:28   ` Daniel Schwierzeck
  2018-10-09 11:22     ` Gregory CLEMENT
  2018-09-26 23:03   ` Marek Vasut
  1 sibling, 1 reply; 22+ messages in thread
From: Daniel Schwierzeck @ 2018-09-26 19:28 UTC (permalink / raw)
  To: u-boot



On 25.09.2018 15:01, Gregory CLEMENT wrote:
> Adding the support for 3 boards sharing common code:
>  - PCB120 and PCB 123 for Ocelot chip
>  - PCB 91 for Luton chip
> 
> Signed-off-by: Gregory CLEMENT <gregory.clement@bootlin.com>
> ---
>  board/mscc/common/board.c  | 29 +++++++++++++++++++++++++++++
>  board/mscc/luton/Kconfig   | 14 ++++++++++++++
>  board/mscc/luton/Makefile  |  4 ++++
>  board/mscc/luton/luton.c   | 14 ++++++++++++++
>  board/mscc/ocelot/Kconfig  | 24 ++++++++++++++++++++++++
>  board/mscc/ocelot/Makefile |  5 +++++
>  board/mscc/ocelot/ocelot.c | 38 ++++++++++++++++++++++++++++++++++++++
>  7 files changed, 128 insertions(+)
>  create mode 100644 board/mscc/common/board.c
>  create mode 100644 board/mscc/luton/Kconfig
>  create mode 100644 board/mscc/luton/Makefile
>  create mode 100644 board/mscc/luton/luton.c
>  create mode 100644 board/mscc/ocelot/Kconfig
>  create mode 100644 board/mscc/ocelot/Makefile
>  create mode 100644 board/mscc/ocelot/ocelot.c
> 
> diff --git a/board/mscc/common/board.c b/board/mscc/common/board.c
> new file mode 100644
> index 0000000000..86e7bf3353
> --- /dev/null
> +++ b/board/mscc/common/board.c
> @@ -0,0 +1,29 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +/*
> + * Copyright (c) 2018 Microsemi Corporation
> + */
> +
> +#include <common.h>
> +#include <asm/io.h>
> +#include <asm/addrspace.h>
> +#include <asm/types.h>
> +#include <environment.h>
> +
> +DECLARE_GLOBAL_DATA_PTR;
> +
> +int board_early_init_r(void)
> +{
> +	u32 ctrl;
> +
> +	/* Prepare SPI controller to be used in master mode */
> +	writel(0, REG_CFG(ICPU_SW_MODE));
> +	ctrl = readl(REG_CFG(ICPU_GENERAL_CTRL));
> +
> +	writel((ctrl & ~ICPU_GENERAL_CTRL_IF_SI_OWNER_M) |
> +	       ICPU_GENERAL_CTRL_IF_SI_OWNER(2),
> +	       REG_CFG(ICPU_GENERAL_CTRL));
> +
> +	/* Address of boot parameters */
> +	gd->bd->bi_boot_params = CONFIG_SYS_SDRAM_BASE;
> +	return 0;
> +}
> diff --git a/board/mscc/luton/Kconfig b/board/mscc/luton/Kconfig
> new file mode 100644
> index 0000000000..e1199808d5
> --- /dev/null
> +++ b/board/mscc/luton/Kconfig
> @@ -0,0 +1,14 @@
> +# SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +
> +if SOC_LUTON
> +
> +config SYS_VENDOR
> +	default "mscc"
> +
> +config SYS_BOARD
> +	default "luton"
> +
> +config SYS_CONFIG_NAME
> +	default "luton"
> +
> +endif
> diff --git a/board/mscc/luton/Makefile b/board/mscc/luton/Makefile
> new file mode 100644
> index 0000000000..98bc47ba82
> --- /dev/null
> +++ b/board/mscc/luton/Makefile
> @@ -0,0 +1,4 @@
> +# SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +
> +obj-$(CONFIG_SOC_LUTON)	:= luton.o
> +obj-y += ../common/board.o
> diff --git a/board/mscc/luton/luton.c b/board/mscc/luton/luton.c
> new file mode 100644
> index 0000000000..8c31bbb12a
> --- /dev/null
> +++ b/board/mscc/luton/luton.c
> @@ -0,0 +1,14 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +/*
> + * Copyright (c) 2018 Microsemi Corporation
> + */
> +
> +#include <common.h>
> +#include <asm/io.h>
> +
> +void board_debug_uart_init(void)
> +{
> +	/* too early for the pinctrl driver, so configure the UART pins here */
> +	writel(BIT(30)|BIT(31), REG_GCB((0x68+8*4)));
> +	writel(~(BIT(30)|BIT(31)), REG_GCB((0x68+9*4)));
> +}
> diff --git a/board/mscc/ocelot/Kconfig b/board/mscc/ocelot/Kconfig
> new file mode 100644
> index 0000000000..0804f5081d
> --- /dev/null
> +++ b/board/mscc/ocelot/Kconfig
> @@ -0,0 +1,24 @@
> +# SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +
> +config SYS_VENDOR
> +	default "mscc"
> +
> +if SOC_OCELOT
> +
> +config SYS_BOARD
> +	default "ocelot"
> +
> +config SYS_CONFIG_NAME
> +	default "ocelot"
> +
> +endif
> +
> +if SOC_LUTON
> +
> +config SYS_BOARD
> +	default "luton"
> +
> +config SYS_CONFIG_NAME
> +	default "luton"
> +

this is already defined in board/mscc/luton/Kconfig

> +endif
> diff --git a/board/mscc/ocelot/Makefile b/board/mscc/ocelot/Makefile
> new file mode 100644
> index 0000000000..f6a665ca83
> --- /dev/null
> +++ b/board/mscc/ocelot/Makefile
> @@ -0,0 +1,5 @@
> +# SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +
> +obj-$(CONFIG_SOC_OCELOT)	:= ocelot.o
> +obj-y += ../common/board.o
> +
> diff --git a/board/mscc/ocelot/ocelot.c b/board/mscc/ocelot/ocelot.c
> new file mode 100644
> index 0000000000..971fa93d07
> --- /dev/null
> +++ b/board/mscc/ocelot/ocelot.c
> @@ -0,0 +1,38 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +/*
> + * Copyright (c) 2018 Microsemi Corporation
> + */
> +
> +#include <common.h>
> +#include <asm/io.h>
> +#include <asm/addrspace.h>
> +#include <asm/types.h>
> +#include <environment.h>
> +#include <spi.h>
> +
> +DECLARE_GLOBAL_DATA_PTR;
> +
> +void external_cs_manage(struct udevice *dev, bool enable)
> +{
> +	u32 cs = spi_chip_select(dev);
> +        /* IF_SI0_OWNER, select the owner of the SI interface
> +         * Encoding: 0: SI Slave
> +         *           1: SI Boot Master
> +         *           2: SI Master Controller
> +         */

style issues like indentation and multi-line comments

> +        if (!enable) {
> +                writel(ICPU_SW_MODE_SW_PIN_CTRL_MODE |
> +		       ICPU_SW_MODE_SW_SPI_CS(BIT(cs)),
> +		       REG_CFG(ICPU_SW_MODE));
> +                writel((readl(REG_CFG(ICPU_GENERAL_CTRL))
> +			& ~ICPU_GENERAL_CTRL_IF_SI_OWNER_M) |
> +		       ICPU_GENERAL_CTRL_IF_SI_OWNER(2),
> +		       REG_CFG(ICPU_GENERAL_CTRL));
> +        } else {
> +                writel(0, REG_CFG(ICPU_SW_MODE));
> +                writel((readl(REG_CFG(ICPU_GENERAL_CTRL)) &
> +			~ICPU_GENERAL_CTRL_IF_SI_OWNER_M) |
> +		       ICPU_GENERAL_CTRL_IF_SI_OWNER(1),
> +		       REG_CFG(ICPU_GENERAL_CTRL));
> +        }
> +}
> 

-- 
- Daniel

-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 833 bytes
Desc: OpenPGP digital signature
URL: <http://lists.denx.de/pipermail/u-boot/attachments/20180926/d73ba871/attachment.sig>

^ permalink raw reply	[flat|nested] 22+ messages in thread

* [U-Boot] [PATCH 4/6] MSCC: add device tree for Ocelot and Luton (boards and SoCs)
  2018-09-25 13:01 ` [U-Boot] [PATCH 4/6] MSCC: add device tree for Ocelot and Luton (boards and SoCs) Gregory CLEMENT
@ 2018-09-26 19:31   ` Daniel Schwierzeck
  2018-10-09 11:23     ` Gregory CLEMENT
  0 siblings, 1 reply; 22+ messages in thread
From: Daniel Schwierzeck @ 2018-09-26 19:31 UTC (permalink / raw)
  To: u-boot



On 25.09.2018 15:01, Gregory CLEMENT wrote:
> Adding device tree for Ocelot SoC (extract from Linux) and the 2
> evaluation boards using this SoC: PCB120 and PCB132.
> 
> Adding device tree for Luton SoC (not yet in Linux) and the evaluation
> boards using this SoC: PCB91.
> 
> Signed-off-by: Gregory CLEMENT <gregory.clement@bootlin.com>
> ---
>  arch/mips/dts/luton_pcb091.dts     |  36 ++++++++
>  arch/mips/dts/mscc,luton.dtsi      |  87 +++++++++++++++++++
>  arch/mips/dts/mscc,ocelot.dtsi     | 132 +++++++++++++++++++++++++++++
>  arch/mips/dts/mscc,ocelot_pcb.dtsi |  37 ++++++++
>  arch/mips/dts/ocelot_pcb120.dts    |  12 +++
>  arch/mips/dts/ocelot_pcb123.dts    |  12 +++
>  6 files changed, 316 insertions(+)
>  create mode 100644 arch/mips/dts/luton_pcb091.dts
>  create mode 100644 arch/mips/dts/mscc,luton.dtsi
>  create mode 100644 arch/mips/dts/mscc,ocelot.dtsi
>  create mode 100644 arch/mips/dts/mscc,ocelot_pcb.dtsi
>  create mode 100644 arch/mips/dts/ocelot_pcb120.dts
>  create mode 100644 arch/mips/dts/ocelot_pcb123.dts

should be added along with the board code. Also please try to add Ocelot
and Luton boards in separate patches.

> 
> diff --git a/arch/mips/dts/luton_pcb091.dts b/arch/mips/dts/luton_pcb091.dts
> new file mode 100644
> index 0000000000..b5e0df8d04
> --- /dev/null
> +++ b/arch/mips/dts/luton_pcb091.dts
> @@ -0,0 +1,36 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +/*
> + * Copyright (c) 2018 Microsemi Corporation
> + */
> +
> +/dts-v1/;
> +#include "mscc,luton.dtsi"
> +
> +/ {
> +	model = "Luton PCB091 Reference Board";
> +	compatible = "mscc,luton-pcb091", "mscc,luton";
> +
> +	aliases {
> +		serial0 = &uart0;
> +		spi0 = &spi0;
> +	};
> +
> +	chosen {
> +		stdout-path = "serial0:115200n8";
> +	};
> +
> +};
> +
> +&uart0 {
> +	status = "okay";
> +};
> +
> +&spi0 {
> +	status = "okay";
> +	spi-flash at 0 {
> +		compatible = "spi-flash";
> +                spi-max-frequency = <18000000>; /* input clock */
> +                reg = <0>; /* CS0 */
> +	};
> +};
> +
> diff --git a/arch/mips/dts/mscc,luton.dtsi b/arch/mips/dts/mscc,luton.dtsi
> new file mode 100644
> index 0000000000..6a4ad2a5be
> --- /dev/null
> +++ b/arch/mips/dts/mscc,luton.dtsi
> @@ -0,0 +1,87 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +/*
> + * Copyright (c) 2018 Microsemi Corporation
> + */
> +
> +#include <dt-bindings/gpio/gpio.h>
> +
> +/ {
> +	#address-cells = <1>;
> +	#size-cells = <1>;
> +	compatible = "mscc,luton";
> +
> +	cpus {
> +		#address-cells = <1>;
> +		#size-cells = <0>;
> +
> +		cpu at 0 {
> +			compatible = "mips,mips24KEc";
> +			device_type = "cpu";
> +			reg = <0>;
> +		};
> +	};
> +
> +	aliases {
> +		serial0 = &uart0;
> +	};
> +
> +	ahb_clk: ahb-clk {
> +		compatible = "fixed-clock";
> +		#clock-cells = <0>;
> +		clock-frequency = <208333333>;
> +	};
> +
> +	ahb {
> +		compatible = "simple-bus";
> +		#address-cells = <1>;
> +		#size-cells = <1>;
> +		ranges = <0 0x60000000 0x10200000>;
> +
> +		uart0: serial at 10100000 {
> +			pinctrl-0 = <&uart_pins>;
> +			pinctrl-names = "default";
> +
> +			compatible = "ns16550a";
> +			reg = <0x10100000 0x20>;
> +			clocks = <&ahb_clk>;
> +			reg-io-width = <4>;
> +			reg-shift = <2>;
> +
> +			status = "disabled";
> +		};
> +
> +		gpio: pinctrl at 70068 {
> +			compatible = "mscc,luton-pinctrl";
> +			reg = <0x70068 0x68>;
> +			gpio-controller;
> +			#gpio-cells = <2>;
> +			gpio-ranges = <&gpio 0 0 32>;
> +
> +			uart_pins: uart-pins {
> +				pins = "GPIO_30", "GPIO_31";
> +				function = "uart";
> +			};
> +
> +		};
> +
> +		gpio_spi_bitbang: gpio at 10000064 {
> +			compatible = "mscc,spi-bitbang-gpio";
> +			reg = <0x10000064 0x4>;
> +			gpio-controller;
> +			#gpio-cells = <2>;
> +
> +		};
> +
> +		spi0: spi-bitbang {
> +			compatible = "spi-gpio";
> +			status = "okay";
> +			gpio-sck = <&gpio_spi_bitbang 6 0>;
> +			gpio-miso = <&gpio_spi_bitbang 0 0>;
> +			gpio-mosi = <&gpio_spi_bitbang 5 0>;
> +			cs-gpios = <&gpio_spi_bitbang 1 0>;
> +			num-chipselects = <1>;
> +			#address-cells = <1>;
> +			#size-cells = <0>;
> +		};
> +	};
> +};
> diff --git a/arch/mips/dts/mscc,ocelot.dtsi b/arch/mips/dts/mscc,ocelot.dtsi
> new file mode 100644
> index 0000000000..81afdffd4b
> --- /dev/null
> +++ b/arch/mips/dts/mscc,ocelot.dtsi
> @@ -0,0 +1,132 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +/*
> + * Copyright (c) 2018 Microsemi Corporation
> + */
> +
> +/ {
> +	#address-cells = <1>;
> +	#size-cells = <1>;
> +	compatible = "mscc,ocelot";
> +
> +	cpus {
> +		#address-cells = <1>;
> +		#size-cells = <0>;
> +
> +		cpu at 0 {
> +			compatible = "mips,mips24KEc";
> +			device_type = "cpu";
> +			clocks = <&cpu_clk>;
> +			reg = <0>;
> +		};
> +	};
> +
> +	aliases {
> +		serial0 = &uart0;
> +	};
> +
> +	cpuintc: interrupt-controller at 0 {
> +		#address-cells = <0>;
> +		#interrupt-cells = <1>;
> +		interrupt-controller;
> +		compatible = "mti,cpu-interrupt-controller";
> +	};
> +
> +	cpu_clk: cpu-clock {
> +		compatible = "fixed-clock";
> +		#clock-cells = <0>;
> +		clock-frequency = <500000000>;
> +	};
> +
> +	ahb_clk: ahb-clk {
> +		compatible = "fixed-clock";
> +		#clock-cells = <0>;
> +		clock-frequency = <250000000>;
> +	};
> +
> +	ahb {
> +		compatible = "simple-bus";
> +		#address-cells = <1>;
> +		#size-cells = <1>;
> +		ranges = <0 0x70000000 0x2000000>;
> +
> +		interrupt-parent = <&intc>;
> +
> +		cpu_ctrl: syscon at 0 {
> +			compatible = "mscc,ocelot-cpu-syscon", "syscon";
> +			reg = <0x0 0x2c>;
> +		};
> +
> +		intc: interrupt-controller at 70 {
> +			compatible = "mscc,ocelot-icpu-intr";
> +			reg = <0x70 0x70>;
> +			#interrupt-cells = <1>;
> +			interrupt-controller;
> +			interrupt-parent = <&cpuintc>;
> +			interrupts = <2>;
> +		};
> +
> +		uart0: serial at 100000 {
> +			pinctrl-0 = <&uart_pins>;
> +			pinctrl-names = "default";
> +			compatible = "ns16550a";
> +			reg = <0x100000 0x20>;
> +			interrupts = <6>;
> +			clocks = <&ahb_clk>;
> +			reg-io-width = <4>;
> +			reg-shift = <2>;
> +
> +			status = "disabled";
> +		};
> +
> +		uart2: serial at 100800 {
> +			pinctrl-0 = <&uart2_pins>;
> +			pinctrl-names = "default";
> +			compatible = "ns16550a";
> +			reg = <0x100800 0x20>;
> +			interrupts = <7>;
> +			clocks = <&ahb_clk>;
> +			reg-io-width = <4>;
> +			reg-shift = <2>;
> +
> +			status = "disabled";
> +		};
> +
> +		spi0: spi-master at 101000 {
> +			#address-cells = <1>;
> +			#size-cells = <0>;
> +			compatible = "snps,dw-apb-ssi";
> +			reg = <0x101000 0x40>;
> +			num-chipselect = <4>;
> +			bus-num = <0>;
> +			reg-io-width = <4>;
> +			reg-shift = <2>;
> +			spi-max-frequency = <18000000>; /* input clock */
> +			clocks = <&ahb_clk>;
> +
> +			status = "disabled";
> +		};
> +
> +		reset at 1070008 {
> +			compatible = "mscc,ocelot-chip-reset";
> +			reg = <0x1070008 0x4>;
> +		};
> +
> +		gpio: pinctrl at 1070034 {
> +			compatible = "mscc,ocelot-pinctrl";
> +			reg = <0x1070034 0x68>;
> +			gpio-controller;
> +			#gpio-cells = <2>;
> +			gpio-ranges = <&gpio 0 0 22>;
> +
> +			uart_pins: uart-pins {
> +				pins = "GPIO_6", "GPIO_7";
> +				function = "uart";
> +			};
> +
> +			uart2_pins: uart2-pins {
> +				pins = "GPIO_12", "GPIO_13";
> +				function = "uart2";
> +			};
> +		};
> +	};
> +};
> diff --git a/arch/mips/dts/mscc,ocelot_pcb.dtsi b/arch/mips/dts/mscc,ocelot_pcb.dtsi
> new file mode 100644
> index 0000000000..4e532363c3
> --- /dev/null
> +++ b/arch/mips/dts/mscc,ocelot_pcb.dtsi
> @@ -0,0 +1,37 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +/*
> + * Copyright (c) 2018 Microsemi Corporation
> + */
> +
> +/dts-v1/;
> +#include "mscc,ocelot.dtsi"
> +
> +/ {
> +	compatible = "mscc,ocelot";
> +
> +	aliases {
> +		spi0 = &spi0;
> +		serial0 = &uart0;
> +	};
> +
> +	chosen {
> +		stdout-path = "serial0:115200n8";
> +	};
> +};
> +
> +&uart0 {
> +	status = "okay";
> +};
> +
> +&spi0 {
> +	status = "okay";
> +	spi-flash at 0 {
> +		compatible = "spi-flash";
> +                spi-max-frequency = <18000000>; /* input clock */
> +                reg = <0>; /* CS0 */
> +	};
> +};
> +
> +&ethernet {
> +	status = "okay";
> +};
> diff --git a/arch/mips/dts/ocelot_pcb120.dts b/arch/mips/dts/ocelot_pcb120.dts
> new file mode 100644
> index 0000000000..47d305a614
> --- /dev/null
> +++ b/arch/mips/dts/ocelot_pcb120.dts
> @@ -0,0 +1,12 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +/*
> + * Copyright (c) 2018 Microsemi Corporation
> + */
> +
> +/dts-v1/;
> +#include "mscc,ocelot_pcb.dtsi"
> +
> +/ {
> +	model = "Ocelot PCB120 Reference Board";
> +	compatible = "mscc,ocelot-pcb120", "mscc,ocelot";
> +};
> diff --git a/arch/mips/dts/ocelot_pcb123.dts b/arch/mips/dts/ocelot_pcb123.dts
> new file mode 100644
> index 0000000000..17d8d326ce
> --- /dev/null
> +++ b/arch/mips/dts/ocelot_pcb123.dts
> @@ -0,0 +1,12 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +/*
> + * Copyright (c) 2018 Microsemi Corporation
> + */
> +
> +/dts-v1/;
> +#include "mscc,ocelot_pcb.dtsi"
> +
> +/ {
> +	model = "Ocelot PCB123 Reference Board";
> +	compatible = "mscc,ocelot-pcb123", "mscc,ocelot";
> +};
> 

-- 
- Daniel

-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 833 bytes
Desc: OpenPGP digital signature
URL: <http://lists.denx.de/pipermail/u-boot/attachments/20180926/801ca514/attachment.sig>

^ permalink raw reply	[flat|nested] 22+ messages in thread

* [U-Boot] [PATCH 5/6] MSCC: add configuration for Ocelot and Luton based boards
  2018-09-25 13:01 ` [U-Boot] [PATCH 5/6] MSCC: add configuration for Ocelot and Luton based boards Gregory CLEMENT
@ 2018-09-26 19:31   ` Daniel Schwierzeck
  2018-10-09 11:24     ` Gregory CLEMENT
  0 siblings, 1 reply; 22+ messages in thread
From: Daniel Schwierzeck @ 2018-09-26 19:31 UTC (permalink / raw)
  To: u-boot



On 25.09.2018 15:01, Gregory CLEMENT wrote:
> Add common configuration header for the VCore III SoCs (currently Ocelot
> and Luton), but also the defconfig for the evaluation boards of these
> SoCs.
> 
> Signed-off-by: Gregory CLEMENT <gregory.clement@bootlin.com>
> ---
>  configs/mscc_luton_defconfig         | 66 +++++++++++++++++++++++++
>  configs/mscc_ocelot_defconfig        | 57 ++++++++++++++++++++++
>  configs/mscc_ocelot_pcb120_defconfig | 56 ++++++++++++++++++++++
>  include/configs/vcoreiii.h           | 72 ++++++++++++++++++++++++++++
>  4 files changed, 251 insertions(+)
>  create mode 100644 configs/mscc_luton_defconfig
>  create mode 100644 configs/mscc_ocelot_defconfig
>  create mode 100644 configs/mscc_ocelot_pcb120_defconfig
>  create mode 100644 include/configs/vcoreiii.h

should also be added along with the board code

> 
> diff --git a/configs/mscc_luton_defconfig b/configs/mscc_luton_defconfig
> new file mode 100644
> index 0000000000..47fe12b6ee
> --- /dev/null
> +++ b/configs/mscc_luton_defconfig
> @@ -0,0 +1,66 @@
> +CONFIG_MIPS=y
> +CONFIG_SYS_TEXT_BASE=0x40000000
> +CONFIG_SYS_MALLOC_F_LEN=0x2000
> +CONFIG_DEBUG_UART_BOARD_INIT=y
> +CONFIG_DEBUG_UART_BASE=0x70100000
> +CONFIG_DEBUG_UART_CLOCK=208333333
> +CONFIG_ARCH_MSCC=y
> +CONFIG_TARGET_LUTON_PCB091=y
> +CONFIG_DDRTYPE_MT47H128M8HQ=y
> +CONFIG_SYS_LITTLE_ENDIAN=y
> +CONFIG_MIPS_BOOT_FDT=y
> +CONFIG_DEFAULT_DEVICE_TREE="luton_pcb091"
> +CONFIG_DEBUG_UART=y
> +CONFIG_FIT=y
> +CONFIG_BOOTDELAY=3
> +CONFIG_USE_BOOTARGS=y
> +CONFIG_BOOTARGS="console=ttyS0,115200"
> +CONFIG_LOGLEVEL=7
> +CONFIG_DISPLAY_CPUINFO=y
> +CONFIG_SYS_PROMPT="pcb091 # "
> +# CONFIG_CMD_BDI is not set
> +# CONFIG_CMD_CONSOLE is not set
> +# CONFIG_CMD_ELF is not set
> +# CONFIG_CMD_EXPORTENV is not set
> +# CONFIG_CMD_IMPORTENV is not set
> +# CONFIG_CMD_CRC32 is not set
> +CONFIG_CMD_MD5SUM=y
> +CONFIG_CMD_MEMINFO=y
> +CONFIG_CMD_MEMTEST=y
> +# CONFIG_CMD_FLASH is not set
> +CONFIG_CMD_GPIO=y
> +CONFIG_CMD_SF=y
> +CONFIG_CMD_SPI=y
> +CONFIG_CMD_DHCP=y
> +# CONFIG_NET_TFTP_VARS is not set
> +# CONFIG_CMD_NFS is not set
> +CONFIG_CMD_PING=y
> +CONFIG_CMD_MTDPARTS=y
> +CONFIG_MTDIDS_DEFAULT="nor0=spi_flash"
> +CONFIG_MTDPARTS_DEFAULT="mtdparts=spi_flash:512k(UBoot),256k(Env),256k(conf),6m at 1m(linux)"
> +# CONFIG_ISO_PARTITION is not set
> +CONFIG_OF_EMBED=y
> +CONFIG_ENV_IS_IN_SPI_FLASH=y
> +CONFIG_NET_RANDOM_ETHADDR=y
> +CONFIG_CLK=y
> +CONFIG_DM_GPIO=y
> +CONFIG_DM_SPI_FLASH=y
> +CONFIG_SPI_FLASH=y
> +CONFIG_SPI_FLASH_BAR=y
> +CONFIG_SPI_FLASH_GIGADEVICE=y
> +CONFIG_SPI_FLASH_MACRONIX=y
> +CONFIG_SPI_FLASH_SPANSION=y
> +CONFIG_SPI_FLASH_STMICRO=y
> +CONFIG_SPI_FLASH_WINBOND=y
> +CONFIG_SPI_FLASH_MTD=y
> +CONFIG_DM_ETH=y
> +CONFIG_PINCTRL=y
> +CONFIG_PINCONF=y
> +CONFIG_DM_SERIAL=y
> +CONFIG_DEBUG_UART_SHIFT=2
> +CONFIG_SYS_NS16550=y
> +CONFIG_SPI=y
> +CONFIG_DM_SPI=y
> +CONFIG_SOFT_SPI=y
> +CONFIG_LZMA=y
> +CONFIG_XZ=y
> diff --git a/configs/mscc_ocelot_defconfig b/configs/mscc_ocelot_defconfig
> new file mode 100644
> index 0000000000..eb0566189a
> --- /dev/null
> +++ b/configs/mscc_ocelot_defconfig
> @@ -0,0 +1,57 @@
> +CONFIG_MIPS=y
> +CONFIG_SYS_TEXT_BASE=0x40000000
> +CONFIG_SYS_MALLOC_F_LEN=0x2000
> +CONFIG_ARCH_MSCC=y
> +CONFIG_TARGET_OCELOT_PCB123=y
> +CONFIG_SYS_LITTLE_ENDIAN=y
> +CONFIG_DEFAULT_DEVICE_TREE="ocelot_pcb123"
> +CONFIG_FIT=y
> +CONFIG_BOOTDELAY=3
> +CONFIG_USE_BOOTARGS=y
> +CONFIG_BOOTARGS="console=ttyS0,115200"
> +CONFIG_LOGLEVEL=7
> +CONFIG_DISPLAY_CPUINFO=y
> +CONFIG_SYS_PROMPT="pcb123 # "
> +# CONFIG_CMD_BDI is not set
> +# CONFIG_CMD_CONSOLE is not set
> +# CONFIG_CMD_ELF is not set
> +# CONFIG_CMD_EXPORTENV is not set
> +# CONFIG_CMD_IMPORTENV is not set
> +# CONFIG_CMD_CRC32 is not set
> +CONFIG_CMD_MD5SUM=y
> +CONFIG_CMD_MEMINFO=y
> +CONFIG_CMD_MEMTEST=y
> +# CONFIG_CMD_FLASH is not set
> +CONFIG_CMD_GPIO=y
> +CONFIG_CMD_SF=y
> +CONFIG_CMD_SPI=y
> +CONFIG_CMD_DHCP=y
> +# CONFIG_NET_TFTP_VARS is not set
> +# CONFIG_CMD_NFS is not set
> +CONFIG_CMD_PING=y
> +CONFIG_CMD_MTDPARTS=y
> +CONFIG_MTDIDS_DEFAULT="nor0=spi_flash"
> +CONFIG_MTDPARTS_DEFAULT="mtdparts=spi_flash:512k(UBoot),256k(Env),256k(conf),15m(linux),15m(linux.bk)"
> +# CONFIG_ISO_PARTITION is not set
> +CONFIG_OF_EMBED=y
> +CONFIG_ENV_IS_IN_SPI_FLASH=y
> +CONFIG_NET_RANDOM_ETHADDR=y
> +CONFIG_CLK=y
> +CONFIG_DM_GPIO=y
> +CONFIG_DM_SPI_FLASH=y
> +CONFIG_SPI_FLASH=y
> +CONFIG_SPI_FLASH_BAR=y
> +CONFIG_SPI_FLASH_GIGADEVICE=y
> +CONFIG_SPI_FLASH_MACRONIX=y
> +CONFIG_SPI_FLASH_SPANSION=y
> +CONFIG_SPI_FLASH_WINBOND=y
> +CONFIG_SPI_FLASH_MTD=y
> +CONFIG_DM_ETH=y
> +CONFIG_PINCTRL=y
> +CONFIG_PINCONF=y
> +CONFIG_DM_SERIAL=y
> +CONFIG_SYS_NS16550=y
> +CONFIG_SPI=y
> +CONFIG_DM_SPI=y
> +CONFIG_DESIGNWARE_SPI=y
> +CONFIG_LZMA=y
> diff --git a/configs/mscc_ocelot_pcb120_defconfig b/configs/mscc_ocelot_pcb120_defconfig
> new file mode 100644
> index 0000000000..40cdec45f1
> --- /dev/null
> +++ b/configs/mscc_ocelot_pcb120_defconfig
> @@ -0,0 +1,56 @@
> +CONFIG_MIPS=y
> +CONFIG_SYS_TEXT_BASE=0x40000000
> +CONFIG_SYS_MALLOC_F_LEN=0x2000
> +CONFIG_ARCH_MSCC=y
> +CONFIG_SYS_LITTLE_ENDIAN=y
> +CONFIG_DEFAULT_DEVICE_TREE="ocelot_pcb120"
> +CONFIG_FIT=y
> +CONFIG_BOOTDELAY=3
> +CONFIG_USE_BOOTARGS=y
> +CONFIG_BOOTARGS="console=ttyS0,115200"
> +CONFIG_LOGLEVEL=7
> +CONFIG_DISPLAY_CPUINFO=y
> +CONFIG_SYS_PROMPT="pcb120 # "
> +# CONFIG_CMD_BDI is not set
> +# CONFIG_CMD_CONSOLE is not set
> +# CONFIG_CMD_ELF is not set
> +# CONFIG_CMD_EXPORTENV is not set
> +# CONFIG_CMD_IMPORTENV is not set
> +# CONFIG_CMD_CRC32 is not set
> +CONFIG_CMD_MD5SUM=y
> +CONFIG_CMD_MEMINFO=y
> +CONFIG_CMD_MEMTEST=y
> +# CONFIG_CMD_FLASH is not set
> +CONFIG_CMD_GPIO=y
> +CONFIG_CMD_SF=y
> +CONFIG_CMD_SPI=y
> +CONFIG_CMD_DHCP=y
> +# CONFIG_NET_TFTP_VARS is not set
> +# CONFIG_CMD_NFS is not set
> +CONFIG_CMD_PING=y
> +CONFIG_CMD_MTDPARTS=y
> +CONFIG_MTDIDS_DEFAULT="nor0=spi_flash"
> +CONFIG_MTDPARTS_DEFAULT="mtdparts=spi_flash:512k(UBoot),256k(Env),256k(conf),15m(linux),15m(linux.bk)"
> +# CONFIG_ISO_PARTITION is not set
> +CONFIG_OF_EMBED=y
> +CONFIG_ENV_IS_IN_SPI_FLASH=y
> +CONFIG_NET_RANDOM_ETHADDR=y
> +CONFIG_CLK=y
> +CONFIG_DM_GPIO=y
> +CONFIG_DM_SPI_FLASH=y
> +CONFIG_SPI_FLASH=y
> +CONFIG_SPI_FLASH_BAR=y
> +CONFIG_SPI_FLASH_GIGADEVICE=y
> +CONFIG_SPI_FLASH_MACRONIX=y
> +CONFIG_SPI_FLASH_SPANSION=y
> +CONFIG_SPI_FLASH_WINBOND=y
> +CONFIG_SPI_FLASH_MTD=y
> +CONFIG_DM_ETH=y
> +CONFIG_PINCTRL=y
> +CONFIG_PINCONF=y
> +CONFIG_DM_SERIAL=y
> +CONFIG_SYS_NS16550=y
> +CONFIG_SPI=y
> +CONFIG_DM_SPI=y
> +CONFIG_DESIGNWARE_SPI=y
> +CONFIG_LZMA=y
> diff --git a/include/configs/vcoreiii.h b/include/configs/vcoreiii.h
> new file mode 100644
> index 0000000000..ce43a27d7d
> --- /dev/null
> +++ b/include/configs/vcoreiii.h
> @@ -0,0 +1,72 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +/*
> + * Copyright (c) 2018 Microsemi Corporation
> + */
> +
> +#ifndef __VCOREIII_H
> +#define __VCOREIII_H
> +
> +#include <linux/sizes.h>
> +
> +/* Onboard devices */
> +
> +#define CONFIG_SYS_MALLOC_LEN		0x80000
> +#define CONFIG_SYS_LOAD_ADDR		0x00100000
> +#define CONFIG_SYS_INIT_SP_OFFSET       0x400000
> +
> +#define CPU_CLOCK_RATE			500000000 /* Clock for the MIPS core */
> +#ifdef CONFIG_SOC_LUTON
> +#define CONFIG_SYS_MIPS_TIMER_FREQ	208333333
> +#else
> +#define CONFIG_SYS_MIPS_TIMER_FREQ	(CPU_CLOCK_RATE / 2)
> +#endif
> +#define CONFIG_SYS_NS16550_CLK		CONFIG_SYS_MIPS_TIMER_FREQ
> +
> +#if defined(CONFIG_ENV_IS_IN_SPI_FLASH) && !defined(CONFIG_ENV_OFFSET)
> +#define CONFIG_ENV_OFFSET		(512 * 1024)
> +#define CONFIG_ENV_SIZE			(256 * 1024)
> +#define CONFIG_ENV_SECT_SIZE		(256 * 1024)
> +#endif
> +
> +#define CONFIG_SYS_SDRAM_BASE		0x80000000
> +#if defined(CONFIG_DDRTYPE_H5TQ1G63BFA) || defined(CONFIG_DDRTYPE_MT47H128M8HQ)
> +#define CONFIG_SYS_SDRAM_SIZE		(128 * SZ_1M)
> +#elif defined(CONFIG_DDRTYPE_MT41J128M16HA) || defined(CONFIG_DDRTYPE_MT41K128M16JT)
> +#define CONFIG_SYS_SDRAM_SIZE		(256 * SZ_1M)
> +#elif defined(CONFIG_DDRTYPE_H5TQ4G63MFR) || defined(CONFIG_DDRTYPE_MT41K256M16)
> +#define CONFIG_SYS_SDRAM_SIZE		(512 * SZ_1M)
> +#else
> +#error Unknown DDR size - please add!
> +#endif
> +
> +#define CONFIG_CONS_INDEX		1
> +
> +#define CONFIG_SYS_MEMTEST_START	CONFIG_SYS_SDRAM_BASE
> +#define CONFIG_SYS_MEMTEST_END		(CONFIG_SYS_SDRAM_BASE + CONFIG_SYS_SDRAM_SIZE - SZ_1M)
> +
> +#define CONFIG_SYS_MONITOR_BASE         CONFIG_SYS_TEXT_BASE    /* start of monitor */
> +
> +#define CONFIG_BOARD_EARLY_INIT_R
> +#if defined (CONFIG_MTDIDS_DEFAULT) && defined(CONFIG_MTDPARTS_DEFAULT)
> +#define VCOREIII_DEFAULT_MTD_ENV                        \
> +        "mtdparts=" CONFIG_MTDPARTS_DEFAULT "\0"        \
> +        "mtdids="CONFIG_MTDIDS_DEFAULT "\0"
> +#else
> +#define VCOREIII_DEFAULT_MTD_ENV    // Go away
> +#endif
> +
> +#define CONFIG_SYS_BOOTM_LEN      (16 << 20)      /* Increase max gunzip size */
> +
> +#define CONFIG_EXTRA_ENV_SETTINGS                                       \
> +    VCOREIII_DEFAULT_MTD_ENV                                            \
> +    "loadaddr=0x81000000" "\0"                                          \
> +    "spi_image_off=0x00100000" "\0"                                     \
> +    "console=ttyS0,115200" "\0"                                         \
> +    "setup=setenv bootargs console=${console} ${mtdparts} ${bootargs_extra}" "\0" \
> +    "spiboot=run setup; sf probe; sf read ${loadaddr} ${spi_image_off} 0x600000; bootm ${loadaddr}" "\0" \
> +    "update=sf probe;mtdparts;dhcp ${loadaddr} u-boot.bin;" \
> +    "sf erase UBoot 0x080000;sf write ${loadaddr} UBoot  ${filesize}" "\0" \
> +    "initrd_high=0x9000000"                                             \
> +    "bootcmd=run spiboot"
> +
> +#endif				/* __VCOREIII_H */
> 

-- 
- Daniel

-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 833 bytes
Desc: OpenPGP digital signature
URL: <http://lists.denx.de/pipermail/u-boot/attachments/20180926/abd003eb/attachment.sig>

^ permalink raw reply	[flat|nested] 22+ messages in thread

* [U-Boot] [PATCH 6/6] MIPS: bootm: Add support for Vcore III linux kernel
  2018-09-25 13:01 ` [U-Boot] [PATCH 6/6] MIPS: bootm: Add support for Vcore III linux kernel Gregory CLEMENT
@ 2018-09-26 19:40   ` Daniel Schwierzeck
  2018-10-09 11:28     ` Gregory CLEMENT
  0 siblings, 1 reply; 22+ messages in thread
From: Daniel Schwierzeck @ 2018-09-26 19:40 UTC (permalink / raw)
  To: u-boot



On 25.09.2018 15:01, Gregory CLEMENT wrote:
> The kernels built for the Vcore III linux kernel have different
> expectation in the way the data were passed.
> 
> Unlike with yamon, the command line is expected to be a single string
> passed in argv[1]. An other expectation is that the arguments are located
> in the cached address space.
> 
> However, like yamon, they expect that rd_start and rd_size was passed by
> the bootloader in the command line of the kernel, and besides that it
> also wait for the root=/dev/ram0.

Can't you use existing boot interfaces? The preferred way would be to
pass a device-tree blob to the kernel and let U-Boot fill the bootargs
in that DTB. I wonder why the linux-mips guys let you add another boot
interface. Or do you simply want to boot some legacy or propietary kernels?

> 
> Signed-off-by: Gregory CLEMENT <gregory.clement@bootlin.com>
> ---
>  arch/mips/lib/bootm.c | 62 +++++++++++++++++++++++++++++--------------
>  1 file changed, 42 insertions(+), 20 deletions(-)
> 
> diff --git a/arch/mips/lib/bootm.c b/arch/mips/lib/bootm.c
> index deca5189e3..417f5ce452 100644
> --- a/arch/mips/lib/bootm.c
> +++ b/arch/mips/lib/bootm.c
> @@ -44,22 +44,38 @@ void arch_lmb_reserve(struct lmb *lmb)
>  	lmb_reserve(lmb, sp, gd->ram_top - sp);
>  }
>  
> -static void linux_cmdline_init(void)
> +static void linux_cmdline_init(int vcoreiii)
>  {
> +	if (!vcoreiii) {
> +		linux_argv = (char **)UNCACHED_SDRAM(gd->bd->bi_boot_params);
> +		linux_argp = (char *)(linux_argv + LINUX_MAX_ARGS);
> +	} else {
> +		/*
> +		 * Vcore III linux kernels expect arguments in the cached
> +		 * address space. They also expect the command line being a
> +		 * single string in the first argument
> +		 */
> +		linux_argv = (char **)(gd->bd->bi_boot_params);
> +		linux_argp = (char *)(linux_argv + LINUX_MAX_ARGS);
> +		linux_argv[1] = linux_argp;
> +	}
>  	linux_argc = 1;
> -	linux_argv = (char **)UNCACHED_SDRAM(gd->bd->bi_boot_params);
>  	linux_argv[0] = 0;
> -	linux_argp = (char *)(linux_argv + LINUX_MAX_ARGS);
>  }
>  
> -static void linux_cmdline_set(const char *value, size_t len)
> +static void linux_cmdline_set(const char *value, size_t len, int vcoreiii)
>  {
> -	linux_argv[linux_argc] = linux_argp;
>  	memcpy(linux_argp, value, len);
> -	linux_argp[len] = 0;
> -
> +	if (!vcoreiii)	{
> +		linux_argv[linux_argc] = linux_argp;
> +		linux_argp[len] = 0;
> +		linux_argc++;
> +	} else {
> +		linux_argp[len] = ' ';
> +		linux_argp[len + 1] = 0;
> +		linux_argc = 2;
> +	}
>  	linux_argp += len + 1;
> -	linux_argc++;
>  }
>  
>  static void linux_cmdline_dump(void)
> @@ -73,12 +89,10 @@ static void linux_cmdline_dump(void)
>  		debug("   arg %03d: %s\n", i, linux_argv[i]);
>  }
>  
> -static void linux_cmdline_legacy(bootm_headers_t *images)
> +static void linux_cmdline_legacy(bootm_headers_t *images, int vcoreiii)
>  {
>  	const char *bootargs, *next, *quote;
> -
> -	linux_cmdline_init();
> -
> +	linux_cmdline_init(vcoreiii);
>  	bootargs = env_get("bootargs");
>  	if (!bootargs)
>  		return;
> @@ -104,7 +118,7 @@ static void linux_cmdline_legacy(bootm_headers_t *images)
>  		if (!next)
>  			next = bootargs + strlen(bootargs);
>  
> -		linux_cmdline_set(bootargs, next - bootargs);
> +		linux_cmdline_set(bootargs, next - bootargs, vcoreiii);
>  
>  		if (*next)
>  			next++;
> @@ -113,7 +127,7 @@ static void linux_cmdline_legacy(bootm_headers_t *images)
>  	}
>  }
>  
> -static void linux_cmdline_append(bootm_headers_t *images)
> +static void linux_cmdline_append(bootm_headers_t *images, int vcoreiii)
>  {
>  	char buf[24];
>  	ulong mem, rd_start, rd_size;
> @@ -121,7 +135,7 @@ static void linux_cmdline_append(bootm_headers_t *images)
>  	/* append mem */
>  	mem = gd->ram_size >> 20;
>  	sprintf(buf, "mem=%luM", mem);
> -	linux_cmdline_set(buf, strlen(buf));
> +	linux_cmdline_set(buf, strlen(buf), vcoreiii);
>  
>  	/* append rd_start and rd_size */
>  	rd_start = images->initrd_start;
> @@ -129,9 +143,13 @@ static void linux_cmdline_append(bootm_headers_t *images)
>  
>  	if (rd_size) {
>  		sprintf(buf, "rd_start=0x%08lX", rd_start);
> -		linux_cmdline_set(buf, strlen(buf));
> +		linux_cmdline_set(buf, strlen(buf), vcoreiii);
>  		sprintf(buf, "rd_size=0x%lX", rd_size);
> -		linux_cmdline_set(buf, strlen(buf));
> +		linux_cmdline_set(buf, strlen(buf), vcoreiii);
> +		if (vcoreiii) {
> +			sprintf(buf, "root=/dev/ram0");
> +			linux_cmdline_set(buf, strlen(buf), vcoreiii);
> +		}
>  	}
>  }
>  
> @@ -276,11 +294,15 @@ static void boot_prep_linux(bootm_headers_t *images)
>  		boot_reloc_fdt(images);
>  		boot_setup_fdt(images);
>  	} else {
> -		if (CONFIG_IS_ENABLED(MIPS_BOOT_CMDLINE_LEGACY)) {
> -			linux_cmdline_legacy(images);
> +		if (CONFIG_IS_ENABLED(SOC_VCOREIII)) {
> +			linux_cmdline_legacy(images, 1);
> +			linux_cmdline_append(images, 1);
> +			linux_cmdline_dump();
> +		} else if (CONFIG_IS_ENABLED(MIPS_BOOT_CMDLINE_LEGACY)) {
> +			linux_cmdline_legacy(images, 0);
>  
>  			if (!CONFIG_IS_ENABLED(MIPS_BOOT_ENV_LEGACY))
> -				linux_cmdline_append(images);
> +				linux_cmdline_append(images, 0);
>  
>  			linux_cmdline_dump();
>  		}
> 

-- 
- Daniel

-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 833 bytes
Desc: OpenPGP digital signature
URL: <http://lists.denx.de/pipermail/u-boot/attachments/20180926/d7691f40/attachment.sig>

^ permalink raw reply	[flat|nested] 22+ messages in thread

* [U-Boot] [PATCH 3/6] MSCC: add board support for the VCoreIII based evaluation boards
  2018-09-25 13:01 ` [U-Boot] [PATCH 3/6] MSCC: add board support for the VCoreIII based evaluation boards Gregory CLEMENT
  2018-09-26 19:28   ` Daniel Schwierzeck
@ 2018-09-26 23:03   ` Marek Vasut
  2018-10-09 11:23     ` Gregory CLEMENT
  1 sibling, 1 reply; 22+ messages in thread
From: Marek Vasut @ 2018-09-26 23:03 UTC (permalink / raw)
  To: u-boot

On 09/25/2018 03:01 PM, Gregory CLEMENT wrote:
> Adding the support for 3 boards sharing common code:
>  - PCB120 and PCB 123 for Ocelot chip
>  - PCB 91 for Luton chip
> 
> Signed-off-by: Gregory CLEMENT <gregory.clement@bootlin.com>
> ---
>  board/mscc/common/board.c  | 29 +++++++++++++++++++++++++++++
>  board/mscc/luton/Kconfig   | 14 ++++++++++++++
>  board/mscc/luton/Makefile  |  4 ++++
>  board/mscc/luton/luton.c   | 14 ++++++++++++++
>  board/mscc/ocelot/Kconfig  | 24 ++++++++++++++++++++++++
>  board/mscc/ocelot/Makefile |  5 +++++
>  board/mscc/ocelot/ocelot.c | 38 ++++++++++++++++++++++++++++++++++++++
>  7 files changed, 128 insertions(+)
>  create mode 100644 board/mscc/common/board.c
>  create mode 100644 board/mscc/luton/Kconfig
>  create mode 100644 board/mscc/luton/Makefile
>  create mode 100644 board/mscc/luton/luton.c
>  create mode 100644 board/mscc/ocelot/Kconfig
>  create mode 100644 board/mscc/ocelot/Makefile
>  create mode 100644 board/mscc/ocelot/ocelot.c
> 
> diff --git a/board/mscc/common/board.c b/board/mscc/common/board.c
> new file mode 100644
> index 0000000000..86e7bf3353
> --- /dev/null
> +++ b/board/mscc/common/board.c
> @@ -0,0 +1,29 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +/*
> + * Copyright (c) 2018 Microsemi Corporation
> + */
> +
> +#include <common.h>
> +#include <asm/io.h>
> +#include <asm/addrspace.h>
> +#include <asm/types.h>
> +#include <environment.h>
> +
> +DECLARE_GLOBAL_DATA_PTR;
> +
> +int board_early_init_r(void)
> +{
> +	u32 ctrl;
> +
> +	/* Prepare SPI controller to be used in master mode */
> +	writel(0, REG_CFG(ICPU_SW_MODE));
> +	ctrl = readl(REG_CFG(ICPU_GENERAL_CTRL));
> +
> +	writel((ctrl & ~ICPU_GENERAL_CTRL_IF_SI_OWNER_M) |
> +	       ICPU_GENERAL_CTRL_IF_SI_OWNER(2),
> +	       REG_CFG(ICPU_GENERAL_CTRL));

This can be replaced by one of the clrsetbits stuff.

[...]

> +++ b/board/mscc/luton/luton.c
> @@ -0,0 +1,14 @@
> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
> +/*
> + * Copyright (c) 2018 Microsemi Corporation
> + */
> +
> +#include <common.h>
> +#include <asm/io.h>
> +
> +void board_debug_uart_init(void)
> +{
> +	/* too early for the pinctrl driver, so configure the UART pins here */
> +	writel(BIT(30)|BIT(31), REG_GCB((0x68+8*4)));
> +	writel(~(BIT(30)|BIT(31)), REG_GCB((0x68+9*4)));

Can this ad-hoc random address be replaced by a macro ?

[...]

-- 
Best regards,
Marek Vasut

^ permalink raw reply	[flat|nested] 22+ messages in thread

* [U-Boot] [PATCH 2/6] MSCC: add support for VCoreIII SoCs
  2018-09-26 19:25   ` Daniel Schwierzeck
@ 2018-09-27 10:14     ` Gregory CLEMENT
  2018-09-27 11:57       ` Alexandre Belloni
  2018-10-09 11:20     ` Gregory CLEMENT
  1 sibling, 1 reply; 22+ messages in thread
From: Gregory CLEMENT @ 2018-09-27 10:14 UTC (permalink / raw)
  To: u-boot

Hi Daniel,

First thanks for you prompt review, it is much appreciate. :)

This week I am at kernel recipes conference, so I won't be able to fully
address your comments but I will do it next week.

However, here are some answers:

 On mer., sept. 26 2018, Daniel Schwierzeck <daniel.schwierzeck@gmail.com> wrote:

> Hi Gregory,
>
> On 25.09.2018 15:01, Gregory CLEMENT wrote:
>> These families of SoCs are found in the Microsemi Switches solution.
>> 
>> Currently the support for two families support is added:
>>  - Ocelot (VSC7513, VSC7514) already supported in Linux
>>  - Luton (Luton10: VSC7423, VSC7424, VSC7428 and Luton26: VSC7425,
>>    VSC7426, VSC7426, VSC7427, VSC7429)
>
> Is this some polished version of the original vendor U-Boot?

No the original vendor version was RedBoot

> Could you maybe add Ocelot and Luton in separate patches?

Yes sure the intent to have a uniq patch was to justify the common code
between both SoC.

>
>> 
>> Signed-off-by: Gregory CLEMENT <gregory.clement@bootlin.com>
>> ---
[..]

>> +endif
>
> from the code below I assume you have a MIPS24k core? If so you should
> use the automatic cache size detection

Yes it is a MIPS24k core. I will have a look on the automatic cache size
detection.

>
>> +
>> +menu "MSCC VCore-III platforms"
>> +	depends on ARCH_MSCC
>> +
>> +config SOC_VCOREIII
>> +	select SUPPORTS_LITTLE_ENDIAN
>> +	select SUPPORTS_BIG_ENDIAN
>> +	select SUPPORTS_CPU_MIPS32_R1
>> +	select SUPPORTS_CPU_MIPS32_R2
>> +	select ROM_EXCEPTION_VECTORS
>> +	select MIPS_TUNE_24KC
>> +	bool
>
> sort this alpahetically

OK

>
>> +
[...]

>> +void vcoreiii_tlb_init(void)
>> +{
>> +        register int tlbix = 0;
>> +
>> +        init_tlb();
>> +
>> +        /* 0x70000000 size 32M (0x02000000) */
>> +        create_tlb(tlbix++, MSCC_IO_ORIGIN1_OFFSET, SZ_16M, MMU_REGIO_RW, MMU_REGIO_RW);
>> +#ifdef CONFIG_SOC_LUTON
>> +	create_tlb(tlbix++, MSCC_IO_ORIGIN2_OFFSET, SZ_16M, MMU_REGIO_RW, MMU_REGIO_RW);
>> +#endif
>> +        /* 0x40000000 - 0x43ffffff - NON-CACHED! */
>> +        /* Flash CS0-3, each 16M = 64M total (16 x 4 below )  */
>> +        create_tlb(tlbix++, MSCC_FLASH_TO,        SZ_16M, MMU_REGIO_RO, MMU_REGIO_RO);
>> +        create_tlb(tlbix++, MSCC_FLASH_TO+SZ_32M, SZ_16M, MMU_REGIO_RO, MMU_REGIO_RO);
>> +
>> +        /* 0x20000000 - up */
>> +#if CONFIG_SYS_SDRAM_SIZE <= SZ_64M
>> +        create_tlb(tlbix++, MSCC_DDR_TO,        SZ_64M,  MMU_REGIO_RW, MMU_REGIO_INVAL);
>> +#elif CONFIG_SYS_SDRAM_SIZE <= SZ_128M
>> +        create_tlb(tlbix++, MSCC_DDR_TO,        SZ_64M,  MMU_REGIO_RW, MMU_REGIO_RW);
>> +#elif CONFIG_SYS_SDRAM_SIZE <= SZ_256M
>> +        create_tlb(tlbix++, MSCC_DDR_TO,       SZ_256M,  MMU_REGIO_RW, MMU_REGIO_INVAL);
>> +#elif CONFIG_SYS_SDRAM_SIZE <= SZ_512M
>> +        create_tlb(tlbix++, MSCC_DDR_TO,       SZ_256M,  MMU_REGIO_RW, MMU_REGIO_RW);
>> +#else  /* 1024M */
>> +        create_tlb(tlbix++, MSCC_DDR_TO,       SZ_512M,  MMU_REGIO_RW, MMU_REGIO_RW);
>> +#endif
>
> can't you leave that to the kernel? U-Boot is only running in kernel
> mode and doesn't need MMU mappings.

You should be right, I will check it.

>
>> +}
>> +
>> +int mach_cpu_init(void)
>> +{
>> +        /* Speed up NOR flash access */
>> +#ifdef CONFIG_SOC_LUTON
>> +        writel(ICPU_SPI_MST_CFG_FAST_READ_ENA +
>> +#else
>> +	writel(
>> +#endif
>> +	       ICPU_SPI_MST_CFG_CS_DESELECT_TIME(0x19) +
>> +               ICPU_SPI_MST_CFG_CLK_DIV(9), REG_CFG(ICPU_SPI_MST_CFG));
>> +
>> +        /* Disable all IRQs - map to destination map 0 */
>> +        writel(0, REG_CFG(ICPU_INTR_ENA));
>> +#ifdef CONFIG_SOC_OCELOT
>> +        writel(~0, REG_CFG(ICPU_DST_INTR_MAP(0)));
>> +        writel(0, REG_CFG(ICPU_DST_INTR_MAP(1)));
>> +        writel(0, REG_CFG(ICPU_DST_INTR_MAP(2)));
>> +        writel(0, REG_CFG(ICPU_DST_INTR_MAP(3)));
>> +#else
>> +	writel(ICPU_INTR_IRQ0_ENA_IRQ0_ENA, REG_CFG(ICPU_INTR_IRQ0_ENA));
>> +#endif
>
> do you really need to disable interrupts after a cold or warm boot?

I think it is needed, but I will check.

>
>> +	return 0;
>> +}
>> diff --git a/arch/mips/mach-mscc/dram.c b/arch/mips/mach-mscc/dram.c
>> new file mode 100644
>> index 0000000000..2db9001fe9
>> --- /dev/null
>> +++ b/arch/mips/mach-mscc/dram.c
>> @@ -0,0 +1,62 @@
>> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
>> +/*
>> + * Copyright (c) 2018 Microsemi Corporation
>> + */
>> +
>> +#include <common.h>
>> +
>> +#include <asm/io.h>
>> +#include <asm/types.h>
>> +
>> +#include <mach/tlb.h>
>> +#include <mach/ddr.h>
>> +
>> +DECLARE_GLOBAL_DATA_PTR;
>> +
>> +int vcoreiii_ddr_init(void)
>> +{
>> +        int res;
>> +        if (!(readl(REG_CFG(ICPU_MEMCTRL_STAT)) &
>> +              ICPU_MEMCTRL_STAT_INIT_DONE)) {
>> +                hal_vcoreiii_init_memctl();
>> +                hal_vcoreiii_wait_memctl();
>> +                if (hal_vcoreiii_init_dqs() != 0 ||
>> +                    hal_vcoreiii_train_bytelane(0) != 0
>> +#ifdef CONFIG_SOC_OCELOT
>> +		    || hal_vcoreiii_train_bytelane(1) != 0
>> +#endif
>> +			)
>> +                        hal_vcoreiii_ddr_failed();
>> +        }
>> +
>> +#if (CONFIG_SYS_TEXT_BASE != 0x20000000)
>> +        res = dram_check();
>> +        if (res == 0)
>> +                hal_vcoreiii_ddr_verified();
>> +        else
>> +                hal_vcoreiii_ddr_failed();
>> +
>> +        /* Clear boot-mode and read-back to activate/verify */
>> +        writel(readl(REG_CFG(ICPU_GENERAL_CTRL))& ~ICPU_GENERAL_CTRL_BOOT_MODE_ENA,
>> +	       REG_CFG(ICPU_GENERAL_CTRL));
>
> clrbits_32()?

I missed this function, thanks to point it!

>
>> +        readl(REG_CFG(ICPU_GENERAL_CTRL));
>> +#else
>> +        res = 0;
>> +#endif
>> +        return res;
>> +}
>> +
>> +int print_cpuinfo(void)
>> +{
>> +        printf("MSCC VCore-III MIPS 24Kec\n");
>> +
>> +	return 0;
>> +}
>> +
>> +int dram_init(void)
>> +{
>> +	while (vcoreiii_ddr_init());
>> +
>> +        gd->ram_size = CONFIG_SYS_SDRAM_SIZE;
>> +        return 0;
>> +}
>> diff --git a/arch/mips/mach-mscc/include/ioremap.h b/arch/mips/mach-mscc/include/ioremap.h
>> new file mode 100644
>> index 0000000000..684f89168c
>> --- /dev/null
>> +++ b/arch/mips/mach-mscc/include/ioremap.h
>> @@ -0,0 +1,49 @@
>> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
>> +/*
>> + * Copyright (c) 2018 Microsemi Corporation
>> + */
>> +
>> +#ifndef __ASM_MACH_MSCC_IOREMAP_H
>> +#define __ASM_MACH_MSCC_IOREMAP_H
>> +
>> +#include <linux/types.h>
>> +#include <mach/common.h>
>> +
>> +/*
>> + * Allow physical addresses to be fixed up to help peripherals located
>> + * outside the low 32-bit range -- generic pass-through version.
>> + */
>> +static inline phys_addr_t fixup_bigphys_addr(phys_addr_t phys_addr,
>> +                                             phys_addr_t size)
>> +{
>> +	return phys_addr;
>> +}
>> +
>> +static inline int is_vcoreiii_internal_registers(phys_addr_t offset)
>> +{
>> +#if defined(CONFIG_ARCH_MSCC)
>> +        if ((offset >= MSCC_IO_ORIGIN1_OFFSET && offset < (MSCC_IO_ORIGIN1_OFFSET+MSCC_IO_ORIGIN1_SIZE)) ||
>> +            (offset >= MSCC_IO_ORIGIN2_OFFSET && offset < (MSCC_IO_ORIGIN2_OFFSET+MSCC_IO_ORIGIN2_SIZE)))
>> +                return 1;
>> +#endif
>> +
>> +	return 0;
>> +}
>> +
>> +static inline void __iomem *plat_ioremap(phys_addr_t offset, unsigned long size,
>> +                                         unsigned long flags)
>> +{
>> +	if (is_vcoreiii_internal_registers(offset))
>> +		return (void __iomem *)offset;
>> +
>> +	return NULL;
>> +}
>> +
>> +static inline int plat_iounmap(const volatile void __iomem *addr)
>> +{
>> +	return is_vcoreiii_internal_registers((unsigned long)addr);
>> +}
>> +
>> +#define _page_cachable_default	_CACHE_CACHABLE_NONCOHERENT
>> +
>> +#endif /* __ASM_MACH_MSCC_IOREMAP_H */
>> diff --git a/arch/mips/mach-mscc/include/mach/cache.h b/arch/mips/mach-mscc/include/mach/cache.h
>> new file mode 100644
>> index 0000000000..f3d09014f3
>> --- /dev/null
>> +++ b/arch/mips/mach-mscc/include/mach/cache.h
>> @@ -0,0 +1,36 @@
>> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
>> +/*
>> + * Copyright (c) 2018 Microsemi Corporation
>> + */
>> +#define MIPS32_CACHE_OP(which, op)             (which | (op << 2))
>> +
>> +#define MIPS32_WHICH_ICACHE                    0x0
>> +#define MIPS32_WHICH_DCACHE                    0x1
>> +
>> +#define MIPS32_INDEX_INVALIDATE                0x0
>> +#define MIPS32_INDEX_LOAD_TAG                  0x1
>> +#define MIPS32_INDEX_STORE_TAG                 0x2
>> +#define MIPS32_HIT_INVALIDATE                  0x4
>> +#define MIPS32_ICACHE_FILL                     0x5
>> +#define MIPS32_DCACHE_HIT_INVALIDATE           0x5
>> +#define MIPS32_DCACHE_HIT_WRITEBACK            0x6
>> +#define MIPS32_FETCH_AND_LOCK                  0x7
>> +
>> +#define ICACHE_LOAD_LOCK (MIPS32_CACHE_OP(MIPS32_WHICH_ICACHE, MIPS32_FETCH_AND_LOCK))
>> +
>> +#define CACHE_LINE_LEN 32
>
> you can use ARCH_DMA_MINALIGN for this

OK

>
>> +
>> +/* Prefetch and lock instructions into cache */
>> +static inline void icache_lock(void *func, size_t len)
>> +{
>> +    int i, lines = ((len - 1) / CACHE_LINE_LEN) + 1;
>> +    for (i = 0; i < lines; i++) {
>> +        asm volatile (" cache %0, %1(%2)"
>> +                      : /* No Output */
>> +                      : "I" ICACHE_LOAD_LOCK,
>> +                        "n" (i*CACHE_LINE_LEN),
>> +                        "r" (func)
>> +                      : /* No Clobbers */);
>> +    }
>> +}
>
> could you try to implement this in a generic way in
> arch/mips/lib/cache.c or arch/mips/include/asm/cacheops.h?

I will do it

[...]

>> +static inline void hal_vcoreiii_ddr_failed(void)
>> +{
>> +        register u32 reset;
>> +
>> +        writel(readl(REG_CFG(ICPU_GPR(6))) + 1, REG_CFG(ICPU_GPR(6)));
>> +
>> +        writel(readl(REG_GCB(PERF_GPIO_OE)) & ~BIT(19),
>> +	       REG_GCB(PERF_GPIO_OE));
>> +
>> +        /* Jump to reset - does not return */
>> +        reset = KSEG0ADDR(_machine_restart);
>> +        icache_lock((void*)reset, 128); // Reset while running from cache
>> +        asm volatile ("jr %0" : : "r" (reset));
>> +
>> +        while(1)
>> +                ;
>
> can't you just use panic() or hang()?

Indeed panic would be a better option.

>
>> +}
>> +/*
>> + * DDR memory sanity checking done, possibly enable ECC.
>> + *
>> + * NB: Assumes inlining as no stack is available!
>> + */
>> +static inline void hal_vcoreiii_ddr_verified(void)
>> +{
>> +#ifdef MIPS_VCOREIII_MEMORY_ECC
>> +        /* Finally, enable ECC */
>> +	u32 val = readl(REG_CFG(ICPU_MEMCTRL_CFG));
>
> shouldn't it "register u32 val" like in the other functions?

Right

>
>> +        sleep_100ns(10000);
>> +#ifdef CONFIG_SOC_OCELOT
>> +        /* Establish data contents in DDR RAM for training */
>> +        ((volatile u32 *)MSCC_DDR_TO)[0] = 0xcacafefe;
>> +        ((volatile u32 *)MSCC_DDR_TO)[1] = 0x22221111;
>> +        ((volatile u32 *)MSCC_DDR_TO)[2] = 0x44443333;
>> +        ((volatile u32 *)MSCC_DDR_TO)[3] = 0x66665555;
>> +        ((volatile u32 *)MSCC_DDR_TO)[4] = 0x88887777;
>> +        ((volatile u32 *)MSCC_DDR_TO)[5] = 0xaaaa9999;
>> +        ((volatile u32 *)MSCC_DDR_TO)[6] = 0xccccbbbb;
>> +        ((volatile u32 *)MSCC_DDR_TO)[7] = 0xeeeedddd;
>> +#else
>> +	((volatile u32 *)MSCC_DDR_TO)[0] = 0xff;
>> +#endif
>
> use writel() or at least __raw_writel()

Yes of course, this part was not poperly converted from redboot.

>
[...]

>> +#define MSCC_IO_ORIGIN1_OFFSET 0x60000000
>> +#define MSCC_IO_ORIGIN1_SIZE   0x01000000
>> +#define MSCC_IO_ORIGIN2_OFFSET 0x70000000
>> +#define MSCC_IO_ORIGIN2_SIZE   0x00200000
>> +#ifndef MSCC_IO_OFFSET1
>> +#define MSCC_IO_OFFSET1(offset) (MSCC_IO_ORIGIN1_OFFSET + offset)
>> +#endif
>> +#ifndef MSCC_IO_OFFSET2
>> +#define MSCC_IO_OFFSET2(offset) (MSCC_IO_ORIGIN2_OFFSET + offset)
>> +#endif
>> +#define BASE_CFG        0x70000000
>> +#define BASE_UART       0x70100000
>> +#define BASE_DEVCPU_GCB 0x60070000
>> +#define BASE_MACRO      0x600a0000
>> +
>> +#define REG_OFFSET(t, o) ((volatile unsigned long *)(t + (o)))
>> +#define REG_CFG(x) REG_OFFSET(BASE_CFG, x)
>> +#define REG_GCB(x) REG_OFFSET(BASE_DEVCPU_GCB, x)
>> +#define REG_MACRO(x) REG_OFFSET(BASE_MACRO, x)
>
> No header files with offsets please except when needed for ASM code.
> This should come from device-tree.

Most of this value are used before the device tree was available.
But I will double check if some of them are used after the device tree
is parsed.

[...]

>
> No header files with thousand of register definitions please. Only
> define what you need per driver.

Actually it should no more the case with the other version I sent on
hte mailing list, after this one was rejected as being too large


>> +static inline void init_tlb(void)
>> +{
>> +    register int i, max;
>> +
>> +    max = get_tlb_count();
>> +    for(i = 0; i < max; i++)
>> +        create_tlb(i, i * SZ_1M, SZ_4K, MMU_REGIO_INVAL, MMU_REGIO_INVAL);
>> +}
>
> again can't you leave the setup of MMU mappings to the kernel?

I will check again


>
>> +
>> +#endif /* __ASM_MACH_TLB_H */
>> diff --git a/arch/mips/mach-mscc/lowlevel_init.S b/arch/mips/mach-mscc/lowlevel_init.S
>> new file mode 100644
>> index 0000000000..87439439f0
>> --- /dev/null
>> +++ b/arch/mips/mach-mscc/lowlevel_init.S
>> @@ -0,0 +1,29 @@
>> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
>> +/*
>> + * Copyright (c) 2018 Microsemi Corporation
>> + */
>> +
>> +#include <asm/asm.h>
>> +#include <asm/regdef.h>
>> +
>> +    .text
>
> don't set .text in ASM files. The LEAF() and NODE() macros are hacked to
> place the code in .text.FUNCNAME to allow section garbage collect.

OK

>
>> +    .set noreorder
>> +    .extern     vcoreiii_tlb_init
>> +#ifdef CONFIG_SOC_LUTON
>> +    .extern     pll_init
>> +#endif
>> +
>> +LEAF(lowlevel_init)
>> +	// As we have no stack yet, we can assume the restricted
>> +        // luxury of the sX-registers without saving them
>> +	move s0,ra
>
> various coding style issues like C++ comments and wrong indentation

I will fix it

>
>> +
>> +        jal vcoreiii_tlb_init
>> +	nop
>> +#ifdef CONFIG_SOC_LUTON
>> +        jal pll_init
>> +	nop
>> +#endif
>> +	jr  s0
>> +	nop
>
> please indent instructions in the delay slot by one space

OK

> - Daniel

Thanks again for your review.

Gregory

-- 
Gregory Clement, Bootlin
Embedded Linux and Kernel engineering
http://bootlin.com

^ permalink raw reply	[flat|nested] 22+ messages in thread

* [U-Boot] [PATCH 2/6] MSCC: add support for VCoreIII SoCs
  2018-09-27 10:14     ` Gregory CLEMENT
@ 2018-09-27 11:57       ` Alexandre Belloni
  0 siblings, 0 replies; 22+ messages in thread
From: Alexandre Belloni @ 2018-09-27 11:57 UTC (permalink / raw)
  To: u-boot

On 27/09/2018 12:14:14+0200, Gregory CLEMENT wrote:
> Hi Daniel,
> 
> First thanks for you prompt review, it is much appreciate. :)
> 
> This week I am at kernel recipes conference, so I won't be able to fully
> address your comments but I will do it next week.
> 
> However, here are some answers:
> 
>  On mer., sept. 26 2018, Daniel Schwierzeck <daniel.schwierzeck@gmail.com> wrote:
> 
> > Hi Gregory,
> >
> > On 25.09.2018 15:01, Gregory CLEMENT wrote:
> >> These families of SoCs are found in the Microsemi Switches solution.
> >> 
> >> Currently the support for two families support is added:
> >>  - Ocelot (VSC7513, VSC7514) already supported in Linux
> >>  - Luton (Luton10: VSC7423, VSC7424, VSC7428 and Luton26: VSC7425,
> >>    VSC7426, VSC7426, VSC7427, VSC7429)
> >
> > Is this some polished version of the original vendor U-Boot?
> 
> No the original vendor version was RedBoot
> 
> > Could you maybe add Ocelot and Luton in separate patches?
> 
> Yes sure the intent to have a uniq patch was to justify the common code
> between both SoC.
> 
> >
> >> 
> >> Signed-off-by: Gregory CLEMENT <gregory.clement@bootlin.com>
> >> ---
> [..]
> 
> >> +endif
> >
> > from the code below I assume you have a MIPS24k core? If so you should
> > use the automatic cache size detection
> 
> Yes it is a MIPS24k core. I will have a look on the automatic cache size
> detection.
> 
> >
> >> +
> >> +menu "MSCC VCore-III platforms"
> >> +	depends on ARCH_MSCC
> >> +
> >> +config SOC_VCOREIII
> >> +	select SUPPORTS_LITTLE_ENDIAN
> >> +	select SUPPORTS_BIG_ENDIAN
> >> +	select SUPPORTS_CPU_MIPS32_R1
> >> +	select SUPPORTS_CPU_MIPS32_R2
> >> +	select ROM_EXCEPTION_VECTORS
> >> +	select MIPS_TUNE_24KC
> >> +	bool
> >
> > sort this alpahetically
> 
> OK
> 
> >
> >> +
> [...]
> 
> >> +void vcoreiii_tlb_init(void)
> >> +{
> >> +        register int tlbix = 0;
> >> +
> >> +        init_tlb();
> >> +
> >> +        /* 0x70000000 size 32M (0x02000000) */
> >> +        create_tlb(tlbix++, MSCC_IO_ORIGIN1_OFFSET, SZ_16M, MMU_REGIO_RW, MMU_REGIO_RW);
> >> +#ifdef CONFIG_SOC_LUTON
> >> +	create_tlb(tlbix++, MSCC_IO_ORIGIN2_OFFSET, SZ_16M, MMU_REGIO_RW, MMU_REGIO_RW);
> >> +#endif
> >> +        /* 0x40000000 - 0x43ffffff - NON-CACHED! */
> >> +        /* Flash CS0-3, each 16M = 64M total (16 x 4 below )  */
> >> +        create_tlb(tlbix++, MSCC_FLASH_TO,        SZ_16M, MMU_REGIO_RO, MMU_REGIO_RO);
> >> +        create_tlb(tlbix++, MSCC_FLASH_TO+SZ_32M, SZ_16M, MMU_REGIO_RO, MMU_REGIO_RO);
> >> +
> >> +        /* 0x20000000 - up */
> >> +#if CONFIG_SYS_SDRAM_SIZE <= SZ_64M
> >> +        create_tlb(tlbix++, MSCC_DDR_TO,        SZ_64M,  MMU_REGIO_RW, MMU_REGIO_INVAL);
> >> +#elif CONFIG_SYS_SDRAM_SIZE <= SZ_128M
> >> +        create_tlb(tlbix++, MSCC_DDR_TO,        SZ_64M,  MMU_REGIO_RW, MMU_REGIO_RW);
> >> +#elif CONFIG_SYS_SDRAM_SIZE <= SZ_256M
> >> +        create_tlb(tlbix++, MSCC_DDR_TO,       SZ_256M,  MMU_REGIO_RW, MMU_REGIO_INVAL);
> >> +#elif CONFIG_SYS_SDRAM_SIZE <= SZ_512M
> >> +        create_tlb(tlbix++, MSCC_DDR_TO,       SZ_256M,  MMU_REGIO_RW, MMU_REGIO_RW);
> >> +#else  /* 1024M */
> >> +        create_tlb(tlbix++, MSCC_DDR_TO,       SZ_512M,  MMU_REGIO_RW, MMU_REGIO_RW);
> >> +#endif
> >
> > can't you leave that to the kernel? U-Boot is only running in kernel
> > mode and doesn't need MMU mappings.
> 
> You should be right, I will check it.
> 

At least MSCC_IO_ORIGIN1_OFFSET is necessary to get earlyprintk working
because the SoC registers are not in kseg0.

> >> +int mach_cpu_init(void)
> >> +{
> >> +        /* Speed up NOR flash access */
> >> +#ifdef CONFIG_SOC_LUTON
> >> +        writel(ICPU_SPI_MST_CFG_FAST_READ_ENA +
> >> +#else
> >> +	writel(
> >> +#endif
> >> +	       ICPU_SPI_MST_CFG_CS_DESELECT_TIME(0x19) +
> >> +               ICPU_SPI_MST_CFG_CLK_DIV(9), REG_CFG(ICPU_SPI_MST_CFG));
> >> +
> >> +        /* Disable all IRQs - map to destination map 0 */
> >> +        writel(0, REG_CFG(ICPU_INTR_ENA));
> >> +#ifdef CONFIG_SOC_OCELOT
> >> +        writel(~0, REG_CFG(ICPU_DST_INTR_MAP(0)));
> >> +        writel(0, REG_CFG(ICPU_DST_INTR_MAP(1)));
> >> +        writel(0, REG_CFG(ICPU_DST_INTR_MAP(2)));
> >> +        writel(0, REG_CFG(ICPU_DST_INTR_MAP(3)));
> >> +#else
> >> +	writel(ICPU_INTR_IRQ0_ENA_IRQ0_ENA, REG_CFG(ICPU_INTR_IRQ0_ENA));
> >> +#endif
> >
> > do you really need to disable interrupts after a cold or warm boot?
> 
> I think it is needed, but I will check.
> 

I would think this was done to avoid the spi driver crash. The interrupt
mapping should stay though.

> 
> >> +static inline void init_tlb(void)
> >> +{
> >> +    register int i, max;
> >> +
> >> +    max = get_tlb_count();
> >> +    for(i = 0; i < max; i++)
> >> +        create_tlb(i, i * SZ_1M, SZ_4K, MMU_REGIO_INVAL, MMU_REGIO_INVAL);
> >> +}
> >
> > again can't you leave the setup of MMU mappings to the kernel?
> 
> I will check again
> 

No, we need those mappings for earlyprintk and SoC detection. They are
needed to boot legacy kernels.


-- 
Alexandre Belloni, Bootlin
Embedded Linux and Kernel engineering
https://bootlin.com

^ permalink raw reply	[flat|nested] 22+ messages in thread

* [U-Boot] [PATCH 2/6] MSCC: add support for VCoreIII SoCs
  2018-09-26 19:25   ` Daniel Schwierzeck
  2018-09-27 10:14     ` Gregory CLEMENT
@ 2018-10-09 11:20     ` Gregory CLEMENT
  1 sibling, 0 replies; 22+ messages in thread
From: Gregory CLEMENT @ 2018-10-09 11:20 UTC (permalink / raw)
  To: u-boot

Hi Daniel,

I am bout to send a new version of the series, but befor I am going to
answer to the pending point I didn't already address in my email 10 days
ago.

 On mer., sept. 26 2018, Daniel Schwierzeck <daniel.schwierzeck@gmail.com> wrote:

> Hi Gregory,
>
> On 25.09.2018 15:01, Gregory CLEMENT wrote:
>> These families of SoCs are found in the Microsemi Switches solution.
>> 
>> Currently the support for two families support is added:
>>  - Ocelot (VSC7513, VSC7514) already supported in Linux
>>  - Luton (Luton10: VSC7423, VSC7424, VSC7428 and Luton26: VSC7425,
>>    VSC7426, VSC7426, VSC7427, VSC7429)
[...]
>>  machdirs := $(patsubst %,arch/mips/mach-%/,$(machine-y))
>>  libs-y += $(machdirs)
>> diff --git a/arch/mips/mach-mscc/Kconfig b/arch/mips/mach-mscc/Kconfig
>> new file mode 100644
>> index 0000000000..20148bfe15
>> --- /dev/null
>> +++ b/arch/mips/mach-mscc/Kconfig
>> @@ -0,0 +1,101 @@
>> +# SPDX-License-Identifier: (GPL-2.0+ OR MIT)
>> +
>> +if ARCH_MSCC
>> +
>> +config SYS_DCACHE_SIZE
>> +	default 32768
>> +
>> +config SYS_DCACHE_LINE_SIZE
>> +	default 32
>> +
>> +config SYS_ICACHE_SIZE
>> +	default 32768
>> +
>> +config SYS_ICACHE_LINE_SIZE
>> +	default 32
>> +
>> +endif
>
> from the code below I assume you have a MIPS24k core? If so you should
> use the automatic cache size detection

Eventually I managed to use the automatic cache size detection.

>> +void vcoreiii_tlb_init(void)
>> +{
>> +        register int tlbix = 0;
>> +
>> +        init_tlb();
>> +
>> +        /* 0x70000000 size 32M (0x02000000) */
>> +        create_tlb(tlbix++, MSCC_IO_ORIGIN1_OFFSET, SZ_16M, MMU_REGIO_RW, MMU_REGIO_RW);
>> +#ifdef CONFIG_SOC_LUTON
>> +	create_tlb(tlbix++, MSCC_IO_ORIGIN2_OFFSET, SZ_16M, MMU_REGIO_RW, MMU_REGIO_RW);
>> +#endif
>> +        /* 0x40000000 - 0x43ffffff - NON-CACHED! */
>> +        /* Flash CS0-3, each 16M = 64M total (16 x 4 below )  */
>> +        create_tlb(tlbix++, MSCC_FLASH_TO,        SZ_16M, MMU_REGIO_RO, MMU_REGIO_RO);
>> +        create_tlb(tlbix++, MSCC_FLASH_TO+SZ_32M, SZ_16M, MMU_REGIO_RO, MMU_REGIO_RO);
>> +
>> +        /* 0x20000000 - up */
>> +#if CONFIG_SYS_SDRAM_SIZE <= SZ_64M
>> +        create_tlb(tlbix++, MSCC_DDR_TO,        SZ_64M,  MMU_REGIO_RW, MMU_REGIO_INVAL);
>> +#elif CONFIG_SYS_SDRAM_SIZE <= SZ_128M
>> +        create_tlb(tlbix++, MSCC_DDR_TO,        SZ_64M,  MMU_REGIO_RW, MMU_REGIO_RW);
>> +#elif CONFIG_SYS_SDRAM_SIZE <= SZ_256M
>> +        create_tlb(tlbix++, MSCC_DDR_TO,       SZ_256M,  MMU_REGIO_RW, MMU_REGIO_INVAL);
>> +#elif CONFIG_SYS_SDRAM_SIZE <= SZ_512M
>> +        create_tlb(tlbix++, MSCC_DDR_TO,       SZ_256M,  MMU_REGIO_RW, MMU_REGIO_RW);
>> +#else  /* 1024M */
>> +        create_tlb(tlbix++, MSCC_DDR_TO,       SZ_512M,  MMU_REGIO_RW, MMU_REGIO_RW);
>> +#endif
>
> can't you leave that to the kernel? U-Boot is only running in kernel
> mode and doesn't need MMU mappings.

Actually, U-Boot doesn't need MMU mappings, and without this chunk of
code U-Boot is running without any problem, but unlike most of the MIPS
based SoCs, the IO register address are not in KSEG0. The mainline linux
kernel built in legacy mode needs to access some of the registers very
early in the boot and make the assumption that the bootloader already
configured them, so we have to match this expectation.

So in code I only keep the tlb entry for MSCC_IO_ORIGIN1_OFFSET and
MSCC_IO_ORIGIN1_OFFSET (where the Io registers are) and I added a
comment to explain it.

>> +}
>> +
>> +int mach_cpu_init(void)
>> +{
>> +        /* Speed up NOR flash access */
>> +#ifdef CONFIG_SOC_LUTON
>> +        writel(ICPU_SPI_MST_CFG_FAST_READ_ENA +
>> +#else
>> +	writel(
>> +#endif
>> +	       ICPU_SPI_MST_CFG_CS_DESELECT_TIME(0x19) +
>> +               ICPU_SPI_MST_CFG_CLK_DIV(9), REG_CFG(ICPU_SPI_MST_CFG));
>> +
>> +        /* Disable all IRQs - map to destination map 0 */
>> +        writel(0, REG_CFG(ICPU_INTR_ENA));
>> +#ifdef CONFIG_SOC_OCELOT
>> +        writel(~0, REG_CFG(ICPU_DST_INTR_MAP(0)));
>> +        writel(0, REG_CFG(ICPU_DST_INTR_MAP(1)));
>> +        writel(0, REG_CFG(ICPU_DST_INTR_MAP(2)));
>> +        writel(0, REG_CFG(ICPU_DST_INTR_MAP(3)));
>> +#else
>> +	writel(ICPU_INTR_IRQ0_ENA_IRQ0_ENA, REG_CFG(ICPU_INTR_IRQ0_ENA));
>> +#endif
>
> do you really need to disable interrupts after a cold or warm boot?

It was a workaround for an issue in a legacy kernel that is now fixed so
indeed can remove it.

[...]

>> +
>> +static inline void init_tlb(void)
>> +{
>> +    register int i, max;
>> +
>> +    max = get_tlb_count();
>> +    for(i = 0; i < max; i++)
>> +        create_tlb(i, i * SZ_1M, SZ_4K, MMU_REGIO_INVAL, MMU_REGIO_INVAL);
>> +}
>
> again can't you leave the setup of MMU mappings to the kernel?

I removed this part

[...]

Gregory

-- 
Gregory Clement, Bootlin
Embedded Linux and Kernel engineering
http://bootlin.com

^ permalink raw reply	[flat|nested] 22+ messages in thread

* [U-Boot] [PATCH 3/6] MSCC: add board support for the VCoreIII based evaluation boards
  2018-09-26 19:28   ` Daniel Schwierzeck
@ 2018-10-09 11:22     ` Gregory CLEMENT
  0 siblings, 0 replies; 22+ messages in thread
From: Gregory CLEMENT @ 2018-10-09 11:22 UTC (permalink / raw)
  To: u-boot

Hi Daniel,
 
 On mer., sept. 26 2018, Daniel Schwierzeck <daniel.schwierzeck@gmail.com> wrote:

> On 25.09.2018 15:01, Gregory CLEMENT wrote:
>> Adding the support for 3 boards sharing common code:
>>  - PCB120 and PCB 123 for Ocelot chip
>>  - PCB 91 for Luton chip
>> 

[...]

>> diff --git a/board/mscc/ocelot/Kconfig b/board/mscc/ocelot/Kconfig
>> new file mode 100644
>> index 0000000000..0804f5081d
>> --- /dev/null
>> +++ b/board/mscc/ocelot/Kconfig
>> @@ -0,0 +1,24 @@
>> +# SPDX-License-Identifier: (GPL-2.0+ OR MIT)
>> +
>> +config SYS_VENDOR
>> +	default "mscc"
>> +
>> +if SOC_OCELOT
>> +
>> +config SYS_BOARD
>> +	default "ocelot"
>> +
>> +config SYS_CONFIG_NAME
>> +	default "ocelot"
>> +
>> +endif
>> +
>> +if SOC_LUTON
>> +
>> +config SYS_BOARD
>> +	default "luton"
>> +
>> +config SYS_CONFIG_NAME
>> +	default "luton"
>> +
>
> this is already defined in board/mscc/luton/Kconfig

I removed it

>
>> +endif
>> diff --git a/board/mscc/ocelot/Makefile b/board/mscc/ocelot/Makefile
>> new file mode 100644
>> index 0000000000..f6a665ca83
>> --- /dev/null
>> +++ b/board/mscc/ocelot/Makefile
>> @@ -0,0 +1,5 @@
>> +# SPDX-License-Identifier: (GPL-2.0+ OR MIT)
>> +
>> +obj-$(CONFIG_SOC_OCELOT)	:= ocelot.o
>> +obj-y += ../common/board.o
>> +
>> diff --git a/board/mscc/ocelot/ocelot.c b/board/mscc/ocelot/ocelot.c
>> new file mode 100644
>> index 0000000000..971fa93d07
>> --- /dev/null
>> +++ b/board/mscc/ocelot/ocelot.c
>> @@ -0,0 +1,38 @@
>> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
>> +/*
>> + * Copyright (c) 2018 Microsemi Corporation
>> + */
>> +
>> +#include <common.h>
>> +#include <asm/io.h>
>> +#include <asm/addrspace.h>
>> +#include <asm/types.h>
>> +#include <environment.h>
>> +#include <spi.h>
>> +
>> +DECLARE_GLOBAL_DATA_PTR;
>> +
>> +void external_cs_manage(struct udevice *dev, bool enable)
>> +{
>> +	u32 cs = spi_chip_select(dev);
>> +        /* IF_SI0_OWNER, select the owner of the SI interface
>> +         * Encoding: 0: SI Slave
>> +         *           1: SI Boot Master
>> +         *           2: SI Master Controller
>> +         */
>
> style issues like indentation and multi-line comments

I fixed it

Gregory

>
>> +        if (!enable) {
>> +                writel(ICPU_SW_MODE_SW_PIN_CTRL_MODE |
>> +		       ICPU_SW_MODE_SW_SPI_CS(BIT(cs)),
>> +		       REG_CFG(ICPU_SW_MODE));
>> +                writel((readl(REG_CFG(ICPU_GENERAL_CTRL))
>> +			& ~ICPU_GENERAL_CTRL_IF_SI_OWNER_M) |
>> +		       ICPU_GENERAL_CTRL_IF_SI_OWNER(2),
>> +		       REG_CFG(ICPU_GENERAL_CTRL));
>> +        } else {
>> +                writel(0, REG_CFG(ICPU_SW_MODE));
>> +                writel((readl(REG_CFG(ICPU_GENERAL_CTRL)) &
>> +			~ICPU_GENERAL_CTRL_IF_SI_OWNER_M) |
>> +		       ICPU_GENERAL_CTRL_IF_SI_OWNER(1),
>> +		       REG_CFG(ICPU_GENERAL_CTRL));
>> +        }
>> +}
>> 
>
> -- 
> - Daniel
>

-- 
Gregory Clement, Bootlin
Embedded Linux and Kernel engineering
http://bootlin.com

^ permalink raw reply	[flat|nested] 22+ messages in thread

* [U-Boot] [PATCH 3/6] MSCC: add board support for the VCoreIII based evaluation boards
  2018-09-26 23:03   ` Marek Vasut
@ 2018-10-09 11:23     ` Gregory CLEMENT
  0 siblings, 0 replies; 22+ messages in thread
From: Gregory CLEMENT @ 2018-10-09 11:23 UTC (permalink / raw)
  To: u-boot

Hi Marek,
 
 On jeu., sept. 27 2018, Marek Vasut <marek.vasut@gmail.com> wrote:

> On 09/25/2018 03:01 PM, Gregory CLEMENT wrote:
>> Adding the support for 3 boards sharing common code:
>>  - PCB120 and PCB 123 for Ocelot chip
>>  - PCB 91 for Luton chip
>> 
>> Signed-off-by: Gregory CLEMENT <gregory.clement@bootlin.com>
>> ---
>>  board/mscc/common/board.c  | 29 +++++++++++++++++++++++++++++
>>  board/mscc/luton/Kconfig   | 14 ++++++++++++++
>>  board/mscc/luton/Makefile  |  4 ++++
>>  board/mscc/luton/luton.c   | 14 ++++++++++++++
>>  board/mscc/ocelot/Kconfig  | 24 ++++++++++++++++++++++++
>>  board/mscc/ocelot/Makefile |  5 +++++
>>  board/mscc/ocelot/ocelot.c | 38 ++++++++++++++++++++++++++++++++++++++
>>  7 files changed, 128 insertions(+)
>>  create mode 100644 board/mscc/common/board.c
>>  create mode 100644 board/mscc/luton/Kconfig
>>  create mode 100644 board/mscc/luton/Makefile
>>  create mode 100644 board/mscc/luton/luton.c
>>  create mode 100644 board/mscc/ocelot/Kconfig
>>  create mode 100644 board/mscc/ocelot/Makefile
>>  create mode 100644 board/mscc/ocelot/ocelot.c
>> 
>> diff --git a/board/mscc/common/board.c b/board/mscc/common/board.c
>> new file mode 100644
>> index 0000000000..86e7bf3353
>> --- /dev/null
>> +++ b/board/mscc/common/board.c
>> @@ -0,0 +1,29 @@
>> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
>> +/*
>> + * Copyright (c) 2018 Microsemi Corporation
>> + */
>> +
>> +#include <common.h>
>> +#include <asm/io.h>
>> +#include <asm/addrspace.h>
>> +#include <asm/types.h>
>> +#include <environment.h>
>> +
>> +DECLARE_GLOBAL_DATA_PTR;
>> +
>> +int board_early_init_r(void)
>> +{
>> +	u32 ctrl;
>> +
>> +	/* Prepare SPI controller to be used in master mode */
>> +	writel(0, REG_CFG(ICPU_SW_MODE));
>> +	ctrl = readl(REG_CFG(ICPU_GENERAL_CTRL));
>> +
>> +	writel((ctrl & ~ICPU_GENERAL_CTRL_IF_SI_OWNER_M) |
>> +	       ICPU_GENERAL_CTRL_IF_SI_OWNER(2),
>> +	       REG_CFG(ICPU_GENERAL_CTRL));
>
> This can be replaced by one of the clrsetbits stuff.

I used the clrsetbits family everywhere it was possible now.

>
> [...]
>
>> +++ b/board/mscc/luton/luton.c
>> @@ -0,0 +1,14 @@
>> +// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
>> +/*
>> + * Copyright (c) 2018 Microsemi Corporation
>> + */
>> +
>> +#include <common.h>
>> +#include <asm/io.h>
>> +
>> +void board_debug_uart_init(void)
>> +{
>> +	/* too early for the pinctrl driver, so configure the UART pins here */
>> +	writel(BIT(30)|BIT(31), REG_GCB((0x68+8*4)));
>> +	writel(~(BIT(30)|BIT(31)), REG_GCB((0x68+9*4)));
>
> Can this ad-hoc random address be replaced by a macro ?

Done!

Gregory

>
> [...]
>
> -- 
> Best regards,
> Marek Vasut

-- 
Gregory Clement, Bootlin
Embedded Linux and Kernel engineering
http://bootlin.com

^ permalink raw reply	[flat|nested] 22+ messages in thread

* [U-Boot] [PATCH 4/6] MSCC: add device tree for Ocelot and Luton (boards and SoCs)
  2018-09-26 19:31   ` Daniel Schwierzeck
@ 2018-10-09 11:23     ` Gregory CLEMENT
  0 siblings, 0 replies; 22+ messages in thread
From: Gregory CLEMENT @ 2018-10-09 11:23 UTC (permalink / raw)
  To: u-boot

Hi Daniel,
 
 On mer., sept. 26 2018, Daniel Schwierzeck <daniel.schwierzeck@gmail.com> wrote:

> On 25.09.2018 15:01, Gregory CLEMENT wrote:
>> Adding device tree for Ocelot SoC (extract from Linux) and the 2
>> evaluation boards using this SoC: PCB120 and PCB132.
>> 
>> Adding device tree for Luton SoC (not yet in Linux) and the evaluation
>> boards using this SoC: PCB91.
>> 
>> Signed-off-by: Gregory CLEMENT <gregory.clement@bootlin.com>
>> ---
>>  arch/mips/dts/luton_pcb091.dts     |  36 ++++++++
>>  arch/mips/dts/mscc,luton.dtsi      |  87 +++++++++++++++++++
>>  arch/mips/dts/mscc,ocelot.dtsi     | 132 +++++++++++++++++++++++++++++
>>  arch/mips/dts/mscc,ocelot_pcb.dtsi |  37 ++++++++
>>  arch/mips/dts/ocelot_pcb120.dts    |  12 +++
>>  arch/mips/dts/ocelot_pcb123.dts    |  12 +++
>>  6 files changed, 316 insertions(+)
>>  create mode 100644 arch/mips/dts/luton_pcb091.dts
>>  create mode 100644 arch/mips/dts/mscc,luton.dtsi
>>  create mode 100644 arch/mips/dts/mscc,ocelot.dtsi
>>  create mode 100644 arch/mips/dts/mscc,ocelot_pcb.dtsi
>>  create mode 100644 arch/mips/dts/ocelot_pcb120.dts
>>  create mode 100644 arch/mips/dts/ocelot_pcb123.dts
>
> should be added along with the board code. Also please try to add Ocelot
> and Luton boards in separate patches.

Done

Gregory


-- 
Gregory Clement, Bootlin
Embedded Linux and Kernel engineering
http://bootlin.com

^ permalink raw reply	[flat|nested] 22+ messages in thread

* [U-Boot] [PATCH 5/6] MSCC: add configuration for Ocelot and Luton based boards
  2018-09-26 19:31   ` Daniel Schwierzeck
@ 2018-10-09 11:24     ` Gregory CLEMENT
  0 siblings, 0 replies; 22+ messages in thread
From: Gregory CLEMENT @ 2018-10-09 11:24 UTC (permalink / raw)
  To: u-boot

Hi Daniel,
 
 On mer., sept. 26 2018, Daniel Schwierzeck <daniel.schwierzeck@gmail.com> wrote:

> On 25.09.2018 15:01, Gregory CLEMENT wrote:
>> Add common configuration header for the VCore III SoCs (currently Ocelot
>> and Luton), but also the defconfig for the evaluation boards of these
>> SoCs.
>> 
>> Signed-off-by: Gregory CLEMENT <gregory.clement@bootlin.com>
>> ---
>>  configs/mscc_luton_defconfig         | 66 +++++++++++++++++++++++++
>>  configs/mscc_ocelot_defconfig        | 57 ++++++++++++++++++++++
>>  configs/mscc_ocelot_pcb120_defconfig | 56 ++++++++++++++++++++++
>>  include/configs/vcoreiii.h           | 72 ++++++++++++++++++++++++++++
>>  4 files changed, 251 insertions(+)
>>  create mode 100644 configs/mscc_luton_defconfig
>>  create mode 100644 configs/mscc_ocelot_defconfig
>>  create mode 100644 configs/mscc_ocelot_pcb120_defconfig
>>  create mode 100644 include/configs/vcoreiii.h
>
> should also be added along with the board code

Done too

Gregory


-- 
Gregory Clement, Bootlin
Embedded Linux and Kernel engineering
http://bootlin.com

^ permalink raw reply	[flat|nested] 22+ messages in thread

* [U-Boot] [PATCH 6/6] MIPS: bootm: Add support for Vcore III linux kernel
  2018-09-26 19:40   ` Daniel Schwierzeck
@ 2018-10-09 11:28     ` Gregory CLEMENT
  0 siblings, 0 replies; 22+ messages in thread
From: Gregory CLEMENT @ 2018-10-09 11:28 UTC (permalink / raw)
  To: u-boot

Hi Daniel,
 
 On mer., sept. 26 2018, Daniel Schwierzeck <daniel.schwierzeck@gmail.com> wrote:

> On 25.09.2018 15:01, Gregory CLEMENT wrote:
>> The kernels built for the Vcore III linux kernel have different
>> expectation in the way the data were passed.
>> 
>> Unlike with yamon, the command line is expected to be a single string
>> passed in argv[1]. An other expectation is that the arguments are located
>> in the cached address space.
>> 
>> However, like yamon, they expect that rd_start and rd_size was passed by
>> the bootloader in the command line of the kernel, and besides that it
>> also wait for the root=/dev/ram0.
>
> Can't you use existing boot interfaces? The preferred way would be to
> pass a device-tree blob to the kernel and let U-Boot fill the bootargs
> in that DTB. I wonder why the linux-mips guys let you add another boot
> interface. Or do you simply want to boot some legacy or propietary
> kernels?

Actually we support the dtb way, but the legacy kernel still neeeds this
see:

https://elixir.bootlin.com/linux/v4.19-rc7/source/arch/mips/generic/board-ocelot.c#L38

Gregory


>
>> 
>> Signed-off-by: Gregory CLEMENT <gregory.clement@bootlin.com>
>> ---
>>  arch/mips/lib/bootm.c | 62 +++++++++++++++++++++++++++++--------------
>>  1 file changed, 42 insertions(+), 20 deletions(-)
>> 
>> diff --git a/arch/mips/lib/bootm.c b/arch/mips/lib/bootm.c
>> index deca5189e3..417f5ce452 100644
>> --- a/arch/mips/lib/bootm.c
>> +++ b/arch/mips/lib/bootm.c
>> @@ -44,22 +44,38 @@ void arch_lmb_reserve(struct lmb *lmb)
>>  	lmb_reserve(lmb, sp, gd->ram_top - sp);
>>  }
>>  
>> -static void linux_cmdline_init(void)
>> +static void linux_cmdline_init(int vcoreiii)
>>  {
>> +	if (!vcoreiii) {
>> +		linux_argv = (char **)UNCACHED_SDRAM(gd->bd->bi_boot_params);
>> +		linux_argp = (char *)(linux_argv + LINUX_MAX_ARGS);
>> +	} else {
>> +		/*
>> +		 * Vcore III linux kernels expect arguments in the cached
>> +		 * address space. They also expect the command line being a
>> +		 * single string in the first argument
>> +		 */
>> +		linux_argv = (char **)(gd->bd->bi_boot_params);
>> +		linux_argp = (char *)(linux_argv + LINUX_MAX_ARGS);
>> +		linux_argv[1] = linux_argp;
>> +	}
>>  	linux_argc = 1;
>> -	linux_argv = (char **)UNCACHED_SDRAM(gd->bd->bi_boot_params);
>>  	linux_argv[0] = 0;
>> -	linux_argp = (char *)(linux_argv + LINUX_MAX_ARGS);
>>  }
>>  
>> -static void linux_cmdline_set(const char *value, size_t len)
>> +static void linux_cmdline_set(const char *value, size_t len, int vcoreiii)
>>  {
>> -	linux_argv[linux_argc] = linux_argp;
>>  	memcpy(linux_argp, value, len);
>> -	linux_argp[len] = 0;
>> -
>> +	if (!vcoreiii)	{
>> +		linux_argv[linux_argc] = linux_argp;
>> +		linux_argp[len] = 0;
>> +		linux_argc++;
>> +	} else {
>> +		linux_argp[len] = ' ';
>> +		linux_argp[len + 1] = 0;
>> +		linux_argc = 2;
>> +	}
>>  	linux_argp += len + 1;
>> -	linux_argc++;
>>  }
>>  
>>  static void linux_cmdline_dump(void)
>> @@ -73,12 +89,10 @@ static void linux_cmdline_dump(void)
>>  		debug("   arg %03d: %s\n", i, linux_argv[i]);
>>  }
>>  
>> -static void linux_cmdline_legacy(bootm_headers_t *images)
>> +static void linux_cmdline_legacy(bootm_headers_t *images, int vcoreiii)
>>  {
>>  	const char *bootargs, *next, *quote;
>> -
>> -	linux_cmdline_init();
>> -
>> +	linux_cmdline_init(vcoreiii);
>>  	bootargs = env_get("bootargs");
>>  	if (!bootargs)
>>  		return;
>> @@ -104,7 +118,7 @@ static void linux_cmdline_legacy(bootm_headers_t *images)
>>  		if (!next)
>>  			next = bootargs + strlen(bootargs);
>>  
>> -		linux_cmdline_set(bootargs, next - bootargs);
>> +		linux_cmdline_set(bootargs, next - bootargs, vcoreiii);
>>  
>>  		if (*next)
>>  			next++;
>> @@ -113,7 +127,7 @@ static void linux_cmdline_legacy(bootm_headers_t *images)
>>  	}
>>  }
>>  
>> -static void linux_cmdline_append(bootm_headers_t *images)
>> +static void linux_cmdline_append(bootm_headers_t *images, int vcoreiii)
>>  {
>>  	char buf[24];
>>  	ulong mem, rd_start, rd_size;
>> @@ -121,7 +135,7 @@ static void linux_cmdline_append(bootm_headers_t *images)
>>  	/* append mem */
>>  	mem = gd->ram_size >> 20;
>>  	sprintf(buf, "mem=%luM", mem);
>> -	linux_cmdline_set(buf, strlen(buf));
>> +	linux_cmdline_set(buf, strlen(buf), vcoreiii);
>>  
>>  	/* append rd_start and rd_size */
>>  	rd_start = images->initrd_start;
>> @@ -129,9 +143,13 @@ static void linux_cmdline_append(bootm_headers_t *images)
>>  
>>  	if (rd_size) {
>>  		sprintf(buf, "rd_start=0x%08lX", rd_start);
>> -		linux_cmdline_set(buf, strlen(buf));
>> +		linux_cmdline_set(buf, strlen(buf), vcoreiii);
>>  		sprintf(buf, "rd_size=0x%lX", rd_size);
>> -		linux_cmdline_set(buf, strlen(buf));
>> +		linux_cmdline_set(buf, strlen(buf), vcoreiii);
>> +		if (vcoreiii) {
>> +			sprintf(buf, "root=/dev/ram0");
>> +			linux_cmdline_set(buf, strlen(buf), vcoreiii);
>> +		}
>>  	}
>>  }
>>  
>> @@ -276,11 +294,15 @@ static void boot_prep_linux(bootm_headers_t *images)
>>  		boot_reloc_fdt(images);
>>  		boot_setup_fdt(images);
>>  	} else {
>> -		if (CONFIG_IS_ENABLED(MIPS_BOOT_CMDLINE_LEGACY)) {
>> -			linux_cmdline_legacy(images);
>> +		if (CONFIG_IS_ENABLED(SOC_VCOREIII)) {
>> +			linux_cmdline_legacy(images, 1);
>> +			linux_cmdline_append(images, 1);
>> +			linux_cmdline_dump();
>> +		} else if (CONFIG_IS_ENABLED(MIPS_BOOT_CMDLINE_LEGACY)) {
>> +			linux_cmdline_legacy(images, 0);
>>  
>>  			if (!CONFIG_IS_ENABLED(MIPS_BOOT_ENV_LEGACY))
>> -				linux_cmdline_append(images);
>> +				linux_cmdline_append(images, 0);
>>  
>>  			linux_cmdline_dump();
>>  		}
>> 
>
> -- 
> - Daniel
>

-- 
Gregory Clement, Bootlin
Embedded Linux and Kernel engineering
http://bootlin.com

^ permalink raw reply	[flat|nested] 22+ messages in thread

end of thread, other threads:[~2018-10-09 11:28 UTC | newest]

Thread overview: 22+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2018-09-25 13:01 [U-Boot] [PATCH 0/6] Add support for VCore III SoCs found in Microsemi switches Gregory CLEMENT
2018-09-25 13:01 ` [U-Boot] [PATCH 1/6] MIPS: move create_tlb() in an proper header: mipsregs.h Gregory CLEMENT
2018-09-25 13:01 ` [U-Boot] [PATCH 3/6] MSCC: add board support for the VCoreIII based evaluation boards Gregory CLEMENT
2018-09-26 19:28   ` Daniel Schwierzeck
2018-10-09 11:22     ` Gregory CLEMENT
2018-09-26 23:03   ` Marek Vasut
2018-10-09 11:23     ` Gregory CLEMENT
2018-09-25 13:01 ` [U-Boot] [PATCH 4/6] MSCC: add device tree for Ocelot and Luton (boards and SoCs) Gregory CLEMENT
2018-09-26 19:31   ` Daniel Schwierzeck
2018-10-09 11:23     ` Gregory CLEMENT
2018-09-25 13:01 ` [U-Boot] [PATCH 5/6] MSCC: add configuration for Ocelot and Luton based boards Gregory CLEMENT
2018-09-26 19:31   ` Daniel Schwierzeck
2018-10-09 11:24     ` Gregory CLEMENT
2018-09-25 13:01 ` [U-Boot] [PATCH 6/6] MIPS: bootm: Add support for Vcore III linux kernel Gregory CLEMENT
2018-09-26 19:40   ` Daniel Schwierzeck
2018-10-09 11:28     ` Gregory CLEMENT
2018-09-25 15:22 ` [U-Boot] [PATCH 0/6] Add support for VCore III SoCs found in Microsemi switches Gregory CLEMENT
2018-09-25 15:25 ` [U-Boot] [PATCH 2/6] MSCC: add support for VCoreIII SoCs Gregory CLEMENT
     [not found] ` <20180925130108.19211-3-gregory.clement@bootlin.com>
2018-09-26 19:25   ` Daniel Schwierzeck
2018-09-27 10:14     ` Gregory CLEMENT
2018-09-27 11:57       ` Alexandre Belloni
2018-10-09 11:20     ` Gregory CLEMENT

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.