All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH 0/8] Introduce initial TI's am62a support
@ 2022-11-04  0:13 Bryan Brattlof
  2022-11-04  0:13 ` [PATCH 1/8] arm: dts: introduce am62a7 dtbs from linux kernel Bryan Brattlof
                   ` (8 more replies)
  0 siblings, 9 replies; 26+ messages in thread
From: Bryan Brattlof @ 2022-11-04  0:13 UTC (permalink / raw)
  To: Lukasz Majewski, Sean Anderson, Jaehoon Chung, Nishanth Menon,
	Georgi Vlaev, Andrew Davis, Vignesh Raghavendra, Tom Rini
  Cc: UBoot Mailing List, Bryan Brattlof

Hello Everyone!

This series will introduce basic support (SD and UART) support for Texas 
Instruments AM62Ax SK EVM. 

The am62ax shares many of the same features as the am62x however it uses 
a new 32bit controller and therefore depends on the patch I sent last 
week updating the macros used by the k3-ddrss ram driver[0].

Here is some proof of life & more documentation if you're interested :)

Bootlog:https://paste.sr.ht/~bryanb/e0a418ba7dd452749d2dd1efb5e91b2875a01708
Technical Reference Manual:https://www.ti.com/lit/zip/spruj16
Schematics:https://www.ti.com/lit/zip/sprr459

Thanks for reviewing!
~Bryan

[0] https://lore.kernel.org/u-boot/20221024215328.22373-1-bb@ti.com/

Bryan Brattlof (8):
  arm: dts: introduce am62a7 dtbs from linux kernel
  arm: dts: introduce am62a7 u-boot dtbs
  ram: k3-ddrss: add am62a controller support
  soc: ti: k3-socinfo: add am62a SoC entry
  arm: mach-k3: introduce basic files to support the am62a
  arm: mach-k3: am62a: introduce auto-generated SoC data
  board: ti: introduce the basic files needed to support the am62a
  configs: introduce configs for the am62a

 arch/arm/dts/Makefile                         |    3 +
 arch/arm/dts/k3-am62a-ddr-1866mhz-32bit.dtsi  | 2798 ++++++++++++++++
 arch/arm/dts/k3-am62a-ddr.dtsi                | 2814 +++++++++++++++++
 arch/arm/dts/k3-am62a-main.dtsi               |  298 ++
 arch/arm/dts/k3-am62a-mcu.dtsi                |   39 +
 arch/arm/dts/k3-am62a-wakeup.dtsi             |   54 +
 arch/arm/dts/k3-am62a.dtsi                    |  122 +
 arch/arm/dts/k3-am62a7-r5-sk.dts              |  143 +
 arch/arm/dts/k3-am62a7-sk-u-boot.dtsi         |  140 +
 arch/arm/dts/k3-am62a7-sk.dts                 |  223 ++
 arch/arm/dts/k3-am62a7.dtsi                   |  103 +
 arch/arm/mach-k3/Kconfig                      |   14 +-
 arch/arm/mach-k3/Makefile                     |    2 +
 arch/arm/mach-k3/am62a7_init.c                |  250 ++
 arch/arm/mach-k3/am62ax/Makefile              |    6 +
 arch/arm/mach-k3/am62ax/clk-data.c            |  317 ++
 arch/arm/mach-k3/am62ax/dev-data.c            |   73 +
 arch/arm/mach-k3/arm64-mmu.c                  |    6 +-
 .../arm/mach-k3/include/mach/am62a_hardware.h |   74 +
 arch/arm/mach-k3/include/mach/am62a_spl.h     |   49 +
 arch/arm/mach-k3/include/mach/hardware.h      |    4 +
 arch/arm/mach-k3/include/mach/spl.h           |    4 +
 board/ti/am62ax/Kconfig                       |   52 +
 board/ti/am62ax/MAINTAINERS                   |    9 +
 board/ti/am62ax/Makefile                      |    7 +
 board/ti/am62ax/evm.c                         |   31 +
 configs/am62ax_evm_a53_defconfig              |   79 +
 configs/am62ax_evm_r5_defconfig               |  106 +
 drivers/clk/ti/clk-k3.c                       |    6 +
 drivers/firmware/ti_sci_static_data.h         |    4 +-
 drivers/power/domain/ti-power-domain.c        |    6 +
 drivers/ram/Kconfig                           |    1 +
 drivers/ram/k3-ddrss/k3-ddrss.c               |    1 +
 drivers/soc/soc_ti_k3.c                       |    4 +
 include/configs/am62ax_evm.h                  |   68 +
 include/dt-bindings/pinctrl/k3.h              |    3 +
 include/k3-clk.h                              |    1 +
 include/k3-dev.h                              |    1 +
 38 files changed, 7906 insertions(+), 9 deletions(-)
 create mode 100644 arch/arm/dts/k3-am62a-ddr-1866mhz-32bit.dtsi
 create mode 100644 arch/arm/dts/k3-am62a-ddr.dtsi
 create mode 100644 arch/arm/dts/k3-am62a-main.dtsi
 create mode 100644 arch/arm/dts/k3-am62a-mcu.dtsi
 create mode 100644 arch/arm/dts/k3-am62a-wakeup.dtsi
 create mode 100644 arch/arm/dts/k3-am62a.dtsi
 create mode 100644 arch/arm/dts/k3-am62a7-r5-sk.dts
 create mode 100644 arch/arm/dts/k3-am62a7-sk-u-boot.dtsi
 create mode 100644 arch/arm/dts/k3-am62a7-sk.dts
 create mode 100644 arch/arm/dts/k3-am62a7.dtsi
 create mode 100644 arch/arm/mach-k3/am62a7_init.c
 create mode 100644 arch/arm/mach-k3/am62ax/Makefile
 create mode 100644 arch/arm/mach-k3/am62ax/clk-data.c
 create mode 100644 arch/arm/mach-k3/am62ax/dev-data.c
 create mode 100644 arch/arm/mach-k3/include/mach/am62a_hardware.h
 create mode 100644 arch/arm/mach-k3/include/mach/am62a_spl.h
 create mode 100644 board/ti/am62ax/Kconfig
 create mode 100644 board/ti/am62ax/MAINTAINERS
 create mode 100644 board/ti/am62ax/Makefile
 create mode 100644 board/ti/am62ax/evm.c
 create mode 100644 configs/am62ax_evm_a53_defconfig
 create mode 100644 configs/am62ax_evm_r5_defconfig
 create mode 100644 include/configs/am62ax_evm.h

-- 
2.38.1


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

* [PATCH 1/8] arm: dts: introduce am62a7 dtbs from linux kernel
  2022-11-04  0:13 [PATCH 0/8] Introduce initial TI's am62a support Bryan Brattlof
@ 2022-11-04  0:13 ` Bryan Brattlof
  2022-11-04 13:08   ` Tom Rini
  2022-12-09 22:53   ` Tom Rini
  2022-11-04  0:13 ` [PATCH 2/8] arm: dts: introduce am62a7 u-boot dtbs Bryan Brattlof
                   ` (7 subsequent siblings)
  8 siblings, 2 replies; 26+ messages in thread
From: Bryan Brattlof @ 2022-11-04  0:13 UTC (permalink / raw)
  To: Lukasz Majewski, Sean Anderson, Jaehoon Chung, Nishanth Menon,
	Georgi Vlaev, Andrew Davis, Vignesh Raghavendra, Tom Rini
  Cc: UBoot Mailing List, Bryan Brattlof

Introduce the basic am62a7 SoC dtbs from the linux kernel along with the
new am62a specific pinmux definition that we will use to generate the
dtbs for the u-boot-spl and u-boot binaries

Co-developed-by: Vignesh Raghavendra <vigneshr@ti.com>
Signed-off-by: Vignesh Raghavendra <vigneshr@ti.com>
Signed-off-by: Bryan Brattlof <bb@ti.com>
---
 arch/arm/dts/k3-am62a-main.dtsi   | 298 ++++++++++++++++++++++++++++++
 arch/arm/dts/k3-am62a-mcu.dtsi    |  39 ++++
 arch/arm/dts/k3-am62a-wakeup.dtsi |  54 ++++++
 arch/arm/dts/k3-am62a.dtsi        | 122 ++++++++++++
 arch/arm/dts/k3-am62a7-sk.dts     | 223 ++++++++++++++++++++++
 arch/arm/dts/k3-am62a7.dtsi       | 103 +++++++++++
 include/dt-bindings/pinctrl/k3.h  |   3 +
 7 files changed, 842 insertions(+)
 create mode 100644 arch/arm/dts/k3-am62a-main.dtsi
 create mode 100644 arch/arm/dts/k3-am62a-mcu.dtsi
 create mode 100644 arch/arm/dts/k3-am62a-wakeup.dtsi
 create mode 100644 arch/arm/dts/k3-am62a.dtsi
 create mode 100644 arch/arm/dts/k3-am62a7-sk.dts
 create mode 100644 arch/arm/dts/k3-am62a7.dtsi

diff --git a/arch/arm/dts/k3-am62a-main.dtsi b/arch/arm/dts/k3-am62a-main.dtsi
new file mode 100644
index 0000000000000..bc4b50bcd1773
--- /dev/null
+++ b/arch/arm/dts/k3-am62a-main.dtsi
@@ -0,0 +1,298 @@
+// SPDX-License-Identifier: GPL-2.0
+/*
+ * Device Tree Source for AM62A SoC Family Main Domain peripherals
+ *
+ * Copyright (C) 2022 Texas Instruments Incorporated - https://www.ti.com/
+ */
+
+&cbass_main {
+	oc_sram: sram@70000000 {
+		compatible = "mmio-sram";
+		reg = <0x00 0x70000000 0x00 0x10000>;
+		#address-cells = <1>;
+		#size-cells = <1>;
+		ranges = <0x0 0x00 0x70000000 0x10000>;
+	};
+
+	gic500: interrupt-controller@1800000 {
+		compatible = "arm,gic-v3";
+		reg = <0x00 0x01800000 0x00 0x10000>,	/* GICD */
+		      <0x00 0x01880000 0x00 0xc0000>,	/* GICR */
+		      <0x00 0x01880000 0x00 0xc0000>,   /* GICR */
+		      <0x01 0x00000000 0x00 0x2000>,    /* GICC */
+		      <0x01 0x00010000 0x00 0x1000>,    /* GICH */
+		      <0x01 0x00020000 0x00 0x2000>;    /* GICV */
+		#address-cells = <2>;
+		#size-cells = <2>;
+		ranges;
+		#interrupt-cells = <3>;
+		interrupt-controller;
+		/*
+		 * vcpumntirq:
+		 * virtual CPU interface maintenance interrupt
+		 */
+		interrupts = <GIC_PPI 9 IRQ_TYPE_LEVEL_HIGH>;
+
+		gic_its: msi-controller@1820000 {
+			compatible = "arm,gic-v3-its";
+			reg = <0x00 0x01820000 0x00 0x10000>;
+			socionext,synquacer-pre-its = <0x1000000 0x400000>;
+			msi-controller;
+			#msi-cells = <1>;
+		};
+	};
+
+	main_conf: syscon@100000 {
+		compatible = "ti,j721e-system-controller", "syscon", "simple-mfd";
+		reg = <0x00 0x00100000 0x00 0x20000>;
+		#address-cells = <1>;
+		#size-cells = <1>;
+		ranges = <0x00 0x00 0x00100000 0x20000>;
+	};
+
+	dmss: bus@48000000 {
+		compatible = "simple-bus";
+		#address-cells = <2>;
+		#size-cells = <2>;
+		dma-ranges;
+		ranges = <0x00 0x48000000 0x00 0x48000000 0x00 0x06000000>;
+
+		ti,sci-dev-id = <25>;
+
+		secure_proxy_main: mailbox@4d000000 {
+			compatible = "ti,am654-secure-proxy";
+			reg = <0x00 0x4d000000 0x00 0x80000>,
+			      <0x00 0x4a600000 0x00 0x80000>,
+			      <0x00 0x4a400000 0x00 0x80000>;
+			reg-names = "target_data", "rt", "scfg";
+			#mbox-cells = <1>;
+			interrupt-names = "rx_012";
+			interrupts = <GIC_SPI 34 IRQ_TYPE_LEVEL_HIGH>;
+		};
+	};
+
+	dmsc: system-controller@44043000 {
+		compatible = "ti,k2g-sci";
+		reg = <0x00 0x44043000 0x00 0xfe0>;
+		reg-names = "debug_messages";
+		ti,host-id = <12>;
+		mbox-names = "rx", "tx";
+		mboxes= <&secure_proxy_main 12>,
+			<&secure_proxy_main 13>;
+
+		k3_pds: power-controller {
+			compatible = "ti,sci-pm-domain";
+			#power-domain-cells = <2>;
+		};
+
+		k3_clks: clock-controller {
+			compatible = "ti,k2g-sci-clk";
+			#clock-cells = <2>;
+		};
+
+		k3_reset: reset-controller {
+			compatible = "ti,sci-reset";
+			#reset-cells = <2>;
+		};
+	};
+
+	main_pmx0: pinctrl@f4000 {
+		compatible = "pinctrl-single";
+		reg = <0x00 0xf4000 0x00 0x2ac>;
+		#pinctrl-cells = <1>;
+		pinctrl-single,register-width = <32>;
+		pinctrl-single,function-mask = <0xffffffff>;
+	};
+
+	main_uart0: serial@2800000 {
+		compatible = "ti,am64-uart", "ti,am654-uart";
+		reg = <0x00 0x02800000 0x00 0x100>;
+		interrupts = <GIC_SPI 178 IRQ_TYPE_LEVEL_HIGH>;
+		power-domains = <&k3_pds 146 TI_SCI_PD_EXCLUSIVE>;
+		clocks = <&k3_clks 146 0>;
+		clock-names = "fclk";
+		status = "disabled";
+	};
+
+	main_uart1: serial@2810000 {
+		compatible = "ti,am64-uart", "ti,am654-uart";
+		reg = <0x00 0x02810000 0x00 0x100>;
+		interrupts = <GIC_SPI 179 IRQ_TYPE_LEVEL_HIGH>;
+		power-domains = <&k3_pds 152 TI_SCI_PD_EXCLUSIVE>;
+		clocks = <&k3_clks 152 0>;
+		clock-names = "fclk";
+		status = "disabled";
+	};
+
+	main_uart2: serial@2820000 {
+		compatible = "ti,am64-uart", "ti,am654-uart";
+		reg = <0x00 0x02820000 0x00 0x100>;
+		interrupts = <GIC_SPI 180 IRQ_TYPE_LEVEL_HIGH>;
+		power-domains = <&k3_pds 153 TI_SCI_PD_EXCLUSIVE>;
+		clocks = <&k3_clks 153 0>;
+		clock-names = "fclk";
+		status = "disabled";
+	};
+
+	main_uart3: serial@2830000 {
+		compatible = "ti,am64-uart", "ti,am654-uart";
+		reg = <0x00 0x02830000 0x00 0x100>;
+		interrupts = <GIC_SPI 181 IRQ_TYPE_LEVEL_HIGH>;
+		power-domains = <&k3_pds 154 TI_SCI_PD_EXCLUSIVE>;
+		clocks = <&k3_clks 154 0>;
+		clock-names = "fclk";
+		status = "disabled";
+	};
+
+	main_uart4: serial@2840000 {
+		compatible = "ti,am64-uart", "ti,am654-uart";
+		reg = <0x00 0x02840000 0x00 0x100>;
+		interrupts = <GIC_SPI 182 IRQ_TYPE_LEVEL_HIGH>;
+		power-domains = <&k3_pds 155 TI_SCI_PD_EXCLUSIVE>;
+		clocks = <&k3_clks 155 0>;
+		clock-names = "fclk";
+		status = "disabled";
+	};
+
+	main_uart5: serial@2850000 {
+		compatible = "ti,am64-uart", "ti,am654-uart";
+		reg = <0x00 0x02850000 0x00 0x100>;
+		interrupts = <GIC_SPI 183 IRQ_TYPE_LEVEL_HIGH>;
+		power-domains = <&k3_pds 156 TI_SCI_PD_EXCLUSIVE>;
+		clocks = <&k3_clks 156 0>;
+		clock-names = "fclk";
+		status = "disabled";
+	};
+
+	main_uart6: serial@2860000 {
+		compatible = "ti,am64-uart", "ti,am654-uart";
+		reg = <0x00 0x02860000 0x00 0x100>;
+		interrupts = <GIC_SPI 184 IRQ_TYPE_LEVEL_HIGH>;
+		power-domains = <&k3_pds 158 TI_SCI_PD_EXCLUSIVE>;
+		clocks = <&k3_clks 158 0>;
+		clock-names = "fclk";
+		status = "disabled";
+	};
+
+	main_i2c0: i2c@20000000 {
+		compatible = "ti,am64-i2c", "ti,omap4-i2c";
+		reg = <0x00 0x20000000 0x00 0x100>;
+		interrupts = <GIC_SPI 161 IRQ_TYPE_LEVEL_HIGH>;
+		#address-cells = <1>;
+		#size-cells = <0>;
+		power-domains = <&k3_pds 102 TI_SCI_PD_EXCLUSIVE>;
+		clocks = <&k3_clks 102 2>;
+		clock-names = "fck";
+		status = "disabled";
+	};
+
+	main_i2c1: i2c@20010000 {
+		compatible = "ti,am64-i2c", "ti,omap4-i2c";
+		reg = <0x00 0x20010000 0x00 0x100>;
+		interrupts = <GIC_SPI 162 IRQ_TYPE_LEVEL_HIGH>;
+		#address-cells = <1>;
+		#size-cells = <0>;
+		power-domains = <&k3_pds 103 TI_SCI_PD_EXCLUSIVE>;
+		clocks = <&k3_clks 103 2>;
+		clock-names = "fck";
+		status = "disabled";
+	};
+
+	main_i2c2: i2c@20020000 {
+		compatible = "ti,am64-i2c", "ti,omap4-i2c";
+		reg = <0x00 0x20020000 0x00 0x100>;
+		interrupts = <GIC_SPI 163 IRQ_TYPE_LEVEL_HIGH>;
+		#address-cells = <1>;
+		#size-cells = <0>;
+		power-domains = <&k3_pds 104 TI_SCI_PD_EXCLUSIVE>;
+		clocks = <&k3_clks 104 2>;
+		clock-names = "fck";
+		status = "disabled";
+	};
+
+	main_i2c3: i2c@20030000 {
+		compatible = "ti,am64-i2c", "ti,omap4-i2c";
+		reg = <0x00 0x20030000 0x00 0x100>;
+		interrupts = <GIC_SPI 164 IRQ_TYPE_LEVEL_HIGH>;
+		#address-cells = <1>;
+		#size-cells = <0>;
+		power-domains = <&k3_pds 105 TI_SCI_PD_EXCLUSIVE>;
+		clocks = <&k3_clks 105 2>;
+		clock-names = "fck";
+		status = "disabled";
+	};
+
+	main_gpio_intr: interrupt-controller@a00000 {
+		compatible = "ti,sci-intr";
+		reg = <0x00 0x00a00000 0x00 0x800>;
+		ti,intr-trigger-type = <1>;
+		interrupt-controller;
+		interrupt-parent = <&gic500>;
+		#interrupt-cells = <1>;
+		ti,sci = <&dmsc>;
+		ti,sci-dev-id = <3>;
+		ti,interrupt-ranges = <0 32 16>;
+		status = "disabled";
+	};
+
+	main_gpio0: gpio@600000 {
+		compatible = "ti,am64-gpio", "ti,keystone-gpio";
+		reg = <0x00 0x00600000 0x0 0x100>;
+		gpio-controller;
+		#gpio-cells = <2>;
+		interrupt-parent = <&main_gpio_intr>;
+		interrupts = <190>, <191>, <192>,
+			     <193>, <194>, <195>;
+		interrupt-controller;
+		#interrupt-cells = <2>;
+		ti,ngpio = <87>;
+		ti,davinci-gpio-unbanked = <0>;
+		power-domains = <&k3_pds 77 TI_SCI_PD_EXCLUSIVE>;
+		clocks = <&k3_clks 77 0>;
+		clock-names = "gpio";
+		status = "disabled";
+	};
+
+	main_gpio1: gpio@601000 {
+		compatible = "ti,am64-gpio", "ti,keystone-gpio";
+		reg = <0x00 0x00601000 0x0 0x100>;
+		gpio-controller;
+		#gpio-cells = <2>;
+		interrupt-parent = <&main_gpio_intr>;
+		interrupts = <180>, <181>, <182>,
+			     <183>, <184>, <185>;
+		interrupt-controller;
+		#interrupt-cells = <2>;
+		ti,ngpio = <88>;
+		ti,davinci-gpio-unbanked = <0>;
+		power-domains = <&k3_pds 78 TI_SCI_PD_EXCLUSIVE>;
+		clocks = <&k3_clks 78 0>;
+		clock-names = "gpio";
+		status = "disabled";
+	};
+
+	sdhci1: mmc@fa00000 {
+		compatible = "ti,am62-sdhci";
+		reg = <0x00 0xfa00000 0x00 0x260>, <0x00 0xfa08000 0x00 0x134>;
+		interrupts = <GIC_SPI 83 IRQ_TYPE_LEVEL_HIGH>;
+		power-domains = <&k3_pds 58 TI_SCI_PD_EXCLUSIVE>;
+		clocks = <&k3_clks 58 5>, <&k3_clks 58 6>;
+		clock-names = "clk_ahb", "clk_xin";
+		ti,trm-icp = <0x2>;
+		ti,otap-del-sel-legacy = <0x0>;
+		ti,otap-del-sel-sd-hs = <0x0>;
+		ti,otap-del-sel-sdr12 = <0xf>;
+		ti,otap-del-sel-sdr25 = <0xf>;
+		ti,otap-del-sel-sdr50 = <0xc>;
+		ti,otap-del-sel-sdr104 = <0x6>;
+		ti,otap-del-sel-ddr50 = <0x9>;
+		ti,itap-del-sel-legacy = <0x0>;
+		ti,itap-del-sel-sd-hs = <0x0>;
+		ti,itap-del-sel-sdr12 = <0x0>;
+		ti,itap-del-sel-sdr25 = <0x0>;
+		ti,clkbuf-sel = <0x7>;
+		bus-width = <4>;
+		no-1-8-v;
+		status = "disabled";
+	};
+};
diff --git a/arch/arm/dts/k3-am62a-mcu.dtsi b/arch/arm/dts/k3-am62a-mcu.dtsi
new file mode 100644
index 0000000000000..6d1e501b94abf
--- /dev/null
+++ b/arch/arm/dts/k3-am62a-mcu.dtsi
@@ -0,0 +1,39 @@
+// SPDX-License-Identifier: GPL-2.0
+/*
+ * Device Tree Source for AM625 SoC Family MCU Domain peripherals
+ *
+ * Copyright (C) 2020-2022 Texas Instruments Incorporated - https://www.ti.com/
+ */
+
+&cbass_mcu {
+	mcu_pmx0: pinctrl@4084000 {
+		compatible = "pinctrl-single";
+		reg = <0x00 0x04084000 0x00 0x88>;
+		#pinctrl-cells = <1>;
+		pinctrl-single,register-width = <32>;
+		pinctrl-single,function-mask = <0xffffffff>;
+		status = "disabled";
+	};
+
+	mcu_uart0: serial@4a00000 {
+		compatible = "ti,am64-uart", "ti,am654-uart";
+		reg = <0x00 0x04a00000 0x00 0x100>;
+		interrupts = <GIC_SPI 185 IRQ_TYPE_LEVEL_HIGH>;
+		power-domains = <&k3_pds 149 TI_SCI_PD_EXCLUSIVE>;
+		clocks = <&k3_clks 149 0>;
+		clock-names = "fclk";
+		status = "disabled";
+	};
+
+	mcu_i2c0: i2c@4900000 {
+		compatible = "ti,am64-i2c", "ti,omap4-i2c";
+		reg = <0x00 0x04900000 0x00 0x100>;
+		interrupts = <GIC_SPI 107 IRQ_TYPE_LEVEL_HIGH>;
+		#address-cells = <1>;
+		#size-cells = <0>;
+		power-domains = <&k3_pds 106 TI_SCI_PD_EXCLUSIVE>;
+		clocks = <&k3_clks 106 2>;
+		clock-names = "fck";
+		status = "disabled";
+	};
+};
diff --git a/arch/arm/dts/k3-am62a-wakeup.dtsi b/arch/arm/dts/k3-am62a-wakeup.dtsi
new file mode 100644
index 0000000000000..99afac40e8d4b
--- /dev/null
+++ b/arch/arm/dts/k3-am62a-wakeup.dtsi
@@ -0,0 +1,54 @@
+// SPDX-License-Identifier: GPL-2.0
+/*
+ * Device Tree Source for AM62A SoC Family Wakeup Domain peripherals
+ *
+ * Copyright (C) 2022 Texas Instruments Incorporated - https://www.ti.com/
+ */
+
+&cbass_wakeup {
+	wkup_conf: syscon@43000000 {
+		compatible = "ti,j721e-system-controller", "syscon", "simple-mfd";
+		reg = <0x00 0x43000000 0x00 0x20000>;
+		#address-cells = <1>;
+		#size-cells = <1>;
+		ranges = <0x00 0x00 0x43000000 0x20000>;
+
+		chipid: chipid@14 {
+			compatible = "ti,am654-chipid";
+			reg = <0x14 0x4>;
+		};
+	};
+
+	wkup_uart0: serial@2b300000 {
+		compatible = "ti,am64-uart", "ti,am654-uart";
+		reg = <0x00 0x2b300000 0x00 0x100>;
+		interrupts = <GIC_SPI 186 IRQ_TYPE_LEVEL_HIGH>;
+		power-domains = <&k3_pds 114 TI_SCI_PD_EXCLUSIVE>;
+		clocks = <&k3_clks 114 0>;
+		clock-names = "fclk";
+		status = "disabled";
+	};
+
+	wkup_i2c0: i2c@2b200000 {
+		compatible = "ti,am64-i2c", "ti,omap4-i2c";
+		reg = <0x00 0x02b200000 0x00 0x100>;
+		interrupts = <GIC_SPI 165 IRQ_TYPE_LEVEL_HIGH>;
+		#address-cells = <1>;
+		#size-cells = <0>;
+		power-domains = <&k3_pds 107 TI_SCI_PD_EXCLUSIVE>;
+		clocks = <&k3_clks 107 4>;
+		clock-names = "fck";
+		status = "disabled";
+	};
+
+	wkup_rtc0: rtc@2b1f0000 {
+		compatible = "ti,am62-rtc";
+		reg = <0x00 0x2b1f0000 0x00 0x100>;
+		interrupts = <GIC_SPI 100 IRQ_TYPE_LEVEL_HIGH>;
+		clocks = <&k3_clks 117 6> , <&k3_clks 117 0>;
+		clock-names = "vbus", "osc32k";
+		power-domains = <&k3_pds 117 TI_SCI_PD_EXCLUSIVE>;
+		wakeup-source;
+		status = "disabled";
+	};
+};
diff --git a/arch/arm/dts/k3-am62a.dtsi b/arch/arm/dts/k3-am62a.dtsi
new file mode 100644
index 0000000000000..6eb87c3f9f3ce
--- /dev/null
+++ b/arch/arm/dts/k3-am62a.dtsi
@@ -0,0 +1,122 @@
+// SPDX-License-Identifier: GPL-2.0
+/*
+ * Device Tree Source for AM62A SoC Family
+ *
+ * Copyright (C) 2022 Texas Instruments Incorporated - https://www.ti.com/
+ */
+
+#include <dt-bindings/gpio/gpio.h>
+#include <dt-bindings/interrupt-controller/irq.h>
+#include <dt-bindings/interrupt-controller/arm-gic.h>
+#include <dt-bindings/pinctrl/k3.h>
+#include <dt-bindings/soc/ti,sci_pm_domain.h>
+
+/ {
+	model = "Texas Instruments K3 AM62A SoC";
+	compatible = "ti,am62a7";
+	interrupt-parent = <&gic500>;
+	#address-cells = <2>;
+	#size-cells = <2>;
+
+	chosen { };
+
+	firmware {
+		optee {
+			compatible = "linaro,optee-tz";
+			method = "smc";
+		};
+
+		psci: psci {
+			compatible = "arm,psci-1.0";
+			method = "smc";
+		};
+	};
+
+	a53_timer0: timer-cl0-cpu0 {
+		compatible = "arm,armv8-timer";
+		interrupts = <GIC_PPI 13 IRQ_TYPE_LEVEL_LOW>, /* cntpsirq */
+			     <GIC_PPI 14 IRQ_TYPE_LEVEL_LOW>, /* cntpnsirq */
+			     <GIC_PPI 11 IRQ_TYPE_LEVEL_LOW>, /* cntvirq */
+			     <GIC_PPI 10 IRQ_TYPE_LEVEL_LOW>; /* cnthpirq */
+	};
+
+	pmu: pmu {
+		compatible = "arm,cortex-a53-pmu";
+		interrupts = <GIC_PPI 7 IRQ_TYPE_LEVEL_HIGH>;
+	};
+
+	cbass_main: bus@f0000 {
+		compatible = "simple-bus";
+		#address-cells = <2>;
+		#size-cells = <2>;
+
+		ranges = <0x00 0x000f0000 0x00 0x000f0000 0x00 0x00030000>, /* Main MMRs */
+			 <0x00 0x00420000 0x00 0x00420000 0x00 0x00001000>, /* ESM0 */
+			 <0x00 0x00600000 0x00 0x00600000 0x00 0x00001100>, /* GPIO */
+			 <0x00 0x00703000 0x00 0x00703000 0x00 0x00000200>, /* USB0 debug trace */
+			 <0x00 0x0070c000 0x00 0x0070c000 0x00 0x00000200>, /* USB1 debug trace */
+			 <0x00 0x00a40000 0x00 0x00a40000 0x00 0x00000800>, /* Timesync router */
+			 <0x00 0x01000000 0x00 0x01000000 0x00 0x01b28400>, /* First peripheral window */
+			 <0x00 0x08000000 0x00 0x08000000 0x00 0x00200000>, /* Main CPSW */
+			 <0x00 0x0e000000 0x00 0x0e000000 0x00 0x01d20000>, /* Second peripheral window */
+			 <0x00 0x0fd00000 0x00 0x0fd00000 0x00 0x00020000>, /* GPU */
+			 <0x00 0x20000000 0x00 0x20000000 0x00 0x0a008000>, /* Third peripheral window */
+			 <0x00 0x30040000 0x00 0x30040000 0x00 0x00080000>, /* PRUSS-M */
+			 <0x00 0x30101000 0x00 0x30101000 0x00 0x00010100>, /* CSI window */
+			 <0x00 0x30200000 0x00 0x30200000 0x00 0x00010000>, /* DSS */
+			 <0x00 0x30210000 0x00 0x30210000 0x00 0x00010000>, /* VPU */
+			 <0x00 0x31000000 0x00 0x31000000 0x00 0x00050000>, /* USB0 DWC3 Core window */
+			 <0x00 0x31100000 0x00 0x31100000 0x00 0x00050000>, /* USB1 DWC3 Core window */
+			 <0x00 0x40900000 0x00 0x40900000 0x00 0x00030000>, /* SA3UL */
+			 <0x00 0x43600000 0x00 0x43600000 0x00 0x00010000>, /* SA3 sproxy data */
+			 <0x00 0x44043000 0x00 0x44043000 0x00 0x00000fe0>, /* TI SCI DEBUG */
+			 <0x00 0x44860000 0x00 0x44860000 0x00 0x00040000>, /* SA3 sproxy config */
+			 <0x00 0x48000000 0x00 0x48000000 0x00 0x06400000>, /* DMSS */
+			 <0x00 0x60000000 0x00 0x60000000 0x00 0x08000000>, /* FSS0 DAT1 */
+			 <0x00 0x70000000 0x00 0x70000000 0x00 0x00010000>, /* OCSRAM */
+			 <0x00 0x7e000000 0x00 0x7e000000 0x00 0x00100000>, /* C7x_0 */
+			 <0x01 0x00000000 0x01 0x00000000 0x00 0x00310000>, /* A53 PERIPHBASE */
+			 <0x05 0x00000000 0x05 0x00000000 0x01 0x00000000>, /* FSS0 DAT3 */
+
+			 /* MCU Domain Range */
+			 <0x00 0x04000000 0x00 0x04000000 0x00 0x01ff1400>,
+			 <0x00 0x79000000 0x00 0x79000000 0x00 0x00008000>, /* MCU R5 ATCM */
+			 <0x00 0x79020000 0x00 0x79020000 0x00 0x00008000>, /* MCU R5 BTCM */
+			 <0x00 0x79100000 0x00 0x79100000 0x00 0x00040000>, /* MCU R5 IRAM0 */
+			 <0x00 0x79140000 0x00 0x79140000 0x00 0x00040000>, /* MCU R5 IRAM1 */
+
+			 /* Wakeup Domain Range */
+			 <0x00 0x00b00000 0x00 0x00b00000 0x00 0x00002400>,
+			 <0x00 0x2b000000 0x00 0x2b000000 0x00 0x00300400>,
+			 <0x00 0x43000000 0x00 0x43000000 0x00 0x00020000>,
+			 <0x00 0x78000000 0x00 0x78000000 0x00 0x00008000>, /* DM R5 ATCM */
+			 <0x00 0x78100000 0x00 0x78100000 0x00 0x00008000>; /* DM R5 BTCM */
+
+		cbass_mcu: bus@4000000 {
+			compatible = "simple-bus";
+			#address-cells = <2>;
+			#size-cells = <2>;
+			ranges = <0x00 0x04000000 0x00 0x04000000 0x00 0x01ff1400>, /* Peripheral window */
+				 <0x00 0x79000000 0x00 0x79000000 0x00 0x00008000>, /* MCU R5 ATCM */
+				 <0x00 0x79020000 0x00 0x79020000 0x00 0x00008000>, /* MCU R5 BTCM */
+				 <0x00 0x79100000 0x00 0x79100000 0x00 0x00040000>, /* MCU IRAM0 */
+				 <0x00 0x79140000 0x00 0x79140000 0x00 0x00040000>; /* MCU IRAM1 */
+		};
+
+		cbass_wakeup: bus@b00000 {
+			compatible = "simple-bus";
+			#address-cells = <2>;
+			#size-cells = <2>;
+			ranges = <0x00 0x00b00000 0x00 0x00b00000 0x00 0x00002400>, /* VTM */
+				 <0x00 0x2b000000 0x00 0x2b000000 0x00 0x00300400>, /* Peripheral Window */
+				 <0x00 0x43000000 0x00 0x43000000 0x00 0x00020000>, /* WKUP CTRL MMR */
+				 <0x00 0x78000000 0x00 0x78000000 0x00 0x00008000>, /* DM R5 ATCM*/
+				 <0x00 0x78100000 0x00 0x78100000 0x00 0x00008000>; /* DM R5 BTCM*/
+		};
+	};
+};
+
+/* Now include the peripherals for each bus segments */
+#include "k3-am62a-main.dtsi"
+#include "k3-am62a-mcu.dtsi"
+#include "k3-am62a-wakeup.dtsi"
diff --git a/arch/arm/dts/k3-am62a7-sk.dts b/arch/arm/dts/k3-am62a7-sk.dts
new file mode 100644
index 0000000000000..576dbce80ad83
--- /dev/null
+++ b/arch/arm/dts/k3-am62a7-sk.dts
@@ -0,0 +1,223 @@
+// SPDX-License-Identifier: GPL-2.0
+/*
+ * AM62A SK: https://www.ti.com/lit/zip/sprr459
+ *
+ * Copyright (C) 2022 Texas Instruments Incorporated - https://www.ti.com/
+ */
+
+/dts-v1/;
+
+#include <dt-bindings/leds/common.h>
+#include <dt-bindings/gpio/gpio.h>
+#include "k3-am62a7.dtsi"
+
+/ {
+	compatible =  "ti,am62a7-sk", "ti,am62a7";
+	model = "Texas Instruments AM62A7 SK";
+
+	aliases {
+		serial2 = &main_uart0;
+		mmc1 = &sdhci1;
+	};
+
+	chosen {
+		stdout-path = "serial2:115200n8";
+	};
+
+	memory@80000000 {
+		device_type = "memory";
+		/* 2G RAM */
+		reg = <0x00000000 0x80000000 0x00000000 0x80000000>;
+	};
+
+	reserved-memory {
+		#address-cells = <2>;
+		#size-cells = <2>;
+		ranges;
+
+		secure_tfa_ddr: tfa@9e780000 {
+			reg = <0x00 0x9e780000 0x00 0x80000>;
+			alignment = <0x1000>;
+			no-map;
+		};
+
+		secure_ddr: optee@9e800000 {
+			reg = <0x00 0x9e800000 0x00 0x01800000>; /* for OP-TEE */
+			alignment = <0x1000>;
+			no-map;
+		};
+
+		wkup_r5fss0_core0_memory_region: r5f-dma-memory@9c900000 {
+			compatible = "shared-dma-pool";
+			reg = <0x00 0x9c900000 0x00 0x01e00000>;
+			no-map;
+		};
+	};
+
+	vmain_pd: regulator-0 {
+		/* TPS25750 PD CONTROLLER OUTPUT */
+		compatible = "regulator-fixed";
+		regulator-name = "vmain_pd";
+		regulator-min-microvolt = <5000000>;
+		regulator-max-microvolt = <5000000>;
+		regulator-always-on;
+		regulator-boot-on;
+	};
+
+	vcc_5v0: regulator-1 {
+		/* Output of TPS63070 */
+		compatible = "regulator-fixed";
+		regulator-name = "vcc_5v0";
+		regulator-min-microvolt = <5000000>;
+		regulator-max-microvolt = <5000000>;
+		vin-supply = <&vmain_pd>;
+		regulator-always-on;
+		regulator-boot-on;
+	};
+
+	vcc_3v3_sys: regulator-2 {
+		/* output of LM5141-Q1 */
+		compatible = "regulator-fixed";
+		regulator-name = "vcc_3v3_sys";
+		regulator-min-microvolt = <3300000>;
+		regulator-max-microvolt = <3300000>;
+		vin-supply = <&vmain_pd>;
+		regulator-always-on;
+		regulator-boot-on;
+	};
+
+	vdd_mmc1: regulator-3 {
+		/* TPS22918DBVR */
+		compatible = "regulator-fixed";
+		regulator-name = "vdd_mmc1";
+		regulator-min-microvolt = <3300000>;
+		regulator-max-microvolt = <3300000>;
+		regulator-boot-on;
+		enable-active-high;
+		gpio = <&exp1 3 GPIO_ACTIVE_HIGH>;
+	};
+
+	leds {
+		compatible = "gpio-leds";
+		pinctrl-names = "default";
+		pinctrl-0 = <&usr_led_pins_default>;
+
+		led-0 {
+			label = "am62a-sk:green:heartbeat";
+			gpios = <&main_gpio1 49 GPIO_ACTIVE_HIGH>;
+			linux,default-trigger = "heartbeat";
+			function = LED_FUNCTION_HEARTBEAT;
+			default-state = "off";
+		};
+	};
+};
+
+&main_pmx0 {
+	main_uart0_pins_default: main-uart0-pins-default {
+		pinctrl-single,pins = <
+			AM62AX_IOPAD(0x1c8, PIN_INPUT, 0) /* (D14) UART0_RXD */
+			AM62AX_IOPAD(0x1cc, PIN_OUTPUT, 0) /* (E14) UART0_TXD */
+		>;
+	};
+
+	main_i2c0_pins_default: main-i2c0-pins-default {
+		pinctrl-single,pins = <
+			AM62AX_IOPAD(0x1e0, PIN_INPUT_PULLUP, 0) /* (B16) I2C0_SCL */
+			AM62AX_IOPAD(0x1e4, PIN_INPUT_PULLUP, 0) /* (A16) I2C0_SDA */
+		>;
+	};
+
+	main_i2c1_pins_default: main-i2c1-pins-default {
+		pinctrl-single,pins = <
+			AM62AX_IOPAD(0x1e8, PIN_INPUT_PULLUP, 0) /* (B17) I2C1_SCL */
+			AM62AX_IOPAD(0x1ec, PIN_INPUT_PULLUP, 0) /* (A17) I2C1_SDA */
+		>;
+	};
+
+	main_i2c2_pins_default: main-i2c2-pins-default {
+		pinctrl-single,pins = <
+			AM62AX_IOPAD(0x0b0, PIN_INPUT_PULLUP, 1) /* (K22) GPMC0_CSn2.I2C2_SCL */
+			AM62AX_IOPAD(0x0b4, PIN_INPUT_PULLUP, 1) /* (K24) GPMC0_CSn3.I2C2_SDA */
+		>;
+	};
+
+	main_mmc1_pins_default: main-mmc1-pins-default {
+		pinctrl-single,pins = <
+			AM62AX_IOPAD(0x23c, PIN_INPUT, 0) /* (A21) MMC1_CMD */
+			AM62AX_IOPAD(0x234, PIN_INPUT, 0) /* (B22) MMC1_CLK */
+			AM62AX_IOPAD(0x230, PIN_INPUT, 0) /* (A22) MMC1_DAT0 */
+			AM62AX_IOPAD(0x22c, PIN_INPUT, 0) /* (B21) MMC1_DAT1 */
+			AM62AX_IOPAD(0x228, PIN_INPUT, 0) /* (C21) MMC1_DAT2 */
+			AM62AX_IOPAD(0x224, PIN_INPUT, 0) /* (D22) MMC1_DAT3 */
+			AM62AX_IOPAD(0x240, PIN_INPUT, 0) /* (D17) MMC1_SDCD */
+		>;
+	};
+
+	usr_led_pins_default: usr-led-pins-default {
+		pinctrl-single,pins = <
+			AM62AX_IOPAD(0x244, PIN_OUTPUT, 7) /* (D18) MMC1_SDWP.GPIO1_49 */
+		>;
+	};
+};
+
+&main_i2c0 {
+	status = "okay";
+	pinctrl-names = "default";
+	pinctrl-0 = <&main_i2c0_pins_default>;
+	clock-frequency = <400000>;
+};
+
+&main_i2c1 {
+	status = "okay";
+	pinctrl-names = "default";
+	pinctrl-0 = <&main_i2c1_pins_default>;
+	clock-frequency = <400000>;
+
+	exp1: gpio@22 {
+		compatible = "ti,tca6424";
+		reg = <0x22>;
+		gpio-controller;
+		#gpio-cells = <2>;
+
+		gpio-line-names = "GPIO_CPSW2_RST", "GPIO_CPSW1_RST",
+				   "BT_EN_SOC", "MMC1_SD_EN",
+				   "VPP_EN", "EXP_PS_3V3_En",
+				   "EXP_PS_5V0_En", "EXP_HAT_DETECT",
+				   "GPIO_AUD_RSTn", "GPIO_eMMC_RSTn",
+				   "UART1_FET_BUF_EN", "BT_UART_WAKE_SOC",
+				   "GPIO_HDMI_RSTn", "CSI_GPIO0",
+				   "CSI_GPIO1", "WLAN_ALERTn",
+				   "HDMI_INTn", "TEST_GPIO2",
+				   "MCASP1_FET_EN", "MCASP1_BUF_BT_EN",
+				   "MCASP1_FET_SEL", "UART1_FET_SEL",
+				   "PD_I2C_IRQ", "IO_EXP_TEST_LED";
+	};
+};
+
+&sdhci1 {
+	/* SD/MMC */
+	status = "okay";
+	vmmc-supply = <&vdd_mmc1>;
+	pinctrl-names = "default";
+	pinctrl-0 = <&main_mmc1_pins_default>;
+	ti,driver-strength-ohm = <50>;
+	disable-wp;
+};
+
+&main_gpio0 {
+	status = "okay";
+};
+
+&main_gpio1 {
+	status = "okay";
+};
+
+&main_gpio_intr {
+	status = "okay";
+};
+
+&main_uart0 {
+	status = "okay";
+	pinctrl-names = "default";
+	pinctrl-0 = <&main_uart0_pins_default>;
+};
diff --git a/arch/arm/dts/k3-am62a7.dtsi b/arch/arm/dts/k3-am62a7.dtsi
new file mode 100644
index 0000000000000..331d89fda29d0
--- /dev/null
+++ b/arch/arm/dts/k3-am62a7.dtsi
@@ -0,0 +1,103 @@
+// SPDX-License-Identifier: GPL-2.0
+/*
+ * Device Tree Source for AM62A7 SoC family in Quad core configuration
+ *
+ * TRM: https://www.ti.com/lit/zip/spruj16
+ *
+ * Copyright (C) 2020-2022 Texas Instruments Incorporated - https://www.ti.com/
+ */
+
+/dts-v1/;
+
+#include "k3-am62a.dtsi"
+
+/ {
+	cpus {
+		#address-cells = <1>;
+		#size-cells = <0>;
+
+		cpu-map {
+			cluster0: cluster0 {
+				core0 {
+					cpu = <&cpu0>;
+				};
+
+				core1 {
+					cpu = <&cpu1>;
+				};
+
+				core2 {
+					cpu = <&cpu2>;
+				};
+
+				core3 {
+					cpu = <&cpu3>;
+				};
+			};
+		};
+
+		cpu0: cpu@0 {
+			compatible = "arm,cortex-a53";
+			reg = <0x000>;
+			device_type = "cpu";
+			enable-method = "psci";
+			i-cache-size = <0x8000>;
+			i-cache-line-size = <64>;
+			i-cache-sets = <256>;
+			d-cache-size = <0x8000>;
+			d-cache-line-size = <64>;
+			d-cache-sets = <128>;
+			next-level-cache = <&L2_0>;
+		};
+
+		cpu1: cpu@1 {
+			compatible = "arm,cortex-a53";
+			reg = <0x001>;
+			device_type = "cpu";
+			enable-method = "psci";
+			i-cache-size = <0x8000>;
+			i-cache-line-size = <64>;
+			i-cache-sets = <256>;
+			d-cache-size = <0x8000>;
+			d-cache-line-size = <64>;
+			d-cache-sets = <128>;
+			next-level-cache = <&L2_0>;
+		};
+
+		cpu2: cpu@2 {
+			compatible = "arm,cortex-a53";
+			reg = <0x002>;
+			device_type = "cpu";
+			enable-method = "psci";
+			i-cache-size = <0x8000>;
+			i-cache-line-size = <64>;
+			i-cache-sets = <256>;
+			d-cache-size = <0x8000>;
+			d-cache-line-size = <64>;
+			d-cache-sets = <128>;
+			next-level-cache = <&L2_0>;
+		};
+
+		cpu3: cpu@3 {
+			compatible = "arm,cortex-a53";
+			reg = <0x003>;
+			device_type = "cpu";
+			enable-method = "psci";
+			i-cache-size = <0x8000>;
+			i-cache-line-size = <64>;
+			i-cache-sets = <256>;
+			d-cache-size = <0x8000>;
+			d-cache-line-size = <64>;
+			d-cache-sets = <128>;
+			next-level-cache = <&L2_0>;
+		};
+	};
+
+	L2_0: l2-cache0 {
+		compatible = "cache";
+		cache-level = <2>;
+		cache-size = <0x40000>;
+		cache-line-size = <64>;
+		cache-sets = <512>;
+	};
+};
diff --git a/include/dt-bindings/pinctrl/k3.h b/include/dt-bindings/pinctrl/k3.h
index a5204ab91d3ec..e8418318eb9c2 100644
--- a/include/dt-bindings/pinctrl/k3.h
+++ b/include/dt-bindings/pinctrl/k3.h
@@ -44,4 +44,7 @@
 #define AM62X_IOPAD(pa, val, muxmode)		(((pa) & 0x1fff)) ((val) | (muxmode))
 #define AM62X_MCU_IOPAD(pa, val, muxmode)	(((pa) & 0x1fff)) ((val) | (muxmode))
 
+#define AM62AX_IOPAD(pa, val, muxmode)		(((pa) & 0x1fff)) ((val) | (muxmode))
+#define AM62AX_MCU_IOPAD(pa, val, muxmode)	(((pa) & 0x1fff)) ((val) | (muxmode))
+
 #endif
-- 
2.38.1


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

* [PATCH 2/8] arm: dts: introduce am62a7 u-boot dtbs
  2022-11-04  0:13 [PATCH 0/8] Introduce initial TI's am62a support Bryan Brattlof
  2022-11-04  0:13 ` [PATCH 1/8] arm: dts: introduce am62a7 dtbs from linux kernel Bryan Brattlof
@ 2022-11-04  0:13 ` Bryan Brattlof
  2022-12-09 22:53   ` Tom Rini
  2022-11-04  0:13 ` [PATCH 3/8] ram: k3-ddrss: add am62a controller support Bryan Brattlof
                   ` (6 subsequent siblings)
  8 siblings, 1 reply; 26+ messages in thread
From: Bryan Brattlof @ 2022-11-04  0:13 UTC (permalink / raw)
  To: Lukasz Majewski, Sean Anderson, Jaehoon Chung, Nishanth Menon,
	Georgi Vlaev, Andrew Davis, Vignesh Raghavendra, Tom Rini
  Cc: UBoot Mailing List, Bryan Brattlof

Introduce the base dts files needed for u-boot or to augment the
linux dtbs for use in the u-boot-spl and u-boot binaries

Signed-off-by: Vignesh Raghavendra <vigneshr@ti.com>
Signed-off-by: Bryan Brattlof <bb@ti.com>
---
 arch/arm/dts/Makefile                        |    3 +
 arch/arm/dts/k3-am62a-ddr-1866mhz-32bit.dtsi | 2798 +++++++++++++++++
 arch/arm/dts/k3-am62a-ddr.dtsi               | 2814 ++++++++++++++++++
 arch/arm/dts/k3-am62a7-r5-sk.dts             |  143 +
 arch/arm/dts/k3-am62a7-sk-u-boot.dtsi        |  140 +
 5 files changed, 5898 insertions(+)
 create mode 100644 arch/arm/dts/k3-am62a-ddr-1866mhz-32bit.dtsi
 create mode 100644 arch/arm/dts/k3-am62a-ddr.dtsi
 create mode 100644 arch/arm/dts/k3-am62a7-r5-sk.dts
 create mode 100644 arch/arm/dts/k3-am62a7-sk-u-boot.dtsi

diff --git a/arch/arm/dts/Makefile b/arch/arm/dts/Makefile
index 791838733c5d3..5e13903d08b5c 100644
--- a/arch/arm/dts/Makefile
+++ b/arch/arm/dts/Makefile
@@ -1255,6 +1255,9 @@ dtb-$(CONFIG_SOC_K3_AM642) += k3-am642-evm.dtb \
 dtb-$(CONFIG_SOC_K3_AM625) += k3-am625-sk.dtb \
 			      k3-am625-r5-sk.dtb
 
+dtb-$(CONFIG_SOC_K3_AM625) += k3-am62a7-sk.dtb \
+			      k3-am62a7-r5-sk.dtb
+
 dtb-$(CONFIG_ARCH_MEDIATEK) += \
 	mt7622-rfb.dtb \
 	mt7623a-unielec-u7623-02-emmc.dtb \
diff --git a/arch/arm/dts/k3-am62a-ddr-1866mhz-32bit.dtsi b/arch/arm/dts/k3-am62a-ddr-1866mhz-32bit.dtsi
new file mode 100644
index 0000000000000..9f50d7eae69b7
--- /dev/null
+++ b/arch/arm/dts/k3-am62a-ddr-1866mhz-32bit.dtsi
@@ -0,0 +1,2798 @@
+// SPDX-License-Identifier: GPL-2.0+
+/*
+ * This file was generated with the
+ * AM62A SysConfig DDR Subsystem Register Configuration Tool v0.09.01
+ * Wed Aug 10 2022 17:34:54 GMT-0500 (Central Daylight Time)
+ * DDR Type: LPDDR4
+ * F0 = 50MHz    F1 = NA     F2 = 1866MHz
+ * Density (per channel): 8Gb
+ * Number of Ranks: 2
+ */
+
+#define DDRSS_PLL_FHS_CNT 5
+#define DDRSS_PLL_FREQUENCY_1 933000000
+#define DDRSS_PLL_FREQUENCY_2 933000000
+
+#define DDRSS_CTL_0_DATA 0x00000B00
+#define DDRSS_CTL_1_DATA 0x00000000
+#define DDRSS_CTL_2_DATA 0x00000000
+#define DDRSS_CTL_3_DATA 0x00000000
+#define DDRSS_CTL_4_DATA 0x00000000
+#define DDRSS_CTL_5_DATA 0x00000000
+#define DDRSS_CTL_6_DATA 0x00000000
+#define DDRSS_CTL_7_DATA 0x00002710
+#define DDRSS_CTL_8_DATA 0x000186A0
+#define DDRSS_CTL_9_DATA 0x00000005
+#define DDRSS_CTL_10_DATA 0x00000064
+#define DDRSS_CTL_11_DATA 0x0005B18F
+#define DDRSS_CTL_12_DATA 0x0038EF90
+#define DDRSS_CTL_13_DATA 0x00000005
+#define DDRSS_CTL_14_DATA 0x00000E94
+#define DDRSS_CTL_15_DATA 0x0005B18F
+#define DDRSS_CTL_16_DATA 0x0038EF90
+#define DDRSS_CTL_17_DATA 0x00000005
+#define DDRSS_CTL_18_DATA 0x00000E94
+#define DDRSS_CTL_19_DATA 0x01010100
+#define DDRSS_CTL_20_DATA 0x01010100
+#define DDRSS_CTL_21_DATA 0x01000110
+#define DDRSS_CTL_22_DATA 0x02010002
+#define DDRSS_CTL_23_DATA 0x0000000A
+#define DDRSS_CTL_24_DATA 0x000186A0
+#define DDRSS_CTL_25_DATA 0x00000000
+#define DDRSS_CTL_26_DATA 0x00000000
+#define DDRSS_CTL_27_DATA 0x00000000
+#define DDRSS_CTL_28_DATA 0x00000000
+#define DDRSS_CTL_29_DATA 0x00020200
+#define DDRSS_CTL_30_DATA 0x00000000
+#define DDRSS_CTL_31_DATA 0x00000000
+#define DDRSS_CTL_32_DATA 0x00000000
+#define DDRSS_CTL_33_DATA 0x00000000
+#define DDRSS_CTL_34_DATA 0x08000010
+#define DDRSS_CTL_35_DATA 0x00004B4B
+#define DDRSS_CTL_36_DATA 0x00000000
+#define DDRSS_CTL_37_DATA 0x00000000
+#define DDRSS_CTL_38_DATA 0x00000000
+#define DDRSS_CTL_39_DATA 0x00000000
+#define DDRSS_CTL_40_DATA 0x0000040C
+#define DDRSS_CTL_41_DATA 0x00000000
+#define DDRSS_CTL_42_DATA 0x00001040
+#define DDRSS_CTL_43_DATA 0x00000000
+#define DDRSS_CTL_44_DATA 0x00001040
+#define DDRSS_CTL_45_DATA 0x00000000
+#define DDRSS_CTL_46_DATA 0x05000804
+#define DDRSS_CTL_47_DATA 0x00000700
+#define DDRSS_CTL_48_DATA 0x09090004
+#define DDRSS_CTL_49_DATA 0x00000303
+#define DDRSS_CTL_50_DATA 0x00720014
+#define DDRSS_CTL_51_DATA 0x09140050
+#define DDRSS_CTL_52_DATA 0x00004D22
+#define DDRSS_CTL_53_DATA 0x00720014
+#define DDRSS_CTL_54_DATA 0x09140050
+#define DDRSS_CTL_55_DATA 0x09004D22
+#define DDRSS_CTL_56_DATA 0x000A0A09
+#define DDRSS_CTL_57_DATA 0x040006DB
+#define DDRSS_CTL_58_DATA 0x090F2005
+#define DDRSS_CTL_59_DATA 0x00001B13
+#define DDRSS_CTL_60_DATA 0x0E00FFCD
+#define DDRSS_CTL_61_DATA 0x090F200F
+#define DDRSS_CTL_62_DATA 0x00001B13
+#define DDRSS_CTL_63_DATA 0x0E00FFCD
+#define DDRSS_CTL_64_DATA 0x0304200F
+#define DDRSS_CTL_65_DATA 0x04050002
+#define DDRSS_CTL_66_DATA 0x24232423
+#define DDRSS_CTL_67_DATA 0x01010008
+#define DDRSS_CTL_68_DATA 0x04464607
+#define DDRSS_CTL_69_DATA 0x03282803
+#define DDRSS_CTL_70_DATA 0x00002828
+#define DDRSS_CTL_71_DATA 0x00000101
+#define DDRSS_CTL_72_DATA 0x00000000
+#define DDRSS_CTL_73_DATA 0x01000000
+#define DDRSS_CTL_74_DATA 0x000E0803
+#define DDRSS_CTL_75_DATA 0x000000BB
+#define DDRSS_CTL_76_DATA 0x0000020B
+#define DDRSS_CTL_77_DATA 0x00001C64
+#define DDRSS_CTL_78_DATA 0x0000020B
+#define DDRSS_CTL_79_DATA 0x00001C64
+#define DDRSS_CTL_80_DATA 0x00000005
+#define DDRSS_CTL_81_DATA 0x00000007
+#define DDRSS_CTL_82_DATA 0x00000010
+#define DDRSS_CTL_83_DATA 0x00000106
+#define DDRSS_CTL_84_DATA 0x00000386
+#define DDRSS_CTL_85_DATA 0x00000106
+#define DDRSS_CTL_86_DATA 0x00000386
+#define DDRSS_CTL_87_DATA 0x03004000
+#define DDRSS_CTL_88_DATA 0x00001201
+#define DDRSS_CTL_89_DATA 0x000E0005
+#define DDRSS_CTL_90_DATA 0x2608000E
+#define DDRSS_CTL_91_DATA 0x0A050526
+#define DDRSS_CTL_92_DATA 0x1B0E0A03
+#define DDRSS_CTL_93_DATA 0x1B0E0A04
+#define DDRSS_CTL_94_DATA 0x04010104
+#define DDRSS_CTL_95_DATA 0x00010401
+#define DDRSS_CTL_96_DATA 0x000F000F
+#define DDRSS_CTL_97_DATA 0x02190219
+#define DDRSS_CTL_98_DATA 0x02190219
+#define DDRSS_CTL_99_DATA 0x00000000
+#define DDRSS_CTL_100_DATA 0x03030000
+#define DDRSS_CTL_101_DATA 0x05050501
+#define DDRSS_CTL_102_DATA 0x04041C04
+#define DDRSS_CTL_103_DATA 0x0E0A0E0A
+#define DDRSS_CTL_104_DATA 0x0A04041C
+#define DDRSS_CTL_105_DATA 0x030E0A0E
+#define DDRSS_CTL_106_DATA 0x00000404
+#define DDRSS_CTL_107_DATA 0x00000301
+#define DDRSS_CTL_108_DATA 0x00000001
+#define DDRSS_CTL_109_DATA 0x00000000
+#define DDRSS_CTL_110_DATA 0x40020100
+#define DDRSS_CTL_111_DATA 0x00038010
+#define DDRSS_CTL_112_DATA 0x00050004
+#define DDRSS_CTL_113_DATA 0x00000004
+#define DDRSS_CTL_114_DATA 0x00040003
+#define DDRSS_CTL_115_DATA 0x00040005
+#define DDRSS_CTL_116_DATA 0x00030000
+#define DDRSS_CTL_117_DATA 0x00050004
+#define DDRSS_CTL_118_DATA 0x00000004
+#define DDRSS_CTL_119_DATA 0x00002EC0
+#define DDRSS_CTL_120_DATA 0x00002EC0
+#define DDRSS_CTL_121_DATA 0x00002EC0
+#define DDRSS_CTL_122_DATA 0x00002EC0
+#define DDRSS_CTL_123_DATA 0x00002EC0
+#define DDRSS_CTL_124_DATA 0x00000000
+#define DDRSS_CTL_125_DATA 0x0000051D
+#define DDRSS_CTL_126_DATA 0x00071900
+#define DDRSS_CTL_127_DATA 0x00071900
+#define DDRSS_CTL_128_DATA 0x00071900
+#define DDRSS_CTL_129_DATA 0x00071900
+#define DDRSS_CTL_130_DATA 0x00071900
+#define DDRSS_CTL_131_DATA 0x00000000
+#define DDRSS_CTL_132_DATA 0x0000C6BC
+#define DDRSS_CTL_133_DATA 0x00071900
+#define DDRSS_CTL_134_DATA 0x00071900
+#define DDRSS_CTL_135_DATA 0x00071900
+#define DDRSS_CTL_136_DATA 0x00071900
+#define DDRSS_CTL_137_DATA 0x00071900
+#define DDRSS_CTL_138_DATA 0x00000000
+#define DDRSS_CTL_139_DATA 0x0000C6BC
+#define DDRSS_CTL_140_DATA 0x00000000
+#define DDRSS_CTL_141_DATA 0x00000000
+#define DDRSS_CTL_142_DATA 0x00000000
+#define DDRSS_CTL_143_DATA 0x00000000
+#define DDRSS_CTL_144_DATA 0x00000000
+#define DDRSS_CTL_145_DATA 0x00000000
+#define DDRSS_CTL_146_DATA 0x00000000
+#define DDRSS_CTL_147_DATA 0x00000000
+#define DDRSS_CTL_148_DATA 0x00000000
+#define DDRSS_CTL_149_DATA 0x00000000
+#define DDRSS_CTL_150_DATA 0x00000000
+#define DDRSS_CTL_151_DATA 0x00000000
+#define DDRSS_CTL_152_DATA 0x00000000
+#define DDRSS_CTL_153_DATA 0x00000000
+#define DDRSS_CTL_154_DATA 0x00000000
+#define DDRSS_CTL_155_DATA 0x00000000
+#define DDRSS_CTL_156_DATA 0x00000000
+#define DDRSS_CTL_157_DATA 0x00000000
+#define DDRSS_CTL_158_DATA 0x03050000
+#define DDRSS_CTL_159_DATA 0x040A040A
+#define DDRSS_CTL_160_DATA 0x00000000
+#define DDRSS_CTL_161_DATA 0x08010000
+#define DDRSS_CTL_162_DATA 0x000E0808
+#define DDRSS_CTL_163_DATA 0x01000000
+#define DDRSS_CTL_164_DATA 0x0E080808
+#define DDRSS_CTL_165_DATA 0x00000000
+#define DDRSS_CTL_166_DATA 0x08080801
+#define DDRSS_CTL_167_DATA 0x0000080E
+#define DDRSS_CTL_168_DATA 0x00040003
+#define DDRSS_CTL_169_DATA 0x00000007
+#define DDRSS_CTL_170_DATA 0x00000000
+#define DDRSS_CTL_171_DATA 0x00000000
+#define DDRSS_CTL_172_DATA 0x00000000
+#define DDRSS_CTL_173_DATA 0x00000000
+#define DDRSS_CTL_174_DATA 0x00000000
+#define DDRSS_CTL_175_DATA 0x00000000
+#define DDRSS_CTL_176_DATA 0x01000000
+#define DDRSS_CTL_177_DATA 0x00000000
+#define DDRSS_CTL_178_DATA 0x00001700
+#define DDRSS_CTL_179_DATA 0x0000100E
+#define DDRSS_CTL_180_DATA 0x00000002
+#define DDRSS_CTL_181_DATA 0x00000000
+#define DDRSS_CTL_182_DATA 0x00000001
+#define DDRSS_CTL_183_DATA 0x00000002
+#define DDRSS_CTL_184_DATA 0x00000C00
+#define DDRSS_CTL_185_DATA 0x00008000
+#define DDRSS_CTL_186_DATA 0x00000C00
+#define DDRSS_CTL_187_DATA 0x00008000
+#define DDRSS_CTL_188_DATA 0x00000C00
+#define DDRSS_CTL_189_DATA 0x00008000
+#define DDRSS_CTL_190_DATA 0x00000000
+#define DDRSS_CTL_191_DATA 0x00000000
+#define DDRSS_CTL_192_DATA 0x00000000
+#define DDRSS_CTL_193_DATA 0x00000000
+#define DDRSS_CTL_194_DATA 0x00000000
+#define DDRSS_CTL_195_DATA 0x0005000A
+#define DDRSS_CTL_196_DATA 0x0404000D
+#define DDRSS_CTL_197_DATA 0x0000000D
+#define DDRSS_CTL_198_DATA 0x00BB0176
+#define DDRSS_CTL_199_DATA 0x0E0E01D3
+#define DDRSS_CTL_200_DATA 0x000001D3
+#define DDRSS_CTL_201_DATA 0x00BB0176
+#define DDRSS_CTL_202_DATA 0x0E0E01D3
+#define DDRSS_CTL_203_DATA 0x000001D3
+#define DDRSS_CTL_204_DATA 0x00000000
+#define DDRSS_CTL_205_DATA 0x00000000
+#define DDRSS_CTL_206_DATA 0x00000000
+#define DDRSS_CTL_207_DATA 0x00000000
+#define DDRSS_CTL_208_DATA 0x00000004
+#define DDRSS_CTL_209_DATA 0x00000000
+#define DDRSS_CTL_210_DATA 0x00000000
+#define DDRSS_CTL_211_DATA 0x00000064
+#define DDRSS_CTL_212_DATA 0x00000036
+#define DDRSS_CTL_213_DATA 0x00000000
+#define DDRSS_CTL_214_DATA 0x00000064
+#define DDRSS_CTL_215_DATA 0x00000036
+#define DDRSS_CTL_216_DATA 0x00000000
+#define DDRSS_CTL_217_DATA 0x00000004
+#define DDRSS_CTL_218_DATA 0x00000000
+#define DDRSS_CTL_219_DATA 0x00000000
+#define DDRSS_CTL_220_DATA 0x00000064
+#define DDRSS_CTL_221_DATA 0x00000036
+#define DDRSS_CTL_222_DATA 0x00000000
+#define DDRSS_CTL_223_DATA 0x00000064
+#define DDRSS_CTL_224_DATA 0x00000036
+#define DDRSS_CTL_225_DATA 0x00000000
+#define DDRSS_CTL_226_DATA 0x00000000
+#define DDRSS_CTL_227_DATA 0x00000031
+#define DDRSS_CTL_228_DATA 0x000000B1
+#define DDRSS_CTL_229_DATA 0x000000B1
+#define DDRSS_CTL_230_DATA 0x00000031
+#define DDRSS_CTL_231_DATA 0x000000B1
+#define DDRSS_CTL_232_DATA 0x000000B1
+#define DDRSS_CTL_233_DATA 0x00000000
+#define DDRSS_CTL_234_DATA 0x00000000
+#define DDRSS_CTL_235_DATA 0x00000000
+#define DDRSS_CTL_236_DATA 0x00000000
+#define DDRSS_CTL_237_DATA 0x00000000
+#define DDRSS_CTL_238_DATA 0x00000000
+#define DDRSS_CTL_239_DATA 0x00000000
+#define DDRSS_CTL_240_DATA 0x00000000
+#define DDRSS_CTL_241_DATA 0x00000000
+#define DDRSS_CTL_242_DATA 0x00000000
+#define DDRSS_CTL_243_DATA 0x00000000
+#define DDRSS_CTL_244_DATA 0x00000000
+#define DDRSS_CTL_245_DATA 0x00000000
+#define DDRSS_CTL_246_DATA 0x00000000
+#define DDRSS_CTL_247_DATA 0x00000000
+#define DDRSS_CTL_248_DATA 0x00000000
+#define DDRSS_CTL_249_DATA 0x00000000
+#define DDRSS_CTL_250_DATA 0x00000000
+#define DDRSS_CTL_251_DATA 0x00000000
+#define DDRSS_CTL_252_DATA 0x00000000
+#define DDRSS_CTL_253_DATA 0x00000000
+#define DDRSS_CTL_254_DATA 0x00000000
+#define DDRSS_CTL_255_DATA 0x00000000
+#define DDRSS_CTL_256_DATA 0x00000000
+#define DDRSS_CTL_257_DATA 0x55005555
+#define DDRSS_CTL_258_DATA 0x00002755
+#define DDRSS_CTL_259_DATA 0x00000027
+#define DDRSS_CTL_260_DATA 0x00000027
+#define DDRSS_CTL_261_DATA 0x00000027
+#define DDRSS_CTL_262_DATA 0x00000027
+#define DDRSS_CTL_263_DATA 0x00000027
+#define DDRSS_CTL_264_DATA 0x00000000
+#define DDRSS_CTL_265_DATA 0x00000000
+#define DDRSS_CTL_266_DATA 0x0000002B
+#define DDRSS_CTL_267_DATA 0x0000002B
+#define DDRSS_CTL_268_DATA 0x0000002B
+#define DDRSS_CTL_269_DATA 0x0000002B
+#define DDRSS_CTL_270_DATA 0x0000002B
+#define DDRSS_CTL_271_DATA 0x0000002B
+#define DDRSS_CTL_272_DATA 0x00000000
+#define DDRSS_CTL_273_DATA 0x00000000
+#define DDRSS_CTL_274_DATA 0x00000016
+#define DDRSS_CTL_275_DATA 0x00000016
+#define DDRSS_CTL_276_DATA 0x00000000
+#define DDRSS_CTL_277_DATA 0x00000016
+#define DDRSS_CTL_278_DATA 0x00000016
+#define DDRSS_CTL_279_DATA 0x00000020
+#define DDRSS_CTL_280_DATA 0x00010000
+#define DDRSS_CTL_281_DATA 0x00000100
+#define DDRSS_CTL_282_DATA 0x00000000
+#define DDRSS_CTL_283_DATA 0x00000000
+#define DDRSS_CTL_284_DATA 0x00000101
+#define DDRSS_CTL_285_DATA 0x00000000
+#define DDRSS_CTL_286_DATA 0x00000000
+#define DDRSS_CTL_287_DATA 0x00000000
+#define DDRSS_CTL_288_DATA 0x00000000
+#define DDRSS_CTL_289_DATA 0x00000000
+#define DDRSS_CTL_290_DATA 0x00000000
+#define DDRSS_CTL_291_DATA 0x00000000
+#define DDRSS_CTL_292_DATA 0x00000000
+#define DDRSS_CTL_293_DATA 0x00000000
+#define DDRSS_CTL_294_DATA 0x00000000
+#define DDRSS_CTL_295_DATA 0x00000000
+#define DDRSS_CTL_296_DATA 0x0C181511
+#define DDRSS_CTL_297_DATA 0x00000304
+#define DDRSS_CTL_298_DATA 0x00000000
+#define DDRSS_CTL_299_DATA 0x00000000
+#define DDRSS_CTL_300_DATA 0x00000000
+#define DDRSS_CTL_301_DATA 0x00000000
+#define DDRSS_CTL_302_DATA 0x00000000
+#define DDRSS_CTL_303_DATA 0x00000000
+#define DDRSS_CTL_304_DATA 0x00000000
+#define DDRSS_CTL_305_DATA 0x00000000
+#define DDRSS_CTL_306_DATA 0x00000000
+#define DDRSS_CTL_307_DATA 0x00000000
+#define DDRSS_CTL_308_DATA 0x00000000
+#define DDRSS_CTL_309_DATA 0x00000000
+#define DDRSS_CTL_310_DATA 0x00000000
+#define DDRSS_CTL_311_DATA 0x00020000
+#define DDRSS_CTL_312_DATA 0x00400100
+#define DDRSS_CTL_313_DATA 0x00080032
+#define DDRSS_CTL_314_DATA 0x01000200
+#define DDRSS_CTL_315_DATA 0x074A0040
+#define DDRSS_CTL_316_DATA 0x00020038
+#define DDRSS_CTL_317_DATA 0x00400100
+#define DDRSS_CTL_318_DATA 0x0038074A
+#define DDRSS_CTL_319_DATA 0x00030000
+#define DDRSS_CTL_320_DATA 0x005E005E
+#define DDRSS_CTL_321_DATA 0x00000100
+#define DDRSS_CTL_322_DATA 0x01010000
+#define DDRSS_CTL_323_DATA 0x00000202
+#define DDRSS_CTL_324_DATA 0x0FFF0000
+#define DDRSS_CTL_325_DATA 0x000FFF00
+#define DDRSS_CTL_326_DATA 0x1FFF1000
+#define DDRSS_CTL_327_DATA 0x000FFF00
+#define DDRSS_CTL_328_DATA 0x0B000001
+#define DDRSS_CTL_329_DATA 0x0001FFFF
+#define DDRSS_CTL_330_DATA 0x01010101
+#define DDRSS_CTL_331_DATA 0x01010101
+#define DDRSS_CTL_332_DATA 0x00000118
+#define DDRSS_CTL_333_DATA 0x00000C03
+#define DDRSS_CTL_334_DATA 0x00040100
+#define DDRSS_CTL_335_DATA 0x00040100
+#define DDRSS_CTL_336_DATA 0x00000000
+#define DDRSS_CTL_337_DATA 0x00000000
+#define DDRSS_CTL_338_DATA 0x01030303
+#define DDRSS_CTL_339_DATA 0x00000001
+#define DDRSS_CTL_340_DATA 0x00000000
+#define DDRSS_CTL_341_DATA 0x00000000
+#define DDRSS_CTL_342_DATA 0x00000000
+#define DDRSS_CTL_343_DATA 0x00000000
+#define DDRSS_CTL_344_DATA 0x00000000
+#define DDRSS_CTL_345_DATA 0x00000000
+#define DDRSS_CTL_346_DATA 0x00000000
+#define DDRSS_CTL_347_DATA 0x00000000
+#define DDRSS_CTL_348_DATA 0x00000000
+#define DDRSS_CTL_349_DATA 0x00000000
+#define DDRSS_CTL_350_DATA 0x00000000
+#define DDRSS_CTL_351_DATA 0x00000000
+#define DDRSS_CTL_352_DATA 0x00000000
+#define DDRSS_CTL_353_DATA 0x00000000
+#define DDRSS_CTL_354_DATA 0x00000000
+#define DDRSS_CTL_355_DATA 0x00000000
+#define DDRSS_CTL_356_DATA 0x00000000
+#define DDRSS_CTL_357_DATA 0x00000000
+#define DDRSS_CTL_358_DATA 0x00000000
+#define DDRSS_CTL_359_DATA 0x00000000
+#define DDRSS_CTL_360_DATA 0x00000000
+#define DDRSS_CTL_361_DATA 0x00000000
+#define DDRSS_CTL_362_DATA 0x00000000
+#define DDRSS_CTL_363_DATA 0x00000000
+#define DDRSS_CTL_364_DATA 0x00000000
+#define DDRSS_CTL_365_DATA 0x00000000
+#define DDRSS_CTL_366_DATA 0x00000000
+#define DDRSS_CTL_367_DATA 0x00000000
+#define DDRSS_CTL_368_DATA 0x00000000
+#define DDRSS_CTL_369_DATA 0x00000000
+#define DDRSS_CTL_370_DATA 0x00000000
+#define DDRSS_CTL_371_DATA 0x00000000
+#define DDRSS_CTL_372_DATA 0x00000000
+#define DDRSS_CTL_373_DATA 0x00000000
+#define DDRSS_CTL_374_DATA 0x00000000
+#define DDRSS_CTL_375_DATA 0x00000000
+#define DDRSS_CTL_376_DATA 0x00000000
+#define DDRSS_CTL_377_DATA 0x00000000
+#define DDRSS_CTL_378_DATA 0x00000000
+#define DDRSS_CTL_379_DATA 0x00000000
+#define DDRSS_CTL_380_DATA 0x00000000
+#define DDRSS_CTL_381_DATA 0x00000000
+#define DDRSS_CTL_382_DATA 0x00000000
+#define DDRSS_CTL_383_DATA 0x01000101
+#define DDRSS_CTL_384_DATA 0x01010001
+#define DDRSS_CTL_385_DATA 0x00010101
+#define DDRSS_CTL_386_DATA 0x01090903
+#define DDRSS_CTL_387_DATA 0x05020201
+#define DDRSS_CTL_388_DATA 0x0E081B1B
+#define DDRSS_CTL_389_DATA 0x0008030E
+#define DDRSS_CTL_390_DATA 0x0B12030E
+#define DDRSS_CTL_391_DATA 0x0B120314
+#define DDRSS_CTL_392_DATA 0x12120814
+#define DDRSS_CTL_393_DATA 0x01000000
+#define DDRSS_CTL_394_DATA 0x07030701
+#define DDRSS_CTL_395_DATA 0x04000103
+#define DDRSS_CTL_396_DATA 0x1B000004
+#define DDRSS_CTL_397_DATA 0x00000176
+#define DDRSS_CTL_398_DATA 0x00000200
+#define DDRSS_CTL_399_DATA 0x00000200
+#define DDRSS_CTL_400_DATA 0x00000200
+#define DDRSS_CTL_401_DATA 0x00000200
+#define DDRSS_CTL_402_DATA 0x00000693
+#define DDRSS_CTL_403_DATA 0x00000E9C
+#define DDRSS_CTL_404_DATA 0x03050202
+#define DDRSS_CTL_405_DATA 0x37200201
+#define DDRSS_CTL_406_DATA 0x000038C8
+#define DDRSS_CTL_407_DATA 0x00000200
+#define DDRSS_CTL_408_DATA 0x00000200
+#define DDRSS_CTL_409_DATA 0x00000200
+#define DDRSS_CTL_410_DATA 0x00000200
+#define DDRSS_CTL_411_DATA 0x0000FF84
+#define DDRSS_CTL_412_DATA 0x000237D0
+#define DDRSS_CTL_413_DATA 0x111F0402
+#define DDRSS_CTL_414_DATA 0x37200C0D
+#define DDRSS_CTL_415_DATA 0x000038C8
+#define DDRSS_CTL_416_DATA 0x00000200
+#define DDRSS_CTL_417_DATA 0x00000200
+#define DDRSS_CTL_418_DATA 0x00000200
+#define DDRSS_CTL_419_DATA 0x00000200
+#define DDRSS_CTL_420_DATA 0x0000FF84
+#define DDRSS_CTL_421_DATA 0x000237D0
+#define DDRSS_CTL_422_DATA 0x111F0402
+#define DDRSS_CTL_423_DATA 0x00200C0D
+#define DDRSS_CTL_424_DATA 0x00000000
+#define DDRSS_CTL_425_DATA 0x02000A00
+#define DDRSS_CTL_426_DATA 0x00050003
+#define DDRSS_CTL_427_DATA 0x00010101
+#define DDRSS_CTL_428_DATA 0x00010101
+#define DDRSS_CTL_429_DATA 0x00010001
+#define DDRSS_CTL_430_DATA 0x00000101
+#define DDRSS_CTL_431_DATA 0x02000201
+#define DDRSS_CTL_432_DATA 0x02010000
+#define DDRSS_CTL_433_DATA 0x06000200
+#define DDRSS_CTL_434_DATA 0x00002222
+#define DDRSS_PI_0_DATA 0x00000B00
+#define DDRSS_PI_1_DATA 0x00000000
+#define DDRSS_PI_2_DATA 0x00000000
+#define DDRSS_PI_3_DATA 0x01000000
+#define DDRSS_PI_4_DATA 0x00000001
+#define DDRSS_PI_5_DATA 0x00010064
+#define DDRSS_PI_6_DATA 0x00000000
+#define DDRSS_PI_7_DATA 0x00000000
+#define DDRSS_PI_8_DATA 0x00000000
+#define DDRSS_PI_9_DATA 0x00000000
+#define DDRSS_PI_10_DATA 0x00000000
+#define DDRSS_PI_11_DATA 0x00000002
+#define DDRSS_PI_12_DATA 0x00000005
+#define DDRSS_PI_13_DATA 0x000F0001
+#define DDRSS_PI_14_DATA 0x08000000
+#define DDRSS_PI_15_DATA 0x00010300
+#define DDRSS_PI_16_DATA 0x00000005
+#define DDRSS_PI_17_DATA 0x00000000
+#define DDRSS_PI_18_DATA 0x00000000
+#define DDRSS_PI_19_DATA 0x00000000
+#define DDRSS_PI_20_DATA 0x00000000
+#define DDRSS_PI_21_DATA 0x00000000
+#define DDRSS_PI_22_DATA 0x00000000
+#define DDRSS_PI_23_DATA 0x00000000
+#define DDRSS_PI_24_DATA 0x00000000
+#define DDRSS_PI_25_DATA 0x00000000
+#define DDRSS_PI_26_DATA 0x01010000
+#define DDRSS_PI_27_DATA 0x0A000100
+#define DDRSS_PI_28_DATA 0x00000028
+#define DDRSS_PI_29_DATA 0x0F000000
+#define DDRSS_PI_30_DATA 0x00320000
+#define DDRSS_PI_31_DATA 0x00000000
+#define DDRSS_PI_32_DATA 0x00000000
+#define DDRSS_PI_33_DATA 0x01010102
+#define DDRSS_PI_34_DATA 0x00000000
+#define DDRSS_PI_35_DATA 0x00000000
+#define DDRSS_PI_36_DATA 0x00000000
+#define DDRSS_PI_37_DATA 0x00000001
+#define DDRSS_PI_38_DATA 0x000000AA
+#define DDRSS_PI_39_DATA 0x00000055
+#define DDRSS_PI_40_DATA 0x000000B5
+#define DDRSS_PI_41_DATA 0x0000004A
+#define DDRSS_PI_42_DATA 0x00000056
+#define DDRSS_PI_43_DATA 0x000000A9
+#define DDRSS_PI_44_DATA 0x000000A9
+#define DDRSS_PI_45_DATA 0x000000B5
+#define DDRSS_PI_46_DATA 0x00000000
+#define DDRSS_PI_47_DATA 0x00000000
+#define DDRSS_PI_48_DATA 0x000F0F00
+#define DDRSS_PI_49_DATA 0x0000001A
+#define DDRSS_PI_50_DATA 0x000007D0
+#define DDRSS_PI_51_DATA 0x00000300
+#define DDRSS_PI_52_DATA 0x00000000
+#define DDRSS_PI_53_DATA 0x00000000
+#define DDRSS_PI_54_DATA 0x01000000
+#define DDRSS_PI_55_DATA 0x00010101
+#define DDRSS_PI_56_DATA 0x01000000
+#define DDRSS_PI_57_DATA 0x03000000
+#define DDRSS_PI_58_DATA 0x00000000
+#define DDRSS_PI_59_DATA 0x0000170F
+#define DDRSS_PI_60_DATA 0x00000000
+#define DDRSS_PI_61_DATA 0x00000000
+#define DDRSS_PI_62_DATA 0x00000000
+#define DDRSS_PI_63_DATA 0x0A0A140A
+#define DDRSS_PI_64_DATA 0x10020101
+#define DDRSS_PI_65_DATA 0x01000210
+#define DDRSS_PI_66_DATA 0x05000404
+#define DDRSS_PI_67_DATA 0x00010001
+#define DDRSS_PI_68_DATA 0x0001000E
+#define DDRSS_PI_69_DATA 0x01010F00
+#define DDRSS_PI_70_DATA 0x00010000
+#define DDRSS_PI_71_DATA 0x00000034
+#define DDRSS_PI_72_DATA 0x00000000
+#define DDRSS_PI_73_DATA 0x00000000
+#define DDRSS_PI_74_DATA 0x0000FFFF
+#define DDRSS_PI_75_DATA 0x00000000
+#define DDRSS_PI_76_DATA 0x00000000
+#define DDRSS_PI_77_DATA 0x00000000
+#define DDRSS_PI_78_DATA 0x00000000
+#define DDRSS_PI_79_DATA 0x01000000
+#define DDRSS_PI_80_DATA 0x02010001
+#define DDRSS_PI_81_DATA 0x02000008
+#define DDRSS_PI_82_DATA 0x01000200
+#define DDRSS_PI_83_DATA 0x00000100
+#define DDRSS_PI_84_DATA 0x02000100
+#define DDRSS_PI_85_DATA 0x02000200
+#define DDRSS_PI_86_DATA 0x00000000
+#define DDRSS_PI_87_DATA 0x00000000
+#define DDRSS_PI_88_DATA 0x00000000
+#define DDRSS_PI_89_DATA 0x00000000
+#define DDRSS_PI_90_DATA 0x00000000
+#define DDRSS_PI_91_DATA 0x00000000
+#define DDRSS_PI_92_DATA 0x00000000
+#define DDRSS_PI_93_DATA 0x00000000
+#define DDRSS_PI_94_DATA 0x00000000
+#define DDRSS_PI_95_DATA 0x00000000
+#define DDRSS_PI_96_DATA 0x00000000
+#define DDRSS_PI_97_DATA 0x00000000
+#define DDRSS_PI_98_DATA 0x00000000
+#define DDRSS_PI_99_DATA 0x01000400
+#define DDRSS_PI_100_DATA 0x0E0D0F10
+#define DDRSS_PI_101_DATA 0x080A1413
+#define DDRSS_PI_102_DATA 0x01000009
+#define DDRSS_PI_103_DATA 0x00000302
+#define DDRSS_PI_104_DATA 0x00000008
+#define DDRSS_PI_105_DATA 0x08000000
+#define DDRSS_PI_106_DATA 0x00000100
+#define DDRSS_PI_107_DATA 0x00000000
+#define DDRSS_PI_108_DATA 0x0000AA00
+#define DDRSS_PI_109_DATA 0x00000000
+#define DDRSS_PI_110_DATA 0x00000000
+#define DDRSS_PI_111_DATA 0x00010000
+#define DDRSS_PI_112_DATA 0x00000000
+#define DDRSS_PI_113_DATA 0x00000000
+#define DDRSS_PI_114_DATA 0x00000000
+#define DDRSS_PI_115_DATA 0x00000000
+#define DDRSS_PI_116_DATA 0x00000000
+#define DDRSS_PI_117_DATA 0x00000000
+#define DDRSS_PI_118_DATA 0x00000000
+#define DDRSS_PI_119_DATA 0x00000000
+#define DDRSS_PI_120_DATA 0x00000000
+#define DDRSS_PI_121_DATA 0x00000000
+#define DDRSS_PI_122_DATA 0x00000000
+#define DDRSS_PI_123_DATA 0x00000000
+#define DDRSS_PI_124_DATA 0x00000000
+#define DDRSS_PI_125_DATA 0x00000000
+#define DDRSS_PI_126_DATA 0x00000000
+#define DDRSS_PI_127_DATA 0x00000000
+#define DDRSS_PI_128_DATA 0x00000000
+#define DDRSS_PI_129_DATA 0x00000000
+#define DDRSS_PI_130_DATA 0x00000000
+#define DDRSS_PI_131_DATA 0x00000000
+#define DDRSS_PI_132_DATA 0x00000000
+#define DDRSS_PI_133_DATA 0x00000000
+#define DDRSS_PI_134_DATA 0x00000000
+#define DDRSS_PI_135_DATA 0x00000000
+#define DDRSS_PI_136_DATA 0x00000008
+#define DDRSS_PI_137_DATA 0x00000000
+#define DDRSS_PI_138_DATA 0x00000000
+#define DDRSS_PI_139_DATA 0x00000000
+#define DDRSS_PI_140_DATA 0x00000000
+#define DDRSS_PI_141_DATA 0x00000000
+#define DDRSS_PI_142_DATA 0x00000000
+#define DDRSS_PI_143_DATA 0x00000000
+#define DDRSS_PI_144_DATA 0x00000000
+#define DDRSS_PI_145_DATA 0x00010000
+#define DDRSS_PI_146_DATA 0x00000000
+#define DDRSS_PI_147_DATA 0x00000000
+#define DDRSS_PI_148_DATA 0x0000000A
+#define DDRSS_PI_149_DATA 0x000186A0
+#define DDRSS_PI_150_DATA 0x00000100
+#define DDRSS_PI_151_DATA 0x00000000
+#define DDRSS_PI_152_DATA 0x00000000
+#define DDRSS_PI_153_DATA 0x00000000
+#define DDRSS_PI_154_DATA 0x00000000
+#define DDRSS_PI_155_DATA 0x00000000
+#define DDRSS_PI_156_DATA 0x01000000
+#define DDRSS_PI_157_DATA 0x00010003
+#define DDRSS_PI_158_DATA 0x02000101
+#define DDRSS_PI_159_DATA 0x01030001
+#define DDRSS_PI_160_DATA 0x00010400
+#define DDRSS_PI_161_DATA 0x06000105
+#define DDRSS_PI_162_DATA 0x01070001
+#define DDRSS_PI_163_DATA 0x00000000
+#define DDRSS_PI_164_DATA 0x00000000
+#define DDRSS_PI_165_DATA 0x00000000
+#define DDRSS_PI_166_DATA 0x00010001
+#define DDRSS_PI_167_DATA 0x00000000
+#define DDRSS_PI_168_DATA 0x00000000
+#define DDRSS_PI_169_DATA 0x00000000
+#define DDRSS_PI_170_DATA 0x00000000
+#define DDRSS_PI_171_DATA 0x00010000
+#define DDRSS_PI_172_DATA 0x00000004
+#define DDRSS_PI_173_DATA 0x00000000
+#define DDRSS_PI_174_DATA 0x00010000
+#define DDRSS_PI_175_DATA 0x00000000
+#define DDRSS_PI_176_DATA 0x00080000
+#define DDRSS_PI_177_DATA 0x01180118
+#define DDRSS_PI_178_DATA 0x00262601
+#define DDRSS_PI_179_DATA 0x00000034
+#define DDRSS_PI_180_DATA 0x0000005E
+#define DDRSS_PI_181_DATA 0x0002005E
+#define DDRSS_PI_182_DATA 0x02000200
+#define DDRSS_PI_183_DATA 0x00000004
+#define DDRSS_PI_184_DATA 0x0000100C
+#define DDRSS_PI_185_DATA 0x00104000
+#define DDRSS_PI_186_DATA 0x00400000
+#define DDRSS_PI_187_DATA 0x0000000E
+#define DDRSS_PI_188_DATA 0x000000BB
+#define DDRSS_PI_189_DATA 0x0000020B
+#define DDRSS_PI_190_DATA 0x00001C64
+#define DDRSS_PI_191_DATA 0x0000020B
+#define DDRSS_PI_192_DATA 0x04001C64
+#define DDRSS_PI_193_DATA 0x01010404
+#define DDRSS_PI_194_DATA 0x00001501
+#define DDRSS_PI_195_DATA 0x00270027
+#define DDRSS_PI_196_DATA 0x01000100
+#define DDRSS_PI_197_DATA 0x00000100
+#define DDRSS_PI_198_DATA 0x00000000
+#define DDRSS_PI_199_DATA 0x05090903
+#define DDRSS_PI_200_DATA 0x01011B1B
+#define DDRSS_PI_201_DATA 0x01010101
+#define DDRSS_PI_202_DATA 0x000C0C0A
+#define DDRSS_PI_203_DATA 0x00000000
+#define DDRSS_PI_204_DATA 0x00000000
+#define DDRSS_PI_205_DATA 0x04000000
+#define DDRSS_PI_206_DATA 0x0C021212
+#define DDRSS_PI_207_DATA 0x0404020C
+#define DDRSS_PI_208_DATA 0x00090031
+#define DDRSS_PI_209_DATA 0x001B0043
+#define DDRSS_PI_210_DATA 0x001B0043
+#define DDRSS_PI_211_DATA 0x01010101
+#define DDRSS_PI_212_DATA 0x0003000D
+#define DDRSS_PI_213_DATA 0x000301D3
+#define DDRSS_PI_214_DATA 0x010001D3
+#define DDRSS_PI_215_DATA 0x000E000E
+#define DDRSS_PI_216_DATA 0x01D40100
+#define DDRSS_PI_217_DATA 0x010001D4
+#define DDRSS_PI_218_DATA 0x01D401D4
+#define DDRSS_PI_219_DATA 0x32103200
+#define DDRSS_PI_220_DATA 0x01013210
+#define DDRSS_PI_221_DATA 0x0A070601
+#define DDRSS_PI_222_DATA 0x1C11090D
+#define DDRSS_PI_223_DATA 0x1C110913
+#define DDRSS_PI_224_DATA 0x000C0013
+#define DDRSS_PI_225_DATA 0x00001000
+#define DDRSS_PI_226_DATA 0x00000C00
+#define DDRSS_PI_227_DATA 0x00001000
+#define DDRSS_PI_228_DATA 0x00000C00
+#define DDRSS_PI_229_DATA 0x02001000
+#define DDRSS_PI_230_DATA 0x0021000D
+#define DDRSS_PI_231_DATA 0x002101D3
+#define DDRSS_PI_232_DATA 0x000001D3
+#define DDRSS_PI_233_DATA 0x00001900
+#define DDRSS_PI_234_DATA 0x32000056
+#define DDRSS_PI_235_DATA 0x06000101
+#define DDRSS_PI_236_DATA 0x00250204
+#define DDRSS_PI_237_DATA 0x3212005A
+#define DDRSS_PI_238_DATA 0x17000101
+#define DDRSS_PI_239_DATA 0x00250C12
+#define DDRSS_PI_240_DATA 0x3212005A
+#define DDRSS_PI_241_DATA 0x17000101
+#define DDRSS_PI_242_DATA 0x00000C12
+#define DDRSS_PI_243_DATA 0x05030900
+#define DDRSS_PI_244_DATA 0x00040900
+#define DDRSS_PI_245_DATA 0x0000062B
+#define DDRSS_PI_246_DATA 0x20010004
+#define DDRSS_PI_247_DATA 0x0A0A0A03
+#define DDRSS_PI_248_DATA 0x280F0000
+#define DDRSS_PI_249_DATA 0x24090023
+#define DDRSS_PI_250_DATA 0x0000E638
+#define DDRSS_PI_251_DATA 0x20070050
+#define DDRSS_PI_252_DATA 0x1B131B1C
+#define DDRSS_PI_253_DATA 0x280F0000
+#define DDRSS_PI_254_DATA 0x24090023
+#define DDRSS_PI_255_DATA 0x0000E638
+#define DDRSS_PI_256_DATA 0x20070050
+#define DDRSS_PI_257_DATA 0x1B131B1C
+#define DDRSS_PI_258_DATA 0x00000000
+#define DDRSS_PI_259_DATA 0x00000176
+#define DDRSS_PI_260_DATA 0x00000E9C
+#define DDRSS_PI_261_DATA 0x000038C8
+#define DDRSS_PI_262_DATA 0x000237D0
+#define DDRSS_PI_263_DATA 0x000038C8
+#define DDRSS_PI_264_DATA 0x000237D0
+#define DDRSS_PI_265_DATA 0x0219000F
+#define DDRSS_PI_266_DATA 0x03030219
+#define DDRSS_PI_267_DATA 0x00000003
+#define DDRSS_PI_268_DATA 0x00000000
+#define DDRSS_PI_269_DATA 0x0A040503
+#define DDRSS_PI_270_DATA 0x00000A04
+#define DDRSS_PI_271_DATA 0x00002710
+#define DDRSS_PI_272_DATA 0x000186A0
+#define DDRSS_PI_273_DATA 0x00000005
+#define DDRSS_PI_274_DATA 0x00000064
+#define DDRSS_PI_275_DATA 0x0000000F
+#define DDRSS_PI_276_DATA 0x0005B18F
+#define DDRSS_PI_277_DATA 0x000186A0
+#define DDRSS_PI_278_DATA 0x00000005
+#define DDRSS_PI_279_DATA 0x00000E94
+#define DDRSS_PI_280_DATA 0x00000219
+#define DDRSS_PI_281_DATA 0x0005B18F
+#define DDRSS_PI_282_DATA 0x000186A0
+#define DDRSS_PI_283_DATA 0x00000005
+#define DDRSS_PI_284_DATA 0x00000E94
+#define DDRSS_PI_285_DATA 0x01000219
+#define DDRSS_PI_286_DATA 0x00320040
+#define DDRSS_PI_287_DATA 0x00010008
+#define DDRSS_PI_288_DATA 0x074A0040
+#define DDRSS_PI_289_DATA 0x00010038
+#define DDRSS_PI_290_DATA 0x074A0040
+#define DDRSS_PI_291_DATA 0x00000338
+#define DDRSS_PI_292_DATA 0x0028005D
+#define DDRSS_PI_293_DATA 0x03040404
+#define DDRSS_PI_294_DATA 0x00000303
+#define DDRSS_PI_295_DATA 0x01010000
+#define DDRSS_PI_296_DATA 0x04040202
+#define DDRSS_PI_297_DATA 0x67670808
+#define DDRSS_PI_298_DATA 0x67676767
+#define DDRSS_PI_299_DATA 0x67676767
+#define DDRSS_PI_300_DATA 0x67676767
+#define DDRSS_PI_301_DATA 0x00006767
+#define DDRSS_PI_302_DATA 0x00000000
+#define DDRSS_PI_303_DATA 0x00000000
+#define DDRSS_PI_304_DATA 0x00000000
+#define DDRSS_PI_305_DATA 0x00000000
+#define DDRSS_PI_306_DATA 0x55000000
+#define DDRSS_PI_307_DATA 0x00000000
+#define DDRSS_PI_308_DATA 0x3C00005A
+#define DDRSS_PI_309_DATA 0x00005500
+#define DDRSS_PI_310_DATA 0x00005A00
+#define DDRSS_PI_311_DATA 0x0055003C
+#define DDRSS_PI_312_DATA 0x00000000
+#define DDRSS_PI_313_DATA 0x3C00005A
+#define DDRSS_PI_314_DATA 0x00005500
+#define DDRSS_PI_315_DATA 0x00005A00
+#define DDRSS_PI_316_DATA 0x1716153C
+#define DDRSS_PI_317_DATA 0x13121118
+#define DDRSS_PI_318_DATA 0x06050414
+#define DDRSS_PI_319_DATA 0x02010007
+#define DDRSS_PI_320_DATA 0x00000003
+#define DDRSS_PI_321_DATA 0x00000000
+#define DDRSS_PI_322_DATA 0x00000000
+#define DDRSS_PI_323_DATA 0x01000000
+#define DDRSS_PI_324_DATA 0x04020201
+#define DDRSS_PI_325_DATA 0x00080804
+#define DDRSS_PI_326_DATA 0x00000000
+#define DDRSS_PI_327_DATA 0x00000000
+#define DDRSS_PI_328_DATA 0x00000000
+#define DDRSS_PI_329_DATA 0x00000004
+#define DDRSS_PI_330_DATA 0x00000000
+#define DDRSS_PI_331_DATA 0x00000031
+#define DDRSS_PI_332_DATA 0x00000000
+#define DDRSS_PI_333_DATA 0x00000000
+#define DDRSS_PI_334_DATA 0x00000000
+#define DDRSS_PI_335_DATA 0x20002B27
+#define DDRSS_PI_336_DATA 0x00000000
+#define DDRSS_PI_337_DATA 0x00000064
+#define DDRSS_PI_338_DATA 0x00000036
+#define DDRSS_PI_339_DATA 0x000000B1
+#define DDRSS_PI_340_DATA 0x00000000
+#define DDRSS_PI_341_DATA 0x00000000
+#define DDRSS_PI_342_DATA 0x55000000
+#define DDRSS_PI_343_DATA 0x20162B27
+#define DDRSS_PI_344_DATA 0x00000000
+#define DDRSS_PI_345_DATA 0x00000064
+#define DDRSS_PI_346_DATA 0x00000036
+#define DDRSS_PI_347_DATA 0x000000B1
+#define DDRSS_PI_348_DATA 0x00000000
+#define DDRSS_PI_349_DATA 0x00000000
+#define DDRSS_PI_350_DATA 0x55000000
+#define DDRSS_PI_351_DATA 0x20162B27
+#define DDRSS_PI_352_DATA 0x00000000
+#define DDRSS_PI_353_DATA 0x00000004
+#define DDRSS_PI_354_DATA 0x00000000
+#define DDRSS_PI_355_DATA 0x00000031
+#define DDRSS_PI_356_DATA 0x00000000
+#define DDRSS_PI_357_DATA 0x00000000
+#define DDRSS_PI_358_DATA 0x00000000
+#define DDRSS_PI_359_DATA 0x20002B27
+#define DDRSS_PI_360_DATA 0x00000000
+#define DDRSS_PI_361_DATA 0x00000064
+#define DDRSS_PI_362_DATA 0x00000036
+#define DDRSS_PI_363_DATA 0x000000B1
+#define DDRSS_PI_364_DATA 0x00000000
+#define DDRSS_PI_365_DATA 0x00000000
+#define DDRSS_PI_366_DATA 0x55000000
+#define DDRSS_PI_367_DATA 0x20162B27
+#define DDRSS_PI_368_DATA 0x00000000
+#define DDRSS_PI_369_DATA 0x00000064
+#define DDRSS_PI_370_DATA 0x00000036
+#define DDRSS_PI_371_DATA 0x000000B1
+#define DDRSS_PI_372_DATA 0x00000000
+#define DDRSS_PI_373_DATA 0x00000000
+#define DDRSS_PI_374_DATA 0x55000000
+#define DDRSS_PI_375_DATA 0x20162B27
+#define DDRSS_PI_376_DATA 0x00000000
+#define DDRSS_PI_377_DATA 0x00000004
+#define DDRSS_PI_378_DATA 0x00000000
+#define DDRSS_PI_379_DATA 0x00000031
+#define DDRSS_PI_380_DATA 0x00000000
+#define DDRSS_PI_381_DATA 0x00000000
+#define DDRSS_PI_382_DATA 0x00000000
+#define DDRSS_PI_383_DATA 0x20002B27
+#define DDRSS_PI_384_DATA 0x00000000
+#define DDRSS_PI_385_DATA 0x00000064
+#define DDRSS_PI_386_DATA 0x00000036
+#define DDRSS_PI_387_DATA 0x000000B1
+#define DDRSS_PI_388_DATA 0x00000000
+#define DDRSS_PI_389_DATA 0x00000000
+#define DDRSS_PI_390_DATA 0x55000000
+#define DDRSS_PI_391_DATA 0x20162B27
+#define DDRSS_PI_392_DATA 0x00000000
+#define DDRSS_PI_393_DATA 0x00000064
+#define DDRSS_PI_394_DATA 0x00000036
+#define DDRSS_PI_395_DATA 0x000000B1
+#define DDRSS_PI_396_DATA 0x00000000
+#define DDRSS_PI_397_DATA 0x00000000
+#define DDRSS_PI_398_DATA 0x55000000
+#define DDRSS_PI_399_DATA 0x20162B27
+#define DDRSS_PI_400_DATA 0x00000000
+#define DDRSS_PI_401_DATA 0x00000004
+#define DDRSS_PI_402_DATA 0x00000000
+#define DDRSS_PI_403_DATA 0x00000031
+#define DDRSS_PI_404_DATA 0x00000000
+#define DDRSS_PI_405_DATA 0x00000000
+#define DDRSS_PI_406_DATA 0x00000000
+#define DDRSS_PI_407_DATA 0x20002B27
+#define DDRSS_PI_408_DATA 0x00000000
+#define DDRSS_PI_409_DATA 0x00000064
+#define DDRSS_PI_410_DATA 0x00000036
+#define DDRSS_PI_411_DATA 0x000000B1
+#define DDRSS_PI_412_DATA 0x00000000
+#define DDRSS_PI_413_DATA 0x00000000
+#define DDRSS_PI_414_DATA 0x55000000
+#define DDRSS_PI_415_DATA 0x20162B27
+#define DDRSS_PI_416_DATA 0x00000000
+#define DDRSS_PI_417_DATA 0x00000064
+#define DDRSS_PI_418_DATA 0x00000036
+#define DDRSS_PI_419_DATA 0x000000B1
+#define DDRSS_PI_420_DATA 0x00000000
+#define DDRSS_PI_421_DATA 0x00000000
+#define DDRSS_PI_422_DATA 0x55000000
+#define DDRSS_PI_423_DATA 0x20162B27
+#define DDRSS_PHY_0_DATA 0x04F00000
+#define DDRSS_PHY_1_DATA 0x00000000
+#define DDRSS_PHY_2_DATA 0x00030200
+#define DDRSS_PHY_3_DATA 0x00000000
+#define DDRSS_PHY_4_DATA 0x00000000
+#define DDRSS_PHY_5_DATA 0x01030000
+#define DDRSS_PHY_6_DATA 0x00010000
+#define DDRSS_PHY_7_DATA 0x01030004
+#define DDRSS_PHY_8_DATA 0x01000000
+#define DDRSS_PHY_9_DATA 0x00000000
+#define DDRSS_PHY_10_DATA 0x00000000
+#define DDRSS_PHY_11_DATA 0x00000000
+#define DDRSS_PHY_12_DATA 0x01010000
+#define DDRSS_PHY_13_DATA 0x00010000
+#define DDRSS_PHY_14_DATA 0x00C00001
+#define DDRSS_PHY_15_DATA 0x00CC0008
+#define DDRSS_PHY_16_DATA 0x00660601
+#define DDRSS_PHY_17_DATA 0x00000003
+#define DDRSS_PHY_18_DATA 0x00000000
+#define DDRSS_PHY_19_DATA 0x00000001
+#define DDRSS_PHY_20_DATA 0x0000AAAA
+#define DDRSS_PHY_21_DATA 0x00005555
+#define DDRSS_PHY_22_DATA 0x0000B5B5
+#define DDRSS_PHY_23_DATA 0x00004A4A
+#define DDRSS_PHY_24_DATA 0x00005656
+#define DDRSS_PHY_25_DATA 0x0000A9A9
+#define DDRSS_PHY_26_DATA 0x0000B7B7
+#define DDRSS_PHY_27_DATA 0x00004848
+#define DDRSS_PHY_28_DATA 0x00000000
+#define DDRSS_PHY_29_DATA 0x00000000
+#define DDRSS_PHY_30_DATA 0x08000000
+#define DDRSS_PHY_31_DATA 0x0F000008
+#define DDRSS_PHY_32_DATA 0x00000F0F
+#define DDRSS_PHY_33_DATA 0x00E4E400
+#define DDRSS_PHY_34_DATA 0x00071020
+#define DDRSS_PHY_35_DATA 0x000C0020
+#define DDRSS_PHY_36_DATA 0x00062000
+#define DDRSS_PHY_37_DATA 0x00000000
+#define DDRSS_PHY_38_DATA 0x55555555
+#define DDRSS_PHY_39_DATA 0xAAAAAAAA
+#define DDRSS_PHY_40_DATA 0x55555555
+#define DDRSS_PHY_41_DATA 0xAAAAAAAA
+#define DDRSS_PHY_42_DATA 0x00005555
+#define DDRSS_PHY_43_DATA 0x01000100
+#define DDRSS_PHY_44_DATA 0x00800180
+#define DDRSS_PHY_45_DATA 0x00000001
+#define DDRSS_PHY_46_DATA 0x00000000
+#define DDRSS_PHY_47_DATA 0x00000000
+#define DDRSS_PHY_48_DATA 0x00000000
+#define DDRSS_PHY_49_DATA 0x00000000
+#define DDRSS_PHY_50_DATA 0x00000000
+#define DDRSS_PHY_51_DATA 0x00000000
+#define DDRSS_PHY_52_DATA 0x00000000
+#define DDRSS_PHY_53_DATA 0x00000000
+#define DDRSS_PHY_54_DATA 0x00000000
+#define DDRSS_PHY_55_DATA 0x00000000
+#define DDRSS_PHY_56_DATA 0x00000000
+#define DDRSS_PHY_57_DATA 0x00000000
+#define DDRSS_PHY_58_DATA 0x00000000
+#define DDRSS_PHY_59_DATA 0x00000000
+#define DDRSS_PHY_60_DATA 0x00000000
+#define DDRSS_PHY_61_DATA 0x00000000
+#define DDRSS_PHY_62_DATA 0x00000000
+#define DDRSS_PHY_63_DATA 0x00000000
+#define DDRSS_PHY_64_DATA 0x00000000
+#define DDRSS_PHY_65_DATA 0x00000000
+#define DDRSS_PHY_66_DATA 0x00000000
+#define DDRSS_PHY_67_DATA 0x00000004
+#define DDRSS_PHY_68_DATA 0x00000000
+#define DDRSS_PHY_69_DATA 0x00000000
+#define DDRSS_PHY_70_DATA 0x00000000
+#define DDRSS_PHY_71_DATA 0x00000000
+#define DDRSS_PHY_72_DATA 0x00000000
+#define DDRSS_PHY_73_DATA 0x00000000
+#define DDRSS_PHY_74_DATA 0x081F07FF
+#define DDRSS_PHY_75_DATA 0x10200080
+#define DDRSS_PHY_76_DATA 0x00000008
+#define DDRSS_PHY_77_DATA 0x00000401
+#define DDRSS_PHY_78_DATA 0x00000000
+#define DDRSS_PHY_79_DATA 0x01CC0C01
+#define DDRSS_PHY_80_DATA 0x1003CC0C
+#define DDRSS_PHY_81_DATA 0x20000140
+#define DDRSS_PHY_82_DATA 0x07FF0200
+#define DDRSS_PHY_83_DATA 0x0000DD01
+#define DDRSS_PHY_84_DATA 0x00100303
+#define DDRSS_PHY_85_DATA 0x00000000
+#define DDRSS_PHY_86_DATA 0x00000000
+#define DDRSS_PHY_87_DATA 0x00041000
+#define DDRSS_PHY_88_DATA 0x00100010
+#define DDRSS_PHY_89_DATA 0x00100010
+#define DDRSS_PHY_90_DATA 0x00100010
+#define DDRSS_PHY_91_DATA 0x00100010
+#define DDRSS_PHY_92_DATA 0x02040010
+#define DDRSS_PHY_93_DATA 0x00000005
+#define DDRSS_PHY_94_DATA 0x51516042
+#define DDRSS_PHY_95_DATA 0x31C06000
+#define DDRSS_PHY_96_DATA 0x07AB0340
+#define DDRSS_PHY_97_DATA 0x00C0C001
+#define DDRSS_PHY_98_DATA 0x0D000000
+#define DDRSS_PHY_99_DATA 0x000D0C0C
+#define DDRSS_PHY_100_DATA 0x42100010
+#define DDRSS_PHY_101_DATA 0x010C073E
+#define DDRSS_PHY_102_DATA 0x000F0C32
+#define DDRSS_PHY_103_DATA 0x01000140
+#define DDRSS_PHY_104_DATA 0x011E0120
+#define DDRSS_PHY_105_DATA 0x00000C00
+#define DDRSS_PHY_106_DATA 0x000002DD
+#define DDRSS_PHY_107_DATA 0x00030200
+#define DDRSS_PHY_108_DATA 0x02800000
+#define DDRSS_PHY_109_DATA 0x80800000
+#define DDRSS_PHY_110_DATA 0x000D2010
+#define DDRSS_PHY_111_DATA 0x76543210
+#define DDRSS_PHY_112_DATA 0x00000008
+#define DDRSS_PHY_113_DATA 0x045D045D
+#define DDRSS_PHY_114_DATA 0x045D045D
+#define DDRSS_PHY_115_DATA 0x045D045D
+#define DDRSS_PHY_116_DATA 0x045D045D
+#define DDRSS_PHY_117_DATA 0x0000045D
+#define DDRSS_PHY_118_DATA 0x0000A000
+#define DDRSS_PHY_119_DATA 0x00A000A0
+#define DDRSS_PHY_120_DATA 0x00A000A0
+#define DDRSS_PHY_121_DATA 0x00A000A0
+#define DDRSS_PHY_122_DATA 0x00A000A0
+#define DDRSS_PHY_123_DATA 0x00A000A0
+#define DDRSS_PHY_124_DATA 0x00A000A0
+#define DDRSS_PHY_125_DATA 0x00A000A0
+#define DDRSS_PHY_126_DATA 0x00A000A0
+#define DDRSS_PHY_127_DATA 0x00B200A0
+#define DDRSS_PHY_128_DATA 0x01000000
+#define DDRSS_PHY_129_DATA 0x00000000
+#define DDRSS_PHY_130_DATA 0x00000000
+#define DDRSS_PHY_131_DATA 0x00080200
+#define DDRSS_PHY_132_DATA 0x00000000
+#define DDRSS_PHY_133_DATA 0x20202020
+#define DDRSS_PHY_134_DATA 0x20202020
+#define DDRSS_PHY_135_DATA 0xF0F02020
+#define DDRSS_PHY_136_DATA 0x00000000
+#define DDRSS_PHY_137_DATA 0x00000000
+#define DDRSS_PHY_138_DATA 0x00000000
+#define DDRSS_PHY_139_DATA 0x00000000
+#define DDRSS_PHY_140_DATA 0x00000000
+#define DDRSS_PHY_141_DATA 0x00000000
+#define DDRSS_PHY_142_DATA 0x00000000
+#define DDRSS_PHY_143_DATA 0x00000000
+#define DDRSS_PHY_144_DATA 0x00000000
+#define DDRSS_PHY_145_DATA 0x00000000
+#define DDRSS_PHY_146_DATA 0x00000000
+#define DDRSS_PHY_147_DATA 0x00000000
+#define DDRSS_PHY_148_DATA 0x00000000
+#define DDRSS_PHY_149_DATA 0x00000000
+#define DDRSS_PHY_150_DATA 0x00000000
+#define DDRSS_PHY_151_DATA 0x00000000
+#define DDRSS_PHY_152_DATA 0x00000000
+#define DDRSS_PHY_153_DATA 0x00000000
+#define DDRSS_PHY_154_DATA 0x00000000
+#define DDRSS_PHY_155_DATA 0x00000000
+#define DDRSS_PHY_156_DATA 0x00000000
+#define DDRSS_PHY_157_DATA 0x00000000
+#define DDRSS_PHY_158_DATA 0x00000000
+#define DDRSS_PHY_159_DATA 0x00000000
+#define DDRSS_PHY_160_DATA 0x00000000
+#define DDRSS_PHY_161_DATA 0x00000000
+#define DDRSS_PHY_162_DATA 0x00000000
+#define DDRSS_PHY_163_DATA 0x00000000
+#define DDRSS_PHY_164_DATA 0x00000000
+#define DDRSS_PHY_165_DATA 0x00000000
+#define DDRSS_PHY_166_DATA 0x00000000
+#define DDRSS_PHY_167_DATA 0x00000000
+#define DDRSS_PHY_168_DATA 0x00000000
+#define DDRSS_PHY_169_DATA 0x00000000
+#define DDRSS_PHY_170_DATA 0x00000000
+#define DDRSS_PHY_171_DATA 0x00000000
+#define DDRSS_PHY_172_DATA 0x00000000
+#define DDRSS_PHY_173_DATA 0x00000000
+#define DDRSS_PHY_174_DATA 0x00000000
+#define DDRSS_PHY_175_DATA 0x00000000
+#define DDRSS_PHY_176_DATA 0x00000000
+#define DDRSS_PHY_177_DATA 0x00000000
+#define DDRSS_PHY_178_DATA 0x00000000
+#define DDRSS_PHY_179_DATA 0x00000000
+#define DDRSS_PHY_180_DATA 0x00000000
+#define DDRSS_PHY_181_DATA 0x00000000
+#define DDRSS_PHY_182_DATA 0x00000000
+#define DDRSS_PHY_183_DATA 0x00000000
+#define DDRSS_PHY_184_DATA 0x00000000
+#define DDRSS_PHY_185_DATA 0x00000000
+#define DDRSS_PHY_186_DATA 0x00000000
+#define DDRSS_PHY_187_DATA 0x00000000
+#define DDRSS_PHY_188_DATA 0x00000000
+#define DDRSS_PHY_189_DATA 0x00000000
+#define DDRSS_PHY_190_DATA 0x00000000
+#define DDRSS_PHY_191_DATA 0x00000000
+#define DDRSS_PHY_192_DATA 0x00000000
+#define DDRSS_PHY_193_DATA 0x00000000
+#define DDRSS_PHY_194_DATA 0x00000000
+#define DDRSS_PHY_195_DATA 0x00000000
+#define DDRSS_PHY_196_DATA 0x00000000
+#define DDRSS_PHY_197_DATA 0x00000000
+#define DDRSS_PHY_198_DATA 0x00000000
+#define DDRSS_PHY_199_DATA 0x00000000
+#define DDRSS_PHY_200_DATA 0x00000000
+#define DDRSS_PHY_201_DATA 0x00000000
+#define DDRSS_PHY_202_DATA 0x00000000
+#define DDRSS_PHY_203_DATA 0x00000000
+#define DDRSS_PHY_204_DATA 0x00000000
+#define DDRSS_PHY_205_DATA 0x00000000
+#define DDRSS_PHY_206_DATA 0x00000000
+#define DDRSS_PHY_207_DATA 0x00000000
+#define DDRSS_PHY_208_DATA 0x00000000
+#define DDRSS_PHY_209_DATA 0x00000000
+#define DDRSS_PHY_210_DATA 0x00000000
+#define DDRSS_PHY_211_DATA 0x00000000
+#define DDRSS_PHY_212_DATA 0x00000000
+#define DDRSS_PHY_213_DATA 0x00000000
+#define DDRSS_PHY_214_DATA 0x00000000
+#define DDRSS_PHY_215_DATA 0x00000000
+#define DDRSS_PHY_216_DATA 0x00000000
+#define DDRSS_PHY_217_DATA 0x00000000
+#define DDRSS_PHY_218_DATA 0x00000000
+#define DDRSS_PHY_219_DATA 0x00000000
+#define DDRSS_PHY_220_DATA 0x00000000
+#define DDRSS_PHY_221_DATA 0x00000000
+#define DDRSS_PHY_222_DATA 0x00000000
+#define DDRSS_PHY_223_DATA 0x00000000
+#define DDRSS_PHY_224_DATA 0x00000000
+#define DDRSS_PHY_225_DATA 0x00000000
+#define DDRSS_PHY_226_DATA 0x00000000
+#define DDRSS_PHY_227_DATA 0x00000000
+#define DDRSS_PHY_228_DATA 0x00000000
+#define DDRSS_PHY_229_DATA 0x00000000
+#define DDRSS_PHY_230_DATA 0x00000000
+#define DDRSS_PHY_231_DATA 0x00000000
+#define DDRSS_PHY_232_DATA 0x00000000
+#define DDRSS_PHY_233_DATA 0x00000000
+#define DDRSS_PHY_234_DATA 0x00000000
+#define DDRSS_PHY_235_DATA 0x00000000
+#define DDRSS_PHY_236_DATA 0x00000000
+#define DDRSS_PHY_237_DATA 0x00000000
+#define DDRSS_PHY_238_DATA 0x00000000
+#define DDRSS_PHY_239_DATA 0x00000000
+#define DDRSS_PHY_240_DATA 0x00000000
+#define DDRSS_PHY_241_DATA 0x00000000
+#define DDRSS_PHY_242_DATA 0x00000000
+#define DDRSS_PHY_243_DATA 0x00000000
+#define DDRSS_PHY_244_DATA 0x00000000
+#define DDRSS_PHY_245_DATA 0x00000000
+#define DDRSS_PHY_246_DATA 0x00000000
+#define DDRSS_PHY_247_DATA 0x00000000
+#define DDRSS_PHY_248_DATA 0x00000000
+#define DDRSS_PHY_249_DATA 0x00000000
+#define DDRSS_PHY_250_DATA 0x00000000
+#define DDRSS_PHY_251_DATA 0x00000000
+#define DDRSS_PHY_252_DATA 0x00000000
+#define DDRSS_PHY_253_DATA 0x00000000
+#define DDRSS_PHY_254_DATA 0x00000000
+#define DDRSS_PHY_255_DATA 0x00000000
+#define DDRSS_PHY_256_DATA 0x04F00000
+#define DDRSS_PHY_257_DATA 0x00000000
+#define DDRSS_PHY_258_DATA 0x00030200
+#define DDRSS_PHY_259_DATA 0x00000000
+#define DDRSS_PHY_260_DATA 0x00000000
+#define DDRSS_PHY_261_DATA 0x01030000
+#define DDRSS_PHY_262_DATA 0x00010000
+#define DDRSS_PHY_263_DATA 0x01030004
+#define DDRSS_PHY_264_DATA 0x01000000
+#define DDRSS_PHY_265_DATA 0x00000000
+#define DDRSS_PHY_266_DATA 0x00000000
+#define DDRSS_PHY_267_DATA 0x00000000
+#define DDRSS_PHY_268_DATA 0x01010000
+#define DDRSS_PHY_269_DATA 0x00010000
+#define DDRSS_PHY_270_DATA 0x00C00001
+#define DDRSS_PHY_271_DATA 0x00CC0008
+#define DDRSS_PHY_272_DATA 0x00660601
+#define DDRSS_PHY_273_DATA 0x00000003
+#define DDRSS_PHY_274_DATA 0x00000000
+#define DDRSS_PHY_275_DATA 0x00000001
+#define DDRSS_PHY_276_DATA 0x0000AAAA
+#define DDRSS_PHY_277_DATA 0x00005555
+#define DDRSS_PHY_278_DATA 0x0000B5B5
+#define DDRSS_PHY_279_DATA 0x00004A4A
+#define DDRSS_PHY_280_DATA 0x00005656
+#define DDRSS_PHY_281_DATA 0x0000A9A9
+#define DDRSS_PHY_282_DATA 0x0000B7B7
+#define DDRSS_PHY_283_DATA 0x00004848
+#define DDRSS_PHY_284_DATA 0x00000000
+#define DDRSS_PHY_285_DATA 0x00000000
+#define DDRSS_PHY_286_DATA 0x08000000
+#define DDRSS_PHY_287_DATA 0x0F000008
+#define DDRSS_PHY_288_DATA 0x00000F0F
+#define DDRSS_PHY_289_DATA 0x00E4E400
+#define DDRSS_PHY_290_DATA 0x00071020
+#define DDRSS_PHY_291_DATA 0x000C0020
+#define DDRSS_PHY_292_DATA 0x00062000
+#define DDRSS_PHY_293_DATA 0x00000000
+#define DDRSS_PHY_294_DATA 0x55555555
+#define DDRSS_PHY_295_DATA 0xAAAAAAAA
+#define DDRSS_PHY_296_DATA 0x55555555
+#define DDRSS_PHY_297_DATA 0xAAAAAAAA
+#define DDRSS_PHY_298_DATA 0x00005555
+#define DDRSS_PHY_299_DATA 0x01000100
+#define DDRSS_PHY_300_DATA 0x00800180
+#define DDRSS_PHY_301_DATA 0x00000000
+#define DDRSS_PHY_302_DATA 0x00000000
+#define DDRSS_PHY_303_DATA 0x00000000
+#define DDRSS_PHY_304_DATA 0x00000000
+#define DDRSS_PHY_305_DATA 0x00000000
+#define DDRSS_PHY_306_DATA 0x00000000
+#define DDRSS_PHY_307_DATA 0x00000000
+#define DDRSS_PHY_308_DATA 0x00000000
+#define DDRSS_PHY_309_DATA 0x00000000
+#define DDRSS_PHY_310_DATA 0x00000000
+#define DDRSS_PHY_311_DATA 0x00000000
+#define DDRSS_PHY_312_DATA 0x00000000
+#define DDRSS_PHY_313_DATA 0x00000000
+#define DDRSS_PHY_314_DATA 0x00000000
+#define DDRSS_PHY_315_DATA 0x00000000
+#define DDRSS_PHY_316_DATA 0x00000000
+#define DDRSS_PHY_317_DATA 0x00000000
+#define DDRSS_PHY_318_DATA 0x00000000
+#define DDRSS_PHY_319_DATA 0x00000000
+#define DDRSS_PHY_320_DATA 0x00000000
+#define DDRSS_PHY_321_DATA 0x00000000
+#define DDRSS_PHY_322_DATA 0x00000000
+#define DDRSS_PHY_323_DATA 0x00000004
+#define DDRSS_PHY_324_DATA 0x00000000
+#define DDRSS_PHY_325_DATA 0x00000000
+#define DDRSS_PHY_326_DATA 0x00000000
+#define DDRSS_PHY_327_DATA 0x00000000
+#define DDRSS_PHY_328_DATA 0x00000000
+#define DDRSS_PHY_329_DATA 0x00000000
+#define DDRSS_PHY_330_DATA 0x081F07FF
+#define DDRSS_PHY_331_DATA 0x10200080
+#define DDRSS_PHY_332_DATA 0x00000008
+#define DDRSS_PHY_333_DATA 0x00000401
+#define DDRSS_PHY_334_DATA 0x00000000
+#define DDRSS_PHY_335_DATA 0x01CC0C01
+#define DDRSS_PHY_336_DATA 0x1003CC0C
+#define DDRSS_PHY_337_DATA 0x20000140
+#define DDRSS_PHY_338_DATA 0x07FF0200
+#define DDRSS_PHY_339_DATA 0x0000DD01
+#define DDRSS_PHY_340_DATA 0x00100303
+#define DDRSS_PHY_341_DATA 0x00000000
+#define DDRSS_PHY_342_DATA 0x00000000
+#define DDRSS_PHY_343_DATA 0x00041000
+#define DDRSS_PHY_344_DATA 0x00100010
+#define DDRSS_PHY_345_DATA 0x00100010
+#define DDRSS_PHY_346_DATA 0x00100010
+#define DDRSS_PHY_347_DATA 0x00100010
+#define DDRSS_PHY_348_DATA 0x02040010
+#define DDRSS_PHY_349_DATA 0x00000005
+#define DDRSS_PHY_350_DATA 0x51516042
+#define DDRSS_PHY_351_DATA 0x31C06000
+#define DDRSS_PHY_352_DATA 0x07AB0340
+#define DDRSS_PHY_353_DATA 0x00C0C001
+#define DDRSS_PHY_354_DATA 0x0D000000
+#define DDRSS_PHY_355_DATA 0x000D0C0C
+#define DDRSS_PHY_356_DATA 0x42100010
+#define DDRSS_PHY_357_DATA 0x010C073E
+#define DDRSS_PHY_358_DATA 0x000F0C32
+#define DDRSS_PHY_359_DATA 0x01000140
+#define DDRSS_PHY_360_DATA 0x011E0120
+#define DDRSS_PHY_361_DATA 0x00000C00
+#define DDRSS_PHY_362_DATA 0x000002DD
+#define DDRSS_PHY_363_DATA 0x00030200
+#define DDRSS_PHY_364_DATA 0x02800000
+#define DDRSS_PHY_365_DATA 0x80800000
+#define DDRSS_PHY_366_DATA 0x000D2010
+#define DDRSS_PHY_367_DATA 0x76543210
+#define DDRSS_PHY_368_DATA 0x00000008
+#define DDRSS_PHY_369_DATA 0x045D045D
+#define DDRSS_PHY_370_DATA 0x045D045D
+#define DDRSS_PHY_371_DATA 0x045D045D
+#define DDRSS_PHY_372_DATA 0x045D045D
+#define DDRSS_PHY_373_DATA 0x0000045D
+#define DDRSS_PHY_374_DATA 0x0000A000
+#define DDRSS_PHY_375_DATA 0x00A000A0
+#define DDRSS_PHY_376_DATA 0x00A000A0
+#define DDRSS_PHY_377_DATA 0x00A000A0
+#define DDRSS_PHY_378_DATA 0x00A000A0
+#define DDRSS_PHY_379_DATA 0x00A000A0
+#define DDRSS_PHY_380_DATA 0x00A000A0
+#define DDRSS_PHY_381_DATA 0x00A000A0
+#define DDRSS_PHY_382_DATA 0x00A000A0
+#define DDRSS_PHY_383_DATA 0x00B200A0
+#define DDRSS_PHY_384_DATA 0x01000000
+#define DDRSS_PHY_385_DATA 0x00000000
+#define DDRSS_PHY_386_DATA 0x00000000
+#define DDRSS_PHY_387_DATA 0x00080200
+#define DDRSS_PHY_388_DATA 0x00000000
+#define DDRSS_PHY_389_DATA 0x20202020
+#define DDRSS_PHY_390_DATA 0x20202020
+#define DDRSS_PHY_391_DATA 0xF0F02020
+#define DDRSS_PHY_392_DATA 0x00000000
+#define DDRSS_PHY_393_DATA 0x00000000
+#define DDRSS_PHY_394_DATA 0x00000000
+#define DDRSS_PHY_395_DATA 0x00000000
+#define DDRSS_PHY_396_DATA 0x00000000
+#define DDRSS_PHY_397_DATA 0x00000000
+#define DDRSS_PHY_398_DATA 0x00000000
+#define DDRSS_PHY_399_DATA 0x00000000
+#define DDRSS_PHY_400_DATA 0x00000000
+#define DDRSS_PHY_401_DATA 0x00000000
+#define DDRSS_PHY_402_DATA 0x00000000
+#define DDRSS_PHY_403_DATA 0x00000000
+#define DDRSS_PHY_404_DATA 0x00000000
+#define DDRSS_PHY_405_DATA 0x00000000
+#define DDRSS_PHY_406_DATA 0x00000000
+#define DDRSS_PHY_407_DATA 0x00000000
+#define DDRSS_PHY_408_DATA 0x00000000
+#define DDRSS_PHY_409_DATA 0x00000000
+#define DDRSS_PHY_410_DATA 0x00000000
+#define DDRSS_PHY_411_DATA 0x00000000
+#define DDRSS_PHY_412_DATA 0x00000000
+#define DDRSS_PHY_413_DATA 0x00000000
+#define DDRSS_PHY_414_DATA 0x00000000
+#define DDRSS_PHY_415_DATA 0x00000000
+#define DDRSS_PHY_416_DATA 0x00000000
+#define DDRSS_PHY_417_DATA 0x00000000
+#define DDRSS_PHY_418_DATA 0x00000000
+#define DDRSS_PHY_419_DATA 0x00000000
+#define DDRSS_PHY_420_DATA 0x00000000
+#define DDRSS_PHY_421_DATA 0x00000000
+#define DDRSS_PHY_422_DATA 0x00000000
+#define DDRSS_PHY_423_DATA 0x00000000
+#define DDRSS_PHY_424_DATA 0x00000000
+#define DDRSS_PHY_425_DATA 0x00000000
+#define DDRSS_PHY_426_DATA 0x00000000
+#define DDRSS_PHY_427_DATA 0x00000000
+#define DDRSS_PHY_428_DATA 0x00000000
+#define DDRSS_PHY_429_DATA 0x00000000
+#define DDRSS_PHY_430_DATA 0x00000000
+#define DDRSS_PHY_431_DATA 0x00000000
+#define DDRSS_PHY_432_DATA 0x00000000
+#define DDRSS_PHY_433_DATA 0x00000000
+#define DDRSS_PHY_434_DATA 0x00000000
+#define DDRSS_PHY_435_DATA 0x00000000
+#define DDRSS_PHY_436_DATA 0x00000000
+#define DDRSS_PHY_437_DATA 0x00000000
+#define DDRSS_PHY_438_DATA 0x00000000
+#define DDRSS_PHY_439_DATA 0x00000000
+#define DDRSS_PHY_440_DATA 0x00000000
+#define DDRSS_PHY_441_DATA 0x00000000
+#define DDRSS_PHY_442_DATA 0x00000000
+#define DDRSS_PHY_443_DATA 0x00000000
+#define DDRSS_PHY_444_DATA 0x00000000
+#define DDRSS_PHY_445_DATA 0x00000000
+#define DDRSS_PHY_446_DATA 0x00000000
+#define DDRSS_PHY_447_DATA 0x00000000
+#define DDRSS_PHY_448_DATA 0x00000000
+#define DDRSS_PHY_449_DATA 0x00000000
+#define DDRSS_PHY_450_DATA 0x00000000
+#define DDRSS_PHY_451_DATA 0x00000000
+#define DDRSS_PHY_452_DATA 0x00000000
+#define DDRSS_PHY_453_DATA 0x00000000
+#define DDRSS_PHY_454_DATA 0x00000000
+#define DDRSS_PHY_455_DATA 0x00000000
+#define DDRSS_PHY_456_DATA 0x00000000
+#define DDRSS_PHY_457_DATA 0x00000000
+#define DDRSS_PHY_458_DATA 0x00000000
+#define DDRSS_PHY_459_DATA 0x00000000
+#define DDRSS_PHY_460_DATA 0x00000000
+#define DDRSS_PHY_461_DATA 0x00000000
+#define DDRSS_PHY_462_DATA 0x00000000
+#define DDRSS_PHY_463_DATA 0x00000000
+#define DDRSS_PHY_464_DATA 0x00000000
+#define DDRSS_PHY_465_DATA 0x00000000
+#define DDRSS_PHY_466_DATA 0x00000000
+#define DDRSS_PHY_467_DATA 0x00000000
+#define DDRSS_PHY_468_DATA 0x00000000
+#define DDRSS_PHY_469_DATA 0x00000000
+#define DDRSS_PHY_470_DATA 0x00000000
+#define DDRSS_PHY_471_DATA 0x00000000
+#define DDRSS_PHY_472_DATA 0x00000000
+#define DDRSS_PHY_473_DATA 0x00000000
+#define DDRSS_PHY_474_DATA 0x00000000
+#define DDRSS_PHY_475_DATA 0x00000000
+#define DDRSS_PHY_476_DATA 0x00000000
+#define DDRSS_PHY_477_DATA 0x00000000
+#define DDRSS_PHY_478_DATA 0x00000000
+#define DDRSS_PHY_479_DATA 0x00000000
+#define DDRSS_PHY_480_DATA 0x00000000
+#define DDRSS_PHY_481_DATA 0x00000000
+#define DDRSS_PHY_482_DATA 0x00000000
+#define DDRSS_PHY_483_DATA 0x00000000
+#define DDRSS_PHY_484_DATA 0x00000000
+#define DDRSS_PHY_485_DATA 0x00000000
+#define DDRSS_PHY_486_DATA 0x00000000
+#define DDRSS_PHY_487_DATA 0x00000000
+#define DDRSS_PHY_488_DATA 0x00000000
+#define DDRSS_PHY_489_DATA 0x00000000
+#define DDRSS_PHY_490_DATA 0x00000000
+#define DDRSS_PHY_491_DATA 0x00000000
+#define DDRSS_PHY_492_DATA 0x00000000
+#define DDRSS_PHY_493_DATA 0x00000000
+#define DDRSS_PHY_494_DATA 0x00000000
+#define DDRSS_PHY_495_DATA 0x00000000
+#define DDRSS_PHY_496_DATA 0x00000000
+#define DDRSS_PHY_497_DATA 0x00000000
+#define DDRSS_PHY_498_DATA 0x00000000
+#define DDRSS_PHY_499_DATA 0x00000000
+#define DDRSS_PHY_500_DATA 0x00000000
+#define DDRSS_PHY_501_DATA 0x00000000
+#define DDRSS_PHY_502_DATA 0x00000000
+#define DDRSS_PHY_503_DATA 0x00000000
+#define DDRSS_PHY_504_DATA 0x00000000
+#define DDRSS_PHY_505_DATA 0x00000000
+#define DDRSS_PHY_506_DATA 0x00000000
+#define DDRSS_PHY_507_DATA 0x00000000
+#define DDRSS_PHY_508_DATA 0x00000000
+#define DDRSS_PHY_509_DATA 0x00000000
+#define DDRSS_PHY_510_DATA 0x00000000
+#define DDRSS_PHY_511_DATA 0x00000000
+#define DDRSS_PHY_512_DATA 0x04F00000
+#define DDRSS_PHY_513_DATA 0x00000000
+#define DDRSS_PHY_514_DATA 0x00030200
+#define DDRSS_PHY_515_DATA 0x00000000
+#define DDRSS_PHY_516_DATA 0x00000000
+#define DDRSS_PHY_517_DATA 0x01030000
+#define DDRSS_PHY_518_DATA 0x00010000
+#define DDRSS_PHY_519_DATA 0x01030004
+#define DDRSS_PHY_520_DATA 0x01000000
+#define DDRSS_PHY_521_DATA 0x00000000
+#define DDRSS_PHY_522_DATA 0x00000000
+#define DDRSS_PHY_523_DATA 0x00000000
+#define DDRSS_PHY_524_DATA 0x01010000
+#define DDRSS_PHY_525_DATA 0x00010000
+#define DDRSS_PHY_526_DATA 0x00C00001
+#define DDRSS_PHY_527_DATA 0x00CC0008
+#define DDRSS_PHY_528_DATA 0x00660601
+#define DDRSS_PHY_529_DATA 0x00000003
+#define DDRSS_PHY_530_DATA 0x00000000
+#define DDRSS_PHY_531_DATA 0x00000001
+#define DDRSS_PHY_532_DATA 0x0000AAAA
+#define DDRSS_PHY_533_DATA 0x00005555
+#define DDRSS_PHY_534_DATA 0x0000B5B5
+#define DDRSS_PHY_535_DATA 0x00004A4A
+#define DDRSS_PHY_536_DATA 0x00005656
+#define DDRSS_PHY_537_DATA 0x0000A9A9
+#define DDRSS_PHY_538_DATA 0x0000B7B7
+#define DDRSS_PHY_539_DATA 0x00004848
+#define DDRSS_PHY_540_DATA 0x00000000
+#define DDRSS_PHY_541_DATA 0x00000000
+#define DDRSS_PHY_542_DATA 0x08000000
+#define DDRSS_PHY_543_DATA 0x0F000008
+#define DDRSS_PHY_544_DATA 0x00000F0F
+#define DDRSS_PHY_545_DATA 0x00E4E400
+#define DDRSS_PHY_546_DATA 0x00071020
+#define DDRSS_PHY_547_DATA 0x000C0020
+#define DDRSS_PHY_548_DATA 0x00062000
+#define DDRSS_PHY_549_DATA 0x00000000
+#define DDRSS_PHY_550_DATA 0x55555555
+#define DDRSS_PHY_551_DATA 0xAAAAAAAA
+#define DDRSS_PHY_552_DATA 0x55555555
+#define DDRSS_PHY_553_DATA 0xAAAAAAAA
+#define DDRSS_PHY_554_DATA 0x00005555
+#define DDRSS_PHY_555_DATA 0x01000100
+#define DDRSS_PHY_556_DATA 0x00800180
+#define DDRSS_PHY_557_DATA 0x00000001
+#define DDRSS_PHY_558_DATA 0x00000000
+#define DDRSS_PHY_559_DATA 0x00000000
+#define DDRSS_PHY_560_DATA 0x00000000
+#define DDRSS_PHY_561_DATA 0x00000000
+#define DDRSS_PHY_562_DATA 0x00000000
+#define DDRSS_PHY_563_DATA 0x00000000
+#define DDRSS_PHY_564_DATA 0x00000000
+#define DDRSS_PHY_565_DATA 0x00000000
+#define DDRSS_PHY_566_DATA 0x00000000
+#define DDRSS_PHY_567_DATA 0x00000000
+#define DDRSS_PHY_568_DATA 0x00000000
+#define DDRSS_PHY_569_DATA 0x00000000
+#define DDRSS_PHY_570_DATA 0x00000000
+#define DDRSS_PHY_571_DATA 0x00000000
+#define DDRSS_PHY_572_DATA 0x00000000
+#define DDRSS_PHY_573_DATA 0x00000000
+#define DDRSS_PHY_574_DATA 0x00000000
+#define DDRSS_PHY_575_DATA 0x00000000
+#define DDRSS_PHY_576_DATA 0x00000000
+#define DDRSS_PHY_577_DATA 0x00000000
+#define DDRSS_PHY_578_DATA 0x00000000
+#define DDRSS_PHY_579_DATA 0x00000004
+#define DDRSS_PHY_580_DATA 0x00000000
+#define DDRSS_PHY_581_DATA 0x00000000
+#define DDRSS_PHY_582_DATA 0x00000000
+#define DDRSS_PHY_583_DATA 0x00000000
+#define DDRSS_PHY_584_DATA 0x00000000
+#define DDRSS_PHY_585_DATA 0x00000000
+#define DDRSS_PHY_586_DATA 0x081F07FF
+#define DDRSS_PHY_587_DATA 0x10200080
+#define DDRSS_PHY_588_DATA 0x00000008
+#define DDRSS_PHY_589_DATA 0x00000401
+#define DDRSS_PHY_590_DATA 0x00000000
+#define DDRSS_PHY_591_DATA 0x01CC0C01
+#define DDRSS_PHY_592_DATA 0x1003CC0C
+#define DDRSS_PHY_593_DATA 0x20000140
+#define DDRSS_PHY_594_DATA 0x07FF0200
+#define DDRSS_PHY_595_DATA 0x0000DD01
+#define DDRSS_PHY_596_DATA 0x00100303
+#define DDRSS_PHY_597_DATA 0x00000000
+#define DDRSS_PHY_598_DATA 0x00000000
+#define DDRSS_PHY_599_DATA 0x00041000
+#define DDRSS_PHY_600_DATA 0x00100010
+#define DDRSS_PHY_601_DATA 0x00100010
+#define DDRSS_PHY_602_DATA 0x00100010
+#define DDRSS_PHY_603_DATA 0x00100010
+#define DDRSS_PHY_604_DATA 0x02040010
+#define DDRSS_PHY_605_DATA 0x00000005
+#define DDRSS_PHY_606_DATA 0x51516042
+#define DDRSS_PHY_607_DATA 0x31C06000
+#define DDRSS_PHY_608_DATA 0x07AB0340
+#define DDRSS_PHY_609_DATA 0x00C0C001
+#define DDRSS_PHY_610_DATA 0x0D000000
+#define DDRSS_PHY_611_DATA 0x000D0C0C
+#define DDRSS_PHY_612_DATA 0x42100010
+#define DDRSS_PHY_613_DATA 0x010C073E
+#define DDRSS_PHY_614_DATA 0x000F0C32
+#define DDRSS_PHY_615_DATA 0x01000140
+#define DDRSS_PHY_616_DATA 0x011E0120
+#define DDRSS_PHY_617_DATA 0x00000C00
+#define DDRSS_PHY_618_DATA 0x000002DD
+#define DDRSS_PHY_619_DATA 0x00030200
+#define DDRSS_PHY_620_DATA 0x02800000
+#define DDRSS_PHY_621_DATA 0x80800000
+#define DDRSS_PHY_622_DATA 0x000D2010
+#define DDRSS_PHY_623_DATA 0x76543210
+#define DDRSS_PHY_624_DATA 0x00000008
+#define DDRSS_PHY_625_DATA 0x045D045D
+#define DDRSS_PHY_626_DATA 0x045D045D
+#define DDRSS_PHY_627_DATA 0x045D045D
+#define DDRSS_PHY_628_DATA 0x045D045D
+#define DDRSS_PHY_629_DATA 0x0000045D
+#define DDRSS_PHY_630_DATA 0x0000A000
+#define DDRSS_PHY_631_DATA 0x00A000A0
+#define DDRSS_PHY_632_DATA 0x00A000A0
+#define DDRSS_PHY_633_DATA 0x00A000A0
+#define DDRSS_PHY_634_DATA 0x00A000A0
+#define DDRSS_PHY_635_DATA 0x00A000A0
+#define DDRSS_PHY_636_DATA 0x00A000A0
+#define DDRSS_PHY_637_DATA 0x00A000A0
+#define DDRSS_PHY_638_DATA 0x00A000A0
+#define DDRSS_PHY_639_DATA 0x00B200A0
+#define DDRSS_PHY_640_DATA 0x01000000
+#define DDRSS_PHY_641_DATA 0x00000000
+#define DDRSS_PHY_642_DATA 0x00000000
+#define DDRSS_PHY_643_DATA 0x00080200
+#define DDRSS_PHY_644_DATA 0x00000000
+#define DDRSS_PHY_645_DATA 0x20202020
+#define DDRSS_PHY_646_DATA 0x20202020
+#define DDRSS_PHY_647_DATA 0xF0F02020
+#define DDRSS_PHY_648_DATA 0x00000000
+#define DDRSS_PHY_649_DATA 0x00000000
+#define DDRSS_PHY_650_DATA 0x00000000
+#define DDRSS_PHY_651_DATA 0x00000000
+#define DDRSS_PHY_652_DATA 0x00000000
+#define DDRSS_PHY_653_DATA 0x00000000
+#define DDRSS_PHY_654_DATA 0x00000000
+#define DDRSS_PHY_655_DATA 0x00000000
+#define DDRSS_PHY_656_DATA 0x00000000
+#define DDRSS_PHY_657_DATA 0x00000000
+#define DDRSS_PHY_658_DATA 0x00000000
+#define DDRSS_PHY_659_DATA 0x00000000
+#define DDRSS_PHY_660_DATA 0x00000000
+#define DDRSS_PHY_661_DATA 0x00000000
+#define DDRSS_PHY_662_DATA 0x00000000
+#define DDRSS_PHY_663_DATA 0x00000000
+#define DDRSS_PHY_664_DATA 0x00000000
+#define DDRSS_PHY_665_DATA 0x00000000
+#define DDRSS_PHY_666_DATA 0x00000000
+#define DDRSS_PHY_667_DATA 0x00000000
+#define DDRSS_PHY_668_DATA 0x00000000
+#define DDRSS_PHY_669_DATA 0x00000000
+#define DDRSS_PHY_670_DATA 0x00000000
+#define DDRSS_PHY_671_DATA 0x00000000
+#define DDRSS_PHY_672_DATA 0x00000000
+#define DDRSS_PHY_673_DATA 0x00000000
+#define DDRSS_PHY_674_DATA 0x00000000
+#define DDRSS_PHY_675_DATA 0x00000000
+#define DDRSS_PHY_676_DATA 0x00000000
+#define DDRSS_PHY_677_DATA 0x00000000
+#define DDRSS_PHY_678_DATA 0x00000000
+#define DDRSS_PHY_679_DATA 0x00000000
+#define DDRSS_PHY_680_DATA 0x00000000
+#define DDRSS_PHY_681_DATA 0x00000000
+#define DDRSS_PHY_682_DATA 0x00000000
+#define DDRSS_PHY_683_DATA 0x00000000
+#define DDRSS_PHY_684_DATA 0x00000000
+#define DDRSS_PHY_685_DATA 0x00000000
+#define DDRSS_PHY_686_DATA 0x00000000
+#define DDRSS_PHY_687_DATA 0x00000000
+#define DDRSS_PHY_688_DATA 0x00000000
+#define DDRSS_PHY_689_DATA 0x00000000
+#define DDRSS_PHY_690_DATA 0x00000000
+#define DDRSS_PHY_691_DATA 0x00000000
+#define DDRSS_PHY_692_DATA 0x00000000
+#define DDRSS_PHY_693_DATA 0x00000000
+#define DDRSS_PHY_694_DATA 0x00000000
+#define DDRSS_PHY_695_DATA 0x00000000
+#define DDRSS_PHY_696_DATA 0x00000000
+#define DDRSS_PHY_697_DATA 0x00000000
+#define DDRSS_PHY_698_DATA 0x00000000
+#define DDRSS_PHY_699_DATA 0x00000000
+#define DDRSS_PHY_700_DATA 0x00000000
+#define DDRSS_PHY_701_DATA 0x00000000
+#define DDRSS_PHY_702_DATA 0x00000000
+#define DDRSS_PHY_703_DATA 0x00000000
+#define DDRSS_PHY_704_DATA 0x00000000
+#define DDRSS_PHY_705_DATA 0x00000000
+#define DDRSS_PHY_706_DATA 0x00000000
+#define DDRSS_PHY_707_DATA 0x00000000
+#define DDRSS_PHY_708_DATA 0x00000000
+#define DDRSS_PHY_709_DATA 0x00000000
+#define DDRSS_PHY_710_DATA 0x00000000
+#define DDRSS_PHY_711_DATA 0x00000000
+#define DDRSS_PHY_712_DATA 0x00000000
+#define DDRSS_PHY_713_DATA 0x00000000
+#define DDRSS_PHY_714_DATA 0x00000000
+#define DDRSS_PHY_715_DATA 0x00000000
+#define DDRSS_PHY_716_DATA 0x00000000
+#define DDRSS_PHY_717_DATA 0x00000000
+#define DDRSS_PHY_718_DATA 0x00000000
+#define DDRSS_PHY_719_DATA 0x00000000
+#define DDRSS_PHY_720_DATA 0x00000000
+#define DDRSS_PHY_721_DATA 0x00000000
+#define DDRSS_PHY_722_DATA 0x00000000
+#define DDRSS_PHY_723_DATA 0x00000000
+#define DDRSS_PHY_724_DATA 0x00000000
+#define DDRSS_PHY_725_DATA 0x00000000
+#define DDRSS_PHY_726_DATA 0x00000000
+#define DDRSS_PHY_727_DATA 0x00000000
+#define DDRSS_PHY_728_DATA 0x00000000
+#define DDRSS_PHY_729_DATA 0x00000000
+#define DDRSS_PHY_730_DATA 0x00000000
+#define DDRSS_PHY_731_DATA 0x00000000
+#define DDRSS_PHY_732_DATA 0x00000000
+#define DDRSS_PHY_733_DATA 0x00000000
+#define DDRSS_PHY_734_DATA 0x00000000
+#define DDRSS_PHY_735_DATA 0x00000000
+#define DDRSS_PHY_736_DATA 0x00000000
+#define DDRSS_PHY_737_DATA 0x00000000
+#define DDRSS_PHY_738_DATA 0x00000000
+#define DDRSS_PHY_739_DATA 0x00000000
+#define DDRSS_PHY_740_DATA 0x00000000
+#define DDRSS_PHY_741_DATA 0x00000000
+#define DDRSS_PHY_742_DATA 0x00000000
+#define DDRSS_PHY_743_DATA 0x00000000
+#define DDRSS_PHY_744_DATA 0x00000000
+#define DDRSS_PHY_745_DATA 0x00000000
+#define DDRSS_PHY_746_DATA 0x00000000
+#define DDRSS_PHY_747_DATA 0x00000000
+#define DDRSS_PHY_748_DATA 0x00000000
+#define DDRSS_PHY_749_DATA 0x00000000
+#define DDRSS_PHY_750_DATA 0x00000000
+#define DDRSS_PHY_751_DATA 0x00000000
+#define DDRSS_PHY_752_DATA 0x00000000
+#define DDRSS_PHY_753_DATA 0x00000000
+#define DDRSS_PHY_754_DATA 0x00000000
+#define DDRSS_PHY_755_DATA 0x00000000
+#define DDRSS_PHY_756_DATA 0x00000000
+#define DDRSS_PHY_757_DATA 0x00000000
+#define DDRSS_PHY_758_DATA 0x00000000
+#define DDRSS_PHY_759_DATA 0x00000000
+#define DDRSS_PHY_760_DATA 0x00000000
+#define DDRSS_PHY_761_DATA 0x00000000
+#define DDRSS_PHY_762_DATA 0x00000000
+#define DDRSS_PHY_763_DATA 0x00000000
+#define DDRSS_PHY_764_DATA 0x00000000
+#define DDRSS_PHY_765_DATA 0x00000000
+#define DDRSS_PHY_766_DATA 0x00000000
+#define DDRSS_PHY_767_DATA 0x00000000
+#define DDRSS_PHY_768_DATA 0x04F00000
+#define DDRSS_PHY_769_DATA 0x00000000
+#define DDRSS_PHY_770_DATA 0x00030200
+#define DDRSS_PHY_771_DATA 0x00000000
+#define DDRSS_PHY_772_DATA 0x00000000
+#define DDRSS_PHY_773_DATA 0x01030000
+#define DDRSS_PHY_774_DATA 0x00010000
+#define DDRSS_PHY_775_DATA 0x01030004
+#define DDRSS_PHY_776_DATA 0x01000000
+#define DDRSS_PHY_777_DATA 0x00000000
+#define DDRSS_PHY_778_DATA 0x00000000
+#define DDRSS_PHY_779_DATA 0x00000000
+#define DDRSS_PHY_780_DATA 0x01010000
+#define DDRSS_PHY_781_DATA 0x00010000
+#define DDRSS_PHY_782_DATA 0x00C00001
+#define DDRSS_PHY_783_DATA 0x00CC0008
+#define DDRSS_PHY_784_DATA 0x00660601
+#define DDRSS_PHY_785_DATA 0x00000003
+#define DDRSS_PHY_786_DATA 0x00000000
+#define DDRSS_PHY_787_DATA 0x00000001
+#define DDRSS_PHY_788_DATA 0x0000AAAA
+#define DDRSS_PHY_789_DATA 0x00005555
+#define DDRSS_PHY_790_DATA 0x0000B5B5
+#define DDRSS_PHY_791_DATA 0x00004A4A
+#define DDRSS_PHY_792_DATA 0x00005656
+#define DDRSS_PHY_793_DATA 0x0000A9A9
+#define DDRSS_PHY_794_DATA 0x0000B7B7
+#define DDRSS_PHY_795_DATA 0x00004848
+#define DDRSS_PHY_796_DATA 0x00000000
+#define DDRSS_PHY_797_DATA 0x00000000
+#define DDRSS_PHY_798_DATA 0x08000000
+#define DDRSS_PHY_799_DATA 0x0F000008
+#define DDRSS_PHY_800_DATA 0x00000F0F
+#define DDRSS_PHY_801_DATA 0x00E4E400
+#define DDRSS_PHY_802_DATA 0x00071020
+#define DDRSS_PHY_803_DATA 0x000C0020
+#define DDRSS_PHY_804_DATA 0x00062000
+#define DDRSS_PHY_805_DATA 0x00000000
+#define DDRSS_PHY_806_DATA 0x55555555
+#define DDRSS_PHY_807_DATA 0xAAAAAAAA
+#define DDRSS_PHY_808_DATA 0x55555555
+#define DDRSS_PHY_809_DATA 0xAAAAAAAA
+#define DDRSS_PHY_810_DATA 0x00005555
+#define DDRSS_PHY_811_DATA 0x01000100
+#define DDRSS_PHY_812_DATA 0x00800180
+#define DDRSS_PHY_813_DATA 0x00000000
+#define DDRSS_PHY_814_DATA 0x00000000
+#define DDRSS_PHY_815_DATA 0x00000000
+#define DDRSS_PHY_816_DATA 0x00000000
+#define DDRSS_PHY_817_DATA 0x00000000
+#define DDRSS_PHY_818_DATA 0x00000000
+#define DDRSS_PHY_819_DATA 0x00000000
+#define DDRSS_PHY_820_DATA 0x00000000
+#define DDRSS_PHY_821_DATA 0x00000000
+#define DDRSS_PHY_822_DATA 0x00000000
+#define DDRSS_PHY_823_DATA 0x00000000
+#define DDRSS_PHY_824_DATA 0x00000000
+#define DDRSS_PHY_825_DATA 0x00000000
+#define DDRSS_PHY_826_DATA 0x00000000
+#define DDRSS_PHY_827_DATA 0x00000000
+#define DDRSS_PHY_828_DATA 0x00000000
+#define DDRSS_PHY_829_DATA 0x00000000
+#define DDRSS_PHY_830_DATA 0x00000000
+#define DDRSS_PHY_831_DATA 0x00000000
+#define DDRSS_PHY_832_DATA 0x00000000
+#define DDRSS_PHY_833_DATA 0x00000000
+#define DDRSS_PHY_834_DATA 0x00000000
+#define DDRSS_PHY_835_DATA 0x00000004
+#define DDRSS_PHY_836_DATA 0x00000000
+#define DDRSS_PHY_837_DATA 0x00000000
+#define DDRSS_PHY_838_DATA 0x00000000
+#define DDRSS_PHY_839_DATA 0x00000000
+#define DDRSS_PHY_840_DATA 0x00000000
+#define DDRSS_PHY_841_DATA 0x00000000
+#define DDRSS_PHY_842_DATA 0x081F07FF
+#define DDRSS_PHY_843_DATA 0x10200080
+#define DDRSS_PHY_844_DATA 0x00000008
+#define DDRSS_PHY_845_DATA 0x00000401
+#define DDRSS_PHY_846_DATA 0x00000000
+#define DDRSS_PHY_847_DATA 0x01CC0C01
+#define DDRSS_PHY_848_DATA 0x1003CC0C
+#define DDRSS_PHY_849_DATA 0x20000140
+#define DDRSS_PHY_850_DATA 0x07FF0200
+#define DDRSS_PHY_851_DATA 0x0000DD01
+#define DDRSS_PHY_852_DATA 0x00100303
+#define DDRSS_PHY_853_DATA 0x00000000
+#define DDRSS_PHY_854_DATA 0x00000000
+#define DDRSS_PHY_855_DATA 0x00041000
+#define DDRSS_PHY_856_DATA 0x00100010
+#define DDRSS_PHY_857_DATA 0x00100010
+#define DDRSS_PHY_858_DATA 0x00100010
+#define DDRSS_PHY_859_DATA 0x00100010
+#define DDRSS_PHY_860_DATA 0x02040010
+#define DDRSS_PHY_861_DATA 0x00000005
+#define DDRSS_PHY_862_DATA 0x51516042
+#define DDRSS_PHY_863_DATA 0x31C06000
+#define DDRSS_PHY_864_DATA 0x07AB0340
+#define DDRSS_PHY_865_DATA 0x00C0C001
+#define DDRSS_PHY_866_DATA 0x0D000000
+#define DDRSS_PHY_867_DATA 0x000D0C0C
+#define DDRSS_PHY_868_DATA 0x42100010
+#define DDRSS_PHY_869_DATA 0x010C073E
+#define DDRSS_PHY_870_DATA 0x000F0C32
+#define DDRSS_PHY_871_DATA 0x01000140
+#define DDRSS_PHY_872_DATA 0x011E0120
+#define DDRSS_PHY_873_DATA 0x00000C00
+#define DDRSS_PHY_874_DATA 0x000002DD
+#define DDRSS_PHY_875_DATA 0x00030200
+#define DDRSS_PHY_876_DATA 0x02800000
+#define DDRSS_PHY_877_DATA 0x80800000
+#define DDRSS_PHY_878_DATA 0x000D2010
+#define DDRSS_PHY_879_DATA 0x76543210
+#define DDRSS_PHY_880_DATA 0x00000008
+#define DDRSS_PHY_881_DATA 0x045D045D
+#define DDRSS_PHY_882_DATA 0x045D045D
+#define DDRSS_PHY_883_DATA 0x045D045D
+#define DDRSS_PHY_884_DATA 0x045D045D
+#define DDRSS_PHY_885_DATA 0x0000045D
+#define DDRSS_PHY_886_DATA 0x0000A000
+#define DDRSS_PHY_887_DATA 0x00A000A0
+#define DDRSS_PHY_888_DATA 0x00A000A0
+#define DDRSS_PHY_889_DATA 0x00A000A0
+#define DDRSS_PHY_890_DATA 0x00A000A0
+#define DDRSS_PHY_891_DATA 0x00A000A0
+#define DDRSS_PHY_892_DATA 0x00A000A0
+#define DDRSS_PHY_893_DATA 0x00A000A0
+#define DDRSS_PHY_894_DATA 0x00A000A0
+#define DDRSS_PHY_895_DATA 0x00B200A0
+#define DDRSS_PHY_896_DATA 0x01000000
+#define DDRSS_PHY_897_DATA 0x00000000
+#define DDRSS_PHY_898_DATA 0x00000000
+#define DDRSS_PHY_899_DATA 0x00080200
+#define DDRSS_PHY_900_DATA 0x00000000
+#define DDRSS_PHY_901_DATA 0x20202020
+#define DDRSS_PHY_902_DATA 0x20202020
+#define DDRSS_PHY_903_DATA 0xF0F02020
+#define DDRSS_PHY_904_DATA 0x00000000
+#define DDRSS_PHY_905_DATA 0x00000000
+#define DDRSS_PHY_906_DATA 0x00000000
+#define DDRSS_PHY_907_DATA 0x00000000
+#define DDRSS_PHY_908_DATA 0x00000000
+#define DDRSS_PHY_909_DATA 0x00000000
+#define DDRSS_PHY_910_DATA 0x00000000
+#define DDRSS_PHY_911_DATA 0x00000000
+#define DDRSS_PHY_912_DATA 0x00000000
+#define DDRSS_PHY_913_DATA 0x00000000
+#define DDRSS_PHY_914_DATA 0x00000000
+#define DDRSS_PHY_915_DATA 0x00000000
+#define DDRSS_PHY_916_DATA 0x00000000
+#define DDRSS_PHY_917_DATA 0x00000000
+#define DDRSS_PHY_918_DATA 0x00000000
+#define DDRSS_PHY_919_DATA 0x00000000
+#define DDRSS_PHY_920_DATA 0x00000000
+#define DDRSS_PHY_921_DATA 0x00000000
+#define DDRSS_PHY_922_DATA 0x00000000
+#define DDRSS_PHY_923_DATA 0x00000000
+#define DDRSS_PHY_924_DATA 0x00000000
+#define DDRSS_PHY_925_DATA 0x00000000
+#define DDRSS_PHY_926_DATA 0x00000000
+#define DDRSS_PHY_927_DATA 0x00000000
+#define DDRSS_PHY_928_DATA 0x00000000
+#define DDRSS_PHY_929_DATA 0x00000000
+#define DDRSS_PHY_930_DATA 0x00000000
+#define DDRSS_PHY_931_DATA 0x00000000
+#define DDRSS_PHY_932_DATA 0x00000000
+#define DDRSS_PHY_933_DATA 0x00000000
+#define DDRSS_PHY_934_DATA 0x00000000
+#define DDRSS_PHY_935_DATA 0x00000000
+#define DDRSS_PHY_936_DATA 0x00000000
+#define DDRSS_PHY_937_DATA 0x00000000
+#define DDRSS_PHY_938_DATA 0x00000000
+#define DDRSS_PHY_939_DATA 0x00000000
+#define DDRSS_PHY_940_DATA 0x00000000
+#define DDRSS_PHY_941_DATA 0x00000000
+#define DDRSS_PHY_942_DATA 0x00000000
+#define DDRSS_PHY_943_DATA 0x00000000
+#define DDRSS_PHY_944_DATA 0x00000000
+#define DDRSS_PHY_945_DATA 0x00000000
+#define DDRSS_PHY_946_DATA 0x00000000
+#define DDRSS_PHY_947_DATA 0x00000000
+#define DDRSS_PHY_948_DATA 0x00000000
+#define DDRSS_PHY_949_DATA 0x00000000
+#define DDRSS_PHY_950_DATA 0x00000000
+#define DDRSS_PHY_951_DATA 0x00000000
+#define DDRSS_PHY_952_DATA 0x00000000
+#define DDRSS_PHY_953_DATA 0x00000000
+#define DDRSS_PHY_954_DATA 0x00000000
+#define DDRSS_PHY_955_DATA 0x00000000
+#define DDRSS_PHY_956_DATA 0x00000000
+#define DDRSS_PHY_957_DATA 0x00000000
+#define DDRSS_PHY_958_DATA 0x00000000
+#define DDRSS_PHY_959_DATA 0x00000000
+#define DDRSS_PHY_960_DATA 0x00000000
+#define DDRSS_PHY_961_DATA 0x00000000
+#define DDRSS_PHY_962_DATA 0x00000000
+#define DDRSS_PHY_963_DATA 0x00000000
+#define DDRSS_PHY_964_DATA 0x00000000
+#define DDRSS_PHY_965_DATA 0x00000000
+#define DDRSS_PHY_966_DATA 0x00000000
+#define DDRSS_PHY_967_DATA 0x00000000
+#define DDRSS_PHY_968_DATA 0x00000000
+#define DDRSS_PHY_969_DATA 0x00000000
+#define DDRSS_PHY_970_DATA 0x00000000
+#define DDRSS_PHY_971_DATA 0x00000000
+#define DDRSS_PHY_972_DATA 0x00000000
+#define DDRSS_PHY_973_DATA 0x00000000
+#define DDRSS_PHY_974_DATA 0x00000000
+#define DDRSS_PHY_975_DATA 0x00000000
+#define DDRSS_PHY_976_DATA 0x00000000
+#define DDRSS_PHY_977_DATA 0x00000000
+#define DDRSS_PHY_978_DATA 0x00000000
+#define DDRSS_PHY_979_DATA 0x00000000
+#define DDRSS_PHY_980_DATA 0x00000000
+#define DDRSS_PHY_981_DATA 0x00000000
+#define DDRSS_PHY_982_DATA 0x00000000
+#define DDRSS_PHY_983_DATA 0x00000000
+#define DDRSS_PHY_984_DATA 0x00000000
+#define DDRSS_PHY_985_DATA 0x00000000
+#define DDRSS_PHY_986_DATA 0x00000000
+#define DDRSS_PHY_987_DATA 0x00000000
+#define DDRSS_PHY_988_DATA 0x00000000
+#define DDRSS_PHY_989_DATA 0x00000000
+#define DDRSS_PHY_990_DATA 0x00000000
+#define DDRSS_PHY_991_DATA 0x00000000
+#define DDRSS_PHY_992_DATA 0x00000000
+#define DDRSS_PHY_993_DATA 0x00000000
+#define DDRSS_PHY_994_DATA 0x00000000
+#define DDRSS_PHY_995_DATA 0x00000000
+#define DDRSS_PHY_996_DATA 0x00000000
+#define DDRSS_PHY_997_DATA 0x00000000
+#define DDRSS_PHY_998_DATA 0x00000000
+#define DDRSS_PHY_999_DATA 0x00000000
+#define DDRSS_PHY_1000_DATA 0x00000000
+#define DDRSS_PHY_1001_DATA 0x00000000
+#define DDRSS_PHY_1002_DATA 0x00000000
+#define DDRSS_PHY_1003_DATA 0x00000000
+#define DDRSS_PHY_1004_DATA 0x00000000
+#define DDRSS_PHY_1005_DATA 0x00000000
+#define DDRSS_PHY_1006_DATA 0x00000000
+#define DDRSS_PHY_1007_DATA 0x00000000
+#define DDRSS_PHY_1008_DATA 0x00000000
+#define DDRSS_PHY_1009_DATA 0x00000000
+#define DDRSS_PHY_1010_DATA 0x00000000
+#define DDRSS_PHY_1011_DATA 0x00000000
+#define DDRSS_PHY_1012_DATA 0x00000000
+#define DDRSS_PHY_1013_DATA 0x00000000
+#define DDRSS_PHY_1014_DATA 0x00000000
+#define DDRSS_PHY_1015_DATA 0x00000000
+#define DDRSS_PHY_1016_DATA 0x00000000
+#define DDRSS_PHY_1017_DATA 0x00000000
+#define DDRSS_PHY_1018_DATA 0x00000000
+#define DDRSS_PHY_1019_DATA 0x00000000
+#define DDRSS_PHY_1020_DATA 0x00000000
+#define DDRSS_PHY_1021_DATA 0x00000000
+#define DDRSS_PHY_1022_DATA 0x00000000
+#define DDRSS_PHY_1023_DATA 0x00000000
+#define DDRSS_PHY_1024_DATA 0x00000000
+#define DDRSS_PHY_1025_DATA 0x00000000
+#define DDRSS_PHY_1026_DATA 0x00000000
+#define DDRSS_PHY_1027_DATA 0x00000000
+#define DDRSS_PHY_1028_DATA 0x00000000
+#define DDRSS_PHY_1029_DATA 0x00000100
+#define DDRSS_PHY_1030_DATA 0x00000200
+#define DDRSS_PHY_1031_DATA 0x00000000
+#define DDRSS_PHY_1032_DATA 0x00000000
+#define DDRSS_PHY_1033_DATA 0x00000000
+#define DDRSS_PHY_1034_DATA 0x00000000
+#define DDRSS_PHY_1035_DATA 0x00400000
+#define DDRSS_PHY_1036_DATA 0x00000080
+#define DDRSS_PHY_1037_DATA 0x00DCBA98
+#define DDRSS_PHY_1038_DATA 0x03000000
+#define DDRSS_PHY_1039_DATA 0x00200000
+#define DDRSS_PHY_1040_DATA 0x00000000
+#define DDRSS_PHY_1041_DATA 0x00000000
+#define DDRSS_PHY_1042_DATA 0x00000000
+#define DDRSS_PHY_1043_DATA 0x00000000
+#define DDRSS_PHY_1044_DATA 0x00000000
+#define DDRSS_PHY_1045_DATA 0x0000002A
+#define DDRSS_PHY_1046_DATA 0x00000015
+#define DDRSS_PHY_1047_DATA 0x00000015
+#define DDRSS_PHY_1048_DATA 0x0000002A
+#define DDRSS_PHY_1049_DATA 0x00000033
+#define DDRSS_PHY_1050_DATA 0x0000000C
+#define DDRSS_PHY_1051_DATA 0x0000000C
+#define DDRSS_PHY_1052_DATA 0x00000033
+#define DDRSS_PHY_1053_DATA 0x0A418820
+#define DDRSS_PHY_1054_DATA 0x003F0000
+#define DDRSS_PHY_1055_DATA 0x000F013F
+#define DDRSS_PHY_1056_DATA 0x20202003
+#define DDRSS_PHY_1057_DATA 0x00202020
+#define DDRSS_PHY_1058_DATA 0x20008008
+#define DDRSS_PHY_1059_DATA 0x00000810
+#define DDRSS_PHY_1060_DATA 0x00000F00
+#define DDRSS_PHY_1061_DATA 0x000405CC
+#define DDRSS_PHY_1062_DATA 0x03000004
+#define DDRSS_PHY_1063_DATA 0x00030000
+#define DDRSS_PHY_1064_DATA 0x00000300
+#define DDRSS_PHY_1065_DATA 0x00000300
+#define DDRSS_PHY_1066_DATA 0x00000300
+#define DDRSS_PHY_1067_DATA 0x00000300
+#define DDRSS_PHY_1068_DATA 0x42080010
+#define DDRSS_PHY_1069_DATA 0x0000803E
+#define DDRSS_PHY_1070_DATA 0x00000001
+#define DDRSS_PHY_1071_DATA 0x01000002
+#define DDRSS_PHY_1072_DATA 0x00008000
+#define DDRSS_PHY_1073_DATA 0x00000000
+#define DDRSS_PHY_1074_DATA 0x00000000
+#define DDRSS_PHY_1075_DATA 0x00000000
+#define DDRSS_PHY_1076_DATA 0x00000000
+#define DDRSS_PHY_1077_DATA 0x00000000
+#define DDRSS_PHY_1078_DATA 0x00000000
+#define DDRSS_PHY_1079_DATA 0x00000000
+#define DDRSS_PHY_1080_DATA 0x00000000
+#define DDRSS_PHY_1081_DATA 0x00000000
+#define DDRSS_PHY_1082_DATA 0x00000000
+#define DDRSS_PHY_1083_DATA 0x00000000
+#define DDRSS_PHY_1084_DATA 0x00000000
+#define DDRSS_PHY_1085_DATA 0x00000000
+#define DDRSS_PHY_1086_DATA 0x00000000
+#define DDRSS_PHY_1087_DATA 0x00000000
+#define DDRSS_PHY_1088_DATA 0x00000000
+#define DDRSS_PHY_1089_DATA 0x00000000
+#define DDRSS_PHY_1090_DATA 0x00000000
+#define DDRSS_PHY_1091_DATA 0x00000000
+#define DDRSS_PHY_1092_DATA 0x00000000
+#define DDRSS_PHY_1093_DATA 0x00000000
+#define DDRSS_PHY_1094_DATA 0x00000000
+#define DDRSS_PHY_1095_DATA 0x00000000
+#define DDRSS_PHY_1096_DATA 0x00000000
+#define DDRSS_PHY_1097_DATA 0x00000000
+#define DDRSS_PHY_1098_DATA 0x00000000
+#define DDRSS_PHY_1099_DATA 0x00000000
+#define DDRSS_PHY_1100_DATA 0x00000000
+#define DDRSS_PHY_1101_DATA 0x00000000
+#define DDRSS_PHY_1102_DATA 0x00000000
+#define DDRSS_PHY_1103_DATA 0x00000000
+#define DDRSS_PHY_1104_DATA 0x00000000
+#define DDRSS_PHY_1105_DATA 0x00000000
+#define DDRSS_PHY_1106_DATA 0x00000000
+#define DDRSS_PHY_1107_DATA 0x00000000
+#define DDRSS_PHY_1108_DATA 0x00000000
+#define DDRSS_PHY_1109_DATA 0x00000000
+#define DDRSS_PHY_1110_DATA 0x00000000
+#define DDRSS_PHY_1111_DATA 0x00000000
+#define DDRSS_PHY_1112_DATA 0x00000000
+#define DDRSS_PHY_1113_DATA 0x00000000
+#define DDRSS_PHY_1114_DATA 0x00000000
+#define DDRSS_PHY_1115_DATA 0x00000000
+#define DDRSS_PHY_1116_DATA 0x00000000
+#define DDRSS_PHY_1117_DATA 0x00000000
+#define DDRSS_PHY_1118_DATA 0x00000000
+#define DDRSS_PHY_1119_DATA 0x00000000
+#define DDRSS_PHY_1120_DATA 0x00000000
+#define DDRSS_PHY_1121_DATA 0x00000000
+#define DDRSS_PHY_1122_DATA 0x00000000
+#define DDRSS_PHY_1123_DATA 0x00000000
+#define DDRSS_PHY_1124_DATA 0x00000000
+#define DDRSS_PHY_1125_DATA 0x00000000
+#define DDRSS_PHY_1126_DATA 0x00000000
+#define DDRSS_PHY_1127_DATA 0x00000000
+#define DDRSS_PHY_1128_DATA 0x00000000
+#define DDRSS_PHY_1129_DATA 0x00000000
+#define DDRSS_PHY_1130_DATA 0x00000000
+#define DDRSS_PHY_1131_DATA 0x00000000
+#define DDRSS_PHY_1132_DATA 0x00000000
+#define DDRSS_PHY_1133_DATA 0x00000000
+#define DDRSS_PHY_1134_DATA 0x00000000
+#define DDRSS_PHY_1135_DATA 0x00000000
+#define DDRSS_PHY_1136_DATA 0x00000000
+#define DDRSS_PHY_1137_DATA 0x00000000
+#define DDRSS_PHY_1138_DATA 0x00000000
+#define DDRSS_PHY_1139_DATA 0x00000000
+#define DDRSS_PHY_1140_DATA 0x00000000
+#define DDRSS_PHY_1141_DATA 0x00000000
+#define DDRSS_PHY_1142_DATA 0x00000000
+#define DDRSS_PHY_1143_DATA 0x00000000
+#define DDRSS_PHY_1144_DATA 0x00000000
+#define DDRSS_PHY_1145_DATA 0x00000000
+#define DDRSS_PHY_1146_DATA 0x00000000
+#define DDRSS_PHY_1147_DATA 0x00000000
+#define DDRSS_PHY_1148_DATA 0x00000000
+#define DDRSS_PHY_1149_DATA 0x00000000
+#define DDRSS_PHY_1150_DATA 0x00000000
+#define DDRSS_PHY_1151_DATA 0x00000000
+#define DDRSS_PHY_1152_DATA 0x00000000
+#define DDRSS_PHY_1153_DATA 0x00000000
+#define DDRSS_PHY_1154_DATA 0x00000000
+#define DDRSS_PHY_1155_DATA 0x00000000
+#define DDRSS_PHY_1156_DATA 0x00000000
+#define DDRSS_PHY_1157_DATA 0x00000000
+#define DDRSS_PHY_1158_DATA 0x00000000
+#define DDRSS_PHY_1159_DATA 0x00000000
+#define DDRSS_PHY_1160_DATA 0x00000000
+#define DDRSS_PHY_1161_DATA 0x00000000
+#define DDRSS_PHY_1162_DATA 0x00000000
+#define DDRSS_PHY_1163_DATA 0x00000000
+#define DDRSS_PHY_1164_DATA 0x00000000
+#define DDRSS_PHY_1165_DATA 0x00000000
+#define DDRSS_PHY_1166_DATA 0x00000000
+#define DDRSS_PHY_1167_DATA 0x00000000
+#define DDRSS_PHY_1168_DATA 0x00000000
+#define DDRSS_PHY_1169_DATA 0x00000000
+#define DDRSS_PHY_1170_DATA 0x00000000
+#define DDRSS_PHY_1171_DATA 0x00000000
+#define DDRSS_PHY_1172_DATA 0x00000000
+#define DDRSS_PHY_1173_DATA 0x00000000
+#define DDRSS_PHY_1174_DATA 0x00000000
+#define DDRSS_PHY_1175_DATA 0x00000000
+#define DDRSS_PHY_1176_DATA 0x00000000
+#define DDRSS_PHY_1177_DATA 0x00000000
+#define DDRSS_PHY_1178_DATA 0x00000000
+#define DDRSS_PHY_1179_DATA 0x00000000
+#define DDRSS_PHY_1180_DATA 0x00000000
+#define DDRSS_PHY_1181_DATA 0x00000000
+#define DDRSS_PHY_1182_DATA 0x00000000
+#define DDRSS_PHY_1183_DATA 0x00000000
+#define DDRSS_PHY_1184_DATA 0x00000000
+#define DDRSS_PHY_1185_DATA 0x00000000
+#define DDRSS_PHY_1186_DATA 0x00000000
+#define DDRSS_PHY_1187_DATA 0x00000000
+#define DDRSS_PHY_1188_DATA 0x00000000
+#define DDRSS_PHY_1189_DATA 0x00000000
+#define DDRSS_PHY_1190_DATA 0x00000000
+#define DDRSS_PHY_1191_DATA 0x00000000
+#define DDRSS_PHY_1192_DATA 0x00000000
+#define DDRSS_PHY_1193_DATA 0x00000000
+#define DDRSS_PHY_1194_DATA 0x00000000
+#define DDRSS_PHY_1195_DATA 0x00000000
+#define DDRSS_PHY_1196_DATA 0x00000000
+#define DDRSS_PHY_1197_DATA 0x00000000
+#define DDRSS_PHY_1198_DATA 0x00000000
+#define DDRSS_PHY_1199_DATA 0x00000000
+#define DDRSS_PHY_1200_DATA 0x00000000
+#define DDRSS_PHY_1201_DATA 0x00000000
+#define DDRSS_PHY_1202_DATA 0x00000000
+#define DDRSS_PHY_1203_DATA 0x00000000
+#define DDRSS_PHY_1204_DATA 0x00000000
+#define DDRSS_PHY_1205_DATA 0x00000000
+#define DDRSS_PHY_1206_DATA 0x00000000
+#define DDRSS_PHY_1207_DATA 0x00000000
+#define DDRSS_PHY_1208_DATA 0x00000000
+#define DDRSS_PHY_1209_DATA 0x00000000
+#define DDRSS_PHY_1210_DATA 0x00000000
+#define DDRSS_PHY_1211_DATA 0x00000000
+#define DDRSS_PHY_1212_DATA 0x00000000
+#define DDRSS_PHY_1213_DATA 0x00000000
+#define DDRSS_PHY_1214_DATA 0x00000000
+#define DDRSS_PHY_1215_DATA 0x00000000
+#define DDRSS_PHY_1216_DATA 0x00000000
+#define DDRSS_PHY_1217_DATA 0x00000000
+#define DDRSS_PHY_1218_DATA 0x00000000
+#define DDRSS_PHY_1219_DATA 0x00000000
+#define DDRSS_PHY_1220_DATA 0x00000000
+#define DDRSS_PHY_1221_DATA 0x00000000
+#define DDRSS_PHY_1222_DATA 0x00000000
+#define DDRSS_PHY_1223_DATA 0x00000000
+#define DDRSS_PHY_1224_DATA 0x00000000
+#define DDRSS_PHY_1225_DATA 0x00000000
+#define DDRSS_PHY_1226_DATA 0x00000000
+#define DDRSS_PHY_1227_DATA 0x00000000
+#define DDRSS_PHY_1228_DATA 0x00000000
+#define DDRSS_PHY_1229_DATA 0x00000000
+#define DDRSS_PHY_1230_DATA 0x00000000
+#define DDRSS_PHY_1231_DATA 0x00000000
+#define DDRSS_PHY_1232_DATA 0x00000000
+#define DDRSS_PHY_1233_DATA 0x00000000
+#define DDRSS_PHY_1234_DATA 0x00000000
+#define DDRSS_PHY_1235_DATA 0x00000000
+#define DDRSS_PHY_1236_DATA 0x00000000
+#define DDRSS_PHY_1237_DATA 0x00000000
+#define DDRSS_PHY_1238_DATA 0x00000000
+#define DDRSS_PHY_1239_DATA 0x00000000
+#define DDRSS_PHY_1240_DATA 0x00000000
+#define DDRSS_PHY_1241_DATA 0x00000000
+#define DDRSS_PHY_1242_DATA 0x00000000
+#define DDRSS_PHY_1243_DATA 0x00000000
+#define DDRSS_PHY_1244_DATA 0x00000000
+#define DDRSS_PHY_1245_DATA 0x00000000
+#define DDRSS_PHY_1246_DATA 0x00000000
+#define DDRSS_PHY_1247_DATA 0x00000000
+#define DDRSS_PHY_1248_DATA 0x00000000
+#define DDRSS_PHY_1249_DATA 0x00000000
+#define DDRSS_PHY_1250_DATA 0x00000000
+#define DDRSS_PHY_1251_DATA 0x00000000
+#define DDRSS_PHY_1252_DATA 0x00000000
+#define DDRSS_PHY_1253_DATA 0x00000000
+#define DDRSS_PHY_1254_DATA 0x00000000
+#define DDRSS_PHY_1255_DATA 0x00000000
+#define DDRSS_PHY_1256_DATA 0x00000000
+#define DDRSS_PHY_1257_DATA 0x00000000
+#define DDRSS_PHY_1258_DATA 0x00000000
+#define DDRSS_PHY_1259_DATA 0x00000000
+#define DDRSS_PHY_1260_DATA 0x00000000
+#define DDRSS_PHY_1261_DATA 0x00000000
+#define DDRSS_PHY_1262_DATA 0x00000000
+#define DDRSS_PHY_1263_DATA 0x00000000
+#define DDRSS_PHY_1264_DATA 0x00000000
+#define DDRSS_PHY_1265_DATA 0x00000000
+#define DDRSS_PHY_1266_DATA 0x00000000
+#define DDRSS_PHY_1267_DATA 0x00000000
+#define DDRSS_PHY_1268_DATA 0x00000000
+#define DDRSS_PHY_1269_DATA 0x00000000
+#define DDRSS_PHY_1270_DATA 0x00000000
+#define DDRSS_PHY_1271_DATA 0x00000000
+#define DDRSS_PHY_1272_DATA 0x00000000
+#define DDRSS_PHY_1273_DATA 0x00000000
+#define DDRSS_PHY_1274_DATA 0x00000000
+#define DDRSS_PHY_1275_DATA 0x00000000
+#define DDRSS_PHY_1276_DATA 0x00000000
+#define DDRSS_PHY_1277_DATA 0x00000000
+#define DDRSS_PHY_1278_DATA 0x00000000
+#define DDRSS_PHY_1279_DATA 0x00000000
+#define DDRSS_PHY_1280_DATA 0x00000000
+#define DDRSS_PHY_1281_DATA 0x00000000
+#define DDRSS_PHY_1282_DATA 0x00000000
+#define DDRSS_PHY_1283_DATA 0x00000000
+#define DDRSS_PHY_1284_DATA 0x00000000
+#define DDRSS_PHY_1285_DATA 0x00000100
+#define DDRSS_PHY_1286_DATA 0x00000200
+#define DDRSS_PHY_1287_DATA 0x00000000
+#define DDRSS_PHY_1288_DATA 0x00000000
+#define DDRSS_PHY_1289_DATA 0x00000000
+#define DDRSS_PHY_1290_DATA 0x00000000
+#define DDRSS_PHY_1291_DATA 0x00400000
+#define DDRSS_PHY_1292_DATA 0x00000080
+#define DDRSS_PHY_1293_DATA 0x00DCBA98
+#define DDRSS_PHY_1294_DATA 0x03000000
+#define DDRSS_PHY_1295_DATA 0x00200000
+#define DDRSS_PHY_1296_DATA 0x00000000
+#define DDRSS_PHY_1297_DATA 0x00000000
+#define DDRSS_PHY_1298_DATA 0x00000000
+#define DDRSS_PHY_1299_DATA 0x00000000
+#define DDRSS_PHY_1300_DATA 0x00000000
+#define DDRSS_PHY_1301_DATA 0x0000002A
+#define DDRSS_PHY_1302_DATA 0x00000015
+#define DDRSS_PHY_1303_DATA 0x00000015
+#define DDRSS_PHY_1304_DATA 0x0000002A
+#define DDRSS_PHY_1305_DATA 0x00000033
+#define DDRSS_PHY_1306_DATA 0x0000000C
+#define DDRSS_PHY_1307_DATA 0x0000000C
+#define DDRSS_PHY_1308_DATA 0x00000033
+#define DDRSS_PHY_1309_DATA 0x0A418820
+#define DDRSS_PHY_1310_DATA 0x00000000
+#define DDRSS_PHY_1311_DATA 0x000F0000
+#define DDRSS_PHY_1312_DATA 0x20202003
+#define DDRSS_PHY_1313_DATA 0x00202020
+#define DDRSS_PHY_1314_DATA 0x20008008
+#define DDRSS_PHY_1315_DATA 0x00000810
+#define DDRSS_PHY_1316_DATA 0x00000F00
+#define DDRSS_PHY_1317_DATA 0x000405CC
+#define DDRSS_PHY_1318_DATA 0x03000004
+#define DDRSS_PHY_1319_DATA 0x00030000
+#define DDRSS_PHY_1320_DATA 0x00000300
+#define DDRSS_PHY_1321_DATA 0x00000300
+#define DDRSS_PHY_1322_DATA 0x00000300
+#define DDRSS_PHY_1323_DATA 0x00000300
+#define DDRSS_PHY_1324_DATA 0x42080010
+#define DDRSS_PHY_1325_DATA 0x0000803E
+#define DDRSS_PHY_1326_DATA 0x00000001
+#define DDRSS_PHY_1327_DATA 0x01000002
+#define DDRSS_PHY_1328_DATA 0x00008000
+#define DDRSS_PHY_1329_DATA 0x00000000
+#define DDRSS_PHY_1330_DATA 0x00000000
+#define DDRSS_PHY_1331_DATA 0x00000000
+#define DDRSS_PHY_1332_DATA 0x00000000
+#define DDRSS_PHY_1333_DATA 0x00000000
+#define DDRSS_PHY_1334_DATA 0x00000000
+#define DDRSS_PHY_1335_DATA 0x00000000
+#define DDRSS_PHY_1336_DATA 0x00000000
+#define DDRSS_PHY_1337_DATA 0x00000000
+#define DDRSS_PHY_1338_DATA 0x00000000
+#define DDRSS_PHY_1339_DATA 0x00000000
+#define DDRSS_PHY_1340_DATA 0x00000000
+#define DDRSS_PHY_1341_DATA 0x00000000
+#define DDRSS_PHY_1342_DATA 0x00000000
+#define DDRSS_PHY_1343_DATA 0x00000000
+#define DDRSS_PHY_1344_DATA 0x00000000
+#define DDRSS_PHY_1345_DATA 0x00000000
+#define DDRSS_PHY_1346_DATA 0x00000000
+#define DDRSS_PHY_1347_DATA 0x00000000
+#define DDRSS_PHY_1348_DATA 0x00000000
+#define DDRSS_PHY_1349_DATA 0x00000000
+#define DDRSS_PHY_1350_DATA 0x00000000
+#define DDRSS_PHY_1351_DATA 0x00000000
+#define DDRSS_PHY_1352_DATA 0x00000000
+#define DDRSS_PHY_1353_DATA 0x00000000
+#define DDRSS_PHY_1354_DATA 0x00000000
+#define DDRSS_PHY_1355_DATA 0x00000000
+#define DDRSS_PHY_1356_DATA 0x00000000
+#define DDRSS_PHY_1357_DATA 0x00000000
+#define DDRSS_PHY_1358_DATA 0x00000000
+#define DDRSS_PHY_1359_DATA 0x00000000
+#define DDRSS_PHY_1360_DATA 0x00000000
+#define DDRSS_PHY_1361_DATA 0x00000000
+#define DDRSS_PHY_1362_DATA 0x00000000
+#define DDRSS_PHY_1363_DATA 0x00000000
+#define DDRSS_PHY_1364_DATA 0x00000000
+#define DDRSS_PHY_1365_DATA 0x00000000
+#define DDRSS_PHY_1366_DATA 0x00000000
+#define DDRSS_PHY_1367_DATA 0x00000000
+#define DDRSS_PHY_1368_DATA 0x00000000
+#define DDRSS_PHY_1369_DATA 0x00000000
+#define DDRSS_PHY_1370_DATA 0x00000000
+#define DDRSS_PHY_1371_DATA 0x00000000
+#define DDRSS_PHY_1372_DATA 0x00000000
+#define DDRSS_PHY_1373_DATA 0x00000000
+#define DDRSS_PHY_1374_DATA 0x00000000
+#define DDRSS_PHY_1375_DATA 0x00000000
+#define DDRSS_PHY_1376_DATA 0x00000000
+#define DDRSS_PHY_1377_DATA 0x00000000
+#define DDRSS_PHY_1378_DATA 0x00000000
+#define DDRSS_PHY_1379_DATA 0x00000000
+#define DDRSS_PHY_1380_DATA 0x00000000
+#define DDRSS_PHY_1381_DATA 0x00000000
+#define DDRSS_PHY_1382_DATA 0x00000000
+#define DDRSS_PHY_1383_DATA 0x00000000
+#define DDRSS_PHY_1384_DATA 0x00000000
+#define DDRSS_PHY_1385_DATA 0x00000000
+#define DDRSS_PHY_1386_DATA 0x00000000
+#define DDRSS_PHY_1387_DATA 0x00000000
+#define DDRSS_PHY_1388_DATA 0x00000000
+#define DDRSS_PHY_1389_DATA 0x00000000
+#define DDRSS_PHY_1390_DATA 0x00000000
+#define DDRSS_PHY_1391_DATA 0x00000000
+#define DDRSS_PHY_1392_DATA 0x00000000
+#define DDRSS_PHY_1393_DATA 0x00000000
+#define DDRSS_PHY_1394_DATA 0x00000000
+#define DDRSS_PHY_1395_DATA 0x00000000
+#define DDRSS_PHY_1396_DATA 0x00000000
+#define DDRSS_PHY_1397_DATA 0x00000000
+#define DDRSS_PHY_1398_DATA 0x00000000
+#define DDRSS_PHY_1399_DATA 0x00000000
+#define DDRSS_PHY_1400_DATA 0x00000000
+#define DDRSS_PHY_1401_DATA 0x00000000
+#define DDRSS_PHY_1402_DATA 0x00000000
+#define DDRSS_PHY_1403_DATA 0x00000000
+#define DDRSS_PHY_1404_DATA 0x00000000
+#define DDRSS_PHY_1405_DATA 0x00000000
+#define DDRSS_PHY_1406_DATA 0x00000000
+#define DDRSS_PHY_1407_DATA 0x00000000
+#define DDRSS_PHY_1408_DATA 0x00000000
+#define DDRSS_PHY_1409_DATA 0x00000000
+#define DDRSS_PHY_1410_DATA 0x00000000
+#define DDRSS_PHY_1411_DATA 0x00000000
+#define DDRSS_PHY_1412_DATA 0x00000000
+#define DDRSS_PHY_1413_DATA 0x00000000
+#define DDRSS_PHY_1414_DATA 0x00000000
+#define DDRSS_PHY_1415_DATA 0x00000000
+#define DDRSS_PHY_1416_DATA 0x00000000
+#define DDRSS_PHY_1417_DATA 0x00000000
+#define DDRSS_PHY_1418_DATA 0x00000000
+#define DDRSS_PHY_1419_DATA 0x00000000
+#define DDRSS_PHY_1420_DATA 0x00000000
+#define DDRSS_PHY_1421_DATA 0x00000000
+#define DDRSS_PHY_1422_DATA 0x00000000
+#define DDRSS_PHY_1423_DATA 0x00000000
+#define DDRSS_PHY_1424_DATA 0x00000000
+#define DDRSS_PHY_1425_DATA 0x00000000
+#define DDRSS_PHY_1426_DATA 0x00000000
+#define DDRSS_PHY_1427_DATA 0x00000000
+#define DDRSS_PHY_1428_DATA 0x00000000
+#define DDRSS_PHY_1429_DATA 0x00000000
+#define DDRSS_PHY_1430_DATA 0x00000000
+#define DDRSS_PHY_1431_DATA 0x00000000
+#define DDRSS_PHY_1432_DATA 0x00000000
+#define DDRSS_PHY_1433_DATA 0x00000000
+#define DDRSS_PHY_1434_DATA 0x00000000
+#define DDRSS_PHY_1435_DATA 0x00000000
+#define DDRSS_PHY_1436_DATA 0x00000000
+#define DDRSS_PHY_1437_DATA 0x00000000
+#define DDRSS_PHY_1438_DATA 0x00000000
+#define DDRSS_PHY_1439_DATA 0x00000000
+#define DDRSS_PHY_1440_DATA 0x00000000
+#define DDRSS_PHY_1441_DATA 0x00000000
+#define DDRSS_PHY_1442_DATA 0x00000000
+#define DDRSS_PHY_1443_DATA 0x00000000
+#define DDRSS_PHY_1444_DATA 0x00000000
+#define DDRSS_PHY_1445_DATA 0x00000000
+#define DDRSS_PHY_1446_DATA 0x00000000
+#define DDRSS_PHY_1447_DATA 0x00000000
+#define DDRSS_PHY_1448_DATA 0x00000000
+#define DDRSS_PHY_1449_DATA 0x00000000
+#define DDRSS_PHY_1450_DATA 0x00000000
+#define DDRSS_PHY_1451_DATA 0x00000000
+#define DDRSS_PHY_1452_DATA 0x00000000
+#define DDRSS_PHY_1453_DATA 0x00000000
+#define DDRSS_PHY_1454_DATA 0x00000000
+#define DDRSS_PHY_1455_DATA 0x00000000
+#define DDRSS_PHY_1456_DATA 0x00000000
+#define DDRSS_PHY_1457_DATA 0x00000000
+#define DDRSS_PHY_1458_DATA 0x00000000
+#define DDRSS_PHY_1459_DATA 0x00000000
+#define DDRSS_PHY_1460_DATA 0x00000000
+#define DDRSS_PHY_1461_DATA 0x00000000
+#define DDRSS_PHY_1462_DATA 0x00000000
+#define DDRSS_PHY_1463_DATA 0x00000000
+#define DDRSS_PHY_1464_DATA 0x00000000
+#define DDRSS_PHY_1465_DATA 0x00000000
+#define DDRSS_PHY_1466_DATA 0x00000000
+#define DDRSS_PHY_1467_DATA 0x00000000
+#define DDRSS_PHY_1468_DATA 0x00000000
+#define DDRSS_PHY_1469_DATA 0x00000000
+#define DDRSS_PHY_1470_DATA 0x00000000
+#define DDRSS_PHY_1471_DATA 0x00000000
+#define DDRSS_PHY_1472_DATA 0x00000000
+#define DDRSS_PHY_1473_DATA 0x00000000
+#define DDRSS_PHY_1474_DATA 0x00000000
+#define DDRSS_PHY_1475_DATA 0x00000000
+#define DDRSS_PHY_1476_DATA 0x00000000
+#define DDRSS_PHY_1477_DATA 0x00000000
+#define DDRSS_PHY_1478_DATA 0x00000000
+#define DDRSS_PHY_1479_DATA 0x00000000
+#define DDRSS_PHY_1480_DATA 0x00000000
+#define DDRSS_PHY_1481_DATA 0x00000000
+#define DDRSS_PHY_1482_DATA 0x00000000
+#define DDRSS_PHY_1483_DATA 0x00000000
+#define DDRSS_PHY_1484_DATA 0x00000000
+#define DDRSS_PHY_1485_DATA 0x00000000
+#define DDRSS_PHY_1486_DATA 0x00000000
+#define DDRSS_PHY_1487_DATA 0x00000000
+#define DDRSS_PHY_1488_DATA 0x00000000
+#define DDRSS_PHY_1489_DATA 0x00000000
+#define DDRSS_PHY_1490_DATA 0x00000000
+#define DDRSS_PHY_1491_DATA 0x00000000
+#define DDRSS_PHY_1492_DATA 0x00000000
+#define DDRSS_PHY_1493_DATA 0x00000000
+#define DDRSS_PHY_1494_DATA 0x00000000
+#define DDRSS_PHY_1495_DATA 0x00000000
+#define DDRSS_PHY_1496_DATA 0x00000000
+#define DDRSS_PHY_1497_DATA 0x00000000
+#define DDRSS_PHY_1498_DATA 0x00000000
+#define DDRSS_PHY_1499_DATA 0x00000000
+#define DDRSS_PHY_1500_DATA 0x00000000
+#define DDRSS_PHY_1501_DATA 0x00000000
+#define DDRSS_PHY_1502_DATA 0x00000000
+#define DDRSS_PHY_1503_DATA 0x00000000
+#define DDRSS_PHY_1504_DATA 0x00000000
+#define DDRSS_PHY_1505_DATA 0x00000000
+#define DDRSS_PHY_1506_DATA 0x00000000
+#define DDRSS_PHY_1507_DATA 0x00000000
+#define DDRSS_PHY_1508_DATA 0x00000000
+#define DDRSS_PHY_1509_DATA 0x00000000
+#define DDRSS_PHY_1510_DATA 0x00000000
+#define DDRSS_PHY_1511_DATA 0x00000000
+#define DDRSS_PHY_1512_DATA 0x00000000
+#define DDRSS_PHY_1513_DATA 0x00000000
+#define DDRSS_PHY_1514_DATA 0x00000000
+#define DDRSS_PHY_1515_DATA 0x00000000
+#define DDRSS_PHY_1516_DATA 0x00000000
+#define DDRSS_PHY_1517_DATA 0x00000000
+#define DDRSS_PHY_1518_DATA 0x00000000
+#define DDRSS_PHY_1519_DATA 0x00000000
+#define DDRSS_PHY_1520_DATA 0x00000000
+#define DDRSS_PHY_1521_DATA 0x00000000
+#define DDRSS_PHY_1522_DATA 0x00000000
+#define DDRSS_PHY_1523_DATA 0x00000000
+#define DDRSS_PHY_1524_DATA 0x00000000
+#define DDRSS_PHY_1525_DATA 0x00000000
+#define DDRSS_PHY_1526_DATA 0x00000000
+#define DDRSS_PHY_1527_DATA 0x00000000
+#define DDRSS_PHY_1528_DATA 0x00000000
+#define DDRSS_PHY_1529_DATA 0x00000000
+#define DDRSS_PHY_1530_DATA 0x00000000
+#define DDRSS_PHY_1531_DATA 0x00000000
+#define DDRSS_PHY_1532_DATA 0x00000000
+#define DDRSS_PHY_1533_DATA 0x00000000
+#define DDRSS_PHY_1534_DATA 0x00000000
+#define DDRSS_PHY_1535_DATA 0x00000000
+#define DDRSS_PHY_1536_DATA 0x00000000
+#define DDRSS_PHY_1537_DATA 0x00000000
+#define DDRSS_PHY_1538_DATA 0x00000000
+#define DDRSS_PHY_1539_DATA 0x00000000
+#define DDRSS_PHY_1540_DATA 0x00000000
+#define DDRSS_PHY_1541_DATA 0x00000100
+#define DDRSS_PHY_1542_DATA 0x00000200
+#define DDRSS_PHY_1543_DATA 0x00000000
+#define DDRSS_PHY_1544_DATA 0x00000000
+#define DDRSS_PHY_1545_DATA 0x00000000
+#define DDRSS_PHY_1546_DATA 0x00000000
+#define DDRSS_PHY_1547_DATA 0x00400000
+#define DDRSS_PHY_1548_DATA 0x00000080
+#define DDRSS_PHY_1549_DATA 0x00DCBA98
+#define DDRSS_PHY_1550_DATA 0x03000000
+#define DDRSS_PHY_1551_DATA 0x00200000
+#define DDRSS_PHY_1552_DATA 0x00000000
+#define DDRSS_PHY_1553_DATA 0x00000000
+#define DDRSS_PHY_1554_DATA 0x00000000
+#define DDRSS_PHY_1555_DATA 0x00000000
+#define DDRSS_PHY_1556_DATA 0x00000000
+#define DDRSS_PHY_1557_DATA 0x0000002A
+#define DDRSS_PHY_1558_DATA 0x00000015
+#define DDRSS_PHY_1559_DATA 0x00000015
+#define DDRSS_PHY_1560_DATA 0x0000002A
+#define DDRSS_PHY_1561_DATA 0x00000033
+#define DDRSS_PHY_1562_DATA 0x0000000C
+#define DDRSS_PHY_1563_DATA 0x0000000C
+#define DDRSS_PHY_1564_DATA 0x00000033
+#define DDRSS_PHY_1565_DATA 0x0A418820
+#define DDRSS_PHY_1566_DATA 0x10000000
+#define DDRSS_PHY_1567_DATA 0x000F0000
+#define DDRSS_PHY_1568_DATA 0x20202003
+#define DDRSS_PHY_1569_DATA 0x00202020
+#define DDRSS_PHY_1570_DATA 0x20008008
+#define DDRSS_PHY_1571_DATA 0x00000810
+#define DDRSS_PHY_1572_DATA 0x00000F00
+#define DDRSS_PHY_1573_DATA 0x000405CC
+#define DDRSS_PHY_1574_DATA 0x03000004
+#define DDRSS_PHY_1575_DATA 0x00030000
+#define DDRSS_PHY_1576_DATA 0x00000300
+#define DDRSS_PHY_1577_DATA 0x00000300
+#define DDRSS_PHY_1578_DATA 0x00000300
+#define DDRSS_PHY_1579_DATA 0x00000300
+#define DDRSS_PHY_1580_DATA 0x42080010
+#define DDRSS_PHY_1581_DATA 0x0000803E
+#define DDRSS_PHY_1582_DATA 0x00000001
+#define DDRSS_PHY_1583_DATA 0x01000002
+#define DDRSS_PHY_1584_DATA 0x00008000
+#define DDRSS_PHY_1585_DATA 0x00000000
+#define DDRSS_PHY_1586_DATA 0x00000000
+#define DDRSS_PHY_1587_DATA 0x00000000
+#define DDRSS_PHY_1588_DATA 0x00000000
+#define DDRSS_PHY_1589_DATA 0x00000000
+#define DDRSS_PHY_1590_DATA 0x00000000
+#define DDRSS_PHY_1591_DATA 0x00000000
+#define DDRSS_PHY_1592_DATA 0x00000000
+#define DDRSS_PHY_1593_DATA 0x00000000
+#define DDRSS_PHY_1594_DATA 0x00000000
+#define DDRSS_PHY_1595_DATA 0x00000000
+#define DDRSS_PHY_1596_DATA 0x00000000
+#define DDRSS_PHY_1597_DATA 0x00000000
+#define DDRSS_PHY_1598_DATA 0x00000000
+#define DDRSS_PHY_1599_DATA 0x00000000
+#define DDRSS_PHY_1600_DATA 0x00000000
+#define DDRSS_PHY_1601_DATA 0x00000000
+#define DDRSS_PHY_1602_DATA 0x00000000
+#define DDRSS_PHY_1603_DATA 0x00000000
+#define DDRSS_PHY_1604_DATA 0x00000000
+#define DDRSS_PHY_1605_DATA 0x00000000
+#define DDRSS_PHY_1606_DATA 0x00000000
+#define DDRSS_PHY_1607_DATA 0x00000000
+#define DDRSS_PHY_1608_DATA 0x00000000
+#define DDRSS_PHY_1609_DATA 0x00000000
+#define DDRSS_PHY_1610_DATA 0x00000000
+#define DDRSS_PHY_1611_DATA 0x00000000
+#define DDRSS_PHY_1612_DATA 0x00000000
+#define DDRSS_PHY_1613_DATA 0x00000000
+#define DDRSS_PHY_1614_DATA 0x00000000
+#define DDRSS_PHY_1615_DATA 0x00000000
+#define DDRSS_PHY_1616_DATA 0x00000000
+#define DDRSS_PHY_1617_DATA 0x00000000
+#define DDRSS_PHY_1618_DATA 0x00000000
+#define DDRSS_PHY_1619_DATA 0x00000000
+#define DDRSS_PHY_1620_DATA 0x00000000
+#define DDRSS_PHY_1621_DATA 0x00000000
+#define DDRSS_PHY_1622_DATA 0x00000000
+#define DDRSS_PHY_1623_DATA 0x00000000
+#define DDRSS_PHY_1624_DATA 0x00000000
+#define DDRSS_PHY_1625_DATA 0x00000000
+#define DDRSS_PHY_1626_DATA 0x00000000
+#define DDRSS_PHY_1627_DATA 0x00000000
+#define DDRSS_PHY_1628_DATA 0x00000000
+#define DDRSS_PHY_1629_DATA 0x00000000
+#define DDRSS_PHY_1630_DATA 0x00000000
+#define DDRSS_PHY_1631_DATA 0x00000000
+#define DDRSS_PHY_1632_DATA 0x00000000
+#define DDRSS_PHY_1633_DATA 0x00000000
+#define DDRSS_PHY_1634_DATA 0x00000000
+#define DDRSS_PHY_1635_DATA 0x00000000
+#define DDRSS_PHY_1636_DATA 0x00000000
+#define DDRSS_PHY_1637_DATA 0x00000000
+#define DDRSS_PHY_1638_DATA 0x00000000
+#define DDRSS_PHY_1639_DATA 0x00000000
+#define DDRSS_PHY_1640_DATA 0x00000000
+#define DDRSS_PHY_1641_DATA 0x00000000
+#define DDRSS_PHY_1642_DATA 0x00000000
+#define DDRSS_PHY_1643_DATA 0x00000000
+#define DDRSS_PHY_1644_DATA 0x00000000
+#define DDRSS_PHY_1645_DATA 0x00000000
+#define DDRSS_PHY_1646_DATA 0x00000000
+#define DDRSS_PHY_1647_DATA 0x00000000
+#define DDRSS_PHY_1648_DATA 0x00000000
+#define DDRSS_PHY_1649_DATA 0x00000000
+#define DDRSS_PHY_1650_DATA 0x00000000
+#define DDRSS_PHY_1651_DATA 0x00000000
+#define DDRSS_PHY_1652_DATA 0x00000000
+#define DDRSS_PHY_1653_DATA 0x00000000
+#define DDRSS_PHY_1654_DATA 0x00000000
+#define DDRSS_PHY_1655_DATA 0x00000000
+#define DDRSS_PHY_1656_DATA 0x00000000
+#define DDRSS_PHY_1657_DATA 0x00000000
+#define DDRSS_PHY_1658_DATA 0x00000000
+#define DDRSS_PHY_1659_DATA 0x00000000
+#define DDRSS_PHY_1660_DATA 0x00000000
+#define DDRSS_PHY_1661_DATA 0x00000000
+#define DDRSS_PHY_1662_DATA 0x00000000
+#define DDRSS_PHY_1663_DATA 0x00000000
+#define DDRSS_PHY_1664_DATA 0x00000000
+#define DDRSS_PHY_1665_DATA 0x00000000
+#define DDRSS_PHY_1666_DATA 0x00000000
+#define DDRSS_PHY_1667_DATA 0x00000000
+#define DDRSS_PHY_1668_DATA 0x00000000
+#define DDRSS_PHY_1669_DATA 0x00000000
+#define DDRSS_PHY_1670_DATA 0x00000000
+#define DDRSS_PHY_1671_DATA 0x00000000
+#define DDRSS_PHY_1672_DATA 0x00000000
+#define DDRSS_PHY_1673_DATA 0x00000000
+#define DDRSS_PHY_1674_DATA 0x00000000
+#define DDRSS_PHY_1675_DATA 0x00000000
+#define DDRSS_PHY_1676_DATA 0x00000000
+#define DDRSS_PHY_1677_DATA 0x00000000
+#define DDRSS_PHY_1678_DATA 0x00000000
+#define DDRSS_PHY_1679_DATA 0x00000000
+#define DDRSS_PHY_1680_DATA 0x00000000
+#define DDRSS_PHY_1681_DATA 0x00000000
+#define DDRSS_PHY_1682_DATA 0x00000000
+#define DDRSS_PHY_1683_DATA 0x00000000
+#define DDRSS_PHY_1684_DATA 0x00000000
+#define DDRSS_PHY_1685_DATA 0x00000000
+#define DDRSS_PHY_1686_DATA 0x00000000
+#define DDRSS_PHY_1687_DATA 0x00000000
+#define DDRSS_PHY_1688_DATA 0x00000000
+#define DDRSS_PHY_1689_DATA 0x00000000
+#define DDRSS_PHY_1690_DATA 0x00000000
+#define DDRSS_PHY_1691_DATA 0x00000000
+#define DDRSS_PHY_1692_DATA 0x00000000
+#define DDRSS_PHY_1693_DATA 0x00000000
+#define DDRSS_PHY_1694_DATA 0x00000000
+#define DDRSS_PHY_1695_DATA 0x00000000
+#define DDRSS_PHY_1696_DATA 0x00000000
+#define DDRSS_PHY_1697_DATA 0x00000000
+#define DDRSS_PHY_1698_DATA 0x00000000
+#define DDRSS_PHY_1699_DATA 0x00000000
+#define DDRSS_PHY_1700_DATA 0x00000000
+#define DDRSS_PHY_1701_DATA 0x00000000
+#define DDRSS_PHY_1702_DATA 0x00000000
+#define DDRSS_PHY_1703_DATA 0x00000000
+#define DDRSS_PHY_1704_DATA 0x00000000
+#define DDRSS_PHY_1705_DATA 0x00000000
+#define DDRSS_PHY_1706_DATA 0x00000000
+#define DDRSS_PHY_1707_DATA 0x00000000
+#define DDRSS_PHY_1708_DATA 0x00000000
+#define DDRSS_PHY_1709_DATA 0x00000000
+#define DDRSS_PHY_1710_DATA 0x00000000
+#define DDRSS_PHY_1711_DATA 0x00000000
+#define DDRSS_PHY_1712_DATA 0x00000000
+#define DDRSS_PHY_1713_DATA 0x00000000
+#define DDRSS_PHY_1714_DATA 0x00000000
+#define DDRSS_PHY_1715_DATA 0x00000000
+#define DDRSS_PHY_1716_DATA 0x00000000
+#define DDRSS_PHY_1717_DATA 0x00000000
+#define DDRSS_PHY_1718_DATA 0x00000000
+#define DDRSS_PHY_1719_DATA 0x00000000
+#define DDRSS_PHY_1720_DATA 0x00000000
+#define DDRSS_PHY_1721_DATA 0x00000000
+#define DDRSS_PHY_1722_DATA 0x00000000
+#define DDRSS_PHY_1723_DATA 0x00000000
+#define DDRSS_PHY_1724_DATA 0x00000000
+#define DDRSS_PHY_1725_DATA 0x00000000
+#define DDRSS_PHY_1726_DATA 0x00000000
+#define DDRSS_PHY_1727_DATA 0x00000000
+#define DDRSS_PHY_1728_DATA 0x00000000
+#define DDRSS_PHY_1729_DATA 0x00000000
+#define DDRSS_PHY_1730_DATA 0x00000000
+#define DDRSS_PHY_1731_DATA 0x00000000
+#define DDRSS_PHY_1732_DATA 0x00000000
+#define DDRSS_PHY_1733_DATA 0x00000000
+#define DDRSS_PHY_1734_DATA 0x00000000
+#define DDRSS_PHY_1735_DATA 0x00000000
+#define DDRSS_PHY_1736_DATA 0x00000000
+#define DDRSS_PHY_1737_DATA 0x00000000
+#define DDRSS_PHY_1738_DATA 0x00000000
+#define DDRSS_PHY_1739_DATA 0x00000000
+#define DDRSS_PHY_1740_DATA 0x00000000
+#define DDRSS_PHY_1741_DATA 0x00000000
+#define DDRSS_PHY_1742_DATA 0x00000000
+#define DDRSS_PHY_1743_DATA 0x00000000
+#define DDRSS_PHY_1744_DATA 0x00000000
+#define DDRSS_PHY_1745_DATA 0x00000000
+#define DDRSS_PHY_1746_DATA 0x00000000
+#define DDRSS_PHY_1747_DATA 0x00000000
+#define DDRSS_PHY_1748_DATA 0x00000000
+#define DDRSS_PHY_1749_DATA 0x00000000
+#define DDRSS_PHY_1750_DATA 0x00000000
+#define DDRSS_PHY_1751_DATA 0x00000000
+#define DDRSS_PHY_1752_DATA 0x00000000
+#define DDRSS_PHY_1753_DATA 0x00000000
+#define DDRSS_PHY_1754_DATA 0x00000000
+#define DDRSS_PHY_1755_DATA 0x00000000
+#define DDRSS_PHY_1756_DATA 0x00000000
+#define DDRSS_PHY_1757_DATA 0x00000000
+#define DDRSS_PHY_1758_DATA 0x00000000
+#define DDRSS_PHY_1759_DATA 0x00000000
+#define DDRSS_PHY_1760_DATA 0x00000000
+#define DDRSS_PHY_1761_DATA 0x00000000
+#define DDRSS_PHY_1762_DATA 0x00000000
+#define DDRSS_PHY_1763_DATA 0x00000000
+#define DDRSS_PHY_1764_DATA 0x00000000
+#define DDRSS_PHY_1765_DATA 0x00000000
+#define DDRSS_PHY_1766_DATA 0x00000000
+#define DDRSS_PHY_1767_DATA 0x00000000
+#define DDRSS_PHY_1768_DATA 0x00000000
+#define DDRSS_PHY_1769_DATA 0x00000000
+#define DDRSS_PHY_1770_DATA 0x00000000
+#define DDRSS_PHY_1771_DATA 0x00000000
+#define DDRSS_PHY_1772_DATA 0x00000000
+#define DDRSS_PHY_1773_DATA 0x00000000
+#define DDRSS_PHY_1774_DATA 0x00000000
+#define DDRSS_PHY_1775_DATA 0x00000000
+#define DDRSS_PHY_1776_DATA 0x00000000
+#define DDRSS_PHY_1777_DATA 0x00000000
+#define DDRSS_PHY_1778_DATA 0x00000000
+#define DDRSS_PHY_1779_DATA 0x00000000
+#define DDRSS_PHY_1780_DATA 0x00000000
+#define DDRSS_PHY_1781_DATA 0x00000000
+#define DDRSS_PHY_1782_DATA 0x00000000
+#define DDRSS_PHY_1783_DATA 0x00000000
+#define DDRSS_PHY_1784_DATA 0x00000000
+#define DDRSS_PHY_1785_DATA 0x00000000
+#define DDRSS_PHY_1786_DATA 0x00000000
+#define DDRSS_PHY_1787_DATA 0x00000000
+#define DDRSS_PHY_1788_DATA 0x00000000
+#define DDRSS_PHY_1789_DATA 0x00000000
+#define DDRSS_PHY_1790_DATA 0x00000000
+#define DDRSS_PHY_1791_DATA 0x00000000
+#define DDRSS_PHY_1792_DATA 0x00000000
+#define DDRSS_PHY_1793_DATA 0x00010100
+#define DDRSS_PHY_1794_DATA 0x00000000
+#define DDRSS_PHY_1795_DATA 0x00000000
+#define DDRSS_PHY_1796_DATA 0x00000000
+#define DDRSS_PHY_1797_DATA 0x00000000
+#define DDRSS_PHY_1798_DATA 0x00050000
+#define DDRSS_PHY_1799_DATA 0x04000000
+#define DDRSS_PHY_1800_DATA 0x00000055
+#define DDRSS_PHY_1801_DATA 0x00000000
+#define DDRSS_PHY_1802_DATA 0x00000000
+#define DDRSS_PHY_1803_DATA 0x00000000
+#define DDRSS_PHY_1804_DATA 0x00000000
+#define DDRSS_PHY_1805_DATA 0x00002001
+#define DDRSS_PHY_1806_DATA 0x00004003
+#define DDRSS_PHY_1807_DATA 0x50020028
+#define DDRSS_PHY_1808_DATA 0x01010000
+#define DDRSS_PHY_1809_DATA 0x80080001
+#define DDRSS_PHY_1810_DATA 0x10200000
+#define DDRSS_PHY_1811_DATA 0x00000008
+#define DDRSS_PHY_1812_DATA 0x00000000
+#define DDRSS_PHY_1813_DATA 0x06000000
+#define DDRSS_PHY_1814_DATA 0x010F0F0E
+#define DDRSS_PHY_1815_DATA 0x00040101
+#define DDRSS_PHY_1816_DATA 0x0000010F
+#define DDRSS_PHY_1817_DATA 0x00000000
+#define DDRSS_PHY_1818_DATA 0x00000064
+#define DDRSS_PHY_1819_DATA 0x00000000
+#define DDRSS_PHY_1820_DATA 0x00000000
+#define DDRSS_PHY_1821_DATA 0x0F0F0F01
+#define DDRSS_PHY_1822_DATA 0x0F0F0F02
+#define DDRSS_PHY_1823_DATA 0x0F0F0F0F
+#define DDRSS_PHY_1824_DATA 0x0F0F0804
+#define DDRSS_PHY_1825_DATA 0x00800120
+#define DDRSS_PHY_1826_DATA 0x00041B42
+#define DDRSS_PHY_1827_DATA 0x00005201
+#define DDRSS_PHY_1828_DATA 0x00000000
+#define DDRSS_PHY_1829_DATA 0x00000000
+#define DDRSS_PHY_1830_DATA 0x00000000
+#define DDRSS_PHY_1831_DATA 0x00000000
+#define DDRSS_PHY_1832_DATA 0x00000000
+#define DDRSS_PHY_1833_DATA 0x00000000
+#define DDRSS_PHY_1834_DATA 0x03010100
+#define DDRSS_PHY_1835_DATA 0x00540007
+#define DDRSS_PHY_1836_DATA 0x000040A2
+#define DDRSS_PHY_1837_DATA 0x00024410
+#define DDRSS_PHY_1838_DATA 0x00004410
+#define DDRSS_PHY_1839_DATA 0x00004410
+#define DDRSS_PHY_1840_DATA 0x00004410
+#define DDRSS_PHY_1841_DATA 0x00004410
+#define DDRSS_PHY_1842_DATA 0x00004410
+#define DDRSS_PHY_1843_DATA 0x00004410
+#define DDRSS_PHY_1844_DATA 0x00004410
+#define DDRSS_PHY_1845_DATA 0x00004410
+#define DDRSS_PHY_1846_DATA 0x00004410
+#define DDRSS_PHY_1847_DATA 0x00000000
+#define DDRSS_PHY_1848_DATA 0x00000076
+#define DDRSS_PHY_1849_DATA 0x00000400
+#define DDRSS_PHY_1850_DATA 0x00000008
+#define DDRSS_PHY_1851_DATA 0x00000000
+#define DDRSS_PHY_1852_DATA 0x00000000
+#define DDRSS_PHY_1853_DATA 0x00000000
+#define DDRSS_PHY_1854_DATA 0x00000000
+#define DDRSS_PHY_1855_DATA 0x00000000
+#define DDRSS_PHY_1856_DATA 0x03000000
+#define DDRSS_PHY_1857_DATA 0x00000000
+#define DDRSS_PHY_1858_DATA 0x00000000
+#define DDRSS_PHY_1859_DATA 0x00000000
+#define DDRSS_PHY_1860_DATA 0x04102006
+#define DDRSS_PHY_1861_DATA 0x00041020
+#define DDRSS_PHY_1862_DATA 0x01C98C98
+#define DDRSS_PHY_1863_DATA 0x3F400000
+#define DDRSS_PHY_1864_DATA 0x3F3F1F3F
+#define DDRSS_PHY_1865_DATA 0x0000001F
+#define DDRSS_PHY_1866_DATA 0x00000000
+#define DDRSS_PHY_1867_DATA 0x00000000
+#define DDRSS_PHY_1868_DATA 0x00000000
+#define DDRSS_PHY_1869_DATA 0x00000001
+#define DDRSS_PHY_1870_DATA 0x00000000
+#define DDRSS_PHY_1871_DATA 0x00000000
+#define DDRSS_PHY_1872_DATA 0x00000000
+#define DDRSS_PHY_1873_DATA 0x00000000
+#define DDRSS_PHY_1874_DATA 0x76543210
+#define DDRSS_PHY_1875_DATA 0x06010198
+#define DDRSS_PHY_1876_DATA 0x00000000
+#define DDRSS_PHY_1877_DATA 0x00000000
+#define DDRSS_PHY_1878_DATA 0x00000000
+#define DDRSS_PHY_1879_DATA 0x00040700
+#define DDRSS_PHY_1880_DATA 0x00000000
+#define DDRSS_PHY_1881_DATA 0x00000000
+#define DDRSS_PHY_1882_DATA 0x00000000
+#define DDRSS_PHY_1883_DATA 0x00000000
+#define DDRSS_PHY_1884_DATA 0x00000000
+#define DDRSS_PHY_1885_DATA 0x00000002
+#define DDRSS_PHY_1886_DATA 0x00000000
+#define DDRSS_PHY_1887_DATA 0x00000000
+#define DDRSS_PHY_1888_DATA 0x00000AC4
+#define DDRSS_PHY_1889_DATA 0x04000004
+#define DDRSS_PHY_1890_DATA 0x00000000
+#define DDRSS_PHY_1891_DATA 0x00001142
+#define DDRSS_PHY_1892_DATA 0x01020000
+#define DDRSS_PHY_1893_DATA 0x00000080
+#define DDRSS_PHY_1894_DATA 0x03900390
+#define DDRSS_PHY_1895_DATA 0x03900390
+#define DDRSS_PHY_1896_DATA 0x03900390
+#define DDRSS_PHY_1897_DATA 0x03900390
+#define DDRSS_PHY_1898_DATA 0x03000300
+#define DDRSS_PHY_1899_DATA 0x03000300
+#define DDRSS_PHY_1900_DATA 0x00000300
+#define DDRSS_PHY_1901_DATA 0x00000300
+#define DDRSS_PHY_1902_DATA 0x00000300
+#define DDRSS_PHY_1903_DATA 0x00000300
+#define DDRSS_PHY_1904_DATA 0x00000005
+#define DDRSS_PHY_1905_DATA 0x3183BF77
+#define DDRSS_PHY_1906_DATA 0x00000000
+#define DDRSS_PHY_1907_DATA 0x0C000DFF
+#define DDRSS_PHY_1908_DATA 0x30000DFF
+#define DDRSS_PHY_1909_DATA 0x3F0DFF11
+#define DDRSS_PHY_1910_DATA 0x00EF0000
+#define DDRSS_PHY_1911_DATA 0x780DFFCC
+#define DDRSS_PHY_1912_DATA 0x00000C11
+#define DDRSS_PHY_1913_DATA 0x00018011
+#define DDRSS_PHY_1914_DATA 0x0089FF00
+#define DDRSS_PHY_1915_DATA 0x000C3F11
+#define DDRSS_PHY_1916_DATA 0x01990000
+#define DDRSS_PHY_1917_DATA 0x000C3F11
+#define DDRSS_PHY_1918_DATA 0x01990000
+#define DDRSS_PHY_1919_DATA 0x3F0DFF11
+#define DDRSS_PHY_1920_DATA 0x00EF0000
+#define DDRSS_PHY_1921_DATA 0x00018011
+#define DDRSS_PHY_1922_DATA 0x0089FF00
+#define DDRSS_PHY_1923_DATA 0x20040004
diff --git a/arch/arm/dts/k3-am62a-ddr.dtsi b/arch/arm/dts/k3-am62a-ddr.dtsi
new file mode 100644
index 0000000000000..15a0799550bac
--- /dev/null
+++ b/arch/arm/dts/k3-am62a-ddr.dtsi
@@ -0,0 +1,2814 @@
+// SPDX-License-Identifier: GPL-2.0+
+/*
+ * Copyright (C) 2020-2021 Texas Instruments Incorporated - https://www.ti.com/
+ */
+
+/ {
+	memorycontroller: memory-controller@f308000 {
+		compatible = "ti,am62a-ddrss";
+		reg = <0x00 0x0f308000 0x00 0x4000>,
+		      <0x00 0x43014000 0x00 0x100>;
+		reg-names = "cfg", "ctrl_mmr_lp4";
+		ti,ddr-freq1 = <DDRSS_PLL_FREQUENCY_1>;
+		ti,ddr-freq2 = <DDRSS_PLL_FREQUENCY_2>;
+		ti,ddr-fhs-cnt = <DDRSS_PLL_FHS_CNT>;
+
+		power-domains = <&k3_pds 170 TI_SCI_PD_SHARED>,
+			<&k3_pds 55 TI_SCI_PD_SHARED>;
+		clocks = <&k3_clks 170 1>, <&k3_clks 16 4>;
+
+		u-boot,dm-spl;
+
+		ti,ctl-data = <
+			DDRSS_CTL_0_DATA
+			DDRSS_CTL_1_DATA
+			DDRSS_CTL_2_DATA
+			DDRSS_CTL_3_DATA
+			DDRSS_CTL_4_DATA
+			DDRSS_CTL_5_DATA
+			DDRSS_CTL_6_DATA
+			DDRSS_CTL_7_DATA
+			DDRSS_CTL_8_DATA
+			DDRSS_CTL_9_DATA
+			DDRSS_CTL_10_DATA
+			DDRSS_CTL_11_DATA
+			DDRSS_CTL_12_DATA
+			DDRSS_CTL_13_DATA
+			DDRSS_CTL_14_DATA
+			DDRSS_CTL_15_DATA
+			DDRSS_CTL_16_DATA
+			DDRSS_CTL_17_DATA
+			DDRSS_CTL_18_DATA
+			DDRSS_CTL_19_DATA
+			DDRSS_CTL_20_DATA
+			DDRSS_CTL_21_DATA
+			DDRSS_CTL_22_DATA
+			DDRSS_CTL_23_DATA
+			DDRSS_CTL_24_DATA
+			DDRSS_CTL_25_DATA
+			DDRSS_CTL_26_DATA
+			DDRSS_CTL_27_DATA
+			DDRSS_CTL_28_DATA
+			DDRSS_CTL_29_DATA
+			DDRSS_CTL_30_DATA
+			DDRSS_CTL_31_DATA
+			DDRSS_CTL_32_DATA
+			DDRSS_CTL_33_DATA
+			DDRSS_CTL_34_DATA
+			DDRSS_CTL_35_DATA
+			DDRSS_CTL_36_DATA
+			DDRSS_CTL_37_DATA
+			DDRSS_CTL_38_DATA
+			DDRSS_CTL_39_DATA
+			DDRSS_CTL_40_DATA
+			DDRSS_CTL_41_DATA
+			DDRSS_CTL_42_DATA
+			DDRSS_CTL_43_DATA
+			DDRSS_CTL_44_DATA
+			DDRSS_CTL_45_DATA
+			DDRSS_CTL_46_DATA
+			DDRSS_CTL_47_DATA
+			DDRSS_CTL_48_DATA
+			DDRSS_CTL_49_DATA
+			DDRSS_CTL_50_DATA
+			DDRSS_CTL_51_DATA
+			DDRSS_CTL_52_DATA
+			DDRSS_CTL_53_DATA
+			DDRSS_CTL_54_DATA
+			DDRSS_CTL_55_DATA
+			DDRSS_CTL_56_DATA
+			DDRSS_CTL_57_DATA
+			DDRSS_CTL_58_DATA
+			DDRSS_CTL_59_DATA
+			DDRSS_CTL_60_DATA
+			DDRSS_CTL_61_DATA
+			DDRSS_CTL_62_DATA
+			DDRSS_CTL_63_DATA
+			DDRSS_CTL_64_DATA
+			DDRSS_CTL_65_DATA
+			DDRSS_CTL_66_DATA
+			DDRSS_CTL_67_DATA
+			DDRSS_CTL_68_DATA
+			DDRSS_CTL_69_DATA
+			DDRSS_CTL_70_DATA
+			DDRSS_CTL_71_DATA
+			DDRSS_CTL_72_DATA
+			DDRSS_CTL_73_DATA
+			DDRSS_CTL_74_DATA
+			DDRSS_CTL_75_DATA
+			DDRSS_CTL_76_DATA
+			DDRSS_CTL_77_DATA
+			DDRSS_CTL_78_DATA
+			DDRSS_CTL_79_DATA
+			DDRSS_CTL_80_DATA
+			DDRSS_CTL_81_DATA
+			DDRSS_CTL_82_DATA
+			DDRSS_CTL_83_DATA
+			DDRSS_CTL_84_DATA
+			DDRSS_CTL_85_DATA
+			DDRSS_CTL_86_DATA
+			DDRSS_CTL_87_DATA
+			DDRSS_CTL_88_DATA
+			DDRSS_CTL_89_DATA
+			DDRSS_CTL_90_DATA
+			DDRSS_CTL_91_DATA
+			DDRSS_CTL_92_DATA
+			DDRSS_CTL_93_DATA
+			DDRSS_CTL_94_DATA
+			DDRSS_CTL_95_DATA
+			DDRSS_CTL_96_DATA
+			DDRSS_CTL_97_DATA
+			DDRSS_CTL_98_DATA
+			DDRSS_CTL_99_DATA
+			DDRSS_CTL_100_DATA
+			DDRSS_CTL_101_DATA
+			DDRSS_CTL_102_DATA
+			DDRSS_CTL_103_DATA
+			DDRSS_CTL_104_DATA
+			DDRSS_CTL_105_DATA
+			DDRSS_CTL_106_DATA
+			DDRSS_CTL_107_DATA
+			DDRSS_CTL_108_DATA
+			DDRSS_CTL_109_DATA
+			DDRSS_CTL_110_DATA
+			DDRSS_CTL_111_DATA
+			DDRSS_CTL_112_DATA
+			DDRSS_CTL_113_DATA
+			DDRSS_CTL_114_DATA
+			DDRSS_CTL_115_DATA
+			DDRSS_CTL_116_DATA
+			DDRSS_CTL_117_DATA
+			DDRSS_CTL_118_DATA
+			DDRSS_CTL_119_DATA
+			DDRSS_CTL_120_DATA
+			DDRSS_CTL_121_DATA
+			DDRSS_CTL_122_DATA
+			DDRSS_CTL_123_DATA
+			DDRSS_CTL_124_DATA
+			DDRSS_CTL_125_DATA
+			DDRSS_CTL_126_DATA
+			DDRSS_CTL_127_DATA
+			DDRSS_CTL_128_DATA
+			DDRSS_CTL_129_DATA
+			DDRSS_CTL_130_DATA
+			DDRSS_CTL_131_DATA
+			DDRSS_CTL_132_DATA
+			DDRSS_CTL_133_DATA
+			DDRSS_CTL_134_DATA
+			DDRSS_CTL_135_DATA
+			DDRSS_CTL_136_DATA
+			DDRSS_CTL_137_DATA
+			DDRSS_CTL_138_DATA
+			DDRSS_CTL_139_DATA
+			DDRSS_CTL_140_DATA
+			DDRSS_CTL_141_DATA
+			DDRSS_CTL_142_DATA
+			DDRSS_CTL_143_DATA
+			DDRSS_CTL_144_DATA
+			DDRSS_CTL_145_DATA
+			DDRSS_CTL_146_DATA
+			DDRSS_CTL_147_DATA
+			DDRSS_CTL_148_DATA
+			DDRSS_CTL_149_DATA
+			DDRSS_CTL_150_DATA
+			DDRSS_CTL_151_DATA
+			DDRSS_CTL_152_DATA
+			DDRSS_CTL_153_DATA
+			DDRSS_CTL_154_DATA
+			DDRSS_CTL_155_DATA
+			DDRSS_CTL_156_DATA
+			DDRSS_CTL_157_DATA
+			DDRSS_CTL_158_DATA
+			DDRSS_CTL_159_DATA
+			DDRSS_CTL_160_DATA
+			DDRSS_CTL_161_DATA
+			DDRSS_CTL_162_DATA
+			DDRSS_CTL_163_DATA
+			DDRSS_CTL_164_DATA
+			DDRSS_CTL_165_DATA
+			DDRSS_CTL_166_DATA
+			DDRSS_CTL_167_DATA
+			DDRSS_CTL_168_DATA
+			DDRSS_CTL_169_DATA
+			DDRSS_CTL_170_DATA
+			DDRSS_CTL_171_DATA
+			DDRSS_CTL_172_DATA
+			DDRSS_CTL_173_DATA
+			DDRSS_CTL_174_DATA
+			DDRSS_CTL_175_DATA
+			DDRSS_CTL_176_DATA
+			DDRSS_CTL_177_DATA
+			DDRSS_CTL_178_DATA
+			DDRSS_CTL_179_DATA
+			DDRSS_CTL_180_DATA
+			DDRSS_CTL_181_DATA
+			DDRSS_CTL_182_DATA
+			DDRSS_CTL_183_DATA
+			DDRSS_CTL_184_DATA
+			DDRSS_CTL_185_DATA
+			DDRSS_CTL_186_DATA
+			DDRSS_CTL_187_DATA
+			DDRSS_CTL_188_DATA
+			DDRSS_CTL_189_DATA
+			DDRSS_CTL_190_DATA
+			DDRSS_CTL_191_DATA
+			DDRSS_CTL_192_DATA
+			DDRSS_CTL_193_DATA
+			DDRSS_CTL_194_DATA
+			DDRSS_CTL_195_DATA
+			DDRSS_CTL_196_DATA
+			DDRSS_CTL_197_DATA
+			DDRSS_CTL_198_DATA
+			DDRSS_CTL_199_DATA
+			DDRSS_CTL_200_DATA
+			DDRSS_CTL_201_DATA
+			DDRSS_CTL_202_DATA
+			DDRSS_CTL_203_DATA
+			DDRSS_CTL_204_DATA
+			DDRSS_CTL_205_DATA
+			DDRSS_CTL_206_DATA
+			DDRSS_CTL_207_DATA
+			DDRSS_CTL_208_DATA
+			DDRSS_CTL_209_DATA
+			DDRSS_CTL_210_DATA
+			DDRSS_CTL_211_DATA
+			DDRSS_CTL_212_DATA
+			DDRSS_CTL_213_DATA
+			DDRSS_CTL_214_DATA
+			DDRSS_CTL_215_DATA
+			DDRSS_CTL_216_DATA
+			DDRSS_CTL_217_DATA
+			DDRSS_CTL_218_DATA
+			DDRSS_CTL_219_DATA
+			DDRSS_CTL_220_DATA
+			DDRSS_CTL_221_DATA
+			DDRSS_CTL_222_DATA
+			DDRSS_CTL_223_DATA
+			DDRSS_CTL_224_DATA
+			DDRSS_CTL_225_DATA
+			DDRSS_CTL_226_DATA
+			DDRSS_CTL_227_DATA
+			DDRSS_CTL_228_DATA
+			DDRSS_CTL_229_DATA
+			DDRSS_CTL_230_DATA
+			DDRSS_CTL_231_DATA
+			DDRSS_CTL_232_DATA
+			DDRSS_CTL_233_DATA
+			DDRSS_CTL_234_DATA
+			DDRSS_CTL_235_DATA
+			DDRSS_CTL_236_DATA
+			DDRSS_CTL_237_DATA
+			DDRSS_CTL_238_DATA
+			DDRSS_CTL_239_DATA
+			DDRSS_CTL_240_DATA
+			DDRSS_CTL_241_DATA
+			DDRSS_CTL_242_DATA
+			DDRSS_CTL_243_DATA
+			DDRSS_CTL_244_DATA
+			DDRSS_CTL_245_DATA
+			DDRSS_CTL_246_DATA
+			DDRSS_CTL_247_DATA
+			DDRSS_CTL_248_DATA
+			DDRSS_CTL_249_DATA
+			DDRSS_CTL_250_DATA
+			DDRSS_CTL_251_DATA
+			DDRSS_CTL_252_DATA
+			DDRSS_CTL_253_DATA
+			DDRSS_CTL_254_DATA
+			DDRSS_CTL_255_DATA
+			DDRSS_CTL_256_DATA
+			DDRSS_CTL_257_DATA
+			DDRSS_CTL_258_DATA
+			DDRSS_CTL_259_DATA
+			DDRSS_CTL_260_DATA
+			DDRSS_CTL_261_DATA
+			DDRSS_CTL_262_DATA
+			DDRSS_CTL_263_DATA
+			DDRSS_CTL_264_DATA
+			DDRSS_CTL_265_DATA
+			DDRSS_CTL_266_DATA
+			DDRSS_CTL_267_DATA
+			DDRSS_CTL_268_DATA
+			DDRSS_CTL_269_DATA
+			DDRSS_CTL_270_DATA
+			DDRSS_CTL_271_DATA
+			DDRSS_CTL_272_DATA
+			DDRSS_CTL_273_DATA
+			DDRSS_CTL_274_DATA
+			DDRSS_CTL_275_DATA
+			DDRSS_CTL_276_DATA
+			DDRSS_CTL_277_DATA
+			DDRSS_CTL_278_DATA
+			DDRSS_CTL_279_DATA
+			DDRSS_CTL_280_DATA
+			DDRSS_CTL_281_DATA
+			DDRSS_CTL_282_DATA
+			DDRSS_CTL_283_DATA
+			DDRSS_CTL_284_DATA
+			DDRSS_CTL_285_DATA
+			DDRSS_CTL_286_DATA
+			DDRSS_CTL_287_DATA
+			DDRSS_CTL_288_DATA
+			DDRSS_CTL_289_DATA
+			DDRSS_CTL_290_DATA
+			DDRSS_CTL_291_DATA
+			DDRSS_CTL_292_DATA
+			DDRSS_CTL_293_DATA
+			DDRSS_CTL_294_DATA
+			DDRSS_CTL_295_DATA
+			DDRSS_CTL_296_DATA
+			DDRSS_CTL_297_DATA
+			DDRSS_CTL_298_DATA
+			DDRSS_CTL_299_DATA
+			DDRSS_CTL_300_DATA
+			DDRSS_CTL_301_DATA
+			DDRSS_CTL_302_DATA
+			DDRSS_CTL_303_DATA
+			DDRSS_CTL_304_DATA
+			DDRSS_CTL_305_DATA
+			DDRSS_CTL_306_DATA
+			DDRSS_CTL_307_DATA
+			DDRSS_CTL_308_DATA
+			DDRSS_CTL_309_DATA
+			DDRSS_CTL_310_DATA
+			DDRSS_CTL_311_DATA
+			DDRSS_CTL_312_DATA
+			DDRSS_CTL_313_DATA
+			DDRSS_CTL_314_DATA
+			DDRSS_CTL_315_DATA
+			DDRSS_CTL_316_DATA
+			DDRSS_CTL_317_DATA
+			DDRSS_CTL_318_DATA
+			DDRSS_CTL_319_DATA
+			DDRSS_CTL_320_DATA
+			DDRSS_CTL_321_DATA
+			DDRSS_CTL_322_DATA
+			DDRSS_CTL_323_DATA
+			DDRSS_CTL_324_DATA
+			DDRSS_CTL_325_DATA
+			DDRSS_CTL_326_DATA
+			DDRSS_CTL_327_DATA
+			DDRSS_CTL_328_DATA
+			DDRSS_CTL_329_DATA
+			DDRSS_CTL_330_DATA
+			DDRSS_CTL_331_DATA
+			DDRSS_CTL_332_DATA
+			DDRSS_CTL_333_DATA
+			DDRSS_CTL_334_DATA
+			DDRSS_CTL_335_DATA
+			DDRSS_CTL_336_DATA
+			DDRSS_CTL_337_DATA
+			DDRSS_CTL_338_DATA
+			DDRSS_CTL_339_DATA
+			DDRSS_CTL_340_DATA
+			DDRSS_CTL_341_DATA
+			DDRSS_CTL_342_DATA
+			DDRSS_CTL_343_DATA
+			DDRSS_CTL_344_DATA
+			DDRSS_CTL_345_DATA
+			DDRSS_CTL_346_DATA
+			DDRSS_CTL_347_DATA
+			DDRSS_CTL_348_DATA
+			DDRSS_CTL_349_DATA
+			DDRSS_CTL_350_DATA
+			DDRSS_CTL_351_DATA
+			DDRSS_CTL_352_DATA
+			DDRSS_CTL_353_DATA
+			DDRSS_CTL_354_DATA
+			DDRSS_CTL_355_DATA
+			DDRSS_CTL_356_DATA
+			DDRSS_CTL_357_DATA
+			DDRSS_CTL_358_DATA
+			DDRSS_CTL_359_DATA
+			DDRSS_CTL_360_DATA
+			DDRSS_CTL_361_DATA
+			DDRSS_CTL_362_DATA
+			DDRSS_CTL_363_DATA
+			DDRSS_CTL_364_DATA
+			DDRSS_CTL_365_DATA
+			DDRSS_CTL_366_DATA
+			DDRSS_CTL_367_DATA
+			DDRSS_CTL_368_DATA
+			DDRSS_CTL_369_DATA
+			DDRSS_CTL_370_DATA
+			DDRSS_CTL_371_DATA
+			DDRSS_CTL_372_DATA
+			DDRSS_CTL_373_DATA
+			DDRSS_CTL_374_DATA
+			DDRSS_CTL_375_DATA
+			DDRSS_CTL_376_DATA
+			DDRSS_CTL_377_DATA
+			DDRSS_CTL_378_DATA
+			DDRSS_CTL_379_DATA
+			DDRSS_CTL_380_DATA
+			DDRSS_CTL_381_DATA
+			DDRSS_CTL_382_DATA
+			DDRSS_CTL_383_DATA
+			DDRSS_CTL_384_DATA
+			DDRSS_CTL_385_DATA
+			DDRSS_CTL_386_DATA
+			DDRSS_CTL_387_DATA
+			DDRSS_CTL_388_DATA
+			DDRSS_CTL_389_DATA
+			DDRSS_CTL_390_DATA
+			DDRSS_CTL_391_DATA
+			DDRSS_CTL_392_DATA
+			DDRSS_CTL_393_DATA
+			DDRSS_CTL_394_DATA
+			DDRSS_CTL_395_DATA
+			DDRSS_CTL_396_DATA
+			DDRSS_CTL_397_DATA
+			DDRSS_CTL_398_DATA
+			DDRSS_CTL_399_DATA
+			DDRSS_CTL_400_DATA
+			DDRSS_CTL_401_DATA
+			DDRSS_CTL_402_DATA
+			DDRSS_CTL_403_DATA
+			DDRSS_CTL_404_DATA
+			DDRSS_CTL_405_DATA
+			DDRSS_CTL_406_DATA
+			DDRSS_CTL_407_DATA
+			DDRSS_CTL_408_DATA
+			DDRSS_CTL_409_DATA
+			DDRSS_CTL_410_DATA
+			DDRSS_CTL_411_DATA
+			DDRSS_CTL_412_DATA
+			DDRSS_CTL_413_DATA
+			DDRSS_CTL_414_DATA
+			DDRSS_CTL_415_DATA
+			DDRSS_CTL_416_DATA
+			DDRSS_CTL_417_DATA
+			DDRSS_CTL_418_DATA
+			DDRSS_CTL_419_DATA
+			DDRSS_CTL_420_DATA
+			DDRSS_CTL_421_DATA
+			DDRSS_CTL_422_DATA
+			DDRSS_CTL_423_DATA
+			DDRSS_CTL_424_DATA
+			DDRSS_CTL_425_DATA
+			DDRSS_CTL_426_DATA
+			DDRSS_CTL_427_DATA
+			DDRSS_CTL_428_DATA
+			DDRSS_CTL_429_DATA
+			DDRSS_CTL_430_DATA
+			DDRSS_CTL_431_DATA
+			DDRSS_CTL_432_DATA
+			DDRSS_CTL_433_DATA
+			DDRSS_CTL_434_DATA
+		>;
+
+		ti,pi-data = <
+			DDRSS_PI_0_DATA
+			DDRSS_PI_1_DATA
+			DDRSS_PI_2_DATA
+			DDRSS_PI_3_DATA
+			DDRSS_PI_4_DATA
+			DDRSS_PI_5_DATA
+			DDRSS_PI_6_DATA
+			DDRSS_PI_7_DATA
+			DDRSS_PI_8_DATA
+			DDRSS_PI_9_DATA
+			DDRSS_PI_10_DATA
+			DDRSS_PI_11_DATA
+			DDRSS_PI_12_DATA
+			DDRSS_PI_13_DATA
+			DDRSS_PI_14_DATA
+			DDRSS_PI_15_DATA
+			DDRSS_PI_16_DATA
+			DDRSS_PI_17_DATA
+			DDRSS_PI_18_DATA
+			DDRSS_PI_19_DATA
+			DDRSS_PI_20_DATA
+			DDRSS_PI_21_DATA
+			DDRSS_PI_22_DATA
+			DDRSS_PI_23_DATA
+			DDRSS_PI_24_DATA
+			DDRSS_PI_25_DATA
+			DDRSS_PI_26_DATA
+			DDRSS_PI_27_DATA
+			DDRSS_PI_28_DATA
+			DDRSS_PI_29_DATA
+			DDRSS_PI_30_DATA
+			DDRSS_PI_31_DATA
+			DDRSS_PI_32_DATA
+			DDRSS_PI_33_DATA
+			DDRSS_PI_34_DATA
+			DDRSS_PI_35_DATA
+			DDRSS_PI_36_DATA
+			DDRSS_PI_37_DATA
+			DDRSS_PI_38_DATA
+			DDRSS_PI_39_DATA
+			DDRSS_PI_40_DATA
+			DDRSS_PI_41_DATA
+			DDRSS_PI_42_DATA
+			DDRSS_PI_43_DATA
+			DDRSS_PI_44_DATA
+			DDRSS_PI_45_DATA
+			DDRSS_PI_46_DATA
+			DDRSS_PI_47_DATA
+			DDRSS_PI_48_DATA
+			DDRSS_PI_49_DATA
+			DDRSS_PI_50_DATA
+			DDRSS_PI_51_DATA
+			DDRSS_PI_52_DATA
+			DDRSS_PI_53_DATA
+			DDRSS_PI_54_DATA
+			DDRSS_PI_55_DATA
+			DDRSS_PI_56_DATA
+			DDRSS_PI_57_DATA
+			DDRSS_PI_58_DATA
+			DDRSS_PI_59_DATA
+			DDRSS_PI_60_DATA
+			DDRSS_PI_61_DATA
+			DDRSS_PI_62_DATA
+			DDRSS_PI_63_DATA
+			DDRSS_PI_64_DATA
+			DDRSS_PI_65_DATA
+			DDRSS_PI_66_DATA
+			DDRSS_PI_67_DATA
+			DDRSS_PI_68_DATA
+			DDRSS_PI_69_DATA
+			DDRSS_PI_70_DATA
+			DDRSS_PI_71_DATA
+			DDRSS_PI_72_DATA
+			DDRSS_PI_73_DATA
+			DDRSS_PI_74_DATA
+			DDRSS_PI_75_DATA
+			DDRSS_PI_76_DATA
+			DDRSS_PI_77_DATA
+			DDRSS_PI_78_DATA
+			DDRSS_PI_79_DATA
+			DDRSS_PI_80_DATA
+			DDRSS_PI_81_DATA
+			DDRSS_PI_82_DATA
+			DDRSS_PI_83_DATA
+			DDRSS_PI_84_DATA
+			DDRSS_PI_85_DATA
+			DDRSS_PI_86_DATA
+			DDRSS_PI_87_DATA
+			DDRSS_PI_88_DATA
+			DDRSS_PI_89_DATA
+			DDRSS_PI_90_DATA
+			DDRSS_PI_91_DATA
+			DDRSS_PI_92_DATA
+			DDRSS_PI_93_DATA
+			DDRSS_PI_94_DATA
+			DDRSS_PI_95_DATA
+			DDRSS_PI_96_DATA
+			DDRSS_PI_97_DATA
+			DDRSS_PI_98_DATA
+			DDRSS_PI_99_DATA
+			DDRSS_PI_100_DATA
+			DDRSS_PI_101_DATA
+			DDRSS_PI_102_DATA
+			DDRSS_PI_103_DATA
+			DDRSS_PI_104_DATA
+			DDRSS_PI_105_DATA
+			DDRSS_PI_106_DATA
+			DDRSS_PI_107_DATA
+			DDRSS_PI_108_DATA
+			DDRSS_PI_109_DATA
+			DDRSS_PI_110_DATA
+			DDRSS_PI_111_DATA
+			DDRSS_PI_112_DATA
+			DDRSS_PI_113_DATA
+			DDRSS_PI_114_DATA
+			DDRSS_PI_115_DATA
+			DDRSS_PI_116_DATA
+			DDRSS_PI_117_DATA
+			DDRSS_PI_118_DATA
+			DDRSS_PI_119_DATA
+			DDRSS_PI_120_DATA
+			DDRSS_PI_121_DATA
+			DDRSS_PI_122_DATA
+			DDRSS_PI_123_DATA
+			DDRSS_PI_124_DATA
+			DDRSS_PI_125_DATA
+			DDRSS_PI_126_DATA
+			DDRSS_PI_127_DATA
+			DDRSS_PI_128_DATA
+			DDRSS_PI_129_DATA
+			DDRSS_PI_130_DATA
+			DDRSS_PI_131_DATA
+			DDRSS_PI_132_DATA
+			DDRSS_PI_133_DATA
+			DDRSS_PI_134_DATA
+			DDRSS_PI_135_DATA
+			DDRSS_PI_136_DATA
+			DDRSS_PI_137_DATA
+			DDRSS_PI_138_DATA
+			DDRSS_PI_139_DATA
+			DDRSS_PI_140_DATA
+			DDRSS_PI_141_DATA
+			DDRSS_PI_142_DATA
+			DDRSS_PI_143_DATA
+			DDRSS_PI_144_DATA
+			DDRSS_PI_145_DATA
+			DDRSS_PI_146_DATA
+			DDRSS_PI_147_DATA
+			DDRSS_PI_148_DATA
+			DDRSS_PI_149_DATA
+			DDRSS_PI_150_DATA
+			DDRSS_PI_151_DATA
+			DDRSS_PI_152_DATA
+			DDRSS_PI_153_DATA
+			DDRSS_PI_154_DATA
+			DDRSS_PI_155_DATA
+			DDRSS_PI_156_DATA
+			DDRSS_PI_157_DATA
+			DDRSS_PI_158_DATA
+			DDRSS_PI_159_DATA
+			DDRSS_PI_160_DATA
+			DDRSS_PI_161_DATA
+			DDRSS_PI_162_DATA
+			DDRSS_PI_163_DATA
+			DDRSS_PI_164_DATA
+			DDRSS_PI_165_DATA
+			DDRSS_PI_166_DATA
+			DDRSS_PI_167_DATA
+			DDRSS_PI_168_DATA
+			DDRSS_PI_169_DATA
+			DDRSS_PI_170_DATA
+			DDRSS_PI_171_DATA
+			DDRSS_PI_172_DATA
+			DDRSS_PI_173_DATA
+			DDRSS_PI_174_DATA
+			DDRSS_PI_175_DATA
+			DDRSS_PI_176_DATA
+			DDRSS_PI_177_DATA
+			DDRSS_PI_178_DATA
+			DDRSS_PI_179_DATA
+			DDRSS_PI_180_DATA
+			DDRSS_PI_181_DATA
+			DDRSS_PI_182_DATA
+			DDRSS_PI_183_DATA
+			DDRSS_PI_184_DATA
+			DDRSS_PI_185_DATA
+			DDRSS_PI_186_DATA
+			DDRSS_PI_187_DATA
+			DDRSS_PI_188_DATA
+			DDRSS_PI_189_DATA
+			DDRSS_PI_190_DATA
+			DDRSS_PI_191_DATA
+			DDRSS_PI_192_DATA
+			DDRSS_PI_193_DATA
+			DDRSS_PI_194_DATA
+			DDRSS_PI_195_DATA
+			DDRSS_PI_196_DATA
+			DDRSS_PI_197_DATA
+			DDRSS_PI_198_DATA
+			DDRSS_PI_199_DATA
+			DDRSS_PI_200_DATA
+			DDRSS_PI_201_DATA
+			DDRSS_PI_202_DATA
+			DDRSS_PI_203_DATA
+			DDRSS_PI_204_DATA
+			DDRSS_PI_205_DATA
+			DDRSS_PI_206_DATA
+			DDRSS_PI_207_DATA
+			DDRSS_PI_208_DATA
+			DDRSS_PI_209_DATA
+			DDRSS_PI_210_DATA
+			DDRSS_PI_211_DATA
+			DDRSS_PI_212_DATA
+			DDRSS_PI_213_DATA
+			DDRSS_PI_214_DATA
+			DDRSS_PI_215_DATA
+			DDRSS_PI_216_DATA
+			DDRSS_PI_217_DATA
+			DDRSS_PI_218_DATA
+			DDRSS_PI_219_DATA
+			DDRSS_PI_220_DATA
+			DDRSS_PI_221_DATA
+			DDRSS_PI_222_DATA
+			DDRSS_PI_223_DATA
+			DDRSS_PI_224_DATA
+			DDRSS_PI_225_DATA
+			DDRSS_PI_226_DATA
+			DDRSS_PI_227_DATA
+			DDRSS_PI_228_DATA
+			DDRSS_PI_229_DATA
+			DDRSS_PI_230_DATA
+			DDRSS_PI_231_DATA
+			DDRSS_PI_232_DATA
+			DDRSS_PI_233_DATA
+			DDRSS_PI_234_DATA
+			DDRSS_PI_235_DATA
+			DDRSS_PI_236_DATA
+			DDRSS_PI_237_DATA
+			DDRSS_PI_238_DATA
+			DDRSS_PI_239_DATA
+			DDRSS_PI_240_DATA
+			DDRSS_PI_241_DATA
+			DDRSS_PI_242_DATA
+			DDRSS_PI_243_DATA
+			DDRSS_PI_244_DATA
+			DDRSS_PI_245_DATA
+			DDRSS_PI_246_DATA
+			DDRSS_PI_247_DATA
+			DDRSS_PI_248_DATA
+			DDRSS_PI_249_DATA
+			DDRSS_PI_250_DATA
+			DDRSS_PI_251_DATA
+			DDRSS_PI_252_DATA
+			DDRSS_PI_253_DATA
+			DDRSS_PI_254_DATA
+			DDRSS_PI_255_DATA
+			DDRSS_PI_256_DATA
+			DDRSS_PI_257_DATA
+			DDRSS_PI_258_DATA
+			DDRSS_PI_259_DATA
+			DDRSS_PI_260_DATA
+			DDRSS_PI_261_DATA
+			DDRSS_PI_262_DATA
+			DDRSS_PI_263_DATA
+			DDRSS_PI_264_DATA
+			DDRSS_PI_265_DATA
+			DDRSS_PI_266_DATA
+			DDRSS_PI_267_DATA
+			DDRSS_PI_268_DATA
+			DDRSS_PI_269_DATA
+			DDRSS_PI_270_DATA
+			DDRSS_PI_271_DATA
+			DDRSS_PI_272_DATA
+			DDRSS_PI_273_DATA
+			DDRSS_PI_274_DATA
+			DDRSS_PI_275_DATA
+			DDRSS_PI_276_DATA
+			DDRSS_PI_277_DATA
+			DDRSS_PI_278_DATA
+			DDRSS_PI_279_DATA
+			DDRSS_PI_280_DATA
+			DDRSS_PI_281_DATA
+			DDRSS_PI_282_DATA
+			DDRSS_PI_283_DATA
+			DDRSS_PI_284_DATA
+			DDRSS_PI_285_DATA
+			DDRSS_PI_286_DATA
+			DDRSS_PI_287_DATA
+			DDRSS_PI_288_DATA
+			DDRSS_PI_289_DATA
+			DDRSS_PI_290_DATA
+			DDRSS_PI_291_DATA
+			DDRSS_PI_292_DATA
+			DDRSS_PI_293_DATA
+			DDRSS_PI_294_DATA
+			DDRSS_PI_295_DATA
+			DDRSS_PI_296_DATA
+			DDRSS_PI_297_DATA
+			DDRSS_PI_298_DATA
+			DDRSS_PI_299_DATA
+			DDRSS_PI_300_DATA
+			DDRSS_PI_301_DATA
+			DDRSS_PI_302_DATA
+			DDRSS_PI_303_DATA
+			DDRSS_PI_304_DATA
+			DDRSS_PI_305_DATA
+			DDRSS_PI_306_DATA
+			DDRSS_PI_307_DATA
+			DDRSS_PI_308_DATA
+			DDRSS_PI_309_DATA
+			DDRSS_PI_310_DATA
+			DDRSS_PI_311_DATA
+			DDRSS_PI_312_DATA
+			DDRSS_PI_313_DATA
+			DDRSS_PI_314_DATA
+			DDRSS_PI_315_DATA
+			DDRSS_PI_316_DATA
+			DDRSS_PI_317_DATA
+			DDRSS_PI_318_DATA
+			DDRSS_PI_319_DATA
+			DDRSS_PI_320_DATA
+			DDRSS_PI_321_DATA
+			DDRSS_PI_322_DATA
+			DDRSS_PI_323_DATA
+			DDRSS_PI_324_DATA
+			DDRSS_PI_325_DATA
+			DDRSS_PI_326_DATA
+			DDRSS_PI_327_DATA
+			DDRSS_PI_328_DATA
+			DDRSS_PI_329_DATA
+			DDRSS_PI_330_DATA
+			DDRSS_PI_331_DATA
+			DDRSS_PI_332_DATA
+			DDRSS_PI_333_DATA
+			DDRSS_PI_334_DATA
+			DDRSS_PI_335_DATA
+			DDRSS_PI_336_DATA
+			DDRSS_PI_337_DATA
+			DDRSS_PI_338_DATA
+			DDRSS_PI_339_DATA
+			DDRSS_PI_340_DATA
+			DDRSS_PI_341_DATA
+			DDRSS_PI_342_DATA
+			DDRSS_PI_343_DATA
+			DDRSS_PI_344_DATA
+			DDRSS_PI_345_DATA
+			DDRSS_PI_346_DATA
+			DDRSS_PI_347_DATA
+			DDRSS_PI_348_DATA
+			DDRSS_PI_349_DATA
+			DDRSS_PI_350_DATA
+			DDRSS_PI_351_DATA
+			DDRSS_PI_352_DATA
+			DDRSS_PI_353_DATA
+			DDRSS_PI_354_DATA
+			DDRSS_PI_355_DATA
+			DDRSS_PI_356_DATA
+			DDRSS_PI_357_DATA
+			DDRSS_PI_358_DATA
+			DDRSS_PI_359_DATA
+			DDRSS_PI_360_DATA
+			DDRSS_PI_361_DATA
+			DDRSS_PI_362_DATA
+			DDRSS_PI_363_DATA
+			DDRSS_PI_364_DATA
+			DDRSS_PI_365_DATA
+			DDRSS_PI_366_DATA
+			DDRSS_PI_367_DATA
+			DDRSS_PI_368_DATA
+			DDRSS_PI_369_DATA
+			DDRSS_PI_370_DATA
+			DDRSS_PI_371_DATA
+			DDRSS_PI_372_DATA
+			DDRSS_PI_373_DATA
+			DDRSS_PI_374_DATA
+			DDRSS_PI_375_DATA
+			DDRSS_PI_376_DATA
+			DDRSS_PI_377_DATA
+			DDRSS_PI_378_DATA
+			DDRSS_PI_379_DATA
+			DDRSS_PI_380_DATA
+			DDRSS_PI_381_DATA
+			DDRSS_PI_382_DATA
+			DDRSS_PI_383_DATA
+			DDRSS_PI_384_DATA
+			DDRSS_PI_385_DATA
+			DDRSS_PI_386_DATA
+			DDRSS_PI_387_DATA
+			DDRSS_PI_388_DATA
+			DDRSS_PI_389_DATA
+			DDRSS_PI_390_DATA
+			DDRSS_PI_391_DATA
+			DDRSS_PI_392_DATA
+			DDRSS_PI_393_DATA
+			DDRSS_PI_394_DATA
+			DDRSS_PI_395_DATA
+			DDRSS_PI_396_DATA
+			DDRSS_PI_397_DATA
+			DDRSS_PI_398_DATA
+			DDRSS_PI_399_DATA
+			DDRSS_PI_400_DATA
+			DDRSS_PI_401_DATA
+			DDRSS_PI_402_DATA
+			DDRSS_PI_403_DATA
+			DDRSS_PI_404_DATA
+			DDRSS_PI_405_DATA
+			DDRSS_PI_406_DATA
+			DDRSS_PI_407_DATA
+			DDRSS_PI_408_DATA
+			DDRSS_PI_409_DATA
+			DDRSS_PI_410_DATA
+			DDRSS_PI_411_DATA
+			DDRSS_PI_412_DATA
+			DDRSS_PI_413_DATA
+			DDRSS_PI_414_DATA
+			DDRSS_PI_415_DATA
+			DDRSS_PI_416_DATA
+			DDRSS_PI_417_DATA
+			DDRSS_PI_418_DATA
+			DDRSS_PI_419_DATA
+			DDRSS_PI_420_DATA
+			DDRSS_PI_421_DATA
+			DDRSS_PI_422_DATA
+			DDRSS_PI_423_DATA
+		>;
+
+		ti,phy-data = <
+			DDRSS_PHY_0_DATA
+			DDRSS_PHY_1_DATA
+			DDRSS_PHY_2_DATA
+			DDRSS_PHY_3_DATA
+			DDRSS_PHY_4_DATA
+			DDRSS_PHY_5_DATA
+			DDRSS_PHY_6_DATA
+			DDRSS_PHY_7_DATA
+			DDRSS_PHY_8_DATA
+			DDRSS_PHY_9_DATA
+			DDRSS_PHY_10_DATA
+			DDRSS_PHY_11_DATA
+			DDRSS_PHY_12_DATA
+			DDRSS_PHY_13_DATA
+			DDRSS_PHY_14_DATA
+			DDRSS_PHY_15_DATA
+			DDRSS_PHY_16_DATA
+			DDRSS_PHY_17_DATA
+			DDRSS_PHY_18_DATA
+			DDRSS_PHY_19_DATA
+			DDRSS_PHY_20_DATA
+			DDRSS_PHY_21_DATA
+			DDRSS_PHY_22_DATA
+			DDRSS_PHY_23_DATA
+			DDRSS_PHY_24_DATA
+			DDRSS_PHY_25_DATA
+			DDRSS_PHY_26_DATA
+			DDRSS_PHY_27_DATA
+			DDRSS_PHY_28_DATA
+			DDRSS_PHY_29_DATA
+			DDRSS_PHY_30_DATA
+			DDRSS_PHY_31_DATA
+			DDRSS_PHY_32_DATA
+			DDRSS_PHY_33_DATA
+			DDRSS_PHY_34_DATA
+			DDRSS_PHY_35_DATA
+			DDRSS_PHY_36_DATA
+			DDRSS_PHY_37_DATA
+			DDRSS_PHY_38_DATA
+			DDRSS_PHY_39_DATA
+			DDRSS_PHY_40_DATA
+			DDRSS_PHY_41_DATA
+			DDRSS_PHY_42_DATA
+			DDRSS_PHY_43_DATA
+			DDRSS_PHY_44_DATA
+			DDRSS_PHY_45_DATA
+			DDRSS_PHY_46_DATA
+			DDRSS_PHY_47_DATA
+			DDRSS_PHY_48_DATA
+			DDRSS_PHY_49_DATA
+			DDRSS_PHY_50_DATA
+			DDRSS_PHY_51_DATA
+			DDRSS_PHY_52_DATA
+			DDRSS_PHY_53_DATA
+			DDRSS_PHY_54_DATA
+			DDRSS_PHY_55_DATA
+			DDRSS_PHY_56_DATA
+			DDRSS_PHY_57_DATA
+			DDRSS_PHY_58_DATA
+			DDRSS_PHY_59_DATA
+			DDRSS_PHY_60_DATA
+			DDRSS_PHY_61_DATA
+			DDRSS_PHY_62_DATA
+			DDRSS_PHY_63_DATA
+			DDRSS_PHY_64_DATA
+			DDRSS_PHY_65_DATA
+			DDRSS_PHY_66_DATA
+			DDRSS_PHY_67_DATA
+			DDRSS_PHY_68_DATA
+			DDRSS_PHY_69_DATA
+			DDRSS_PHY_70_DATA
+			DDRSS_PHY_71_DATA
+			DDRSS_PHY_72_DATA
+			DDRSS_PHY_73_DATA
+			DDRSS_PHY_74_DATA
+			DDRSS_PHY_75_DATA
+			DDRSS_PHY_76_DATA
+			DDRSS_PHY_77_DATA
+			DDRSS_PHY_78_DATA
+			DDRSS_PHY_79_DATA
+			DDRSS_PHY_80_DATA
+			DDRSS_PHY_81_DATA
+			DDRSS_PHY_82_DATA
+			DDRSS_PHY_83_DATA
+			DDRSS_PHY_84_DATA
+			DDRSS_PHY_85_DATA
+			DDRSS_PHY_86_DATA
+			DDRSS_PHY_87_DATA
+			DDRSS_PHY_88_DATA
+			DDRSS_PHY_89_DATA
+			DDRSS_PHY_90_DATA
+			DDRSS_PHY_91_DATA
+			DDRSS_PHY_92_DATA
+			DDRSS_PHY_93_DATA
+			DDRSS_PHY_94_DATA
+			DDRSS_PHY_95_DATA
+			DDRSS_PHY_96_DATA
+			DDRSS_PHY_97_DATA
+			DDRSS_PHY_98_DATA
+			DDRSS_PHY_99_DATA
+			DDRSS_PHY_100_DATA
+			DDRSS_PHY_101_DATA
+			DDRSS_PHY_102_DATA
+			DDRSS_PHY_103_DATA
+			DDRSS_PHY_104_DATA
+			DDRSS_PHY_105_DATA
+			DDRSS_PHY_106_DATA
+			DDRSS_PHY_107_DATA
+			DDRSS_PHY_108_DATA
+			DDRSS_PHY_109_DATA
+			DDRSS_PHY_110_DATA
+			DDRSS_PHY_111_DATA
+			DDRSS_PHY_112_DATA
+			DDRSS_PHY_113_DATA
+			DDRSS_PHY_114_DATA
+			DDRSS_PHY_115_DATA
+			DDRSS_PHY_116_DATA
+			DDRSS_PHY_117_DATA
+			DDRSS_PHY_118_DATA
+			DDRSS_PHY_119_DATA
+			DDRSS_PHY_120_DATA
+			DDRSS_PHY_121_DATA
+			DDRSS_PHY_122_DATA
+			DDRSS_PHY_123_DATA
+			DDRSS_PHY_124_DATA
+			DDRSS_PHY_125_DATA
+			DDRSS_PHY_126_DATA
+			DDRSS_PHY_127_DATA
+			DDRSS_PHY_128_DATA
+			DDRSS_PHY_129_DATA
+			DDRSS_PHY_130_DATA
+			DDRSS_PHY_131_DATA
+			DDRSS_PHY_132_DATA
+			DDRSS_PHY_133_DATA
+			DDRSS_PHY_134_DATA
+			DDRSS_PHY_135_DATA
+			DDRSS_PHY_136_DATA
+			DDRSS_PHY_137_DATA
+			DDRSS_PHY_138_DATA
+			DDRSS_PHY_139_DATA
+			DDRSS_PHY_140_DATA
+			DDRSS_PHY_141_DATA
+			DDRSS_PHY_142_DATA
+			DDRSS_PHY_143_DATA
+			DDRSS_PHY_144_DATA
+			DDRSS_PHY_145_DATA
+			DDRSS_PHY_146_DATA
+			DDRSS_PHY_147_DATA
+			DDRSS_PHY_148_DATA
+			DDRSS_PHY_149_DATA
+			DDRSS_PHY_150_DATA
+			DDRSS_PHY_151_DATA
+			DDRSS_PHY_152_DATA
+			DDRSS_PHY_153_DATA
+			DDRSS_PHY_154_DATA
+			DDRSS_PHY_155_DATA
+			DDRSS_PHY_156_DATA
+			DDRSS_PHY_157_DATA
+			DDRSS_PHY_158_DATA
+			DDRSS_PHY_159_DATA
+			DDRSS_PHY_160_DATA
+			DDRSS_PHY_161_DATA
+			DDRSS_PHY_162_DATA
+			DDRSS_PHY_163_DATA
+			DDRSS_PHY_164_DATA
+			DDRSS_PHY_165_DATA
+			DDRSS_PHY_166_DATA
+			DDRSS_PHY_167_DATA
+			DDRSS_PHY_168_DATA
+			DDRSS_PHY_169_DATA
+			DDRSS_PHY_170_DATA
+			DDRSS_PHY_171_DATA
+			DDRSS_PHY_172_DATA
+			DDRSS_PHY_173_DATA
+			DDRSS_PHY_174_DATA
+			DDRSS_PHY_175_DATA
+			DDRSS_PHY_176_DATA
+			DDRSS_PHY_177_DATA
+			DDRSS_PHY_178_DATA
+			DDRSS_PHY_179_DATA
+			DDRSS_PHY_180_DATA
+			DDRSS_PHY_181_DATA
+			DDRSS_PHY_182_DATA
+			DDRSS_PHY_183_DATA
+			DDRSS_PHY_184_DATA
+			DDRSS_PHY_185_DATA
+			DDRSS_PHY_186_DATA
+			DDRSS_PHY_187_DATA
+			DDRSS_PHY_188_DATA
+			DDRSS_PHY_189_DATA
+			DDRSS_PHY_190_DATA
+			DDRSS_PHY_191_DATA
+			DDRSS_PHY_192_DATA
+			DDRSS_PHY_193_DATA
+			DDRSS_PHY_194_DATA
+			DDRSS_PHY_195_DATA
+			DDRSS_PHY_196_DATA
+			DDRSS_PHY_197_DATA
+			DDRSS_PHY_198_DATA
+			DDRSS_PHY_199_DATA
+			DDRSS_PHY_200_DATA
+			DDRSS_PHY_201_DATA
+			DDRSS_PHY_202_DATA
+			DDRSS_PHY_203_DATA
+			DDRSS_PHY_204_DATA
+			DDRSS_PHY_205_DATA
+			DDRSS_PHY_206_DATA
+			DDRSS_PHY_207_DATA
+			DDRSS_PHY_208_DATA
+			DDRSS_PHY_209_DATA
+			DDRSS_PHY_210_DATA
+			DDRSS_PHY_211_DATA
+			DDRSS_PHY_212_DATA
+			DDRSS_PHY_213_DATA
+			DDRSS_PHY_214_DATA
+			DDRSS_PHY_215_DATA
+			DDRSS_PHY_216_DATA
+			DDRSS_PHY_217_DATA
+			DDRSS_PHY_218_DATA
+			DDRSS_PHY_219_DATA
+			DDRSS_PHY_220_DATA
+			DDRSS_PHY_221_DATA
+			DDRSS_PHY_222_DATA
+			DDRSS_PHY_223_DATA
+			DDRSS_PHY_224_DATA
+			DDRSS_PHY_225_DATA
+			DDRSS_PHY_226_DATA
+			DDRSS_PHY_227_DATA
+			DDRSS_PHY_228_DATA
+			DDRSS_PHY_229_DATA
+			DDRSS_PHY_230_DATA
+			DDRSS_PHY_231_DATA
+			DDRSS_PHY_232_DATA
+			DDRSS_PHY_233_DATA
+			DDRSS_PHY_234_DATA
+			DDRSS_PHY_235_DATA
+			DDRSS_PHY_236_DATA
+			DDRSS_PHY_237_DATA
+			DDRSS_PHY_238_DATA
+			DDRSS_PHY_239_DATA
+			DDRSS_PHY_240_DATA
+			DDRSS_PHY_241_DATA
+			DDRSS_PHY_242_DATA
+			DDRSS_PHY_243_DATA
+			DDRSS_PHY_244_DATA
+			DDRSS_PHY_245_DATA
+			DDRSS_PHY_246_DATA
+			DDRSS_PHY_247_DATA
+			DDRSS_PHY_248_DATA
+			DDRSS_PHY_249_DATA
+			DDRSS_PHY_250_DATA
+			DDRSS_PHY_251_DATA
+			DDRSS_PHY_252_DATA
+			DDRSS_PHY_253_DATA
+			DDRSS_PHY_254_DATA
+			DDRSS_PHY_255_DATA
+			DDRSS_PHY_256_DATA
+			DDRSS_PHY_257_DATA
+			DDRSS_PHY_258_DATA
+			DDRSS_PHY_259_DATA
+			DDRSS_PHY_260_DATA
+			DDRSS_PHY_261_DATA
+			DDRSS_PHY_262_DATA
+			DDRSS_PHY_263_DATA
+			DDRSS_PHY_264_DATA
+			DDRSS_PHY_265_DATA
+			DDRSS_PHY_266_DATA
+			DDRSS_PHY_267_DATA
+			DDRSS_PHY_268_DATA
+			DDRSS_PHY_269_DATA
+			DDRSS_PHY_270_DATA
+			DDRSS_PHY_271_DATA
+			DDRSS_PHY_272_DATA
+			DDRSS_PHY_273_DATA
+			DDRSS_PHY_274_DATA
+			DDRSS_PHY_275_DATA
+			DDRSS_PHY_276_DATA
+			DDRSS_PHY_277_DATA
+			DDRSS_PHY_278_DATA
+			DDRSS_PHY_279_DATA
+			DDRSS_PHY_280_DATA
+			DDRSS_PHY_281_DATA
+			DDRSS_PHY_282_DATA
+			DDRSS_PHY_283_DATA
+			DDRSS_PHY_284_DATA
+			DDRSS_PHY_285_DATA
+			DDRSS_PHY_286_DATA
+			DDRSS_PHY_287_DATA
+			DDRSS_PHY_288_DATA
+			DDRSS_PHY_289_DATA
+			DDRSS_PHY_290_DATA
+			DDRSS_PHY_291_DATA
+			DDRSS_PHY_292_DATA
+			DDRSS_PHY_293_DATA
+			DDRSS_PHY_294_DATA
+			DDRSS_PHY_295_DATA
+			DDRSS_PHY_296_DATA
+			DDRSS_PHY_297_DATA
+			DDRSS_PHY_298_DATA
+			DDRSS_PHY_299_DATA
+			DDRSS_PHY_300_DATA
+			DDRSS_PHY_301_DATA
+			DDRSS_PHY_302_DATA
+			DDRSS_PHY_303_DATA
+			DDRSS_PHY_304_DATA
+			DDRSS_PHY_305_DATA
+			DDRSS_PHY_306_DATA
+			DDRSS_PHY_307_DATA
+			DDRSS_PHY_308_DATA
+			DDRSS_PHY_309_DATA
+			DDRSS_PHY_310_DATA
+			DDRSS_PHY_311_DATA
+			DDRSS_PHY_312_DATA
+			DDRSS_PHY_313_DATA
+			DDRSS_PHY_314_DATA
+			DDRSS_PHY_315_DATA
+			DDRSS_PHY_316_DATA
+			DDRSS_PHY_317_DATA
+			DDRSS_PHY_318_DATA
+			DDRSS_PHY_319_DATA
+			DDRSS_PHY_320_DATA
+			DDRSS_PHY_321_DATA
+			DDRSS_PHY_322_DATA
+			DDRSS_PHY_323_DATA
+			DDRSS_PHY_324_DATA
+			DDRSS_PHY_325_DATA
+			DDRSS_PHY_326_DATA
+			DDRSS_PHY_327_DATA
+			DDRSS_PHY_328_DATA
+			DDRSS_PHY_329_DATA
+			DDRSS_PHY_330_DATA
+			DDRSS_PHY_331_DATA
+			DDRSS_PHY_332_DATA
+			DDRSS_PHY_333_DATA
+			DDRSS_PHY_334_DATA
+			DDRSS_PHY_335_DATA
+			DDRSS_PHY_336_DATA
+			DDRSS_PHY_337_DATA
+			DDRSS_PHY_338_DATA
+			DDRSS_PHY_339_DATA
+			DDRSS_PHY_340_DATA
+			DDRSS_PHY_341_DATA
+			DDRSS_PHY_342_DATA
+			DDRSS_PHY_343_DATA
+			DDRSS_PHY_344_DATA
+			DDRSS_PHY_345_DATA
+			DDRSS_PHY_346_DATA
+			DDRSS_PHY_347_DATA
+			DDRSS_PHY_348_DATA
+			DDRSS_PHY_349_DATA
+			DDRSS_PHY_350_DATA
+			DDRSS_PHY_351_DATA
+			DDRSS_PHY_352_DATA
+			DDRSS_PHY_353_DATA
+			DDRSS_PHY_354_DATA
+			DDRSS_PHY_355_DATA
+			DDRSS_PHY_356_DATA
+			DDRSS_PHY_357_DATA
+			DDRSS_PHY_358_DATA
+			DDRSS_PHY_359_DATA
+			DDRSS_PHY_360_DATA
+			DDRSS_PHY_361_DATA
+			DDRSS_PHY_362_DATA
+			DDRSS_PHY_363_DATA
+			DDRSS_PHY_364_DATA
+			DDRSS_PHY_365_DATA
+			DDRSS_PHY_366_DATA
+			DDRSS_PHY_367_DATA
+			DDRSS_PHY_368_DATA
+			DDRSS_PHY_369_DATA
+			DDRSS_PHY_370_DATA
+			DDRSS_PHY_371_DATA
+			DDRSS_PHY_372_DATA
+			DDRSS_PHY_373_DATA
+			DDRSS_PHY_374_DATA
+			DDRSS_PHY_375_DATA
+			DDRSS_PHY_376_DATA
+			DDRSS_PHY_377_DATA
+			DDRSS_PHY_378_DATA
+			DDRSS_PHY_379_DATA
+			DDRSS_PHY_380_DATA
+			DDRSS_PHY_381_DATA
+			DDRSS_PHY_382_DATA
+			DDRSS_PHY_383_DATA
+			DDRSS_PHY_384_DATA
+			DDRSS_PHY_385_DATA
+			DDRSS_PHY_386_DATA
+			DDRSS_PHY_387_DATA
+			DDRSS_PHY_388_DATA
+			DDRSS_PHY_389_DATA
+			DDRSS_PHY_390_DATA
+			DDRSS_PHY_391_DATA
+			DDRSS_PHY_392_DATA
+			DDRSS_PHY_393_DATA
+			DDRSS_PHY_394_DATA
+			DDRSS_PHY_395_DATA
+			DDRSS_PHY_396_DATA
+			DDRSS_PHY_397_DATA
+			DDRSS_PHY_398_DATA
+			DDRSS_PHY_399_DATA
+			DDRSS_PHY_400_DATA
+			DDRSS_PHY_401_DATA
+			DDRSS_PHY_402_DATA
+			DDRSS_PHY_403_DATA
+			DDRSS_PHY_404_DATA
+			DDRSS_PHY_405_DATA
+			DDRSS_PHY_406_DATA
+			DDRSS_PHY_407_DATA
+			DDRSS_PHY_408_DATA
+			DDRSS_PHY_409_DATA
+			DDRSS_PHY_410_DATA
+			DDRSS_PHY_411_DATA
+			DDRSS_PHY_412_DATA
+			DDRSS_PHY_413_DATA
+			DDRSS_PHY_414_DATA
+			DDRSS_PHY_415_DATA
+			DDRSS_PHY_416_DATA
+			DDRSS_PHY_417_DATA
+			DDRSS_PHY_418_DATA
+			DDRSS_PHY_419_DATA
+			DDRSS_PHY_420_DATA
+			DDRSS_PHY_421_DATA
+			DDRSS_PHY_422_DATA
+			DDRSS_PHY_423_DATA
+			DDRSS_PHY_424_DATA
+			DDRSS_PHY_425_DATA
+			DDRSS_PHY_426_DATA
+			DDRSS_PHY_427_DATA
+			DDRSS_PHY_428_DATA
+			DDRSS_PHY_429_DATA
+			DDRSS_PHY_430_DATA
+			DDRSS_PHY_431_DATA
+			DDRSS_PHY_432_DATA
+			DDRSS_PHY_433_DATA
+			DDRSS_PHY_434_DATA
+			DDRSS_PHY_435_DATA
+			DDRSS_PHY_436_DATA
+			DDRSS_PHY_437_DATA
+			DDRSS_PHY_438_DATA
+			DDRSS_PHY_439_DATA
+			DDRSS_PHY_440_DATA
+			DDRSS_PHY_441_DATA
+			DDRSS_PHY_442_DATA
+			DDRSS_PHY_443_DATA
+			DDRSS_PHY_444_DATA
+			DDRSS_PHY_445_DATA
+			DDRSS_PHY_446_DATA
+			DDRSS_PHY_447_DATA
+			DDRSS_PHY_448_DATA
+			DDRSS_PHY_449_DATA
+			DDRSS_PHY_450_DATA
+			DDRSS_PHY_451_DATA
+			DDRSS_PHY_452_DATA
+			DDRSS_PHY_453_DATA
+			DDRSS_PHY_454_DATA
+			DDRSS_PHY_455_DATA
+			DDRSS_PHY_456_DATA
+			DDRSS_PHY_457_DATA
+			DDRSS_PHY_458_DATA
+			DDRSS_PHY_459_DATA
+			DDRSS_PHY_460_DATA
+			DDRSS_PHY_461_DATA
+			DDRSS_PHY_462_DATA
+			DDRSS_PHY_463_DATA
+			DDRSS_PHY_464_DATA
+			DDRSS_PHY_465_DATA
+			DDRSS_PHY_466_DATA
+			DDRSS_PHY_467_DATA
+			DDRSS_PHY_468_DATA
+			DDRSS_PHY_469_DATA
+			DDRSS_PHY_470_DATA
+			DDRSS_PHY_471_DATA
+			DDRSS_PHY_472_DATA
+			DDRSS_PHY_473_DATA
+			DDRSS_PHY_474_DATA
+			DDRSS_PHY_475_DATA
+			DDRSS_PHY_476_DATA
+			DDRSS_PHY_477_DATA
+			DDRSS_PHY_478_DATA
+			DDRSS_PHY_479_DATA
+			DDRSS_PHY_480_DATA
+			DDRSS_PHY_481_DATA
+			DDRSS_PHY_482_DATA
+			DDRSS_PHY_483_DATA
+			DDRSS_PHY_484_DATA
+			DDRSS_PHY_485_DATA
+			DDRSS_PHY_486_DATA
+			DDRSS_PHY_487_DATA
+			DDRSS_PHY_488_DATA
+			DDRSS_PHY_489_DATA
+			DDRSS_PHY_490_DATA
+			DDRSS_PHY_491_DATA
+			DDRSS_PHY_492_DATA
+			DDRSS_PHY_493_DATA
+			DDRSS_PHY_494_DATA
+			DDRSS_PHY_495_DATA
+			DDRSS_PHY_496_DATA
+			DDRSS_PHY_497_DATA
+			DDRSS_PHY_498_DATA
+			DDRSS_PHY_499_DATA
+			DDRSS_PHY_500_DATA
+			DDRSS_PHY_501_DATA
+			DDRSS_PHY_502_DATA
+			DDRSS_PHY_503_DATA
+			DDRSS_PHY_504_DATA
+			DDRSS_PHY_505_DATA
+			DDRSS_PHY_506_DATA
+			DDRSS_PHY_507_DATA
+			DDRSS_PHY_508_DATA
+			DDRSS_PHY_509_DATA
+			DDRSS_PHY_510_DATA
+			DDRSS_PHY_511_DATA
+			DDRSS_PHY_512_DATA
+			DDRSS_PHY_513_DATA
+			DDRSS_PHY_514_DATA
+			DDRSS_PHY_515_DATA
+			DDRSS_PHY_516_DATA
+			DDRSS_PHY_517_DATA
+			DDRSS_PHY_518_DATA
+			DDRSS_PHY_519_DATA
+			DDRSS_PHY_520_DATA
+			DDRSS_PHY_521_DATA
+			DDRSS_PHY_522_DATA
+			DDRSS_PHY_523_DATA
+			DDRSS_PHY_524_DATA
+			DDRSS_PHY_525_DATA
+			DDRSS_PHY_526_DATA
+			DDRSS_PHY_527_DATA
+			DDRSS_PHY_528_DATA
+			DDRSS_PHY_529_DATA
+			DDRSS_PHY_530_DATA
+			DDRSS_PHY_531_DATA
+			DDRSS_PHY_532_DATA
+			DDRSS_PHY_533_DATA
+			DDRSS_PHY_534_DATA
+			DDRSS_PHY_535_DATA
+			DDRSS_PHY_536_DATA
+			DDRSS_PHY_537_DATA
+			DDRSS_PHY_538_DATA
+			DDRSS_PHY_539_DATA
+			DDRSS_PHY_540_DATA
+			DDRSS_PHY_541_DATA
+			DDRSS_PHY_542_DATA
+			DDRSS_PHY_543_DATA
+			DDRSS_PHY_544_DATA
+			DDRSS_PHY_545_DATA
+			DDRSS_PHY_546_DATA
+			DDRSS_PHY_547_DATA
+			DDRSS_PHY_548_DATA
+			DDRSS_PHY_549_DATA
+			DDRSS_PHY_550_DATA
+			DDRSS_PHY_551_DATA
+			DDRSS_PHY_552_DATA
+			DDRSS_PHY_553_DATA
+			DDRSS_PHY_554_DATA
+			DDRSS_PHY_555_DATA
+			DDRSS_PHY_556_DATA
+			DDRSS_PHY_557_DATA
+			DDRSS_PHY_558_DATA
+			DDRSS_PHY_559_DATA
+			DDRSS_PHY_560_DATA
+			DDRSS_PHY_561_DATA
+			DDRSS_PHY_562_DATA
+			DDRSS_PHY_563_DATA
+			DDRSS_PHY_564_DATA
+			DDRSS_PHY_565_DATA
+			DDRSS_PHY_566_DATA
+			DDRSS_PHY_567_DATA
+			DDRSS_PHY_568_DATA
+			DDRSS_PHY_569_DATA
+			DDRSS_PHY_570_DATA
+			DDRSS_PHY_571_DATA
+			DDRSS_PHY_572_DATA
+			DDRSS_PHY_573_DATA
+			DDRSS_PHY_574_DATA
+			DDRSS_PHY_575_DATA
+			DDRSS_PHY_576_DATA
+			DDRSS_PHY_577_DATA
+			DDRSS_PHY_578_DATA
+			DDRSS_PHY_579_DATA
+			DDRSS_PHY_580_DATA
+			DDRSS_PHY_581_DATA
+			DDRSS_PHY_582_DATA
+			DDRSS_PHY_583_DATA
+			DDRSS_PHY_584_DATA
+			DDRSS_PHY_585_DATA
+			DDRSS_PHY_586_DATA
+			DDRSS_PHY_587_DATA
+			DDRSS_PHY_588_DATA
+			DDRSS_PHY_589_DATA
+			DDRSS_PHY_590_DATA
+			DDRSS_PHY_591_DATA
+			DDRSS_PHY_592_DATA
+			DDRSS_PHY_593_DATA
+			DDRSS_PHY_594_DATA
+			DDRSS_PHY_595_DATA
+			DDRSS_PHY_596_DATA
+			DDRSS_PHY_597_DATA
+			DDRSS_PHY_598_DATA
+			DDRSS_PHY_599_DATA
+			DDRSS_PHY_600_DATA
+			DDRSS_PHY_601_DATA
+			DDRSS_PHY_602_DATA
+			DDRSS_PHY_603_DATA
+			DDRSS_PHY_604_DATA
+			DDRSS_PHY_605_DATA
+			DDRSS_PHY_606_DATA
+			DDRSS_PHY_607_DATA
+			DDRSS_PHY_608_DATA
+			DDRSS_PHY_609_DATA
+			DDRSS_PHY_610_DATA
+			DDRSS_PHY_611_DATA
+			DDRSS_PHY_612_DATA
+			DDRSS_PHY_613_DATA
+			DDRSS_PHY_614_DATA
+			DDRSS_PHY_615_DATA
+			DDRSS_PHY_616_DATA
+			DDRSS_PHY_617_DATA
+			DDRSS_PHY_618_DATA
+			DDRSS_PHY_619_DATA
+			DDRSS_PHY_620_DATA
+			DDRSS_PHY_621_DATA
+			DDRSS_PHY_622_DATA
+			DDRSS_PHY_623_DATA
+			DDRSS_PHY_624_DATA
+			DDRSS_PHY_625_DATA
+			DDRSS_PHY_626_DATA
+			DDRSS_PHY_627_DATA
+			DDRSS_PHY_628_DATA
+			DDRSS_PHY_629_DATA
+			DDRSS_PHY_630_DATA
+			DDRSS_PHY_631_DATA
+			DDRSS_PHY_632_DATA
+			DDRSS_PHY_633_DATA
+			DDRSS_PHY_634_DATA
+			DDRSS_PHY_635_DATA
+			DDRSS_PHY_636_DATA
+			DDRSS_PHY_637_DATA
+			DDRSS_PHY_638_DATA
+			DDRSS_PHY_639_DATA
+			DDRSS_PHY_640_DATA
+			DDRSS_PHY_641_DATA
+			DDRSS_PHY_642_DATA
+			DDRSS_PHY_643_DATA
+			DDRSS_PHY_644_DATA
+			DDRSS_PHY_645_DATA
+			DDRSS_PHY_646_DATA
+			DDRSS_PHY_647_DATA
+			DDRSS_PHY_648_DATA
+			DDRSS_PHY_649_DATA
+			DDRSS_PHY_650_DATA
+			DDRSS_PHY_651_DATA
+			DDRSS_PHY_652_DATA
+			DDRSS_PHY_653_DATA
+			DDRSS_PHY_654_DATA
+			DDRSS_PHY_655_DATA
+			DDRSS_PHY_656_DATA
+			DDRSS_PHY_657_DATA
+			DDRSS_PHY_658_DATA
+			DDRSS_PHY_659_DATA
+			DDRSS_PHY_660_DATA
+			DDRSS_PHY_661_DATA
+			DDRSS_PHY_662_DATA
+			DDRSS_PHY_663_DATA
+			DDRSS_PHY_664_DATA
+			DDRSS_PHY_665_DATA
+			DDRSS_PHY_666_DATA
+			DDRSS_PHY_667_DATA
+			DDRSS_PHY_668_DATA
+			DDRSS_PHY_669_DATA
+			DDRSS_PHY_670_DATA
+			DDRSS_PHY_671_DATA
+			DDRSS_PHY_672_DATA
+			DDRSS_PHY_673_DATA
+			DDRSS_PHY_674_DATA
+			DDRSS_PHY_675_DATA
+			DDRSS_PHY_676_DATA
+			DDRSS_PHY_677_DATA
+			DDRSS_PHY_678_DATA
+			DDRSS_PHY_679_DATA
+			DDRSS_PHY_680_DATA
+			DDRSS_PHY_681_DATA
+			DDRSS_PHY_682_DATA
+			DDRSS_PHY_683_DATA
+			DDRSS_PHY_684_DATA
+			DDRSS_PHY_685_DATA
+			DDRSS_PHY_686_DATA
+			DDRSS_PHY_687_DATA
+			DDRSS_PHY_688_DATA
+			DDRSS_PHY_689_DATA
+			DDRSS_PHY_690_DATA
+			DDRSS_PHY_691_DATA
+			DDRSS_PHY_692_DATA
+			DDRSS_PHY_693_DATA
+			DDRSS_PHY_694_DATA
+			DDRSS_PHY_695_DATA
+			DDRSS_PHY_696_DATA
+			DDRSS_PHY_697_DATA
+			DDRSS_PHY_698_DATA
+			DDRSS_PHY_699_DATA
+			DDRSS_PHY_700_DATA
+			DDRSS_PHY_701_DATA
+			DDRSS_PHY_702_DATA
+			DDRSS_PHY_703_DATA
+			DDRSS_PHY_704_DATA
+			DDRSS_PHY_705_DATA
+			DDRSS_PHY_706_DATA
+			DDRSS_PHY_707_DATA
+			DDRSS_PHY_708_DATA
+			DDRSS_PHY_709_DATA
+			DDRSS_PHY_710_DATA
+			DDRSS_PHY_711_DATA
+			DDRSS_PHY_712_DATA
+			DDRSS_PHY_713_DATA
+			DDRSS_PHY_714_DATA
+			DDRSS_PHY_715_DATA
+			DDRSS_PHY_716_DATA
+			DDRSS_PHY_717_DATA
+			DDRSS_PHY_718_DATA
+			DDRSS_PHY_719_DATA
+			DDRSS_PHY_720_DATA
+			DDRSS_PHY_721_DATA
+			DDRSS_PHY_722_DATA
+			DDRSS_PHY_723_DATA
+			DDRSS_PHY_724_DATA
+			DDRSS_PHY_725_DATA
+			DDRSS_PHY_726_DATA
+			DDRSS_PHY_727_DATA
+			DDRSS_PHY_728_DATA
+			DDRSS_PHY_729_DATA
+			DDRSS_PHY_730_DATA
+			DDRSS_PHY_731_DATA
+			DDRSS_PHY_732_DATA
+			DDRSS_PHY_733_DATA
+			DDRSS_PHY_734_DATA
+			DDRSS_PHY_735_DATA
+			DDRSS_PHY_736_DATA
+			DDRSS_PHY_737_DATA
+			DDRSS_PHY_738_DATA
+			DDRSS_PHY_739_DATA
+			DDRSS_PHY_740_DATA
+			DDRSS_PHY_741_DATA
+			DDRSS_PHY_742_DATA
+			DDRSS_PHY_743_DATA
+			DDRSS_PHY_744_DATA
+			DDRSS_PHY_745_DATA
+			DDRSS_PHY_746_DATA
+			DDRSS_PHY_747_DATA
+			DDRSS_PHY_748_DATA
+			DDRSS_PHY_749_DATA
+			DDRSS_PHY_750_DATA
+			DDRSS_PHY_751_DATA
+			DDRSS_PHY_752_DATA
+			DDRSS_PHY_753_DATA
+			DDRSS_PHY_754_DATA
+			DDRSS_PHY_755_DATA
+			DDRSS_PHY_756_DATA
+			DDRSS_PHY_757_DATA
+			DDRSS_PHY_758_DATA
+			DDRSS_PHY_759_DATA
+			DDRSS_PHY_760_DATA
+			DDRSS_PHY_761_DATA
+			DDRSS_PHY_762_DATA
+			DDRSS_PHY_763_DATA
+			DDRSS_PHY_764_DATA
+			DDRSS_PHY_765_DATA
+			DDRSS_PHY_766_DATA
+			DDRSS_PHY_767_DATA
+			DDRSS_PHY_768_DATA
+			DDRSS_PHY_769_DATA
+			DDRSS_PHY_770_DATA
+			DDRSS_PHY_771_DATA
+			DDRSS_PHY_772_DATA
+			DDRSS_PHY_773_DATA
+			DDRSS_PHY_774_DATA
+			DDRSS_PHY_775_DATA
+			DDRSS_PHY_776_DATA
+			DDRSS_PHY_777_DATA
+			DDRSS_PHY_778_DATA
+			DDRSS_PHY_779_DATA
+			DDRSS_PHY_780_DATA
+			DDRSS_PHY_781_DATA
+			DDRSS_PHY_782_DATA
+			DDRSS_PHY_783_DATA
+			DDRSS_PHY_784_DATA
+			DDRSS_PHY_785_DATA
+			DDRSS_PHY_786_DATA
+			DDRSS_PHY_787_DATA
+			DDRSS_PHY_788_DATA
+			DDRSS_PHY_789_DATA
+			DDRSS_PHY_790_DATA
+			DDRSS_PHY_791_DATA
+			DDRSS_PHY_792_DATA
+			DDRSS_PHY_793_DATA
+			DDRSS_PHY_794_DATA
+			DDRSS_PHY_795_DATA
+			DDRSS_PHY_796_DATA
+			DDRSS_PHY_797_DATA
+			DDRSS_PHY_798_DATA
+			DDRSS_PHY_799_DATA
+			DDRSS_PHY_800_DATA
+			DDRSS_PHY_801_DATA
+			DDRSS_PHY_802_DATA
+			DDRSS_PHY_803_DATA
+			DDRSS_PHY_804_DATA
+			DDRSS_PHY_805_DATA
+			DDRSS_PHY_806_DATA
+			DDRSS_PHY_807_DATA
+			DDRSS_PHY_808_DATA
+			DDRSS_PHY_809_DATA
+			DDRSS_PHY_810_DATA
+			DDRSS_PHY_811_DATA
+			DDRSS_PHY_812_DATA
+			DDRSS_PHY_813_DATA
+			DDRSS_PHY_814_DATA
+			DDRSS_PHY_815_DATA
+			DDRSS_PHY_816_DATA
+			DDRSS_PHY_817_DATA
+			DDRSS_PHY_818_DATA
+			DDRSS_PHY_819_DATA
+			DDRSS_PHY_820_DATA
+			DDRSS_PHY_821_DATA
+			DDRSS_PHY_822_DATA
+			DDRSS_PHY_823_DATA
+			DDRSS_PHY_824_DATA
+			DDRSS_PHY_825_DATA
+			DDRSS_PHY_826_DATA
+			DDRSS_PHY_827_DATA
+			DDRSS_PHY_828_DATA
+			DDRSS_PHY_829_DATA
+			DDRSS_PHY_830_DATA
+			DDRSS_PHY_831_DATA
+			DDRSS_PHY_832_DATA
+			DDRSS_PHY_833_DATA
+			DDRSS_PHY_834_DATA
+			DDRSS_PHY_835_DATA
+			DDRSS_PHY_836_DATA
+			DDRSS_PHY_837_DATA
+			DDRSS_PHY_838_DATA
+			DDRSS_PHY_839_DATA
+			DDRSS_PHY_840_DATA
+			DDRSS_PHY_841_DATA
+			DDRSS_PHY_842_DATA
+			DDRSS_PHY_843_DATA
+			DDRSS_PHY_844_DATA
+			DDRSS_PHY_845_DATA
+			DDRSS_PHY_846_DATA
+			DDRSS_PHY_847_DATA
+			DDRSS_PHY_848_DATA
+			DDRSS_PHY_849_DATA
+			DDRSS_PHY_850_DATA
+			DDRSS_PHY_851_DATA
+			DDRSS_PHY_852_DATA
+			DDRSS_PHY_853_DATA
+			DDRSS_PHY_854_DATA
+			DDRSS_PHY_855_DATA
+			DDRSS_PHY_856_DATA
+			DDRSS_PHY_857_DATA
+			DDRSS_PHY_858_DATA
+			DDRSS_PHY_859_DATA
+			DDRSS_PHY_860_DATA
+			DDRSS_PHY_861_DATA
+			DDRSS_PHY_862_DATA
+			DDRSS_PHY_863_DATA
+			DDRSS_PHY_864_DATA
+			DDRSS_PHY_865_DATA
+			DDRSS_PHY_866_DATA
+			DDRSS_PHY_867_DATA
+			DDRSS_PHY_868_DATA
+			DDRSS_PHY_869_DATA
+			DDRSS_PHY_870_DATA
+			DDRSS_PHY_871_DATA
+			DDRSS_PHY_872_DATA
+			DDRSS_PHY_873_DATA
+			DDRSS_PHY_874_DATA
+			DDRSS_PHY_875_DATA
+			DDRSS_PHY_876_DATA
+			DDRSS_PHY_877_DATA
+			DDRSS_PHY_878_DATA
+			DDRSS_PHY_879_DATA
+			DDRSS_PHY_880_DATA
+			DDRSS_PHY_881_DATA
+			DDRSS_PHY_882_DATA
+			DDRSS_PHY_883_DATA
+			DDRSS_PHY_884_DATA
+			DDRSS_PHY_885_DATA
+			DDRSS_PHY_886_DATA
+			DDRSS_PHY_887_DATA
+			DDRSS_PHY_888_DATA
+			DDRSS_PHY_889_DATA
+			DDRSS_PHY_890_DATA
+			DDRSS_PHY_891_DATA
+			DDRSS_PHY_892_DATA
+			DDRSS_PHY_893_DATA
+			DDRSS_PHY_894_DATA
+			DDRSS_PHY_895_DATA
+			DDRSS_PHY_896_DATA
+			DDRSS_PHY_897_DATA
+			DDRSS_PHY_898_DATA
+			DDRSS_PHY_899_DATA
+			DDRSS_PHY_900_DATA
+			DDRSS_PHY_901_DATA
+			DDRSS_PHY_902_DATA
+			DDRSS_PHY_903_DATA
+			DDRSS_PHY_904_DATA
+			DDRSS_PHY_905_DATA
+			DDRSS_PHY_906_DATA
+			DDRSS_PHY_907_DATA
+			DDRSS_PHY_908_DATA
+			DDRSS_PHY_909_DATA
+			DDRSS_PHY_910_DATA
+			DDRSS_PHY_911_DATA
+			DDRSS_PHY_912_DATA
+			DDRSS_PHY_913_DATA
+			DDRSS_PHY_914_DATA
+			DDRSS_PHY_915_DATA
+			DDRSS_PHY_916_DATA
+			DDRSS_PHY_917_DATA
+			DDRSS_PHY_918_DATA
+			DDRSS_PHY_919_DATA
+			DDRSS_PHY_920_DATA
+			DDRSS_PHY_921_DATA
+			DDRSS_PHY_922_DATA
+			DDRSS_PHY_923_DATA
+			DDRSS_PHY_924_DATA
+			DDRSS_PHY_925_DATA
+			DDRSS_PHY_926_DATA
+			DDRSS_PHY_927_DATA
+			DDRSS_PHY_928_DATA
+			DDRSS_PHY_929_DATA
+			DDRSS_PHY_930_DATA
+			DDRSS_PHY_931_DATA
+			DDRSS_PHY_932_DATA
+			DDRSS_PHY_933_DATA
+			DDRSS_PHY_934_DATA
+			DDRSS_PHY_935_DATA
+			DDRSS_PHY_936_DATA
+			DDRSS_PHY_937_DATA
+			DDRSS_PHY_938_DATA
+			DDRSS_PHY_939_DATA
+			DDRSS_PHY_940_DATA
+			DDRSS_PHY_941_DATA
+			DDRSS_PHY_942_DATA
+			DDRSS_PHY_943_DATA
+			DDRSS_PHY_944_DATA
+			DDRSS_PHY_945_DATA
+			DDRSS_PHY_946_DATA
+			DDRSS_PHY_947_DATA
+			DDRSS_PHY_948_DATA
+			DDRSS_PHY_949_DATA
+			DDRSS_PHY_950_DATA
+			DDRSS_PHY_951_DATA
+			DDRSS_PHY_952_DATA
+			DDRSS_PHY_953_DATA
+			DDRSS_PHY_954_DATA
+			DDRSS_PHY_955_DATA
+			DDRSS_PHY_956_DATA
+			DDRSS_PHY_957_DATA
+			DDRSS_PHY_958_DATA
+			DDRSS_PHY_959_DATA
+			DDRSS_PHY_960_DATA
+			DDRSS_PHY_961_DATA
+			DDRSS_PHY_962_DATA
+			DDRSS_PHY_963_DATA
+			DDRSS_PHY_964_DATA
+			DDRSS_PHY_965_DATA
+			DDRSS_PHY_966_DATA
+			DDRSS_PHY_967_DATA
+			DDRSS_PHY_968_DATA
+			DDRSS_PHY_969_DATA
+			DDRSS_PHY_970_DATA
+			DDRSS_PHY_971_DATA
+			DDRSS_PHY_972_DATA
+			DDRSS_PHY_973_DATA
+			DDRSS_PHY_974_DATA
+			DDRSS_PHY_975_DATA
+			DDRSS_PHY_976_DATA
+			DDRSS_PHY_977_DATA
+			DDRSS_PHY_978_DATA
+			DDRSS_PHY_979_DATA
+			DDRSS_PHY_980_DATA
+			DDRSS_PHY_981_DATA
+			DDRSS_PHY_982_DATA
+			DDRSS_PHY_983_DATA
+			DDRSS_PHY_984_DATA
+			DDRSS_PHY_985_DATA
+			DDRSS_PHY_986_DATA
+			DDRSS_PHY_987_DATA
+			DDRSS_PHY_988_DATA
+			DDRSS_PHY_989_DATA
+			DDRSS_PHY_990_DATA
+			DDRSS_PHY_991_DATA
+			DDRSS_PHY_992_DATA
+			DDRSS_PHY_993_DATA
+			DDRSS_PHY_994_DATA
+			DDRSS_PHY_995_DATA
+			DDRSS_PHY_996_DATA
+			DDRSS_PHY_997_DATA
+			DDRSS_PHY_998_DATA
+			DDRSS_PHY_999_DATA
+			DDRSS_PHY_1000_DATA
+			DDRSS_PHY_1001_DATA
+			DDRSS_PHY_1002_DATA
+			DDRSS_PHY_1003_DATA
+			DDRSS_PHY_1004_DATA
+			DDRSS_PHY_1005_DATA
+			DDRSS_PHY_1006_DATA
+			DDRSS_PHY_1007_DATA
+			DDRSS_PHY_1008_DATA
+			DDRSS_PHY_1009_DATA
+			DDRSS_PHY_1010_DATA
+			DDRSS_PHY_1011_DATA
+			DDRSS_PHY_1012_DATA
+			DDRSS_PHY_1013_DATA
+			DDRSS_PHY_1014_DATA
+			DDRSS_PHY_1015_DATA
+			DDRSS_PHY_1016_DATA
+			DDRSS_PHY_1017_DATA
+			DDRSS_PHY_1018_DATA
+			DDRSS_PHY_1019_DATA
+			DDRSS_PHY_1020_DATA
+			DDRSS_PHY_1021_DATA
+			DDRSS_PHY_1022_DATA
+			DDRSS_PHY_1023_DATA
+			DDRSS_PHY_1024_DATA
+			DDRSS_PHY_1025_DATA
+			DDRSS_PHY_1026_DATA
+			DDRSS_PHY_1027_DATA
+			DDRSS_PHY_1028_DATA
+			DDRSS_PHY_1029_DATA
+			DDRSS_PHY_1030_DATA
+			DDRSS_PHY_1031_DATA
+			DDRSS_PHY_1032_DATA
+			DDRSS_PHY_1033_DATA
+			DDRSS_PHY_1034_DATA
+			DDRSS_PHY_1035_DATA
+			DDRSS_PHY_1036_DATA
+			DDRSS_PHY_1037_DATA
+			DDRSS_PHY_1038_DATA
+			DDRSS_PHY_1039_DATA
+			DDRSS_PHY_1040_DATA
+			DDRSS_PHY_1041_DATA
+			DDRSS_PHY_1042_DATA
+			DDRSS_PHY_1043_DATA
+			DDRSS_PHY_1044_DATA
+			DDRSS_PHY_1045_DATA
+			DDRSS_PHY_1046_DATA
+			DDRSS_PHY_1047_DATA
+			DDRSS_PHY_1048_DATA
+			DDRSS_PHY_1049_DATA
+			DDRSS_PHY_1050_DATA
+			DDRSS_PHY_1051_DATA
+			DDRSS_PHY_1052_DATA
+			DDRSS_PHY_1053_DATA
+			DDRSS_PHY_1054_DATA
+			DDRSS_PHY_1055_DATA
+			DDRSS_PHY_1056_DATA
+			DDRSS_PHY_1057_DATA
+			DDRSS_PHY_1058_DATA
+			DDRSS_PHY_1059_DATA
+			DDRSS_PHY_1060_DATA
+			DDRSS_PHY_1061_DATA
+			DDRSS_PHY_1062_DATA
+			DDRSS_PHY_1063_DATA
+			DDRSS_PHY_1064_DATA
+			DDRSS_PHY_1065_DATA
+			DDRSS_PHY_1066_DATA
+			DDRSS_PHY_1067_DATA
+			DDRSS_PHY_1068_DATA
+			DDRSS_PHY_1069_DATA
+			DDRSS_PHY_1070_DATA
+			DDRSS_PHY_1071_DATA
+			DDRSS_PHY_1072_DATA
+			DDRSS_PHY_1073_DATA
+			DDRSS_PHY_1074_DATA
+			DDRSS_PHY_1075_DATA
+			DDRSS_PHY_1076_DATA
+			DDRSS_PHY_1077_DATA
+			DDRSS_PHY_1078_DATA
+			DDRSS_PHY_1079_DATA
+			DDRSS_PHY_1080_DATA
+			DDRSS_PHY_1081_DATA
+			DDRSS_PHY_1082_DATA
+			DDRSS_PHY_1083_DATA
+			DDRSS_PHY_1084_DATA
+			DDRSS_PHY_1085_DATA
+			DDRSS_PHY_1086_DATA
+			DDRSS_PHY_1087_DATA
+			DDRSS_PHY_1088_DATA
+			DDRSS_PHY_1089_DATA
+			DDRSS_PHY_1090_DATA
+			DDRSS_PHY_1091_DATA
+			DDRSS_PHY_1092_DATA
+			DDRSS_PHY_1093_DATA
+			DDRSS_PHY_1094_DATA
+			DDRSS_PHY_1095_DATA
+			DDRSS_PHY_1096_DATA
+			DDRSS_PHY_1097_DATA
+			DDRSS_PHY_1098_DATA
+			DDRSS_PHY_1099_DATA
+			DDRSS_PHY_1100_DATA
+			DDRSS_PHY_1101_DATA
+			DDRSS_PHY_1102_DATA
+			DDRSS_PHY_1103_DATA
+			DDRSS_PHY_1104_DATA
+			DDRSS_PHY_1105_DATA
+			DDRSS_PHY_1106_DATA
+			DDRSS_PHY_1107_DATA
+			DDRSS_PHY_1108_DATA
+			DDRSS_PHY_1109_DATA
+			DDRSS_PHY_1110_DATA
+			DDRSS_PHY_1111_DATA
+			DDRSS_PHY_1112_DATA
+			DDRSS_PHY_1113_DATA
+			DDRSS_PHY_1114_DATA
+			DDRSS_PHY_1115_DATA
+			DDRSS_PHY_1116_DATA
+			DDRSS_PHY_1117_DATA
+			DDRSS_PHY_1118_DATA
+			DDRSS_PHY_1119_DATA
+			DDRSS_PHY_1120_DATA
+			DDRSS_PHY_1121_DATA
+			DDRSS_PHY_1122_DATA
+			DDRSS_PHY_1123_DATA
+			DDRSS_PHY_1124_DATA
+			DDRSS_PHY_1125_DATA
+			DDRSS_PHY_1126_DATA
+			DDRSS_PHY_1127_DATA
+			DDRSS_PHY_1128_DATA
+			DDRSS_PHY_1129_DATA
+			DDRSS_PHY_1130_DATA
+			DDRSS_PHY_1131_DATA
+			DDRSS_PHY_1132_DATA
+			DDRSS_PHY_1133_DATA
+			DDRSS_PHY_1134_DATA
+			DDRSS_PHY_1135_DATA
+			DDRSS_PHY_1136_DATA
+			DDRSS_PHY_1137_DATA
+			DDRSS_PHY_1138_DATA
+			DDRSS_PHY_1139_DATA
+			DDRSS_PHY_1140_DATA
+			DDRSS_PHY_1141_DATA
+			DDRSS_PHY_1142_DATA
+			DDRSS_PHY_1143_DATA
+			DDRSS_PHY_1144_DATA
+			DDRSS_PHY_1145_DATA
+			DDRSS_PHY_1146_DATA
+			DDRSS_PHY_1147_DATA
+			DDRSS_PHY_1148_DATA
+			DDRSS_PHY_1149_DATA
+			DDRSS_PHY_1150_DATA
+			DDRSS_PHY_1151_DATA
+			DDRSS_PHY_1152_DATA
+			DDRSS_PHY_1153_DATA
+			DDRSS_PHY_1154_DATA
+			DDRSS_PHY_1155_DATA
+			DDRSS_PHY_1156_DATA
+			DDRSS_PHY_1157_DATA
+			DDRSS_PHY_1158_DATA
+			DDRSS_PHY_1159_DATA
+			DDRSS_PHY_1160_DATA
+			DDRSS_PHY_1161_DATA
+			DDRSS_PHY_1162_DATA
+			DDRSS_PHY_1163_DATA
+			DDRSS_PHY_1164_DATA
+			DDRSS_PHY_1165_DATA
+			DDRSS_PHY_1166_DATA
+			DDRSS_PHY_1167_DATA
+			DDRSS_PHY_1168_DATA
+			DDRSS_PHY_1169_DATA
+			DDRSS_PHY_1170_DATA
+			DDRSS_PHY_1171_DATA
+			DDRSS_PHY_1172_DATA
+			DDRSS_PHY_1173_DATA
+			DDRSS_PHY_1174_DATA
+			DDRSS_PHY_1175_DATA
+			DDRSS_PHY_1176_DATA
+			DDRSS_PHY_1177_DATA
+			DDRSS_PHY_1178_DATA
+			DDRSS_PHY_1179_DATA
+			DDRSS_PHY_1180_DATA
+			DDRSS_PHY_1181_DATA
+			DDRSS_PHY_1182_DATA
+			DDRSS_PHY_1183_DATA
+			DDRSS_PHY_1184_DATA
+			DDRSS_PHY_1185_DATA
+			DDRSS_PHY_1186_DATA
+			DDRSS_PHY_1187_DATA
+			DDRSS_PHY_1188_DATA
+			DDRSS_PHY_1189_DATA
+			DDRSS_PHY_1190_DATA
+			DDRSS_PHY_1191_DATA
+			DDRSS_PHY_1192_DATA
+			DDRSS_PHY_1193_DATA
+			DDRSS_PHY_1194_DATA
+			DDRSS_PHY_1195_DATA
+			DDRSS_PHY_1196_DATA
+			DDRSS_PHY_1197_DATA
+			DDRSS_PHY_1198_DATA
+			DDRSS_PHY_1199_DATA
+			DDRSS_PHY_1200_DATA
+			DDRSS_PHY_1201_DATA
+			DDRSS_PHY_1202_DATA
+			DDRSS_PHY_1203_DATA
+			DDRSS_PHY_1204_DATA
+			DDRSS_PHY_1205_DATA
+			DDRSS_PHY_1206_DATA
+			DDRSS_PHY_1207_DATA
+			DDRSS_PHY_1208_DATA
+			DDRSS_PHY_1209_DATA
+			DDRSS_PHY_1210_DATA
+			DDRSS_PHY_1211_DATA
+			DDRSS_PHY_1212_DATA
+			DDRSS_PHY_1213_DATA
+			DDRSS_PHY_1214_DATA
+			DDRSS_PHY_1215_DATA
+			DDRSS_PHY_1216_DATA
+			DDRSS_PHY_1217_DATA
+			DDRSS_PHY_1218_DATA
+			DDRSS_PHY_1219_DATA
+			DDRSS_PHY_1220_DATA
+			DDRSS_PHY_1221_DATA
+			DDRSS_PHY_1222_DATA
+			DDRSS_PHY_1223_DATA
+			DDRSS_PHY_1224_DATA
+			DDRSS_PHY_1225_DATA
+			DDRSS_PHY_1226_DATA
+			DDRSS_PHY_1227_DATA
+			DDRSS_PHY_1228_DATA
+			DDRSS_PHY_1229_DATA
+			DDRSS_PHY_1230_DATA
+			DDRSS_PHY_1231_DATA
+			DDRSS_PHY_1232_DATA
+			DDRSS_PHY_1233_DATA
+			DDRSS_PHY_1234_DATA
+			DDRSS_PHY_1235_DATA
+			DDRSS_PHY_1236_DATA
+			DDRSS_PHY_1237_DATA
+			DDRSS_PHY_1238_DATA
+			DDRSS_PHY_1239_DATA
+			DDRSS_PHY_1240_DATA
+			DDRSS_PHY_1241_DATA
+			DDRSS_PHY_1242_DATA
+			DDRSS_PHY_1243_DATA
+			DDRSS_PHY_1244_DATA
+			DDRSS_PHY_1245_DATA
+			DDRSS_PHY_1246_DATA
+			DDRSS_PHY_1247_DATA
+			DDRSS_PHY_1248_DATA
+			DDRSS_PHY_1249_DATA
+			DDRSS_PHY_1250_DATA
+			DDRSS_PHY_1251_DATA
+			DDRSS_PHY_1252_DATA
+			DDRSS_PHY_1253_DATA
+			DDRSS_PHY_1254_DATA
+			DDRSS_PHY_1255_DATA
+			DDRSS_PHY_1256_DATA
+			DDRSS_PHY_1257_DATA
+			DDRSS_PHY_1258_DATA
+			DDRSS_PHY_1259_DATA
+			DDRSS_PHY_1260_DATA
+			DDRSS_PHY_1261_DATA
+			DDRSS_PHY_1262_DATA
+			DDRSS_PHY_1263_DATA
+			DDRSS_PHY_1264_DATA
+			DDRSS_PHY_1265_DATA
+			DDRSS_PHY_1266_DATA
+			DDRSS_PHY_1267_DATA
+			DDRSS_PHY_1268_DATA
+			DDRSS_PHY_1269_DATA
+			DDRSS_PHY_1270_DATA
+			DDRSS_PHY_1271_DATA
+			DDRSS_PHY_1272_DATA
+			DDRSS_PHY_1273_DATA
+			DDRSS_PHY_1274_DATA
+			DDRSS_PHY_1275_DATA
+			DDRSS_PHY_1276_DATA
+			DDRSS_PHY_1277_DATA
+			DDRSS_PHY_1278_DATA
+			DDRSS_PHY_1279_DATA
+			DDRSS_PHY_1280_DATA
+			DDRSS_PHY_1281_DATA
+			DDRSS_PHY_1282_DATA
+			DDRSS_PHY_1283_DATA
+			DDRSS_PHY_1284_DATA
+			DDRSS_PHY_1285_DATA
+			DDRSS_PHY_1286_DATA
+			DDRSS_PHY_1287_DATA
+			DDRSS_PHY_1288_DATA
+			DDRSS_PHY_1289_DATA
+			DDRSS_PHY_1290_DATA
+			DDRSS_PHY_1291_DATA
+			DDRSS_PHY_1292_DATA
+			DDRSS_PHY_1293_DATA
+			DDRSS_PHY_1294_DATA
+			DDRSS_PHY_1295_DATA
+			DDRSS_PHY_1296_DATA
+			DDRSS_PHY_1297_DATA
+			DDRSS_PHY_1298_DATA
+			DDRSS_PHY_1299_DATA
+			DDRSS_PHY_1300_DATA
+			DDRSS_PHY_1301_DATA
+			DDRSS_PHY_1302_DATA
+			DDRSS_PHY_1303_DATA
+			DDRSS_PHY_1304_DATA
+			DDRSS_PHY_1305_DATA
+			DDRSS_PHY_1306_DATA
+			DDRSS_PHY_1307_DATA
+			DDRSS_PHY_1308_DATA
+			DDRSS_PHY_1309_DATA
+			DDRSS_PHY_1310_DATA
+			DDRSS_PHY_1311_DATA
+			DDRSS_PHY_1312_DATA
+			DDRSS_PHY_1313_DATA
+			DDRSS_PHY_1314_DATA
+			DDRSS_PHY_1315_DATA
+			DDRSS_PHY_1316_DATA
+			DDRSS_PHY_1317_DATA
+			DDRSS_PHY_1318_DATA
+			DDRSS_PHY_1319_DATA
+			DDRSS_PHY_1320_DATA
+			DDRSS_PHY_1321_DATA
+			DDRSS_PHY_1322_DATA
+			DDRSS_PHY_1323_DATA
+			DDRSS_PHY_1324_DATA
+			DDRSS_PHY_1325_DATA
+			DDRSS_PHY_1326_DATA
+			DDRSS_PHY_1327_DATA
+			DDRSS_PHY_1328_DATA
+			DDRSS_PHY_1329_DATA
+			DDRSS_PHY_1330_DATA
+			DDRSS_PHY_1331_DATA
+			DDRSS_PHY_1332_DATA
+			DDRSS_PHY_1333_DATA
+			DDRSS_PHY_1334_DATA
+			DDRSS_PHY_1335_DATA
+			DDRSS_PHY_1336_DATA
+			DDRSS_PHY_1337_DATA
+			DDRSS_PHY_1338_DATA
+			DDRSS_PHY_1339_DATA
+			DDRSS_PHY_1340_DATA
+			DDRSS_PHY_1341_DATA
+			DDRSS_PHY_1342_DATA
+			DDRSS_PHY_1343_DATA
+			DDRSS_PHY_1344_DATA
+			DDRSS_PHY_1345_DATA
+			DDRSS_PHY_1346_DATA
+			DDRSS_PHY_1347_DATA
+			DDRSS_PHY_1348_DATA
+			DDRSS_PHY_1349_DATA
+			DDRSS_PHY_1350_DATA
+			DDRSS_PHY_1351_DATA
+			DDRSS_PHY_1352_DATA
+			DDRSS_PHY_1353_DATA
+			DDRSS_PHY_1354_DATA
+			DDRSS_PHY_1355_DATA
+			DDRSS_PHY_1356_DATA
+			DDRSS_PHY_1357_DATA
+			DDRSS_PHY_1358_DATA
+			DDRSS_PHY_1359_DATA
+			DDRSS_PHY_1360_DATA
+			DDRSS_PHY_1361_DATA
+			DDRSS_PHY_1362_DATA
+			DDRSS_PHY_1363_DATA
+			DDRSS_PHY_1364_DATA
+			DDRSS_PHY_1365_DATA
+			DDRSS_PHY_1366_DATA
+			DDRSS_PHY_1367_DATA
+			DDRSS_PHY_1368_DATA
+			DDRSS_PHY_1369_DATA
+			DDRSS_PHY_1370_DATA
+			DDRSS_PHY_1371_DATA
+			DDRSS_PHY_1372_DATA
+			DDRSS_PHY_1373_DATA
+			DDRSS_PHY_1374_DATA
+			DDRSS_PHY_1375_DATA
+			DDRSS_PHY_1376_DATA
+			DDRSS_PHY_1377_DATA
+			DDRSS_PHY_1378_DATA
+			DDRSS_PHY_1379_DATA
+			DDRSS_PHY_1380_DATA
+			DDRSS_PHY_1381_DATA
+			DDRSS_PHY_1382_DATA
+			DDRSS_PHY_1383_DATA
+			DDRSS_PHY_1384_DATA
+			DDRSS_PHY_1385_DATA
+			DDRSS_PHY_1386_DATA
+			DDRSS_PHY_1387_DATA
+			DDRSS_PHY_1388_DATA
+			DDRSS_PHY_1389_DATA
+			DDRSS_PHY_1390_DATA
+			DDRSS_PHY_1391_DATA
+			DDRSS_PHY_1392_DATA
+			DDRSS_PHY_1393_DATA
+			DDRSS_PHY_1394_DATA
+			DDRSS_PHY_1395_DATA
+			DDRSS_PHY_1396_DATA
+			DDRSS_PHY_1397_DATA
+			DDRSS_PHY_1398_DATA
+			DDRSS_PHY_1399_DATA
+			DDRSS_PHY_1400_DATA
+			DDRSS_PHY_1401_DATA
+			DDRSS_PHY_1402_DATA
+			DDRSS_PHY_1403_DATA
+			DDRSS_PHY_1404_DATA
+			DDRSS_PHY_1405_DATA
+			DDRSS_PHY_1406_DATA
+			DDRSS_PHY_1407_DATA
+			DDRSS_PHY_1408_DATA
+			DDRSS_PHY_1409_DATA
+			DDRSS_PHY_1410_DATA
+			DDRSS_PHY_1411_DATA
+			DDRSS_PHY_1412_DATA
+			DDRSS_PHY_1413_DATA
+			DDRSS_PHY_1414_DATA
+			DDRSS_PHY_1415_DATA
+			DDRSS_PHY_1416_DATA
+			DDRSS_PHY_1417_DATA
+			DDRSS_PHY_1418_DATA
+			DDRSS_PHY_1419_DATA
+			DDRSS_PHY_1420_DATA
+			DDRSS_PHY_1421_DATA
+			DDRSS_PHY_1422_DATA
+			DDRSS_PHY_1423_DATA
+			DDRSS_PHY_1424_DATA
+			DDRSS_PHY_1425_DATA
+			DDRSS_PHY_1426_DATA
+			DDRSS_PHY_1427_DATA
+			DDRSS_PHY_1428_DATA
+			DDRSS_PHY_1429_DATA
+			DDRSS_PHY_1430_DATA
+			DDRSS_PHY_1431_DATA
+			DDRSS_PHY_1432_DATA
+			DDRSS_PHY_1433_DATA
+			DDRSS_PHY_1434_DATA
+			DDRSS_PHY_1435_DATA
+			DDRSS_PHY_1436_DATA
+			DDRSS_PHY_1437_DATA
+			DDRSS_PHY_1438_DATA
+			DDRSS_PHY_1439_DATA
+			DDRSS_PHY_1440_DATA
+			DDRSS_PHY_1441_DATA
+			DDRSS_PHY_1442_DATA
+			DDRSS_PHY_1443_DATA
+			DDRSS_PHY_1444_DATA
+			DDRSS_PHY_1445_DATA
+			DDRSS_PHY_1446_DATA
+			DDRSS_PHY_1447_DATA
+			DDRSS_PHY_1448_DATA
+			DDRSS_PHY_1449_DATA
+			DDRSS_PHY_1450_DATA
+			DDRSS_PHY_1451_DATA
+			DDRSS_PHY_1452_DATA
+			DDRSS_PHY_1453_DATA
+			DDRSS_PHY_1454_DATA
+			DDRSS_PHY_1455_DATA
+			DDRSS_PHY_1456_DATA
+			DDRSS_PHY_1457_DATA
+			DDRSS_PHY_1458_DATA
+			DDRSS_PHY_1459_DATA
+			DDRSS_PHY_1460_DATA
+			DDRSS_PHY_1461_DATA
+			DDRSS_PHY_1462_DATA
+			DDRSS_PHY_1463_DATA
+			DDRSS_PHY_1464_DATA
+			DDRSS_PHY_1465_DATA
+			DDRSS_PHY_1466_DATA
+			DDRSS_PHY_1467_DATA
+			DDRSS_PHY_1468_DATA
+			DDRSS_PHY_1469_DATA
+			DDRSS_PHY_1470_DATA
+			DDRSS_PHY_1471_DATA
+			DDRSS_PHY_1472_DATA
+			DDRSS_PHY_1473_DATA
+			DDRSS_PHY_1474_DATA
+			DDRSS_PHY_1475_DATA
+			DDRSS_PHY_1476_DATA
+			DDRSS_PHY_1477_DATA
+			DDRSS_PHY_1478_DATA
+			DDRSS_PHY_1479_DATA
+			DDRSS_PHY_1480_DATA
+			DDRSS_PHY_1481_DATA
+			DDRSS_PHY_1482_DATA
+			DDRSS_PHY_1483_DATA
+			DDRSS_PHY_1484_DATA
+			DDRSS_PHY_1485_DATA
+			DDRSS_PHY_1486_DATA
+			DDRSS_PHY_1487_DATA
+			DDRSS_PHY_1488_DATA
+			DDRSS_PHY_1489_DATA
+			DDRSS_PHY_1490_DATA
+			DDRSS_PHY_1491_DATA
+			DDRSS_PHY_1492_DATA
+			DDRSS_PHY_1493_DATA
+			DDRSS_PHY_1494_DATA
+			DDRSS_PHY_1495_DATA
+			DDRSS_PHY_1496_DATA
+			DDRSS_PHY_1497_DATA
+			DDRSS_PHY_1498_DATA
+			DDRSS_PHY_1499_DATA
+			DDRSS_PHY_1500_DATA
+			DDRSS_PHY_1501_DATA
+			DDRSS_PHY_1502_DATA
+			DDRSS_PHY_1503_DATA
+			DDRSS_PHY_1504_DATA
+			DDRSS_PHY_1505_DATA
+			DDRSS_PHY_1506_DATA
+			DDRSS_PHY_1507_DATA
+			DDRSS_PHY_1508_DATA
+			DDRSS_PHY_1509_DATA
+			DDRSS_PHY_1510_DATA
+			DDRSS_PHY_1511_DATA
+			DDRSS_PHY_1512_DATA
+			DDRSS_PHY_1513_DATA
+			DDRSS_PHY_1514_DATA
+			DDRSS_PHY_1515_DATA
+			DDRSS_PHY_1516_DATA
+			DDRSS_PHY_1517_DATA
+			DDRSS_PHY_1518_DATA
+			DDRSS_PHY_1519_DATA
+			DDRSS_PHY_1520_DATA
+			DDRSS_PHY_1521_DATA
+			DDRSS_PHY_1522_DATA
+			DDRSS_PHY_1523_DATA
+			DDRSS_PHY_1524_DATA
+			DDRSS_PHY_1525_DATA
+			DDRSS_PHY_1526_DATA
+			DDRSS_PHY_1527_DATA
+			DDRSS_PHY_1528_DATA
+			DDRSS_PHY_1529_DATA
+			DDRSS_PHY_1530_DATA
+			DDRSS_PHY_1531_DATA
+			DDRSS_PHY_1532_DATA
+			DDRSS_PHY_1533_DATA
+			DDRSS_PHY_1534_DATA
+			DDRSS_PHY_1535_DATA
+			DDRSS_PHY_1536_DATA
+			DDRSS_PHY_1537_DATA
+			DDRSS_PHY_1538_DATA
+			DDRSS_PHY_1539_DATA
+			DDRSS_PHY_1540_DATA
+			DDRSS_PHY_1541_DATA
+			DDRSS_PHY_1542_DATA
+			DDRSS_PHY_1543_DATA
+			DDRSS_PHY_1544_DATA
+			DDRSS_PHY_1545_DATA
+			DDRSS_PHY_1546_DATA
+			DDRSS_PHY_1547_DATA
+			DDRSS_PHY_1548_DATA
+			DDRSS_PHY_1549_DATA
+			DDRSS_PHY_1550_DATA
+			DDRSS_PHY_1551_DATA
+			DDRSS_PHY_1552_DATA
+			DDRSS_PHY_1553_DATA
+			DDRSS_PHY_1554_DATA
+			DDRSS_PHY_1555_DATA
+			DDRSS_PHY_1556_DATA
+			DDRSS_PHY_1557_DATA
+			DDRSS_PHY_1558_DATA
+			DDRSS_PHY_1559_DATA
+			DDRSS_PHY_1560_DATA
+			DDRSS_PHY_1561_DATA
+			DDRSS_PHY_1562_DATA
+			DDRSS_PHY_1563_DATA
+			DDRSS_PHY_1564_DATA
+			DDRSS_PHY_1565_DATA
+			DDRSS_PHY_1566_DATA
+			DDRSS_PHY_1567_DATA
+			DDRSS_PHY_1568_DATA
+			DDRSS_PHY_1569_DATA
+			DDRSS_PHY_1570_DATA
+			DDRSS_PHY_1571_DATA
+			DDRSS_PHY_1572_DATA
+			DDRSS_PHY_1573_DATA
+			DDRSS_PHY_1574_DATA
+			DDRSS_PHY_1575_DATA
+			DDRSS_PHY_1576_DATA
+			DDRSS_PHY_1577_DATA
+			DDRSS_PHY_1578_DATA
+			DDRSS_PHY_1579_DATA
+			DDRSS_PHY_1580_DATA
+			DDRSS_PHY_1581_DATA
+			DDRSS_PHY_1582_DATA
+			DDRSS_PHY_1583_DATA
+			DDRSS_PHY_1584_DATA
+			DDRSS_PHY_1585_DATA
+			DDRSS_PHY_1586_DATA
+			DDRSS_PHY_1587_DATA
+			DDRSS_PHY_1588_DATA
+			DDRSS_PHY_1589_DATA
+			DDRSS_PHY_1590_DATA
+			DDRSS_PHY_1591_DATA
+			DDRSS_PHY_1592_DATA
+			DDRSS_PHY_1593_DATA
+			DDRSS_PHY_1594_DATA
+			DDRSS_PHY_1595_DATA
+			DDRSS_PHY_1596_DATA
+			DDRSS_PHY_1597_DATA
+			DDRSS_PHY_1598_DATA
+			DDRSS_PHY_1599_DATA
+			DDRSS_PHY_1600_DATA
+			DDRSS_PHY_1601_DATA
+			DDRSS_PHY_1602_DATA
+			DDRSS_PHY_1603_DATA
+			DDRSS_PHY_1604_DATA
+			DDRSS_PHY_1605_DATA
+			DDRSS_PHY_1606_DATA
+			DDRSS_PHY_1607_DATA
+			DDRSS_PHY_1608_DATA
+			DDRSS_PHY_1609_DATA
+			DDRSS_PHY_1610_DATA
+			DDRSS_PHY_1611_DATA
+			DDRSS_PHY_1612_DATA
+			DDRSS_PHY_1613_DATA
+			DDRSS_PHY_1614_DATA
+			DDRSS_PHY_1615_DATA
+			DDRSS_PHY_1616_DATA
+			DDRSS_PHY_1617_DATA
+			DDRSS_PHY_1618_DATA
+			DDRSS_PHY_1619_DATA
+			DDRSS_PHY_1620_DATA
+			DDRSS_PHY_1621_DATA
+			DDRSS_PHY_1622_DATA
+			DDRSS_PHY_1623_DATA
+			DDRSS_PHY_1624_DATA
+			DDRSS_PHY_1625_DATA
+			DDRSS_PHY_1626_DATA
+			DDRSS_PHY_1627_DATA
+			DDRSS_PHY_1628_DATA
+			DDRSS_PHY_1629_DATA
+			DDRSS_PHY_1630_DATA
+			DDRSS_PHY_1631_DATA
+			DDRSS_PHY_1632_DATA
+			DDRSS_PHY_1633_DATA
+			DDRSS_PHY_1634_DATA
+			DDRSS_PHY_1635_DATA
+			DDRSS_PHY_1636_DATA
+			DDRSS_PHY_1637_DATA
+			DDRSS_PHY_1638_DATA
+			DDRSS_PHY_1639_DATA
+			DDRSS_PHY_1640_DATA
+			DDRSS_PHY_1641_DATA
+			DDRSS_PHY_1642_DATA
+			DDRSS_PHY_1643_DATA
+			DDRSS_PHY_1644_DATA
+			DDRSS_PHY_1645_DATA
+			DDRSS_PHY_1646_DATA
+			DDRSS_PHY_1647_DATA
+			DDRSS_PHY_1648_DATA
+			DDRSS_PHY_1649_DATA
+			DDRSS_PHY_1650_DATA
+			DDRSS_PHY_1651_DATA
+			DDRSS_PHY_1652_DATA
+			DDRSS_PHY_1653_DATA
+			DDRSS_PHY_1654_DATA
+			DDRSS_PHY_1655_DATA
+			DDRSS_PHY_1656_DATA
+			DDRSS_PHY_1657_DATA
+			DDRSS_PHY_1658_DATA
+			DDRSS_PHY_1659_DATA
+			DDRSS_PHY_1660_DATA
+			DDRSS_PHY_1661_DATA
+			DDRSS_PHY_1662_DATA
+			DDRSS_PHY_1663_DATA
+			DDRSS_PHY_1664_DATA
+			DDRSS_PHY_1665_DATA
+			DDRSS_PHY_1666_DATA
+			DDRSS_PHY_1667_DATA
+			DDRSS_PHY_1668_DATA
+			DDRSS_PHY_1669_DATA
+			DDRSS_PHY_1670_DATA
+			DDRSS_PHY_1671_DATA
+			DDRSS_PHY_1672_DATA
+			DDRSS_PHY_1673_DATA
+			DDRSS_PHY_1674_DATA
+			DDRSS_PHY_1675_DATA
+			DDRSS_PHY_1676_DATA
+			DDRSS_PHY_1677_DATA
+			DDRSS_PHY_1678_DATA
+			DDRSS_PHY_1679_DATA
+			DDRSS_PHY_1680_DATA
+			DDRSS_PHY_1681_DATA
+			DDRSS_PHY_1682_DATA
+			DDRSS_PHY_1683_DATA
+			DDRSS_PHY_1684_DATA
+			DDRSS_PHY_1685_DATA
+			DDRSS_PHY_1686_DATA
+			DDRSS_PHY_1687_DATA
+			DDRSS_PHY_1688_DATA
+			DDRSS_PHY_1689_DATA
+			DDRSS_PHY_1690_DATA
+			DDRSS_PHY_1691_DATA
+			DDRSS_PHY_1692_DATA
+			DDRSS_PHY_1693_DATA
+			DDRSS_PHY_1694_DATA
+			DDRSS_PHY_1695_DATA
+			DDRSS_PHY_1696_DATA
+			DDRSS_PHY_1697_DATA
+			DDRSS_PHY_1698_DATA
+			DDRSS_PHY_1699_DATA
+			DDRSS_PHY_1700_DATA
+			DDRSS_PHY_1701_DATA
+			DDRSS_PHY_1702_DATA
+			DDRSS_PHY_1703_DATA
+			DDRSS_PHY_1704_DATA
+			DDRSS_PHY_1705_DATA
+			DDRSS_PHY_1706_DATA
+			DDRSS_PHY_1707_DATA
+			DDRSS_PHY_1708_DATA
+			DDRSS_PHY_1709_DATA
+			DDRSS_PHY_1710_DATA
+			DDRSS_PHY_1711_DATA
+			DDRSS_PHY_1712_DATA
+			DDRSS_PHY_1713_DATA
+			DDRSS_PHY_1714_DATA
+			DDRSS_PHY_1715_DATA
+			DDRSS_PHY_1716_DATA
+			DDRSS_PHY_1717_DATA
+			DDRSS_PHY_1718_DATA
+			DDRSS_PHY_1719_DATA
+			DDRSS_PHY_1720_DATA
+			DDRSS_PHY_1721_DATA
+			DDRSS_PHY_1722_DATA
+			DDRSS_PHY_1723_DATA
+			DDRSS_PHY_1724_DATA
+			DDRSS_PHY_1725_DATA
+			DDRSS_PHY_1726_DATA
+			DDRSS_PHY_1727_DATA
+			DDRSS_PHY_1728_DATA
+			DDRSS_PHY_1729_DATA
+			DDRSS_PHY_1730_DATA
+			DDRSS_PHY_1731_DATA
+			DDRSS_PHY_1732_DATA
+			DDRSS_PHY_1733_DATA
+			DDRSS_PHY_1734_DATA
+			DDRSS_PHY_1735_DATA
+			DDRSS_PHY_1736_DATA
+			DDRSS_PHY_1737_DATA
+			DDRSS_PHY_1738_DATA
+			DDRSS_PHY_1739_DATA
+			DDRSS_PHY_1740_DATA
+			DDRSS_PHY_1741_DATA
+			DDRSS_PHY_1742_DATA
+			DDRSS_PHY_1743_DATA
+			DDRSS_PHY_1744_DATA
+			DDRSS_PHY_1745_DATA
+			DDRSS_PHY_1746_DATA
+			DDRSS_PHY_1747_DATA
+			DDRSS_PHY_1748_DATA
+			DDRSS_PHY_1749_DATA
+			DDRSS_PHY_1750_DATA
+			DDRSS_PHY_1751_DATA
+			DDRSS_PHY_1752_DATA
+			DDRSS_PHY_1753_DATA
+			DDRSS_PHY_1754_DATA
+			DDRSS_PHY_1755_DATA
+			DDRSS_PHY_1756_DATA
+			DDRSS_PHY_1757_DATA
+			DDRSS_PHY_1758_DATA
+			DDRSS_PHY_1759_DATA
+			DDRSS_PHY_1760_DATA
+			DDRSS_PHY_1761_DATA
+			DDRSS_PHY_1762_DATA
+			DDRSS_PHY_1763_DATA
+			DDRSS_PHY_1764_DATA
+			DDRSS_PHY_1765_DATA
+			DDRSS_PHY_1766_DATA
+			DDRSS_PHY_1767_DATA
+			DDRSS_PHY_1768_DATA
+			DDRSS_PHY_1769_DATA
+			DDRSS_PHY_1770_DATA
+			DDRSS_PHY_1771_DATA
+			DDRSS_PHY_1772_DATA
+			DDRSS_PHY_1773_DATA
+			DDRSS_PHY_1774_DATA
+			DDRSS_PHY_1775_DATA
+			DDRSS_PHY_1776_DATA
+			DDRSS_PHY_1777_DATA
+			DDRSS_PHY_1778_DATA
+			DDRSS_PHY_1779_DATA
+			DDRSS_PHY_1780_DATA
+			DDRSS_PHY_1781_DATA
+			DDRSS_PHY_1782_DATA
+			DDRSS_PHY_1783_DATA
+			DDRSS_PHY_1784_DATA
+			DDRSS_PHY_1785_DATA
+			DDRSS_PHY_1786_DATA
+			DDRSS_PHY_1787_DATA
+			DDRSS_PHY_1788_DATA
+			DDRSS_PHY_1789_DATA
+			DDRSS_PHY_1790_DATA
+			DDRSS_PHY_1791_DATA
+			DDRSS_PHY_1792_DATA
+			DDRSS_PHY_1793_DATA
+			DDRSS_PHY_1794_DATA
+			DDRSS_PHY_1795_DATA
+			DDRSS_PHY_1796_DATA
+			DDRSS_PHY_1797_DATA
+			DDRSS_PHY_1798_DATA
+			DDRSS_PHY_1799_DATA
+			DDRSS_PHY_1800_DATA
+			DDRSS_PHY_1801_DATA
+			DDRSS_PHY_1802_DATA
+			DDRSS_PHY_1803_DATA
+			DDRSS_PHY_1804_DATA
+			DDRSS_PHY_1805_DATA
+			DDRSS_PHY_1806_DATA
+			DDRSS_PHY_1807_DATA
+			DDRSS_PHY_1808_DATA
+			DDRSS_PHY_1809_DATA
+			DDRSS_PHY_1810_DATA
+			DDRSS_PHY_1811_DATA
+			DDRSS_PHY_1812_DATA
+			DDRSS_PHY_1813_DATA
+			DDRSS_PHY_1814_DATA
+			DDRSS_PHY_1815_DATA
+			DDRSS_PHY_1816_DATA
+			DDRSS_PHY_1817_DATA
+			DDRSS_PHY_1818_DATA
+			DDRSS_PHY_1819_DATA
+			DDRSS_PHY_1820_DATA
+			DDRSS_PHY_1821_DATA
+			DDRSS_PHY_1822_DATA
+			DDRSS_PHY_1823_DATA
+			DDRSS_PHY_1824_DATA
+			DDRSS_PHY_1825_DATA
+			DDRSS_PHY_1826_DATA
+			DDRSS_PHY_1827_DATA
+			DDRSS_PHY_1828_DATA
+			DDRSS_PHY_1829_DATA
+			DDRSS_PHY_1830_DATA
+			DDRSS_PHY_1831_DATA
+			DDRSS_PHY_1832_DATA
+			DDRSS_PHY_1833_DATA
+			DDRSS_PHY_1834_DATA
+			DDRSS_PHY_1835_DATA
+			DDRSS_PHY_1836_DATA
+			DDRSS_PHY_1837_DATA
+			DDRSS_PHY_1838_DATA
+			DDRSS_PHY_1839_DATA
+			DDRSS_PHY_1840_DATA
+			DDRSS_PHY_1841_DATA
+			DDRSS_PHY_1842_DATA
+			DDRSS_PHY_1843_DATA
+			DDRSS_PHY_1844_DATA
+			DDRSS_PHY_1845_DATA
+			DDRSS_PHY_1846_DATA
+			DDRSS_PHY_1847_DATA
+			DDRSS_PHY_1848_DATA
+			DDRSS_PHY_1849_DATA
+			DDRSS_PHY_1850_DATA
+			DDRSS_PHY_1851_DATA
+			DDRSS_PHY_1852_DATA
+			DDRSS_PHY_1853_DATA
+			DDRSS_PHY_1854_DATA
+			DDRSS_PHY_1855_DATA
+			DDRSS_PHY_1856_DATA
+			DDRSS_PHY_1857_DATA
+			DDRSS_PHY_1858_DATA
+			DDRSS_PHY_1859_DATA
+			DDRSS_PHY_1860_DATA
+			DDRSS_PHY_1861_DATA
+			DDRSS_PHY_1862_DATA
+			DDRSS_PHY_1863_DATA
+			DDRSS_PHY_1864_DATA
+			DDRSS_PHY_1865_DATA
+			DDRSS_PHY_1866_DATA
+			DDRSS_PHY_1867_DATA
+			DDRSS_PHY_1868_DATA
+			DDRSS_PHY_1869_DATA
+			DDRSS_PHY_1870_DATA
+			DDRSS_PHY_1871_DATA
+			DDRSS_PHY_1872_DATA
+			DDRSS_PHY_1873_DATA
+			DDRSS_PHY_1874_DATA
+			DDRSS_PHY_1875_DATA
+			DDRSS_PHY_1876_DATA
+			DDRSS_PHY_1877_DATA
+			DDRSS_PHY_1878_DATA
+			DDRSS_PHY_1879_DATA
+			DDRSS_PHY_1880_DATA
+			DDRSS_PHY_1881_DATA
+			DDRSS_PHY_1882_DATA
+			DDRSS_PHY_1883_DATA
+			DDRSS_PHY_1884_DATA
+			DDRSS_PHY_1885_DATA
+			DDRSS_PHY_1886_DATA
+			DDRSS_PHY_1887_DATA
+			DDRSS_PHY_1888_DATA
+			DDRSS_PHY_1889_DATA
+			DDRSS_PHY_1890_DATA
+			DDRSS_PHY_1891_DATA
+			DDRSS_PHY_1892_DATA
+			DDRSS_PHY_1893_DATA
+			DDRSS_PHY_1894_DATA
+			DDRSS_PHY_1895_DATA
+			DDRSS_PHY_1896_DATA
+			DDRSS_PHY_1897_DATA
+			DDRSS_PHY_1898_DATA
+			DDRSS_PHY_1899_DATA
+			DDRSS_PHY_1900_DATA
+			DDRSS_PHY_1901_DATA
+			DDRSS_PHY_1902_DATA
+			DDRSS_PHY_1903_DATA
+			DDRSS_PHY_1904_DATA
+			DDRSS_PHY_1905_DATA
+			DDRSS_PHY_1906_DATA
+			DDRSS_PHY_1907_DATA
+			DDRSS_PHY_1908_DATA
+			DDRSS_PHY_1909_DATA
+			DDRSS_PHY_1910_DATA
+			DDRSS_PHY_1911_DATA
+			DDRSS_PHY_1912_DATA
+			DDRSS_PHY_1913_DATA
+			DDRSS_PHY_1914_DATA
+			DDRSS_PHY_1915_DATA
+			DDRSS_PHY_1916_DATA
+			DDRSS_PHY_1917_DATA
+			DDRSS_PHY_1918_DATA
+			DDRSS_PHY_1919_DATA
+			DDRSS_PHY_1920_DATA
+			DDRSS_PHY_1921_DATA
+			DDRSS_PHY_1922_DATA
+			DDRSS_PHY_1923_DATA
+		>;
+	};
+};
diff --git a/arch/arm/dts/k3-am62a7-r5-sk.dts b/arch/arm/dts/k3-am62a7-r5-sk.dts
new file mode 100644
index 0000000000000..58b7c8ad050fd
--- /dev/null
+++ b/arch/arm/dts/k3-am62a7-r5-sk.dts
@@ -0,0 +1,143 @@
+// SPDX-License-Identifier: GPL-2.0
+/*
+ * AM62A7 SK dts file for R5 SPL
+ * Copyright (C) 2022 Texas Instruments Incorporated - https://www.ti.com/
+ */
+
+#include "k3-am62a7-sk.dts"
+#include "k3-am62a-ddr-1866mhz-32bit.dtsi"
+#include "k3-am62a-ddr.dtsi"
+
+#include "k3-am62a7-sk-u-boot.dtsi"
+
+/ {
+	aliases {
+		remoteproc0 = &sysctrler;
+		remoteproc1 = &a53_0;
+		serial0 = &wkup_uart0;
+		serial3 = &main_uart1;
+	};
+
+	chosen {
+		stdout-path = "serial2:115200n8";
+		tick-timer = &timer1;
+	};
+
+	memory@80000000 {
+		device_type = "memory";
+		reg = <0x00000000 0x80000000 0x00000000 0x80000000>; /* 2G RAM */
+		u-boot,dm-spl;
+	};
+
+	reserved-memory {
+		#address-cells = <2>;
+		#size-cells = <2>;
+		ranges;
+
+		secure_ddr: optee@9e800000 {
+			reg = <0x00 0x9e800000 0x00 0x01800000>; /* for OP-TEE */
+			alignment = <0x1000>;
+			no-map;
+		};
+	};
+
+	a53_0: a53@0 {
+		compatible = "ti,am654-rproc";
+		reg = <0x00 0x00a90000 0x00 0x10>;
+		power-domains = <&k3_pds 61 TI_SCI_PD_EXCLUSIVE>,
+				<&k3_pds 135 TI_SCI_PD_EXCLUSIVE>;
+		resets = <&k3_reset 135 0>;
+		clocks = <&k3_clks 61 0>;
+		assigned-clocks = <&k3_clks 61 0>, <&k3_clks 135 0>;
+		assigned-clock-parents = <&k3_clks 61 2>;
+		assigned-clock-rates = <200000000>, <1200000000>;
+		ti,sci = <&dmsc>;
+		ti,sci-proc-id = <32>;
+		ti,sci-host-id = <10>;
+		u-boot,dm-spl;
+	};
+
+	dm_tifs: dm-tifs {
+		compatible = "ti,j721e-dm-sci";
+		ti,host-id = <36>;
+		ti,secure-host;
+		mbox-names = "rx", "tx";
+		mboxes= <&secure_proxy_main 22>,
+			<&secure_proxy_main 23>;
+		u-boot,dm-spl;
+	};
+};
+
+&dmsc {
+	mboxes= <&secure_proxy_main 0>,
+		<&secure_proxy_main 1>,
+		<&secure_proxy_main 0>;
+	mbox-names = "rx", "tx", "notify";
+	ti,host-id = <35>;
+	ti,secure-host;
+};
+
+&cbass_main {
+	sa3_secproxy: secproxy@44880000 {
+		compatible = "ti,am654-secure-proxy";
+		#mbox-cells = <1>;
+		reg = <0x00 0x44880000 0x00 0x20000>,
+		      <0x0 0x44860000 0x0 0x20000>,
+		      <0x0 0x43600000 0x0 0x10000>;
+		reg-names = "rt", "scfg", "target_data";
+		u-boot,dm-spl;
+	};
+
+	sysctrler: sysctrler {
+		compatible = "ti,am654-system-controller";
+		mboxes= <&secure_proxy_main 1>,
+			<&secure_proxy_main 0>,
+			<&sa3_secproxy 0>;
+		mbox-names = "tx", "rx", "boot_notify";
+		u-boot,dm-spl;
+	};
+};
+
+&mcu_pmx0 {
+	status = "okay";
+	u-boot,dm-spl;
+
+	wkup_uart0_pins_default: wkup-uart0-pins-default {
+		pinctrl-single,pins = <
+			AM62X_MCU_IOPAD(0x02c, PIN_INPUT, 0)	/* (C6) WKUP_UART0_CTSn */
+			AM62X_MCU_IOPAD(0x030, PIN_OUTPUT, 0)	/* (A4) WKUP_UART0_RTSn */
+			AM62X_MCU_IOPAD(0x024, PIN_INPUT, 0)	/* (B4) WKUP_UART0_RXD */
+			AM62X_MCU_IOPAD(0x028, PIN_OUTPUT, 0)	/* (C5) WKUP_UART0_TXD */
+		>;
+		u-boot,dm-spl;
+	};
+};
+
+&main_pmx0 {
+	u-boot,dm-spl;
+	main_uart1_pins_default: main-uart1-pins-default {
+		pinctrl-single,pins = <
+			AM62X_IOPAD(0x194, PIN_INPUT, 2)	/* (B19) MCASP0_AXR3.UART1_CTSn */
+			AM62X_IOPAD(0x198, PIN_OUTPUT, 2)	/* (A19) MCASP0_AXR2.UART1_RTSn */
+			AM62X_IOPAD(0x1ac, PIN_INPUT, 2)	/* (E19) MCASP0_AFSR.UART1_RXD */
+			AM62X_IOPAD(0x1b0, PIN_OUTPUT, 2)	/* (A20) MCASP0_ACLKR.UART1_TXD */
+		>;
+		u-boot,dm-spl;
+	};
+};
+
+/* WKUP UART0 is used for DM firmware logs */
+&wkup_uart0 {
+	pinctrl-names = "default";
+	pinctrl-0 = <&wkup_uart0_pins_default>;
+	status = "okay";
+	u-boot,dm-spl;
+};
+
+/* Main UART1 is used for TIFS firmware logs */
+&main_uart1 {
+	pinctrl-names = "default";
+	pinctrl-0 = <&main_uart1_pins_default>;
+	status = "okay";
+	u-boot,dm-spl;
+};
diff --git a/arch/arm/dts/k3-am62a7-sk-u-boot.dtsi b/arch/arm/dts/k3-am62a7-sk-u-boot.dtsi
new file mode 100644
index 0000000000000..7fc749ed70976
--- /dev/null
+++ b/arch/arm/dts/k3-am62a7-sk-u-boot.dtsi
@@ -0,0 +1,140 @@
+// SPDX-License-Identifier: GPL-2.0
+/*
+ * Common AM62A EVM dts file for SPLs
+ * Copyright (C) 2022 Texas Instruments Incorporated - https://www.ti.com/
+ */
+
+/ {
+	chosen {
+		stdout-path = "serial2:115200n8";
+		tick-timer = &timer1;
+	};
+
+	memory@80000000 {
+		u-boot,dm-spl;
+	};
+};
+
+&cbass_main{
+	u-boot,dm-spl;
+
+	timer1: timer@2400000 {
+		compatible = "ti,omap5430-timer";
+		reg = <0x00 0x2400000 0x00 0x80>;
+		ti,timer-alwon;
+		clock-frequency = <25000000>;
+		u-boot,dm-spl;
+	};
+};
+
+&dmss {
+	u-boot,dm-spl;
+};
+
+&secure_proxy_main {
+	u-boot,dm-spl;
+};
+
+&dmsc {
+	u-boot,dm-spl;
+};
+
+&k3_pds {
+	u-boot,dm-spl;
+};
+
+&k3_clks {
+	u-boot,dm-spl;
+};
+
+&k3_reset {
+	u-boot,dm-spl;
+};
+
+&wkup_conf {
+	u-boot,dm-spl;
+};
+
+&chipid {
+	u-boot,dm-spl;
+};
+
+&main_pmx0 {
+	u-boot,dm-spl;
+};
+
+&main_uart0 {
+	u-boot,dm-spl;
+};
+
+&main_uart0_pins_default {
+	u-boot,dm-spl;
+};
+
+&main_uart1 {
+	u-boot,dm-spl;
+};
+
+&cbass_mcu {
+	u-boot,dm-spl;
+};
+
+&cbass_wakeup {
+	u-boot,dm-spl;
+};
+
+&mcu_pmx0 {
+	u-boot,dm-spl;
+};
+
+&wkup_uart0 {
+	u-boot,dm-spl;
+};
+
+&main_gpio0 {
+	u-boot,dm-spl;
+};
+
+&main_i2c0 {
+	u-boot,dm-spl;
+};
+
+&main_i2c0_pins_default {
+	u-boot,dm-spl;
+};
+
+&main_i2c1 {
+	u-boot,dm-spl;
+};
+
+&main_i2c1_pins_default {
+	u-boot,dm-spl;
+};
+
+&exp1 {
+	u-boot,dm-spl;
+};
+
+&sdhci1 {
+	u-boot,dm-spl;
+};
+
+&main_mmc1_pins_default {
+	u-boot,dm-spl;
+};
+
+&k3_reset {
+	u-boot,dm-spl;
+};
+
+&dmsc {
+	u-boot,dm-spl;
+	k3_sysreset: sysreset-controller {
+		compatible = "ti,sci-sysreset";
+		u-boot,dm-spl;
+	};
+};
+
+&vdd_mmc1 {
+	u-boot,dm-spl;
+};
-- 
2.38.1


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

* [PATCH 3/8] ram: k3-ddrss: add am62a controller support
  2022-11-04  0:13 [PATCH 0/8] Introduce initial TI's am62a support Bryan Brattlof
  2022-11-04  0:13 ` [PATCH 1/8] arm: dts: introduce am62a7 dtbs from linux kernel Bryan Brattlof
  2022-11-04  0:13 ` [PATCH 2/8] arm: dts: introduce am62a7 u-boot dtbs Bryan Brattlof
@ 2022-11-04  0:13 ` Bryan Brattlof
  2022-11-04 13:08   ` Tom Rini
  2022-12-09 22:53   ` Tom Rini
  2022-11-04  0:13 ` [PATCH 4/8] soc: ti: k3-socinfo: add am62a SoC entry Bryan Brattlof
                   ` (5 subsequent siblings)
  8 siblings, 2 replies; 26+ messages in thread
From: Bryan Brattlof @ 2022-11-04  0:13 UTC (permalink / raw)
  To: Lukasz Majewski, Sean Anderson, Jaehoon Chung, Nishanth Menon,
	Georgi Vlaev, Andrew Davis, Vignesh Raghavendra, Tom Rini
  Cc: UBoot Mailing List, Bryan Brattlof

TI's am62a family of SoCs uses a new 32bit DDR controller that shares
much of the same functionality with the existing am64 and j721e
controllers.

Select this controller by default when u-boot is build for the am62a

Signed-off-by: Bryan Brattlof <bb@ti.com>
---
 drivers/ram/Kconfig             | 1 +
 drivers/ram/k3-ddrss/k3-ddrss.c | 1 +
 2 files changed, 2 insertions(+)

diff --git a/drivers/ram/Kconfig b/drivers/ram/Kconfig
index bf279b79f6d1a..e085119963b6c 100644
--- a/drivers/ram/Kconfig
+++ b/drivers/ram/Kconfig
@@ -65,6 +65,7 @@ choice
 	default K3_J721E_DDRSS if SOC_K3_J721E || SOC_K3_J721S2
 	default K3_AM64_DDRSS if SOC_K3_AM642
 	default K3_AM64_DDRSS if SOC_K3_AM625
+	default K3_AM62A_DDRSS if SOC_K3_AM62A7
 
 config K3_J721E_DDRSS
 	bool "Enable J721E DDRSS support"
diff --git a/drivers/ram/k3-ddrss/k3-ddrss.c b/drivers/ram/k3-ddrss/k3-ddrss.c
index e8b7aec9e0bb3..7e445d2b737b3 100644
--- a/drivers/ram/k3-ddrss/k3-ddrss.c
+++ b/drivers/ram/k3-ddrss/k3-ddrss.c
@@ -706,6 +706,7 @@ static const struct k3_ddrss_data j721s2_data = {
 };
 
 static const struct udevice_id k3_ddrss_ids[] = {
+	{.compatible = "ti,am62a-ddrss", .data = (ulong)&k3_data, },
 	{.compatible = "ti,am64-ddrss", .data = (ulong)&k3_data, },
 	{.compatible = "ti,j721e-ddrss", .data = (ulong)&k3_data, },
 	{.compatible = "ti,j721s2-ddrss", .data = (ulong)&j721s2_data, },
-- 
2.38.1


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

* [PATCH 4/8] soc: ti: k3-socinfo: add am62a SoC entry
  2022-11-04  0:13 [PATCH 0/8] Introduce initial TI's am62a support Bryan Brattlof
                   ` (2 preceding siblings ...)
  2022-11-04  0:13 ` [PATCH 3/8] ram: k3-ddrss: add am62a controller support Bryan Brattlof
@ 2022-11-04  0:13 ` Bryan Brattlof
  2022-11-04 13:08   ` Tom Rini
  2022-12-09 22:53   ` Tom Rini
  2022-11-04  0:13 ` [PATCH 5/8] arm: mach-k3: introduce basic files to support the am62a Bryan Brattlof
                   ` (4 subsequent siblings)
  8 siblings, 2 replies; 26+ messages in thread
From: Bryan Brattlof @ 2022-11-04  0:13 UTC (permalink / raw)
  To: Lukasz Majewski, Sean Anderson, Jaehoon Chung, Nishanth Menon,
	Georgi Vlaev, Andrew Davis, Vignesh Raghavendra, Tom Rini
  Cc: UBoot Mailing List, Bryan Brattlof

Add identification support for TI's am62ax family of SoCs

Signed-off-by: Bryan Brattlof <bb@ti.com>
---
 drivers/soc/soc_ti_k3.c | 4 ++++
 1 file changed, 4 insertions(+)

diff --git a/drivers/soc/soc_ti_k3.c b/drivers/soc/soc_ti_k3.c
index b1e7c4ae5f6aa..8af0ac7051925 100644
--- a/drivers/soc/soc_ti_k3.c
+++ b/drivers/soc/soc_ti_k3.c
@@ -16,6 +16,7 @@
 #define AM64X			0xbb38
 #define J721S2			0xbb75
 #define AM62X			0xbb7e
+#define AM62AX			0xbb8d
 
 #define JTAG_ID_VARIANT_SHIFT	28
 #define JTAG_ID_VARIANT_MASK	(0xf << 28)
@@ -53,6 +54,9 @@ static const char *get_family_string(u32 idreg)
 	case AM62X:
 		family = "AM62X";
 		break;
+	case AM62AX:
+		family = "AM62AX";
+		break;
 	default:
 		family = "Unknown Silicon";
 	};
-- 
2.38.1


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

* [PATCH 5/8] arm: mach-k3: introduce basic files to support the am62a
  2022-11-04  0:13 [PATCH 0/8] Introduce initial TI's am62a support Bryan Brattlof
                   ` (3 preceding siblings ...)
  2022-11-04  0:13 ` [PATCH 4/8] soc: ti: k3-socinfo: add am62a SoC entry Bryan Brattlof
@ 2022-11-04  0:13 ` Bryan Brattlof
  2022-12-09 22:53   ` Tom Rini
  2022-11-04  0:13 ` [PATCH 6/8] arm: mach-k3: am62a: introduce auto-generated SoC data Bryan Brattlof
                   ` (3 subsequent siblings)
  8 siblings, 1 reply; 26+ messages in thread
From: Bryan Brattlof @ 2022-11-04  0:13 UTC (permalink / raw)
  To: Lukasz Majewski, Sean Anderson, Jaehoon Chung, Nishanth Menon,
	Georgi Vlaev, Andrew Davis, Vignesh Raghavendra, Tom Rini
  Cc: UBoot Mailing List, Bryan Brattlof

Introduce the mach-k3 files needed to properly boot TI's am62a SoC
family of devices

Signed-off-by: Bryan Brattlof <bb@ti.com>
---
 arch/arm/mach-k3/Kconfig                      |  14 +-
 arch/arm/mach-k3/Makefile                     |   2 +
 arch/arm/mach-k3/am62a7_init.c                | 250 ++++++++++++++++++
 arch/arm/mach-k3/arm64-mmu.c                  |   6 +-
 .../arm/mach-k3/include/mach/am62a_hardware.h |  74 ++++++
 arch/arm/mach-k3/include/mach/am62a_spl.h     |  49 ++++
 arch/arm/mach-k3/include/mach/hardware.h      |   4 +
 arch/arm/mach-k3/include/mach/spl.h           |   4 +
 8 files changed, 396 insertions(+), 7 deletions(-)
 create mode 100644 arch/arm/mach-k3/am62a7_init.c
 create mode 100644 arch/arm/mach-k3/include/mach/am62a_hardware.h
 create mode 100644 arch/arm/mach-k3/include/mach/am62a_spl.h

diff --git a/arch/arm/mach-k3/Kconfig b/arch/arm/mach-k3/Kconfig
index 171a7f2f25f8d..87da6b49ee6b7 100644
--- a/arch/arm/mach-k3/Kconfig
+++ b/arch/arm/mach-k3/Kconfig
@@ -19,6 +19,9 @@ config SOC_K3_AM642
 config SOC_K3_AM625
 	bool "TI's K3 based AM625 SoC Family Support"
 
+config SOC_K3_AM62A7
+	bool "TI's K3 based AM62A7 SoC Family Support"
+
 endchoice
 
 config SYS_SOC
@@ -29,7 +32,7 @@ config SYS_K3_NON_SECURE_MSRAM_SIZE
 	default 0x80000 if SOC_K3_AM654
 	default 0x100000 if SOC_K3_J721E || SOC_K3_J721S2
 	default 0x1c0000 if SOC_K3_AM642
-	default 0x3c000 if SOC_K3_AM625
+	default 0x3c000 if SOC_K3_AM625 || SOC_K3_AM62A7
 	help
 	  Describes the total size of the MCU or OCMC MSRAM present on
 	  the SoC in use. This doesn't specify the total size of SPL as
@@ -41,7 +44,7 @@ config SYS_K3_MAX_DOWNLODABLE_IMAGE_SIZE
 	default 0x58000 if SOC_K3_AM654
 	default 0xc0000 if SOC_K3_J721E || SOC_K3_J721S2
 	default 0x180000 if SOC_K3_AM642
-	default 0x38000 if SOC_K3_AM625
+	default 0x38000 if SOC_K3_AM625 || SOC_K3_AM62A7
 	help
 	  Describes the maximum size of the image that ROM can download
 	  from any boot media.
@@ -66,7 +69,7 @@ config SYS_K3_BOOT_PARAM_TABLE_INDEX
 	default 0x41cffbfc if SOC_K3_J721E
 	default 0x41cfdbfc if SOC_K3_J721S2
 	default 0x701bebfc if SOC_K3_AM642
-	default 0x43c3f290 if SOC_K3_AM625
+	default 0x43c3f290 if SOC_K3_AM625 || SOC_K3_AM62A7
 	help
 	  Address at which ROM stores the value which determines if SPL
 	  is booted up by primary boot media or secondary boot media.
@@ -135,7 +138,7 @@ config K3_SYSFW_IMAGE_MMCSD_RAW_MODE_PART
 config K3_SYSFW_IMAGE_SIZE_MAX
 	int "Amount of memory dynamically allocated for loading SYSFW blob"
 	depends on K3_LOAD_SYSFW
-	default 163840 if SOC_K3_AM625
+	default 163840 if SOC_K3_AM625 || SOC_K3_AM62A7
 	default	278000
 	help
 	  Amount of memory (in bytes) reserved through dynamic allocation at
@@ -167,7 +170,7 @@ config K3_ATF_LOAD_ADDR
 
 config K3_DM_FW
 	bool "Separate DM firmware image"
-	depends on SPL && CPU_V7R && (SOC_K3_J721E || SOC_K3_J721S2 || SOC_K3_AM625) && !CLK_TI_SCI && !TI_SCI_POWER_DOMAIN
+	depends on SPL && CPU_V7R && (SOC_K3_J721E || SOC_K3_J721S2 || SOC_K3_AM625 || SOC_K3_AM62A7) && !CLK_TI_SCI && !TI_SCI_POWER_DOMAIN
 	default y
 	help
 	  Enabling this will indicate that the system has separate DM
@@ -185,6 +188,7 @@ config K3_X509_SWRV
 source "board/ti/am65x/Kconfig"
 source "board/ti/am64x/Kconfig"
 source "board/ti/am62x/Kconfig"
+source "board/ti/am62ax/Kconfig"
 source "board/ti/j721e/Kconfig"
 source "board/siemens/iot2050/Kconfig"
 source "board/ti/j721s2/Kconfig"
diff --git a/arch/arm/mach-k3/Makefile b/arch/arm/mach-k3/Makefile
index 6ac2b61c3d7ba..b5bc2367813c8 100644
--- a/arch/arm/mach-k3/Makefile
+++ b/arch/arm/mach-k3/Makefile
@@ -6,6 +6,7 @@
 obj-$(CONFIG_SOC_K3_J721E) += j721e/ j7200/
 obj-$(CONFIG_SOC_K3_J721S2) += j721s2/
 obj-$(CONFIG_SOC_K3_AM625) += am62x/
+obj-$(CONFIG_SOC_K3_AM62A7) += am62ax/
 obj-$(CONFIG_ARM64) += arm64-mmu.o
 obj-$(CONFIG_CPU_V7R) += r5_mpu.o lowlevel_init.o
 obj-$(CONFIG_ARM64) += cache.o
@@ -15,6 +16,7 @@ obj-$(CONFIG_SOC_K3_J721E) += j721e_init.o
 obj-$(CONFIG_SOC_K3_J721S2) += j721s2_init.o
 obj-$(CONFIG_SOC_K3_AM642) += am642_init.o
 obj-$(CONFIG_SOC_K3_AM625) += am625_init.o
+obj-$(CONFIG_SOC_K3_AM62A7) += am62a7_init.o
 obj-$(CONFIG_K3_LOAD_SYSFW) += sysfw-loader.o
 endif
 obj-y += common.o security.o
diff --git a/arch/arm/mach-k3/am62a7_init.c b/arch/arm/mach-k3/am62a7_init.c
new file mode 100644
index 0000000000000..e9569f0d26418
--- /dev/null
+++ b/arch/arm/mach-k3/am62a7_init.c
@@ -0,0 +1,250 @@
+// SPDX-License-Identifier: GPL-2.0
+/*
+ * AM62A7: SoC specific initialization
+ *
+ * Copyright (C) 2022 Texas Instruments Incorporated - https://www.ti.com/
+ */
+
+#include <spl.h>
+#include <asm/io.h>
+#include <asm/arch/hardware.h>
+#include <asm/arch/sysfw-loader.h>
+#include "common.h"
+#include <dm.h>
+#include <dm/uclass-internal.h>
+#include <dm/pinctrl.h>
+
+/*
+ * This uninitialized global variable would normal end up in the .bss section,
+ * but the .bss is cleared between writing and reading this variable, so move
+ * it to the .data section.
+ */
+u32 bootindex __section(".data");
+static struct rom_extended_boot_data bootdata __section(".data");
+
+static void store_boot_info_from_rom(void)
+{
+	bootindex = *(u32 *)(CONFIG_SYS_K3_BOOT_PARAM_TABLE_INDEX);
+	memcpy(&bootdata, (uintptr_t *)ROM_ENTENDED_BOOT_DATA_INFO,
+	       sizeof(struct rom_extended_boot_data));
+}
+
+static void ctrl_mmr_unlock(void)
+{
+	/* Unlock all WKUP_CTRL_MMR0 module registers */
+	mmr_unlock(WKUP_CTRL_MMR0_BASE, 0);
+	mmr_unlock(WKUP_CTRL_MMR0_BASE, 1);
+	mmr_unlock(WKUP_CTRL_MMR0_BASE, 2);
+	mmr_unlock(WKUP_CTRL_MMR0_BASE, 3);
+	mmr_unlock(WKUP_CTRL_MMR0_BASE, 4);
+	mmr_unlock(WKUP_CTRL_MMR0_BASE, 5);
+	mmr_unlock(WKUP_CTRL_MMR0_BASE, 6);
+	mmr_unlock(WKUP_CTRL_MMR0_BASE, 7);
+
+	/* Unlock all CTRL_MMR0 module registers */
+	mmr_unlock(CTRL_MMR0_BASE, 0);
+	mmr_unlock(CTRL_MMR0_BASE, 1);
+	mmr_unlock(CTRL_MMR0_BASE, 2);
+	mmr_unlock(CTRL_MMR0_BASE, 4);
+	mmr_unlock(CTRL_MMR0_BASE, 5);
+	mmr_unlock(CTRL_MMR0_BASE, 6);
+
+	/* Unlock all MCU_CTRL_MMR0 module registers */
+	mmr_unlock(MCU_CTRL_MMR0_BASE, 0);
+	mmr_unlock(MCU_CTRL_MMR0_BASE, 1);
+	mmr_unlock(MCU_CTRL_MMR0_BASE, 2);
+	mmr_unlock(MCU_CTRL_MMR0_BASE, 3);
+	mmr_unlock(MCU_CTRL_MMR0_BASE, 4);
+	mmr_unlock(MCU_CTRL_MMR0_BASE, 6);
+
+	/* Unlock PADCFG_CTRL_MMR padconf registers */
+	mmr_unlock(PADCFG_MMR0_BASE, 1);
+	mmr_unlock(PADCFG_MMR1_BASE, 1);
+}
+
+void board_init_f(ulong dummy)
+{
+	struct udevice *dev;
+	int ret;
+
+#if defined(CONFIG_CPU_V7R)
+	setup_k3_mpu_regions();
+#endif
+
+	/*
+	 * Cannot delay this further as there is a chance that
+	 * K3_BOOT_PARAM_TABLE_INDEX can be over written by SPL MALLOC section.
+	 */
+	store_boot_info_from_rom();
+
+	ctrl_mmr_unlock();
+
+	/* Init DM early */
+	spl_early_init();
+
+	/*
+	 * Process pinctrl for the serial0 and serial3, aka WKUP_UART0 and
+	 * MAIN_UART1 modules and continue regardless of the result of pinctrl.
+	 * Do this without probing the device, but instead by searching the
+	 * device that would request the given sequence number if probed. The
+	 * UARTs will be used by the DM firmware and TIFS firmware images
+	 * respectively and the firmware depend on SPL to initialize the pin
+	 * settings.
+	 */
+	ret = uclass_find_device_by_seq(UCLASS_SERIAL, 0, &dev);
+	if (!ret)
+		pinctrl_select_state(dev, "default");
+
+	ret = uclass_find_device_by_seq(UCLASS_SERIAL, 3, &dev);
+	if (!ret)
+		pinctrl_select_state(dev, "default");
+
+#ifdef CONFIG_K3_EARLY_CONS
+	/*
+	 * Allow establishing an early console as required for example when
+	 * doing a UART-based boot. Note that this console may not "survive"
+	 * through a SYSFW PM-init step and will need a re-init in some way
+	 * due to changing module clock frequencies.
+	 */
+	early_console_init();
+#endif
+
+#if defined(CONFIG_K3_LOAD_SYSFW)
+	/*
+	 * Configure and start up system controller firmware. Provide
+	 * the U-Boot console init function to the SYSFW post-PM configuration
+	 * callback hook, effectively switching on (or over) the console
+	 * output.
+	 */
+	ret = is_rom_loaded_sysfw(&bootdata);
+	if (!ret)
+		panic("ROM has not loaded TIFS firmware\n");
+
+	k3_sysfw_loader(true, NULL, NULL);
+#endif
+
+	/*
+	 * Force probe of clk_k3 driver here to ensure basic default clock
+	 * configuration is always done.
+	 */
+	if (IS_ENABLED(CONFIG_SPL_CLK_K3)) {
+		ret = uclass_get_device_by_driver(UCLASS_CLK,
+						  DM_DRIVER_GET(ti_clk),
+						  &dev);
+		if (ret)
+			printf("Failed to initialize clk-k3!\n");
+	}
+
+	preloader_console_init();
+
+	/* Output System Firmware version info */
+	k3_sysfw_print_ver();
+
+#if defined(CONFIG_K3_AM62A_DDRSS)
+	ret = uclass_get_device(UCLASS_RAM, 0, &dev);
+	if (ret)
+		panic("DRAM init failed: %d\n", ret);
+#endif
+
+	printf("am62a_init: %s done\n", __func__);
+}
+
+static u32 __get_backup_bootmedia(u32 devstat)
+{
+	u32 bkup_bootmode = (devstat & MAIN_DEVSTAT_BACKUP_BOOTMODE_MASK) >>
+				MAIN_DEVSTAT_BACKUP_BOOTMODE_SHIFT;
+	u32 bkup_bootmode_cfg =
+			(devstat & MAIN_DEVSTAT_BACKUP_BOOTMODE_CFG_MASK) >>
+				MAIN_DEVSTAT_BACKUP_BOOTMODE_CFG_SHIFT;
+
+	switch (bkup_bootmode) {
+	case BACKUP_BOOT_DEVICE_UART:
+		return BOOT_DEVICE_UART;
+
+	case BACKUP_BOOT_DEVICE_USB:
+		return BOOT_DEVICE_USB;
+
+	case BACKUP_BOOT_DEVICE_ETHERNET:
+		return BOOT_DEVICE_ETHERNET;
+
+	case BACKUP_BOOT_DEVICE_MMC:
+		if (bkup_bootmode_cfg)
+			return BOOT_DEVICE_MMC2;
+		return BOOT_DEVICE_MMC1;
+
+	case BACKUP_BOOT_DEVICE_SPI:
+		return BOOT_DEVICE_SPI;
+
+	case BACKUP_BOOT_DEVICE_I2C:
+		return BOOT_DEVICE_I2C;
+
+	case BACKUP_BOOT_DEVICE_DFU:
+		if (bkup_bootmode_cfg & MAIN_DEVSTAT_BACKUP_USB_MODE_MASK)
+			return BOOT_DEVICE_USB;
+		return BOOT_DEVICE_DFU;
+	};
+
+	return BOOT_DEVICE_RAM;
+}
+
+static u32 __get_primary_bootmedia(u32 devstat)
+{
+	u32 bootmode = (devstat & MAIN_DEVSTAT_PRIMARY_BOOTMODE_MASK) >>
+				MAIN_DEVSTAT_PRIMARY_BOOTMODE_SHIFT;
+	u32 bootmode_cfg = (devstat & MAIN_DEVSTAT_PRIMARY_BOOTMODE_CFG_MASK) >>
+				MAIN_DEVSTAT_PRIMARY_BOOTMODE_CFG_SHIFT;
+
+	switch (bootmode) {
+	case BOOT_DEVICE_OSPI:
+		fallthrough;
+	case BOOT_DEVICE_QSPI:
+		fallthrough;
+	case BOOT_DEVICE_XSPI:
+		fallthrough;
+	case BOOT_DEVICE_SPI:
+		return BOOT_DEVICE_SPI;
+
+	case BOOT_DEVICE_ETHERNET_RGMII:
+		fallthrough;
+	case BOOT_DEVICE_ETHERNET_RMII:
+		return BOOT_DEVICE_ETHERNET;
+
+	case BOOT_DEVICE_EMMC:
+		return BOOT_DEVICE_MMC1;
+
+	case BOOT_DEVICE_SPI_NAND:
+		return BOOT_DEVICE_SPINAND;
+
+	case BOOT_DEVICE_MMC:
+		if ((bootmode_cfg & MAIN_DEVSTAT_PRIMARY_MMC_PORT_MASK) >>
+				MAIN_DEVSTAT_PRIMARY_MMC_PORT_SHIFT)
+			return BOOT_DEVICE_MMC2;
+		return BOOT_DEVICE_MMC1;
+
+	case BOOT_DEVICE_DFU:
+		if ((bootmode_cfg & MAIN_DEVSTAT_PRIMARY_USB_MODE_MASK) >>
+		    MAIN_DEVSTAT_PRIMARY_USB_MODE_SHIFT)
+			return BOOT_DEVICE_USB;
+		return BOOT_DEVICE_DFU;
+
+	case BOOT_DEVICE_NOBOOT:
+		return BOOT_DEVICE_RAM;
+	}
+
+	return bootmode;
+}
+
+u32 spl_boot_device(void)
+{
+	u32 devstat = readl(CTRLMMR_MAIN_DEVSTAT);
+	u32 bootmedia;
+
+	if (bootindex == K3_PRIMARY_BOOTMODE)
+		bootmedia = __get_primary_bootmedia(devstat);
+	else
+		bootmedia = __get_backup_bootmedia(devstat);
+
+	printf("am62a_init: %s: devstat = 0x%x bootmedia = 0x%x bootindex = %d\n",
+	       __func__, devstat, bootmedia, bootindex);
+	return bootmedia;
+}
diff --git a/arch/arm/mach-k3/arm64-mmu.c b/arch/arm/mach-k3/arm64-mmu.c
index b4d7ab1f16dc8..88687c2d09450 100644
--- a/arch/arm/mach-k3/arm64-mmu.c
+++ b/arch/arm/mach-k3/arm64-mmu.c
@@ -222,7 +222,9 @@ struct mm_region *mem_map = j721s2_mem_map;
 
 #endif /* CONFIG_SOC_K3_J721S2 */
 
-#if defined(CONFIG_SOC_K3_AM642) || defined(CONFIG_SOC_K3_AM625)
+#if defined(CONFIG_SOC_K3_AM642) || defined(CONFIG_SOC_K3_AM625) || \
+	defined(CONFIG_SOC_K3_AM62A7)
+
 /* NR_DRAM_BANKS + 32bit IO + 64bit IO + terminator */
 #define NR_MMU_REGIONS	(CONFIG_NR_DRAM_BANKS + 3)
 
@@ -261,4 +263,4 @@ struct mm_region am64_mem_map[NR_MMU_REGIONS] = {
 };
 
 struct mm_region *mem_map = am64_mem_map;
-#endif /* CONFIG_SOC_K3_AM642 || CONFIG_SOC_K3_AM625 */
+#endif /* CONFIG_SOC_K3_AM642 || CONFIG_SOC_K3_AM625 || CONFIG_SOC_K3_AM62A7 */
diff --git a/arch/arm/mach-k3/include/mach/am62a_hardware.h b/arch/arm/mach-k3/include/mach/am62a_hardware.h
new file mode 100644
index 0000000000000..52b0d9b3cb95c
--- /dev/null
+++ b/arch/arm/mach-k3/include/mach/am62a_hardware.h
@@ -0,0 +1,74 @@
+/* SPDX-License-Identifier: GPL-2.0+ */
+/*
+ * K3: AM62A SoC definitions, structures etc.
+ *
+ * Copyright (C) 2022 Texas Instruments Incorporated - https://www.ti.com/
+ */
+
+#ifndef __ASM_ARCH_AM62A_HARDWARE_H
+#define __ASM_ARCH_AM62A_HARDWARE_H
+
+#include <config.h>
+#ifndef __ASSEMBLY__
+#include <linux/bitops.h>
+#endif
+
+#define PADCFG_MMR0_BASE			0x04080000
+#define PADCFG_MMR1_BASE			0x000f0000
+#define CTRL_MMR0_BASE				0x00100000
+#define MCU_CTRL_MMR0_BASE			0x04500000
+#define WKUP_CTRL_MMR0_BASE			0x43000000
+
+#define CTRLMMR_MAIN_DEVSTAT			(WKUP_CTRL_MMR0_BASE + 0x30)
+#define MAIN_DEVSTAT_PRIMARY_BOOTMODE_MASK	GENMASK(6, 3)
+#define MAIN_DEVSTAT_PRIMARY_BOOTMODE_SHIFT	3
+#define MAIN_DEVSTAT_PRIMARY_BOOTMODE_CFG_MASK	GENMASK(9, 7)
+#define MAIN_DEVSTAT_PRIMARY_BOOTMODE_CFG_SHIFT	7
+#define MAIN_DEVSTAT_BACKUP_BOOTMODE_MASK	GENMASK(12, 10)
+#define MAIN_DEVSTAT_BACKUP_BOOTMODE_SHIFT	10
+#define MAIN_DEVSTAT_BACKUP_BOOTMODE_CFG_MASK	BIT(13)
+#define MAIN_DEVSTAT_BACKUP_BOOTMODE_CFG_SHIFT	13
+
+/* Primary Bootmode MMC Config macros */
+#define MAIN_DEVSTAT_PRIMARY_MMC_PORT_MASK	0x4
+#define MAIN_DEVSTAT_PRIMARY_MMC_PORT_SHIFT	2
+#define MAIN_DEVSTAT_PRIMARY_MMC_FS_RAW_MASK	0x1
+#define MAIN_DEVSTAT_PRIMARY_MMC_FS_RAW_SHIFT	0
+
+/* Primary Bootmode USB Config macros */
+#define MAIN_DEVSTAT_PRIMARY_USB_MODE_SHIFT	1
+#define MAIN_DEVSTAT_PRIMARY_USB_MODE_MASK	0x02
+
+/* Backup Bootmode USB Config macros */
+#define MAIN_DEVSTAT_BACKUP_USB_MODE_MASK	0x01
+
+/*
+ * The CTRL_MMR0 memory space is divided into several equally-spaced
+ * partitions, so defining the partition size allows us to determine
+ * register addresses common to those partitions.
+ */
+#define CTRL_MMR0_PARTITION_SIZE		0x4000
+
+/*
+ * CTRL_MMR0, WKUP_CTRL_MMR0, and MCU_CTRL_MMR0 lock/kick-mechanism
+ * shared register definitions. The same registers are also used for
+ * PADCFG_MMR lock/kick-mechanism.
+ */
+#define CTRLMMR_LOCK_KICK0			0x1008
+#define CTRLMMR_LOCK_KICK0_UNLOCK_VAL		0x68ef3490
+#define CTRLMMR_LOCK_KICK1			0x100c
+#define CTRLMMR_LOCK_KICK1_UNLOCK_VAL		0xd172bc5a
+
+#define MCU_CTRL_LFXOSC_CTRL			(MCU_CTRL_MMR0_BASE + 0x8038)
+#define MCU_CTRL_LFXOSC_TRIM			(MCU_CTRL_MMR0_BASE + 0x803c)
+#define MCU_CTRL_LFXOSC_32K_DISABLE_VAL		BIT(7)
+
+#define MCU_CTRL_DEVICE_CLKOUT_32K_CTRL		(MCU_CTRL_MMR0_BASE + 0x8058)
+#define MCU_CTRL_DEVICE_CLKOUT_LFOSC_SELECT_VAL	(0x3)
+
+#define ROM_ENTENDED_BOOT_DATA_INFO		0x43c3f1e0
+
+/* Use Last 2K as Scratch pad */
+#define TI_SRAM_SCRATCH_BOARD_EEPROM_START	0x70000001
+
+#endif /* __ASM_ARCH_AM62A_HARDWARE_H */
diff --git a/arch/arm/mach-k3/include/mach/am62a_spl.h b/arch/arm/mach-k3/include/mach/am62a_spl.h
new file mode 100644
index 0000000000000..dd0f57714f5a2
--- /dev/null
+++ b/arch/arm/mach-k3/include/mach/am62a_spl.h
@@ -0,0 +1,49 @@
+/* SPDX-License-Identifier: GPL-2.0+ */
+/*
+ * Copyright (C) 2022 Texas Instruments Incorporated - https://www.ti.com/
+ */
+
+#ifndef _ASM_ARCH_AM62A_SPL_H_
+#define _ASM_ARCH_AM62A_SPL_H_
+
+/* Primary BootMode devices */
+#define BOOT_DEVICE_SPI_NAND		0x00
+#define BOOT_DEVICE_RAM		0xFF
+#define BOOT_DEVICE_OSPI		0x01
+#define BOOT_DEVICE_QSPI		0x02
+#define BOOT_DEVICE_SPI			0x03
+#define BOOT_DEVICE_CPGMAC		0x04
+#define BOOT_DEVICE_ETHERNET_RGMII	0x04
+#define BOOT_DEVICE_ETHERNET_RMII	0x05
+#define BOOT_DEVICE_I2C			0x06
+#define BOOT_DEVICE_UART		0x07
+#define BOOT_DEVICE_MMC			0x08
+#define BOOT_DEVICE_EMMC		0x09
+
+#define BOOT_DEVICE_USB			0x2A
+#define BOOT_DEVICE_DFU			0x0A
+#define BOOT_DEVICE_GPMC_NAND		0x0B
+#define BOOT_DEVICE_GPMC_NOR		0x0C
+#define BOOT_DEVICE_XSPI		0x0E
+#define BOOT_DEVICE_NOBOOT		0x0F
+
+/* U-Boot used aliases */
+#define BOOT_DEVICE_ETHERNET		0x04
+#define BOOT_DEVICE_SPINAND		0x10
+#define BOOT_DEVICE_MMC2		0x08
+#define BOOT_DEVICE_MMC1		0x09
+/* Invalid */
+#define BOOT_DEVICE_MMC2_2		0x1F
+
+/* Backup BootMode devices */
+#define BACKUP_BOOT_DEVICE_DFU		0x01
+#define BACKUP_BOOT_DEVICE_UART		0x03
+#define BACKUP_BOOT_DEVICE_ETHERNET	0x04
+#define BACKUP_BOOT_DEVICE_MMC		0x05
+#define BACKUP_BOOT_DEVICE_SPI		0x06
+#define BACKUP_BOOT_DEVICE_I2C		0x07
+#define BACKUP_BOOT_DEVICE_USB		0x09
+
+#define K3_PRIMARY_BOOTMODE		0x0
+
+#endif /* _ASM_ARCH_AM62A_SPL_H_ */
diff --git a/arch/arm/mach-k3/include/mach/hardware.h b/arch/arm/mach-k3/include/mach/hardware.h
index d6d2cf6dc2658..2c60ef85432bc 100644
--- a/arch/arm/mach-k3/include/mach/hardware.h
+++ b/arch/arm/mach-k3/include/mach/hardware.h
@@ -26,6 +26,10 @@
 #include "am62_hardware.h"
 #endif
 
+#ifdef CONFIG_SOC_K3_AM62A7
+#include "am62a_hardware.h"
+#endif
+
 /* Assuming these addresses and definitions stay common across K3 devices */
 #define CTRLMMR_WKUP_JTAG_ID	(WKUP_CTRL_MMR0_BASE + 0x14)
 #define JTAG_ID_VARIANT_SHIFT	28
diff --git a/arch/arm/mach-k3/include/mach/spl.h b/arch/arm/mach-k3/include/mach/spl.h
index c9a324a5f0fea..356cd89210962 100644
--- a/arch/arm/mach-k3/include/mach/spl.h
+++ b/arch/arm/mach-k3/include/mach/spl.h
@@ -26,4 +26,8 @@
 #include "am62_spl.h"
 #endif
 
+#ifdef CONFIG_SOC_K3_AM62A7
+#include "am62a_spl.h"
+#endif
+
 #endif /* _ASM_ARCH_SPL_H_ */
-- 
2.38.1


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

* [PATCH 6/8] arm: mach-k3: am62a: introduce auto-generated SoC data
  2022-11-04  0:13 [PATCH 0/8] Introduce initial TI's am62a support Bryan Brattlof
                   ` (4 preceding siblings ...)
  2022-11-04  0:13 ` [PATCH 5/8] arm: mach-k3: introduce basic files to support the am62a Bryan Brattlof
@ 2022-11-04  0:13 ` Bryan Brattlof
  2022-12-09 22:54   ` Tom Rini
  2022-11-04  0:13 ` [PATCH 7/8] board: ti: introduce the basic files needed to support the am62a Bryan Brattlof
                   ` (2 subsequent siblings)
  8 siblings, 1 reply; 26+ messages in thread
From: Bryan Brattlof @ 2022-11-04  0:13 UTC (permalink / raw)
  To: Lukasz Majewski, Sean Anderson, Jaehoon Chung, Nishanth Menon,
	Georgi Vlaev, Andrew Davis, Vignesh Raghavendra, Tom Rini
  Cc: UBoot Mailing List, Bryan Brattlof

Introduce the auto-generated clock tree and power domain data needed to
attach the am62a into the power-domain and clock frameworks of uboot

Signed-off-by: Bryan Brattlof <bb@ti.com>
---
 arch/arm/mach-k3/am62ax/Makefile       |   6 +
 arch/arm/mach-k3/am62ax/clk-data.c     | 317 +++++++++++++++++++++++++
 arch/arm/mach-k3/am62ax/dev-data.c     |  73 ++++++
 drivers/clk/ti/clk-k3.c                |   6 +
 drivers/power/domain/ti-power-domain.c |   6 +
 include/k3-clk.h                       |   1 +
 include/k3-dev.h                       |   1 +
 7 files changed, 410 insertions(+)
 create mode 100644 arch/arm/mach-k3/am62ax/Makefile
 create mode 100644 arch/arm/mach-k3/am62ax/clk-data.c
 create mode 100644 arch/arm/mach-k3/am62ax/dev-data.c

diff --git a/arch/arm/mach-k3/am62ax/Makefile b/arch/arm/mach-k3/am62ax/Makefile
new file mode 100644
index 0000000000000..c58e52df1fa27
--- /dev/null
+++ b/arch/arm/mach-k3/am62ax/Makefile
@@ -0,0 +1,6 @@
+# SPDX-License-Identifier:	GPL-2.0+
+#
+# Copyright (C) 2022 Texas Instruments Incorporated - https://www.ti.com/
+
+obj-y += clk-data.o
+obj-y += dev-data.o
diff --git a/arch/arm/mach-k3/am62ax/clk-data.c b/arch/arm/mach-k3/am62ax/clk-data.c
new file mode 100644
index 0000000000000..d950b35e0beb7
--- /dev/null
+++ b/arch/arm/mach-k3/am62ax/clk-data.c
@@ -0,0 +1,317 @@
+// SPDX-License-Identifier: GPL-2.0+
+/*
+ * AM62AX specific clock platform data
+ *
+ * This file is auto generated. Please do not hand edit and report any issues
+ * to Bryan Brattlof <bb@ti.com>.
+ *
+ * Copyright (C) 2020-2022 Texas Instruments Incorporated - https://www.ti.com/
+ */
+
+#include <linux/clk-provider.h>
+#include "k3-clk.h"
+
+static const char * const gluelogic_hfosc0_clkout_parents[] = {
+	NULL,
+	NULL,
+	"osc_24_mhz",
+	"osc_25_mhz",
+	"osc_26_mhz",
+	NULL,
+};
+
+static const char * const clk_32k_rc_sel_out0_parents[] = {
+	"gluelogic_rcosc_clk_1p0v_97p65k",
+	"gluelogic_hfosc0_clkout",
+	"gluelogic_rcosc_clk_1p0v_97p65k",
+	"gluelogic_lfosc0_clkout",
+};
+
+static const char * const main_emmcsd0_io_clklb_sel_out0_parents[] = {
+	"board_0_mmc0_clklb_out",
+	"board_0_mmc0_clk_out",
+};
+
+static const char * const main_emmcsd1_io_clklb_sel_out0_parents[] = {
+	"board_0_mmc1_clklb_out",
+	"board_0_mmc1_clk_out",
+};
+
+static const char * const main_ospi_loopback_clk_sel_out0_parents[] = {
+	"board_0_ospi0_dqs_out",
+	"board_0_ospi0_lbclko_out",
+};
+
+static const char * const main_usb0_refclk_sel_out0_parents[] = {
+	"gluelogic_hfosc0_clkout",
+	"postdiv4_16ff_main_0_hsdivout8_clk",
+};
+
+static const char * const main_usb1_refclk_sel_out0_parents[] = {
+	"gluelogic_hfosc0_clkout",
+	"postdiv4_16ff_main_0_hsdivout8_clk",
+};
+
+static const char * const sam62_pll_ctrl_wrap_main_0_sysclkout_clk_parents[] = {
+	"gluelogic_hfosc0_clkout",
+	"hsdiv4_16fft_main_0_hsdivout0_clk",
+};
+
+static const char * const sam62_pll_ctrl_wrap_mcu_0_sysclkout_clk_parents[] = {
+	"gluelogic_hfosc0_clkout",
+	"hsdiv4_16fft_mcu_0_hsdivout0_clk",
+};
+
+static const char * const clkout0_ctrl_out0_parents[] = {
+	"hsdiv4_16fft_main_2_hsdivout1_clk",
+	"hsdiv4_16fft_main_2_hsdivout1_clk",
+};
+
+static const char * const main_emmcsd0_refclk_sel_out0_parents[] = {
+	"postdiv4_16ff_main_0_hsdivout5_clk",
+	"hsdiv4_16fft_main_2_hsdivout2_clk",
+};
+
+static const char * const main_emmcsd1_refclk_sel_out0_parents[] = {
+	"postdiv4_16ff_main_0_hsdivout5_clk",
+	"hsdiv4_16fft_main_2_hsdivout2_clk",
+};
+
+static const char * const main_gtcclk_sel_out0_parents[] = {
+	"postdiv4_16ff_main_2_hsdivout5_clk",
+	"postdiv4_16ff_main_0_hsdivout6_clk",
+	"board_0_cp_gemac_cpts0_rft_clk_out",
+	NULL,
+	"board_0_mcu_ext_refclk0_out",
+	"board_0_ext_refclk1_out",
+	"sam62_pll_ctrl_wrap_mcu_0_chip_div1_clk_clk",
+	"sam62_pll_ctrl_wrap_main_0_chip_div1_clk_clk",
+};
+
+static const char * const main_ospi_ref_clk_sel_out0_parents[] = {
+	"hsdiv4_16fft_main_0_hsdivout1_clk",
+	"postdiv1_16fft_main_1_hsdivout5_clk",
+};
+
+static const char * const wkup_clkout_sel_out0_parents[] = {
+	NULL,
+	"gluelogic_lfosc0_clkout",
+	"hsdiv4_16fft_main_0_hsdivout2_clk",
+	"hsdiv4_16fft_main_1_hsdivout2_clk",
+	"postdiv4_16ff_main_2_hsdivout9_clk",
+	"clk_32k_rc_sel_out0",
+	"gluelogic_rcosc_clkout",
+	"gluelogic_hfosc0_clkout",
+};
+
+static const char * const wkup_clkout_sel_io_out0_parents[] = {
+	"wkup_clkout_sel_out0",
+	"gluelogic_hfosc0_clkout",
+};
+
+static const char * const wkup_clksel_out0_parents[] = {
+	"hsdiv2_16fft_main_15_hsdivout0_clk",
+	"hsdiv4_16fft_mcu_0_hsdivout0_clk",
+};
+
+static const char * const main_usart0_fclk_sel_out0_parents[] = {
+	"usart_programmable_clock_divider_out0",
+	"hsdiv4_16fft_main_1_hsdivout1_clk",
+};
+
+static const struct clk_data clk_list[] = {
+	CLK_FIXED_RATE("osc_26_mhz", 26000000, 0),
+	CLK_FIXED_RATE("osc_25_mhz", 25000000, 0),
+	CLK_FIXED_RATE("osc_24_mhz", 24000000, 0),
+	CLK_MUX("gluelogic_hfosc0_clkout", gluelogic_hfosc0_clkout_parents, 6, 0x43000030, 0, 3, 0),
+	CLK_FIXED_RATE("gluelogic_rcosc_clkout", 12500000, 0),
+	CLK_FIXED_RATE("gluelogic_rcosc_clk_1p0v_97p65k", 97656, 0),
+	CLK_FIXED_RATE("board_0_cp_gemac_cpts0_rft_clk_out", 0, 0),
+	CLK_FIXED_RATE("board_0_ddr0_ck0_out", 0, 0),
+	CLK_FIXED_RATE("board_0_ext_refclk1_out", 0, 0),
+	CLK_FIXED_RATE("board_0_i2c0_scl_out", 0, 0),
+	CLK_FIXED_RATE("board_0_mcu_ext_refclk0_out", 0, 0),
+	CLK_FIXED_RATE("board_0_mmc0_clklb_out", 0, 0),
+	CLK_FIXED_RATE("board_0_mmc0_clk_out", 0, 0),
+	CLK_FIXED_RATE("board_0_mmc1_clklb_out", 0, 0),
+	CLK_FIXED_RATE("board_0_mmc1_clk_out", 0, 0),
+	CLK_FIXED_RATE("board_0_ospi0_dqs_out", 0, 0),
+	CLK_FIXED_RATE("board_0_ospi0_lbclko_out", 0, 0),
+	CLK_FIXED_RATE("board_0_tck_out", 0, 0),
+	CLK_FIXED_RATE("emmcsd4ss_main_0_emmcsdss_io_clk_o", 0, 0),
+	CLK_FIXED_RATE("emmcsd8ss_main_0_emmcsdss_io_clk_o", 0, 0),
+	CLK_FIXED_RATE("fss_ul_main_0_ospi_0_ospi_oclk_clk", 0, 0),
+	CLK_FIXED_RATE("mshsi2c_main_0_porscl", 0, 0),
+	CLK_PLL("pllfracf_ssmod_16fft_main_0_foutvcop_clk", "gluelogic_hfosc0_clkout", 0x680000, 0),
+	CLK_DIV("pllfracf_ssmod_16fft_main_0_foutpostdiv_clk_subdiv", "pllfracf_ssmod_16fft_main_0_foutvcop_clk", 0x680038, 16, 3, 0, CLK_DIVIDER_ONE_BASED),
+	CLK_DIV("pllfracf_ssmod_16fft_main_0_foutpostdiv_clk", "pllfracf_ssmod_16fft_main_0_foutpostdiv_clk_subdiv", 0x680038, 24, 3, 0, CLK_DIVIDER_ONE_BASED),
+	CLK_PLL("pllfracf_ssmod_16fft_main_1_foutvcop_clk", "gluelogic_hfosc0_clkout", 0x681000, 0),
+	CLK_DIV("pllfracf_ssmod_16fft_main_1_foutpostdiv_clk_subdiv", "pllfracf_ssmod_16fft_main_1_foutvcop_clk", 0x681038, 16, 3, 0, CLK_DIVIDER_ONE_BASED),
+	CLK_DIV("pllfracf_ssmod_16fft_main_1_foutpostdiv_clk", "pllfracf_ssmod_16fft_main_1_foutpostdiv_clk_subdiv", 0x681038, 24, 3, 0, CLK_DIVIDER_ONE_BASED),
+	CLK_PLL("pllfracf_ssmod_16fft_main_12_foutvcop_clk", "gluelogic_hfosc0_clkout", 0x68c000, 0),
+	CLK_PLL("pllfracf_ssmod_16fft_main_15_foutvcop_clk", "gluelogic_hfosc0_clkout", 0x68f000, 0),
+	CLK_PLL("pllfracf_ssmod_16fft_main_2_foutvcop_clk", "gluelogic_hfosc0_clkout", 0x682000, 0),
+	CLK_DIV("pllfracf_ssmod_16fft_main_2_foutpostdiv_clk_subdiv", "pllfracf_ssmod_16fft_main_2_foutvcop_clk", 0x682038, 16, 3, 0, CLK_DIVIDER_ONE_BASED),
+	CLK_DIV("pllfracf_ssmod_16fft_main_2_foutpostdiv_clk", "pllfracf_ssmod_16fft_main_2_foutpostdiv_clk_subdiv", 0x682038, 24, 3, 0, CLK_DIVIDER_ONE_BASED),
+	CLK_PLL("pllfracf_ssmod_16fft_main_8_foutvcop_clk", "gluelogic_hfosc0_clkout", 0x688000, 0),
+	CLK_PLL("pllfracf_ssmod_16fft_mcu_0_foutvcop_clk", "gluelogic_hfosc0_clkout", 0x4040000, 0),
+	CLK_DIV("postdiv1_16fft_main_1_hsdivout5_clk", "pllfracf_ssmod_16fft_main_1_foutpostdiv_clk", 0x681094, 0, 7, 0, 0),
+	CLK_DIV("postdiv4_16ff_main_0_hsdivout5_clk", "pllfracf_ssmod_16fft_main_0_foutpostdiv_clk", 0x680094, 0, 7, 0, 0),
+	CLK_DIV("postdiv4_16ff_main_0_hsdivout6_clk", "pllfracf_ssmod_16fft_main_0_foutpostdiv_clk", 0x680098, 0, 7, 0, 0),
+	CLK_DIV("postdiv4_16ff_main_0_hsdivout8_clk", "pllfracf_ssmod_16fft_main_0_foutpostdiv_clk", 0x6800a0, 0, 7, 0, 0),
+	CLK_DIV("postdiv4_16ff_main_2_hsdivout5_clk", "pllfracf_ssmod_16fft_main_2_foutpostdiv_clk", 0x682094, 0, 7, 0, 0),
+	CLK_DIV("postdiv4_16ff_main_2_hsdivout8_clk", "pllfracf_ssmod_16fft_main_2_foutpostdiv_clk", 0x6820a0, 0, 7, 0, 0),
+	CLK_DIV("postdiv4_16ff_main_2_hsdivout9_clk", "pllfracf_ssmod_16fft_main_2_foutpostdiv_clk", 0x6820a4, 0, 7, 0, 0),
+	CLK_MUX("clk_32k_rc_sel_out0", clk_32k_rc_sel_out0_parents, 4, 0x4508058, 0, 2, 0),
+	CLK_MUX("main_emmcsd0_io_clklb_sel_out0", main_emmcsd0_io_clklb_sel_out0_parents, 2, 0x108160, 16, 1, 0),
+	CLK_MUX("main_emmcsd1_io_clklb_sel_out0", main_emmcsd1_io_clklb_sel_out0_parents, 2, 0x108168, 16, 1, 0),
+	CLK_MUX("main_ospi_loopback_clk_sel_out0", main_ospi_loopback_clk_sel_out0_parents, 2, 0x108500, 4, 1, 0),
+	CLK_MUX("main_usb0_refclk_sel_out0", main_usb0_refclk_sel_out0_parents, 2, 0x43008190, 0, 1, 0),
+	CLK_MUX("main_usb1_refclk_sel_out0", main_usb1_refclk_sel_out0_parents, 2, 0x43008194, 0, 1, 0),
+	CLK_DIV("hsdiv0_16fft_main_12_hsdivout0_clk", "pllfracf_ssmod_16fft_main_12_foutvcop_clk", 0x68c080, 0, 7, 0, 0),
+	CLK_DIV("hsdiv0_16fft_main_8_hsdivout0_clk", "pllfracf_ssmod_16fft_main_8_foutvcop_clk", 0x688080, 0, 7, 0, 0),
+	CLK_DIV("hsdiv2_16fft_main_15_hsdivout0_clk", "pllfracf_ssmod_16fft_main_15_foutvcop_clk", 0x68f080, 0, 7, 0, 0),
+	CLK_DIV("hsdiv4_16fft_main_0_hsdivout0_clk", "pllfracf_ssmod_16fft_main_0_foutvcop_clk", 0x680080, 0, 7, 0, 0),
+	CLK_DIV("hsdiv4_16fft_main_0_hsdivout1_clk", "pllfracf_ssmod_16fft_main_0_foutvcop_clk", 0x680084, 0, 7, 0, 0),
+	CLK_DIV("hsdiv4_16fft_main_0_hsdivout2_clk", "pllfracf_ssmod_16fft_main_0_foutvcop_clk", 0x680088, 0, 7, 0, 0),
+	CLK_DIV("hsdiv4_16fft_main_0_hsdivout3_clk", "pllfracf_ssmod_16fft_main_0_foutvcop_clk", 0x68008c, 0, 7, 0, 0),
+	CLK_DIV("hsdiv4_16fft_main_0_hsdivout4_clk", "pllfracf_ssmod_16fft_main_0_foutvcop_clk", 0x680090, 0, 7, 0, 0),
+	CLK_DIV_DEFFREQ("hsdiv4_16fft_main_1_hsdivout0_clk", "pllfracf_ssmod_16fft_main_1_foutvcop_clk", 0x681080, 0, 7, 0, 0, 192000000),
+	CLK_DIV("hsdiv4_16fft_main_1_hsdivout1_clk", "pllfracf_ssmod_16fft_main_1_foutvcop_clk", 0x681084, 0, 7, 0, 0),
+	CLK_DIV("hsdiv4_16fft_main_1_hsdivout2_clk", "pllfracf_ssmod_16fft_main_1_foutvcop_clk", 0x681088, 0, 7, 0, 0),
+	CLK_DIV("hsdiv4_16fft_main_2_hsdivout1_clk", "pllfracf_ssmod_16fft_main_2_foutvcop_clk", 0x682084, 0, 7, 0, 0),
+	CLK_DIV("hsdiv4_16fft_main_2_hsdivout2_clk", "pllfracf_ssmod_16fft_main_2_foutvcop_clk", 0x682088, 0, 7, 0, 0),
+	CLK_DIV("hsdiv4_16fft_mcu_0_hsdivout0_clk", "pllfracf_ssmod_16fft_mcu_0_foutvcop_clk", 0x4040080, 0, 7, 0, 0),
+	CLK_MUX_PLLCTRL("sam62_pll_ctrl_wrap_main_0_sysclkout_clk", sam62_pll_ctrl_wrap_main_0_sysclkout_clk_parents, 2, 0x410000, 0),
+	CLK_DIV("sam62_pll_ctrl_wrap_main_0_chip_div1_clk_clk", "sam62_pll_ctrl_wrap_main_0_sysclkout_clk", 0x410118, 0, 5, 0, 0),
+	CLK_MUX_PLLCTRL("sam62_pll_ctrl_wrap_mcu_0_sysclkout_clk", sam62_pll_ctrl_wrap_mcu_0_sysclkout_clk_parents, 2, 0x4020000, 0),
+	CLK_DIV("sam62_pll_ctrl_wrap_mcu_0_chip_div1_clk_clk", "sam62_pll_ctrl_wrap_mcu_0_sysclkout_clk", 0x4020118, 0, 5, 0, 0),
+	CLK_MUX("clkout0_ctrl_out0", clkout0_ctrl_out0_parents, 2, 0x108010, 0, 1, 0),
+	CLK_MUX("main_emmcsd0_refclk_sel_out0", main_emmcsd0_refclk_sel_out0_parents, 2, 0x108160, 0, 1, 0),
+	CLK_MUX("main_emmcsd1_refclk_sel_out0", main_emmcsd1_refclk_sel_out0_parents, 2, 0x108168, 0, 1, 0),
+	CLK_MUX("main_gtcclk_sel_out0", main_gtcclk_sel_out0_parents, 8, 0x43008030, 0, 3, 0),
+	CLK_MUX("main_ospi_ref_clk_sel_out0", main_ospi_ref_clk_sel_out0_parents, 2, 0x108500, 0, 1, 0),
+	CLK_DIV_DEFFREQ("usart_programmable_clock_divider_out0", "hsdiv4_16fft_main_1_hsdivout0_clk", 0x108240, 0, 2, 0, 0, 48000000),
+	CLK_MUX("wkup_clkout_sel_out0", wkup_clkout_sel_out0_parents, 8, 0x43008020, 0, 3, 0),
+	CLK_MUX("wkup_clkout_sel_io_out0", wkup_clkout_sel_io_out0_parents, 2, 0x43008020, 24, 1, 0),
+	CLK_MUX("wkup_clksel_out0", wkup_clksel_out0_parents, 2, 0x43008010, 0, 1, 0),
+	CLK_MUX("main_usart0_fclk_sel_out0", main_usart0_fclk_sel_out0_parents, 2, 0x108280, 0, 1, 0),
+	CLK_DIV("hsdiv4_16fft_mcu_0_hsdivout1_clk", "pllfracf_ssmod_16fft_mcu_0_foutvcop_clk", 0x4040084, 0, 7, 0, 0),
+	CLK_FIXED_RATE("mshsi2c_wkup_0_porscl", 0, 0),
+	CLK_DIV("sam62_pll_ctrl_wrap_main_0_chip_div24_clk_clk", "sam62_pll_ctrl_wrap_main_0_sysclkout_clk", 0x41011c, 0, 5, 0, 0),
+	CLK_DIV("sam62_pll_ctrl_wrap_mcu_0_chip_div24_clk_clk", "sam62_pll_ctrl_wrap_mcu_0_sysclkout_clk", 0x402011c, 0, 5, 0, 0),
+};
+
+static const struct dev_clk soc_dev_clk_data[] = {
+	DEV_CLK(16, 0, "hsdiv4_16fft_main_0_hsdivout1_clk"),
+	DEV_CLK(16, 1, "hsdiv4_16fft_main_0_hsdivout2_clk"),
+	DEV_CLK(16, 2, "hsdiv4_16fft_main_0_hsdivout3_clk"),
+	DEV_CLK(16, 3, "hsdiv4_16fft_main_0_hsdivout4_clk"),
+	DEV_CLK(16, 4, "gluelogic_hfosc0_clkout"),
+	DEV_CLK(16, 5, "board_0_ext_refclk1_out"),
+	DEV_CLK(16, 6, "sam62_pll_ctrl_wrap_main_0_chip_div1_clk_clk"),
+	DEV_CLK(16, 7, "postdiv4_16ff_main_2_hsdivout8_clk"),
+	DEV_CLK(16, 8, "gluelogic_hfosc0_clkout"),
+	DEV_CLK(16, 9, "board_0_ext_refclk1_out"),
+	DEV_CLK(16, 10, "gluelogic_rcosc_clkout"),
+	DEV_CLK(16, 11, "sam62_pll_ctrl_wrap_main_0_chip_div1_clk_clk"),
+	DEV_CLK(16, 12, "sam62_pll_ctrl_wrap_main_0_chip_div1_clk_clk"),
+	DEV_CLK(57, 0, "main_emmcsd0_io_clklb_sel_out0"),
+	DEV_CLK(57, 1, "board_0_mmc0_clklb_out"),
+	DEV_CLK(57, 2, "board_0_mmc0_clk_out"),
+	DEV_CLK(57, 5, "sam62_pll_ctrl_wrap_main_0_chip_div1_clk_clk"),
+	DEV_CLK(57, 6, "main_emmcsd0_refclk_sel_out0"),
+	DEV_CLK(57, 7, "postdiv4_16ff_main_0_hsdivout5_clk"),
+	DEV_CLK(57, 8, "hsdiv4_16fft_main_2_hsdivout2_clk"),
+	DEV_CLK(58, 0, "main_emmcsd1_io_clklb_sel_out0"),
+	DEV_CLK(58, 1, "board_0_mmc1_clklb_out"),
+	DEV_CLK(58, 2, "board_0_mmc1_clk_out"),
+	DEV_CLK(58, 5, "sam62_pll_ctrl_wrap_main_0_chip_div1_clk_clk"),
+	DEV_CLK(58, 6, "main_emmcsd1_refclk_sel_out0"),
+	DEV_CLK(58, 7, "postdiv4_16ff_main_0_hsdivout5_clk"),
+	DEV_CLK(58, 8, "hsdiv4_16fft_main_2_hsdivout2_clk"),
+	DEV_CLK(61, 0, "main_gtcclk_sel_out0"),
+	DEV_CLK(61, 1, "postdiv4_16ff_main_2_hsdivout5_clk"),
+	DEV_CLK(61, 2, "postdiv4_16ff_main_0_hsdivout6_clk"),
+	DEV_CLK(61, 3, "board_0_cp_gemac_cpts0_rft_clk_out"),
+	DEV_CLK(61, 5, "board_0_mcu_ext_refclk0_out"),
+	DEV_CLK(61, 6, "board_0_ext_refclk1_out"),
+	DEV_CLK(61, 7, "sam62_pll_ctrl_wrap_mcu_0_chip_div1_clk_clk"),
+	DEV_CLK(61, 8, "sam62_pll_ctrl_wrap_main_0_chip_div1_clk_clk"),
+	DEV_CLK(61, 9, "wkup_clksel_out0"),
+	DEV_CLK(61, 10, "hsdiv2_16fft_main_15_hsdivout0_clk"),
+	DEV_CLK(61, 11, "hsdiv4_16fft_mcu_0_hsdivout0_clk"),
+	DEV_CLK(75, 0, "board_0_ospi0_dqs_out"),
+	DEV_CLK(75, 1, "sam62_pll_ctrl_wrap_main_0_chip_div1_clk_clk"),
+	DEV_CLK(75, 2, "main_ospi_loopback_clk_sel_out0"),
+	DEV_CLK(75, 3, "board_0_ospi0_dqs_out"),
+	DEV_CLK(75, 4, "board_0_ospi0_lbclko_out"),
+	DEV_CLK(75, 6, "sam62_pll_ctrl_wrap_main_0_chip_div1_clk_clk"),
+	DEV_CLK(75, 7, "main_ospi_ref_clk_sel_out0"),
+	DEV_CLK(75, 8, "hsdiv4_16fft_main_0_hsdivout1_clk"),
+	DEV_CLK(75, 9, "postdiv1_16fft_main_1_hsdivout5_clk"),
+	DEV_CLK(77, 0, "sam62_pll_ctrl_wrap_main_0_chip_div1_clk_clk"),
+	DEV_CLK(95, 0, "gluelogic_rcosc_clkout"),
+	DEV_CLK(95, 1, "gluelogic_hfosc0_clkout"),
+	DEV_CLK(95, 2, "wkup_clksel_out0"),
+	DEV_CLK(95, 3, "hsdiv2_16fft_main_15_hsdivout0_clk"),
+	DEV_CLK(95, 4, "hsdiv4_16fft_mcu_0_hsdivout0_clk"),
+	DEV_CLK(102, 0, "sam62_pll_ctrl_wrap_main_0_chip_div1_clk_clk"),
+	DEV_CLK(102, 1, "board_0_i2c0_scl_out"),
+	DEV_CLK(102, 2, "hsdiv4_16fft_main_1_hsdivout0_clk"),
+	DEV_CLK(107, 0, "wkup_clksel_out0"),
+	DEV_CLK(107, 1, "hsdiv2_16fft_main_15_hsdivout0_clk"),
+	DEV_CLK(107, 2, "hsdiv4_16fft_mcu_0_hsdivout0_clk"),
+	DEV_CLK(107, 4, "hsdiv4_16fft_mcu_0_hsdivout1_clk"),
+	DEV_CLK(135, 0, "hsdiv0_16fft_main_8_hsdivout0_clk"),
+	DEV_CLK(140, 0, "sam62_pll_ctrl_wrap_mcu_0_chip_div1_clk_clk"),
+	DEV_CLK(140, 1, "sam62_pll_ctrl_wrap_mcu_0_chip_div1_clk_clk"),
+	DEV_CLK(146, 0, "main_usart0_fclk_sel_out0"),
+	DEV_CLK(146, 1, "usart_programmable_clock_divider_out0"),
+	DEV_CLK(146, 2, "hsdiv4_16fft_main_1_hsdivout1_clk"),
+	DEV_CLK(146, 5, "sam62_pll_ctrl_wrap_main_0_chip_div1_clk_clk"),
+	DEV_CLK(157, 20, "clkout0_ctrl_out0"),
+	DEV_CLK(157, 21, "hsdiv4_16fft_main_2_hsdivout1_clk"),
+	DEV_CLK(157, 22, "hsdiv4_16fft_main_2_hsdivout1_clk"),
+	DEV_CLK(157, 24, "sam62_pll_ctrl_wrap_main_0_chip_div1_clk_clk"),
+	DEV_CLK(157, 25, "board_0_ddr0_ck0_out"),
+	DEV_CLK(157, 40, "mshsi2c_main_0_porscl"),
+	DEV_CLK(157, 77, "sam62_pll_ctrl_wrap_mcu_0_sysclkout_clk"),
+	DEV_CLK(157, 83, "emmcsd8ss_main_0_emmcsdss_io_clk_o"),
+	DEV_CLK(157, 85, "emmcsd8ss_main_0_emmcsdss_io_clk_o"),
+	DEV_CLK(157, 87, "emmcsd4ss_main_0_emmcsdss_io_clk_o"),
+	DEV_CLK(157, 89, "emmcsd4ss_main_0_emmcsdss_io_clk_o"),
+	DEV_CLK(157, 130, "fss_ul_main_0_ospi_0_ospi_oclk_clk"),
+	DEV_CLK(157, 146, "sam62_pll_ctrl_wrap_main_0_sysclkout_clk"),
+	DEV_CLK(157, 159, "wkup_clkout_sel_io_out0"),
+	DEV_CLK(157, 160, "wkup_clkout_sel_out0"),
+	DEV_CLK(157, 161, "gluelogic_hfosc0_clkout"),
+	DEV_CLK(161, 0, "sam62_pll_ctrl_wrap_main_0_chip_div1_clk_clk"),
+	DEV_CLK(161, 1, "sam62_pll_ctrl_wrap_main_0_chip_div1_clk_clk"),
+	DEV_CLK(161, 2, "sam62_pll_ctrl_wrap_main_0_chip_div1_clk_clk"),
+	DEV_CLK(161, 3, "main_usb0_refclk_sel_out0"),
+	DEV_CLK(161, 4, "gluelogic_hfosc0_clkout"),
+	DEV_CLK(161, 5, "postdiv4_16ff_main_0_hsdivout8_clk"),
+	DEV_CLK(161, 10, "board_0_tck_out"),
+	DEV_CLK(162, 0, "sam62_pll_ctrl_wrap_main_0_chip_div1_clk_clk"),
+	DEV_CLK(162, 1, "sam62_pll_ctrl_wrap_main_0_chip_div1_clk_clk"),
+	DEV_CLK(162, 2, "sam62_pll_ctrl_wrap_main_0_chip_div1_clk_clk"),
+	DEV_CLK(162, 3, "main_usb1_refclk_sel_out0"),
+	DEV_CLK(162, 4, "gluelogic_hfosc0_clkout"),
+	DEV_CLK(162, 5, "postdiv4_16ff_main_0_hsdivout8_clk"),
+	DEV_CLK(162, 10, "board_0_tck_out"),
+	DEV_CLK(166, 3, "hsdiv0_16fft_main_8_hsdivout0_clk"),
+	DEV_CLK(166, 5, "sam62_pll_ctrl_wrap_main_0_chip_div1_clk_clk"),
+	DEV_CLK(169, 0, "sam62_pll_ctrl_wrap_main_0_chip_div1_clk_clk"),
+	DEV_CLK(169, 1, "sam62_pll_ctrl_wrap_main_0_chip_div1_clk_clk"),
+	DEV_CLK(170, 1, "hsdiv0_16fft_main_12_hsdivout0_clk"),
+	DEV_CLK(170, 2, "board_0_tck_out"),
+	DEV_CLK(170, 3, "sam62_pll_ctrl_wrap_main_0_chip_div1_clk_clk"),
+};
+
+const struct ti_k3_clk_platdata am62ax_clk_platdata = {
+	.clk_list = clk_list,
+	.clk_list_cnt = 80,
+	.soc_dev_clk_data = soc_dev_clk_data,
+	.soc_dev_clk_data_cnt = 104,
+};
diff --git a/arch/arm/mach-k3/am62ax/dev-data.c b/arch/arm/mach-k3/am62ax/dev-data.c
new file mode 100644
index 0000000000000..74739c6385246
--- /dev/null
+++ b/arch/arm/mach-k3/am62ax/dev-data.c
@@ -0,0 +1,73 @@
+// SPDX-License-Identifier: GPL-2.0+
+/*
+ * AM62AX specific device platform data
+ *
+ * This file is auto generated. Please do not hand edit and report any issues
+ * to Bryan Brattlof <bb@ti.com>.
+ *
+ * Copyright (C) 2020-2022 Texas Instruments Incorporated - https://www.ti.com/
+ */
+
+#include "k3-dev.h"
+
+static struct ti_psc soc_psc_list[] = {
+	[0] = PSC(0, 0x04000000),
+	[1] = PSC(1, 0x00400000),
+};
+
+static struct ti_pd soc_pd_list[] = {
+	[0] = PSC_PD(0, &soc_psc_list[1], NULL),
+	[1] = PSC_PD(3, &soc_psc_list[1], &soc_pd_list[0]),
+	[2] = PSC_PD(4, &soc_psc_list[1], &soc_pd_list[1]),
+	[3] = PSC_PD(13, &soc_psc_list[1], &soc_pd_list[0]),
+};
+
+static struct ti_lpsc soc_lpsc_list[] = {
+	[0] = PSC_LPSC(0, &soc_psc_list[1], &soc_pd_list[0], NULL),
+	[1] = PSC_LPSC(12, &soc_psc_list[1], &soc_pd_list[0], &soc_lpsc_list[5]),
+	[2] = PSC_LPSC(13, &soc_psc_list[1], &soc_pd_list[0], &soc_lpsc_list[6]),
+	[3] = PSC_LPSC(20, &soc_psc_list[1], &soc_pd_list[0], &soc_lpsc_list[8]),
+	[4] = PSC_LPSC(21, &soc_psc_list[1], &soc_pd_list[0], &soc_lpsc_list[8]),
+	[5] = PSC_LPSC(23, &soc_psc_list[1], &soc_pd_list[0], &soc_lpsc_list[8]),
+	[6] = PSC_LPSC(24, &soc_psc_list[1], &soc_pd_list[0], &soc_lpsc_list[8]),
+	[7] = PSC_LPSC(28, &soc_psc_list[1], &soc_pd_list[0], &soc_lpsc_list[8]),
+	[8] = PSC_LPSC(34, &soc_psc_list[1], &soc_pd_list[0], &soc_lpsc_list[8]),
+	[9] = PSC_LPSC(43, &soc_psc_list[1], &soc_pd_list[1], &soc_lpsc_list[8]),
+	[10] = PSC_LPSC(46, &soc_psc_list[1], &soc_pd_list[2], &soc_lpsc_list[9]),
+	[11] = PSC_LPSC(60, &soc_psc_list[1], &soc_pd_list[3], &soc_lpsc_list[8]),
+	[12] = PSC_LPSC(61, &soc_psc_list[1], &soc_pd_list[3], &soc_lpsc_list[11]),
+	[13] = PSC_LPSC(62, &soc_psc_list[1], &soc_pd_list[3], &soc_lpsc_list[12]),
+};
+
+static struct ti_dev soc_dev_list[] = {
+	PSC_DEV(16, &soc_lpsc_list[0]),
+	PSC_DEV(77, &soc_lpsc_list[0]),
+	PSC_DEV(61, &soc_lpsc_list[0]),
+	PSC_DEV(95, &soc_lpsc_list[0]),
+	PSC_DEV(107, &soc_lpsc_list[0]),
+	PSC_DEV(178, &soc_lpsc_list[1]),
+	PSC_DEV(179, &soc_lpsc_list[2]),
+	PSC_DEV(57, &soc_lpsc_list[3]),
+	PSC_DEV(58, &soc_lpsc_list[4]),
+	PSC_DEV(161, &soc_lpsc_list[5]),
+	PSC_DEV(162, &soc_lpsc_list[6]),
+	PSC_DEV(75, &soc_lpsc_list[7]),
+	PSC_DEV(102, &soc_lpsc_list[8]),
+	PSC_DEV(146, &soc_lpsc_list[8]),
+	PSC_DEV(166, &soc_lpsc_list[9]),
+	PSC_DEV(135, &soc_lpsc_list[10]),
+	PSC_DEV(170, &soc_lpsc_list[11]),
+	PSC_DEV(177, &soc_lpsc_list[12]),
+	PSC_DEV(55, &soc_lpsc_list[13]),
+};
+
+const struct ti_k3_pd_platdata am62ax_pd_platdata = {
+	.psc = soc_psc_list,
+	.pd = soc_pd_list,
+	.lpsc = soc_lpsc_list,
+	.devs = soc_dev_list,
+	.num_psc = 2,
+	.num_pd = 4,
+	.num_lpsc = 14,
+	.num_devs = 19,
+};
diff --git a/drivers/clk/ti/clk-k3.c b/drivers/clk/ti/clk-k3.c
index 0dd65934b361b..ba925fa3c4805 100644
--- a/drivers/clk/ti/clk-k3.c
+++ b/drivers/clk/ti/clk-k3.c
@@ -79,6 +79,12 @@ static const struct soc_attr ti_k3_soc_clk_data[] = {
 		.family = "AM62X",
 		.data = &am62x_clk_platdata,
 	},
+#endif
+#ifdef CONFIG_SOC_K3_AM62A7
+	{
+		.family = "AM62AX",
+		.data = &am62ax_clk_platdata,
+	},
 #endif
 	{ /* sentinel */ }
 };
diff --git a/drivers/power/domain/ti-power-domain.c b/drivers/power/domain/ti-power-domain.c
index a7f64d04f5c20..9e7151307c893 100644
--- a/drivers/power/domain/ti-power-domain.c
+++ b/drivers/power/domain/ti-power-domain.c
@@ -92,6 +92,12 @@ static const struct soc_attr ti_k3_soc_pd_data[] = {
 		.family = "AM62X",
 		.data = &am62x_pd_platdata,
 	},
+#endif
+#ifdef CONFIG_SOC_K3_AM62A7
+	{
+		.family = "AM62AX",
+		.data = &am62ax_pd_platdata,
+	},
 #endif
 	{ /* sentinel */ }
 };
diff --git a/include/k3-clk.h b/include/k3-clk.h
index 371f077c4476d..49ba53d20f79f 100644
--- a/include/k3-clk.h
+++ b/include/k3-clk.h
@@ -175,6 +175,7 @@ extern const struct ti_k3_clk_platdata j721e_clk_platdata;
 extern const struct ti_k3_clk_platdata j7200_clk_platdata;
 extern const struct ti_k3_clk_platdata j721s2_clk_platdata;
 extern const struct ti_k3_clk_platdata am62x_clk_platdata;
+extern const struct ti_k3_clk_platdata am62ax_clk_platdata;
 
 struct clk *clk_register_ti_pll(const char *name, const char *parent_name,
 				void __iomem *reg);
diff --git a/include/k3-dev.h b/include/k3-dev.h
index 87e873b9cedb9..d288ae3be7386 100644
--- a/include/k3-dev.h
+++ b/include/k3-dev.h
@@ -79,6 +79,7 @@ extern const struct ti_k3_pd_platdata j721e_pd_platdata;
 extern const struct ti_k3_pd_platdata j7200_pd_platdata;
 extern const struct ti_k3_pd_platdata j721s2_pd_platdata;
 extern const struct ti_k3_pd_platdata am62x_pd_platdata;
+extern const struct ti_k3_pd_platdata am62ax_pd_platdata;
 
 u8 ti_pd_state(struct ti_pd *pd);
 u8 lpsc_get_state(struct ti_lpsc *lpsc);
-- 
2.38.1


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

* [PATCH 7/8] board: ti: introduce the basic files needed to support the am62a
  2022-11-04  0:13 [PATCH 0/8] Introduce initial TI's am62a support Bryan Brattlof
                   ` (5 preceding siblings ...)
  2022-11-04  0:13 ` [PATCH 6/8] arm: mach-k3: am62a: introduce auto-generated SoC data Bryan Brattlof
@ 2022-11-04  0:13 ` Bryan Brattlof
  2022-11-04 13:08   ` Tom Rini
  2022-12-09 22:54   ` Tom Rini
  2022-11-04  0:13 ` [PATCH 8/8] configs: introduce configs for " Bryan Brattlof
  2022-11-04 11:49 ` [PATCH 0/8] Introduce initial TI's am62a support Peter Robinson
  8 siblings, 2 replies; 26+ messages in thread
From: Bryan Brattlof @ 2022-11-04  0:13 UTC (permalink / raw)
  To: Lukasz Majewski, Sean Anderson, Jaehoon Chung, Nishanth Menon,
	Georgi Vlaev, Andrew Davis, Vignesh Raghavendra, Tom Rini
  Cc: UBoot Mailing List, Bryan Brattlof

Introduce the bare minimum SD and UART support for the am62a sk.

Signed-off-by: Bryan Brattlof <bb@ti.com>
---
 board/ti/am62ax/Kconfig               | 52 +++++++++++++++++++++++++++
 board/ti/am62ax/MAINTAINERS           |  9 +++++
 board/ti/am62ax/Makefile              |  7 ++++
 board/ti/am62ax/evm.c                 | 31 ++++++++++++++++
 drivers/firmware/ti_sci_static_data.h |  4 +--
 5 files changed, 101 insertions(+), 2 deletions(-)
 create mode 100644 board/ti/am62ax/Kconfig
 create mode 100644 board/ti/am62ax/MAINTAINERS
 create mode 100644 board/ti/am62ax/Makefile
 create mode 100644 board/ti/am62ax/evm.c

diff --git a/board/ti/am62ax/Kconfig b/board/ti/am62ax/Kconfig
new file mode 100644
index 0000000000000..2c18cd49b5d27
--- /dev/null
+++ b/board/ti/am62ax/Kconfig
@@ -0,0 +1,52 @@
+# SPDX-License-Identifier: GPL-2.0+
+#
+# Copyright (C) 2022 Texas Instruments Incorporated - https://www.ti.com/
+#
+
+choice
+	prompt "TI K3 AM62Ax based boards"
+	optional
+
+config TARGET_AM62A7_A53_EVM
+	bool "TI K3 based AM62A7 EVM running on A53"
+	select ARM64
+	select SOC_K3_AM62A7
+	imply BOARD
+	imply SPL_BOARD
+	imply TI_I2C_BOARD_DETECT
+
+config TARGET_AM62A7_R5_EVM
+	bool "TI K3 based AM62A7 EVM running on R5"
+	select CPU_V7R
+	select SYS_THUMB_BUILD
+	select K3_LOAD_SYSFW
+	select SOC_K3_AM62A7
+	select RAM
+	select SPL_RAM
+	select K3_DDRSS
+	imply SYS_K3_SPL_ATF
+	imply TI_I2C_BOARD_DETECT
+
+endchoice
+
+if TARGET_AM62A7_R5_EVM || TARGET_AM62A7_A53_EVM
+
+config SYS_BOARD
+       default "am62ax"
+
+config SYS_VENDOR
+       default "ti"
+
+config SYS_CONFIG_NAME
+       default "am62ax_evm"
+
+source "board/ti/common/Kconfig"
+
+endif
+
+if TARGET_AM62A7_R5_EVM
+
+config SPL_LDSCRIPT
+	default "arch/arm/mach-omap2/u-boot-spl.lds"
+
+endif
diff --git a/board/ti/am62ax/MAINTAINERS b/board/ti/am62ax/MAINTAINERS
new file mode 100644
index 0000000000000..590f683584e52
--- /dev/null
+++ b/board/ti/am62ax/MAINTAINERS
@@ -0,0 +1,9 @@
+AM62Ax BOARD
+M:	Vignesh Raghavendra <vigneshr@ti.com>
+M:	Bryan Brattlof <bb@ti.com>
+M:	Tom Rini <trini@konsulko.com>
+S:	Maintained
+F:	board/ti/am62ax/
+F:	include/configs/am62a7_evm.h
+F:	configs/am62ax_evm_r5_defconfig
+F:	configs/am62ax_evm_a53_defconfig
diff --git a/board/ti/am62ax/Makefile b/board/ti/am62ax/Makefile
new file mode 100644
index 0000000000000..4e8e7aa23003e
--- /dev/null
+++ b/board/ti/am62ax/Makefile
@@ -0,0 +1,7 @@
+#
+# Copyright (C) 2022 Texas Instruments Incorporated - https://www.ti.com/
+#
+# SPDX-License-Identifier:     GPL-2.0+
+#
+
+obj-y	+= evm.o
diff --git a/board/ti/am62ax/evm.c b/board/ti/am62ax/evm.c
new file mode 100644
index 0000000000000..beef3f2f3da70
--- /dev/null
+++ b/board/ti/am62ax/evm.c
@@ -0,0 +1,31 @@
+// SPDX-License-Identifier: GPL-2.0+
+/*
+ * Board specific initialization for AM62Ax platforms
+ *
+ * Copyright (C) 2022 Texas Instruments Incorporated - https://www.ti.com/
+ *
+ */
+
+#include <asm/arch/hardware.h>
+#include <asm/arch/sys_proto.h>
+#include <asm/io.h>
+#include <common.h>
+#include <dm/uclass.h>
+#include <env.h>
+#include <fdt_support.h>
+#include <spl.h>
+
+int board_init(void)
+{
+	return 0;
+}
+
+int dram_init(void)
+{
+	return fdtdec_setup_mem_size_base();
+}
+
+int dram_init_banksize(void)
+{
+	return fdtdec_setup_memory_banksize();
+}
diff --git a/drivers/firmware/ti_sci_static_data.h b/drivers/firmware/ti_sci_static_data.h
index 5ae0556a9a453..1a461fab6199b 100644
--- a/drivers/firmware/ti_sci_static_data.h
+++ b/drivers/firmware/ti_sci_static_data.h
@@ -84,7 +84,7 @@ static struct ti_sci_resource_static_data rm_static_data[] = {
 };
 #endif /* CONFIG_SOC_K3_J721S2 */
 
-#if IS_ENABLED(CONFIG_SOC_K3_AM625)
+#if IS_ENABLED(CONFIG_SOC_K3_AM625) || IS_ENABLED(CONFIG_SOC_K3_AM62A7)
 static struct ti_sci_resource_static_data rm_static_data[] = {
 	/* BC channels */
 	{
@@ -95,7 +95,7 @@ static struct ti_sci_resource_static_data rm_static_data[] = {
 	},
 	{ },
 };
-#endif /* CONFIG_SOC_K3_AM625 */
+#endif /* CONFIG_SOC_K3_AM625 || CONFIG_SOC_K3_AM62A7 */
 
 #else
 static struct ti_sci_resource_static_data rm_static_data[] = {
-- 
2.38.1


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

* [PATCH 8/8] configs: introduce configs for the am62a
  2022-11-04  0:13 [PATCH 0/8] Introduce initial TI's am62a support Bryan Brattlof
                   ` (6 preceding siblings ...)
  2022-11-04  0:13 ` [PATCH 7/8] board: ti: introduce the basic files needed to support the am62a Bryan Brattlof
@ 2022-11-04  0:13 ` Bryan Brattlof
  2022-12-09 22:54   ` Tom Rini
  2022-11-04 11:49 ` [PATCH 0/8] Introduce initial TI's am62a support Peter Robinson
  8 siblings, 1 reply; 26+ messages in thread
From: Bryan Brattlof @ 2022-11-04  0:13 UTC (permalink / raw)
  To: Lukasz Majewski, Sean Anderson, Jaehoon Chung, Nishanth Menon,
	Georgi Vlaev, Andrew Davis, Vignesh Raghavendra, Tom Rini
  Cc: UBoot Mailing List, Bryan Brattlof

Introduce the minimum configs, only SD-MMC and UART boot related
settings, to serve as a good starting point for the am62a as we add more
functionality.

Signed-off-by: Bryan Brattlof <bb@ti.com>
---
 configs/am62ax_evm_a53_defconfig |  79 +++++++++++++++++++++++
 configs/am62ax_evm_r5_defconfig  | 106 +++++++++++++++++++++++++++++++
 include/configs/am62ax_evm.h     |  68 ++++++++++++++++++++
 3 files changed, 253 insertions(+)
 create mode 100644 configs/am62ax_evm_a53_defconfig
 create mode 100644 configs/am62ax_evm_r5_defconfig
 create mode 100644 include/configs/am62ax_evm.h

diff --git a/configs/am62ax_evm_a53_defconfig b/configs/am62ax_evm_a53_defconfig
new file mode 100644
index 0000000000000..79f3592656530
--- /dev/null
+++ b/configs/am62ax_evm_a53_defconfig
@@ -0,0 +1,79 @@
+CONFIG_ARM=y
+CONFIG_ARCH_K3=y
+CONFIG_SYS_MALLOC_F_LEN=0x8000
+CONFIG_SPL_LIBCOMMON_SUPPORT=y
+CONFIG_SPL_LIBGENERIC_SUPPORT=y
+CONFIG_NR_DRAM_BANKS=2
+CONFIG_SOC_K3_AM62A7=y
+CONFIG_K3_ATF_LOAD_ADDR=0x9e780000
+CONFIG_TARGET_AM62A7_A53_EVM=y
+CONFIG_DEFAULT_DEVICE_TREE="k3-am62a7-sk"
+CONFIG_SPL_TEXT_BASE=0x80080000
+CONFIG_SPL_MMC=y
+CONFIG_SPL_SERIAL=y
+CONFIG_SPL_STACK_R_ADDR=0x82000000
+CONFIG_SPL_FS_FAT=y
+CONFIG_SPL_LIBDISK_SUPPORT=y
+CONFIG_DISTRO_DEFAULTS=y
+CONFIG_HAS_CUSTOM_SYS_INIT_SP_ADDR=y
+CONFIG_CUSTOM_SYS_INIT_SP_ADDR=0x80480000
+# CONFIG_SYS_MALLOC_CLEAR_ON_INIT is not set
+CONFIG_SPL_LOAD_FIT=y
+CONFIG_SPL_LOAD_FIT_ADDRESS=0x81000000
+CONFIG_BOOTCOMMAND="run findfdt; run envboot; run init_${boot}; run get_kern_${boot}; run get_fdt_${boot}; run get_overlay_${boot}; run run_kern"
+CONFIG_SPL_MAX_SIZE=0x58000
+CONFIG_SPL_PAD_TO=0x0
+CONFIG_SPL_HAS_BSS_LINKER_SECTION=y
+CONFIG_SPL_BSS_START_ADDR=0x80a00000
+CONFIG_SPL_BSS_MAX_SIZE=0x80000
+CONFIG_SPL_SYS_MALLOC_SIMPLE=y
+CONFIG_SPL_STACK_R=y
+CONFIG_SYS_MMCSD_RAW_MODE_U_BOOT_USE_SECTOR=y
+CONFIG_SYS_MMCSD_RAW_MODE_U_BOOT_SECTOR=0x1400
+CONFIG_SPL_FS_LOAD_PAYLOAD_NAME="u-boot.img"
+CONFIG_SPL_DM_MAILBOX=y
+CONFIG_SPL_POWER_DOMAIN=y
+CONFIG_CMD_MMC=y
+CONFIG_OF_CONTROL=y
+CONFIG_SPL_OF_CONTROL=y
+CONFIG_MULTI_DTB_FIT=y
+CONFIG_SPL_MULTI_DTB_FIT=y
+CONFIG_SPL_MULTI_DTB_FIT_NO_COMPRESSION=y
+CONFIG_NET_RANDOM_ETHADDR=y
+CONFIG_DM=y
+CONFIG_SPL_DM=y
+CONFIG_SPL_DM_SEQ_ALIAS=y
+CONFIG_REGMAP=y
+CONFIG_SPL_REGMAP=y
+CONFIG_SPL_OF_TRANSLATE=y
+CONFIG_CLK=y
+CONFIG_SPL_CLK=y
+CONFIG_CLK_TI_SCI=y
+CONFIG_TI_SCI_PROTOCOL=y
+# CONFIG_GPIO is not set
+# CONFIG_I2C is not set
+CONFIG_DM_MAILBOX=y
+CONFIG_K3_SEC_PROXY=y
+CONFIG_MMC_SDHCI=y
+CONFIG_MMC_SDHCI_ADMA=y
+CONFIG_SPL_MMC_SDHCI_ADMA=y
+CONFIG_MMC_SDHCI_AM654=y
+# CONFIG_NETDEVICES is not set
+CONFIG_PINCTRL=y
+CONFIG_SPL_PINCTRL=y
+CONFIG_PINCTRL_SINGLE=y
+CONFIG_POWER_DOMAIN=y
+CONFIG_TI_SCI_POWER_DOMAIN=y
+CONFIG_K3_SYSTEM_CONTROLLER=y
+CONFIG_REMOTEPROC_TI_K3_ARM64=y
+CONFIG_DM_RESET=y
+CONFIG_RESET_TI_SCI=y
+CONFIG_DM_SERIAL=y
+CONFIG_SOC_DEVICE=y
+CONFIG_SOC_DEVICE_TI_K3=y
+CONFIG_SOC_TI=y
+CONFIG_SYSRESET=y
+CONFIG_SPL_SYSRESET=y
+CONFIG_SYSRESET_TI_SCI=y
+CONFIG_FS_FAT_MAX_CLUSTSIZE=16384
+CONFIG_OF_LIBFDT_OVERLAY=y
diff --git a/configs/am62ax_evm_r5_defconfig b/configs/am62ax_evm_r5_defconfig
new file mode 100644
index 0000000000000..b871a5143cb14
--- /dev/null
+++ b/configs/am62ax_evm_r5_defconfig
@@ -0,0 +1,106 @@
+CONFIG_ARM=y
+CONFIG_ARCH_K3=y
+CONFIG_SYS_MALLOC_F_LEN=0x9000
+CONFIG_SPL_LIBCOMMON_SUPPORT=y
+CONFIG_SPL_LIBGENERIC_SUPPORT=y
+CONFIG_SOC_K3_AM62A7=y
+CONFIG_TARGET_AM62A7_R5_EVM=y
+CONFIG_ENV_SIZE=0x20000
+CONFIG_ENV_OFFSET=0x680000
+CONFIG_SPL_DM_SPI=y
+CONFIG_DEFAULT_DEVICE_TREE="k3-am62a7-r5-sk"
+CONFIG_SPL_TEXT_BASE=0x43c00000
+CONFIG_SPL_MMC=y
+CONFIG_SPL_SERIAL=y
+CONFIG_SPL_STACK_R_ADDR=0x82000000
+CONFIG_SPL_SIZE_LIMIT=0x40000
+CONFIG_SPL_FS_FAT=y
+CONFIG_SPL_LIBDISK_SUPPORT=y
+CONFIG_HAS_CUSTOM_SYS_INIT_SP_ADDR=y
+CONFIG_CUSTOM_SYS_INIT_SP_ADDR=0x7000ffff
+CONFIG_SPL_LOAD_FIT=y
+CONFIG_SPL_LOAD_FIT_ADDRESS=0x80080000
+CONFIG_SPL_FIT_IMAGE_POST_PROCESS=y
+# CONFIG_DISPLAY_CPUINFO is not set
+CONFIG_SPL_MAX_SIZE=0x58000
+CONFIG_SPL_PAD_TO=0x0
+CONFIG_SPL_HAS_BSS_LINKER_SECTION=y
+CONFIG_SPL_BSS_START_ADDR=0x43c37800
+CONFIG_SPL_BSS_MAX_SIZE=0x5000
+CONFIG_SPL_SYS_MALLOC_SIMPLE=y
+CONFIG_SPL_STACK_R=y
+CONFIG_SPL_SEPARATE_BSS=y
+CONFIG_SYS_SPL_MALLOC=y
+CONFIG_HAS_CUSTOM_SPL_MALLOC_START=y
+CONFIG_CUSTOM_SYS_SPL_MALLOC_ADDR=0x84000000
+CONFIG_SPL_EARLY_BSS=y
+CONFIG_SYS_MMCSD_RAW_MODE_U_BOOT_USE_SECTOR=y
+CONFIG_SYS_MMCSD_RAW_MODE_U_BOOT_SECTOR=0x400
+CONFIG_SPL_DMA=y
+CONFIG_SPL_DM_MAILBOX=y
+CONFIG_SPL_MTD_SUPPORT=y
+CONFIG_SPL_DM_SPI_FLASH=y
+CONFIG_SPL_DM_RESET=y
+CONFIG_SPL_POWER_DOMAIN=y
+CONFIG_SPL_RAM_SUPPORT=y
+CONFIG_SPL_RAM_DEVICE=y
+CONFIG_SPL_REMOTEPROC=y
+CONFIG_SPL_THERMAL=y
+CONFIG_HUSH_PARSER=y
+CONFIG_CMD_ASKENV=y
+CONFIG_CMD_DFU=y
+CONFIG_CMD_GPT=y
+CONFIG_CMD_MMC=y
+CONFIG_CMD_REMOTEPROC=y
+# CONFIG_CMD_SETEXPR is not set
+CONFIG_CMD_TIME=y
+CONFIG_CMD_FAT=y
+CONFIG_OF_CONTROL=y
+CONFIG_SPL_OF_CONTROL=y
+CONFIG_ENV_IS_NOWHERE=y
+CONFIG_ENV_IS_IN_MMC=y
+CONFIG_SYS_RELOC_GD_ENV_ADDR=y
+CONFIG_SYS_MMC_ENV_PART=1
+CONFIG_DM=y
+CONFIG_SPL_DM=y
+CONFIG_SPL_DM_SEQ_ALIAS=y
+CONFIG_REGMAP=y
+CONFIG_SPL_REGMAP=y
+CONFIG_SPL_OF_TRANSLATE=y
+CONFIG_CLK=y
+CONFIG_SPL_CLK=y
+CONFIG_SPL_CLK_CCF=y
+CONFIG_SPL_CLK_K3_PLL=y
+CONFIG_SPL_CLK_K3=y
+CONFIG_DMA_CHANNELS=y
+CONFIG_TI_K3_NAVSS_UDMA=y
+CONFIG_TI_SCI_PROTOCOL=y
+# CONFIG_GPIO is not set
+CONFIG_DM_I2C=y
+CONFIG_SYS_I2C_OMAP24XX=y
+CONFIG_DM_MAILBOX=y
+CONFIG_K3_SEC_PROXY=y
+CONFIG_MMC_SDHCI=y
+CONFIG_MMC_SDHCI_ADMA=y
+CONFIG_MMC_SDHCI_AM654=y
+CONFIG_PINCTRL=y
+# CONFIG_PINCTRL_GENERIC is not set
+CONFIG_SPL_PINCTRL=y
+# CONFIG_SPL_PINCTRL_GENERIC is not set
+CONFIG_PINCTRL_SINGLE=y
+CONFIG_POWER_DOMAIN=y
+CONFIG_TI_POWER_DOMAIN=y
+CONFIG_K3_SYSTEM_CONTROLLER=y
+CONFIG_REMOTEPROC_TI_K3_ARM64=y
+CONFIG_DM_RESET=y
+CONFIG_RESET_TI_SCI=y
+CONFIG_SPECIFY_CONSOLE_INDEX=y
+CONFIG_DM_SERIAL=y
+CONFIG_SOC_DEVICE=y
+CONFIG_SOC_DEVICE_TI_K3=y
+CONFIG_SOC_TI=y
+CONFIG_TIMER=y
+CONFIG_SPL_TIMER=y
+CONFIG_OMAP_TIMER=y
+CONFIG_LIB_RATIONAL=y
+CONFIG_SPL_LIB_RATIONAL=y
diff --git a/include/configs/am62ax_evm.h b/include/configs/am62ax_evm.h
new file mode 100644
index 0000000000000..7a2332e33cdcb
--- /dev/null
+++ b/include/configs/am62ax_evm.h
@@ -0,0 +1,68 @@
+/* SPDX-License-Identifier: GPL-2.0+ */
+/*
+ * Configuration header file for K3 AM62Ax SoC family
+ *
+ * Copyright (C) 2022 Texas Instruments Incorporated - https://www.ti.com/
+ */
+
+#ifndef __CONFIG_AM62AX_EVM_H
+#define __CONFIG_AM62AX_EVM_H
+
+#include <linux/sizes.h>
+#include <config_distro_bootcmd.h>
+#include <environment/ti/mmc.h>
+#include <environment/ti/k3_dfu.h>
+
+/* DDR Configuration */
+#define CONFIG_SYS_SDRAM_BASE1		0x880000000
+
+#define PARTS_DEFAULT \
+	/* Linux partitions */ \
+	"name=rootfs,start=0,size=-,uuid=${uuid_gpt_rootfs}\0" \
+
+/* U-Boot general configuration */
+#define EXTRA_ENV_AM62A7_BOARD_SETTINGS					\
+	"default_device_tree=" CONFIG_DEFAULT_DEVICE_TREE ".dtb\0"	\
+	"findfdt="							\
+		"setenv name_fdt ${default_device_tree};"		\
+		"setenv fdtfile ${name_fdt}\0"				\
+	"name_kern=Image\0"						\
+	"console=ttyS2,115200n8\0"					\
+	"args_all=setenv optargs earlycon=ns16550a,mmio32,0x02800000 "	\
+		"${mtdparts}\0"						\
+	"run_kern=booti ${loadaddr} ${rd_spec} ${fdtaddr}\0"
+
+/* U-Boot MMC-specific configuration */
+#define EXTRA_ENV_AM62A7_BOARD_SETTINGS_MMC				\
+	"boot=mmc\0"							\
+	"mmcdev=1\0"							\
+	"bootpart=1:2\0"						\
+	"bootdir=/boot\0"						\
+	"rd_spec=-\0"							\
+	"init_mmc=run args_all args_mmc\0"				\
+	"get_fdt_mmc=load mmc ${bootpart} ${fdtaddr} ${bootdir}/${name_fdt}\0" \
+	"get_overlay_mmc="						\
+		"fdt address ${fdtaddr};"				\
+		"fdt resize 0x100000;"					\
+		"for overlay in $name_overlays;"			\
+		"do;"							\
+		"load mmc ${bootpart} ${dtboaddr} ${bootdir}/${overlay} && "	\
+		"fdt apply ${dtboaddr};"				\
+		"done;\0"						\
+	"get_kern_mmc=load mmc ${bootpart} ${loadaddr} "		\
+		"${bootdir}/${name_kern}\0"				\
+	"get_fit_mmc=load mmc ${bootpart} ${addr_fit} "			\
+		"${bootdir}/${name_fit}\0"				\
+	"partitions=" PARTS_DEFAULT
+
+/* Incorporate settings into the U-Boot environment */
+#define CONFIG_EXTRA_ENV_SETTINGS					\
+	DEFAULT_LINUX_BOOT_ENV						\
+	DEFAULT_MMC_TI_ARGS						\
+	EXTRA_ENV_AM62A7_BOARD_SETTINGS					\
+	EXTRA_ENV_AM62A7_BOARD_SETTINGS_MMC				\
+
+/* Now for the remaining common defines */
+#include <configs/ti_armv7_common.h>
+
+#endif /* __CONFIG_AM62A7_EVM_H */
-- 
2.38.1


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

* Re: [PATCH 0/8] Introduce initial TI's am62a support
  2022-11-04  0:13 [PATCH 0/8] Introduce initial TI's am62a support Bryan Brattlof
                   ` (7 preceding siblings ...)
  2022-11-04  0:13 ` [PATCH 8/8] configs: introduce configs for " Bryan Brattlof
@ 2022-11-04 11:49 ` Peter Robinson
  2022-11-04 13:08   ` Tom Rini
  8 siblings, 1 reply; 26+ messages in thread
From: Peter Robinson @ 2022-11-04 11:49 UTC (permalink / raw)
  To: Bryan Brattlof
  Cc: Lukasz Majewski, Sean Anderson, Jaehoon Chung, Nishanth Menon,
	Georgi Vlaev, Andrew Davis, Vignesh Raghavendra, Tom Rini,
	UBoot Mailing List

Hi Bryan,

> This series will introduce basic support (SD and UART) support for Texas
> Instruments AM62Ax SK EVM.
>
> The am62ax shares many of the same features as the am62x however it uses
> a new 32bit controller and therefore depends on the patch I sent last
> week updating the macros used by the k3-ddrss ram driver[0].
>
> Here is some proof of life & more documentation if you're interested :)
>
> Bootlog:https://paste.sr.ht/~bryanb/e0a418ba7dd452749d2dd1efb5e91b2875a01708
> Technical Reference Manual:https://www.ti.com/lit/zip/spruj16
> Schematics:https://www.ti.com/lit/zip/sprr459

Does this board need a readme for how to build the firmware, these
days there generally needs to be ATF and probably a slew of other
firmwares linked into a FIT image or similar to build the entire
firmware bundle, a readme would likely be a useful addition for people
getting started if there's not a generic TI 64 bit build doc, and if
there is that likely needs an update to include this SoC/board. I
didn't see anything that looked like that in the file list below.

Peter

> Thanks for reviewing!
> ~Bryan
>
> [0] https://lore.kernel.org/u-boot/20221024215328.22373-1-bb@ti.com/
>
> Bryan Brattlof (8):
>   arm: dts: introduce am62a7 dtbs from linux kernel
>   arm: dts: introduce am62a7 u-boot dtbs
>   ram: k3-ddrss: add am62a controller support
>   soc: ti: k3-socinfo: add am62a SoC entry
>   arm: mach-k3: introduce basic files to support the am62a
>   arm: mach-k3: am62a: introduce auto-generated SoC data
>   board: ti: introduce the basic files needed to support the am62a
>   configs: introduce configs for the am62a
>
>  arch/arm/dts/Makefile                         |    3 +
>  arch/arm/dts/k3-am62a-ddr-1866mhz-32bit.dtsi  | 2798 ++++++++++++++++
>  arch/arm/dts/k3-am62a-ddr.dtsi                | 2814 +++++++++++++++++
>  arch/arm/dts/k3-am62a-main.dtsi               |  298 ++
>  arch/arm/dts/k3-am62a-mcu.dtsi                |   39 +
>  arch/arm/dts/k3-am62a-wakeup.dtsi             |   54 +
>  arch/arm/dts/k3-am62a.dtsi                    |  122 +
>  arch/arm/dts/k3-am62a7-r5-sk.dts              |  143 +
>  arch/arm/dts/k3-am62a7-sk-u-boot.dtsi         |  140 +
>  arch/arm/dts/k3-am62a7-sk.dts                 |  223 ++
>  arch/arm/dts/k3-am62a7.dtsi                   |  103 +
>  arch/arm/mach-k3/Kconfig                      |   14 +-
>  arch/arm/mach-k3/Makefile                     |    2 +
>  arch/arm/mach-k3/am62a7_init.c                |  250 ++
>  arch/arm/mach-k3/am62ax/Makefile              |    6 +
>  arch/arm/mach-k3/am62ax/clk-data.c            |  317 ++
>  arch/arm/mach-k3/am62ax/dev-data.c            |   73 +
>  arch/arm/mach-k3/arm64-mmu.c                  |    6 +-
>  .../arm/mach-k3/include/mach/am62a_hardware.h |   74 +
>  arch/arm/mach-k3/include/mach/am62a_spl.h     |   49 +
>  arch/arm/mach-k3/include/mach/hardware.h      |    4 +
>  arch/arm/mach-k3/include/mach/spl.h           |    4 +
>  board/ti/am62ax/Kconfig                       |   52 +
>  board/ti/am62ax/MAINTAINERS                   |    9 +
>  board/ti/am62ax/Makefile                      |    7 +
>  board/ti/am62ax/evm.c                         |   31 +
>  configs/am62ax_evm_a53_defconfig              |   79 +
>  configs/am62ax_evm_r5_defconfig               |  106 +
>  drivers/clk/ti/clk-k3.c                       |    6 +
>  drivers/firmware/ti_sci_static_data.h         |    4 +-
>  drivers/power/domain/ti-power-domain.c        |    6 +
>  drivers/ram/Kconfig                           |    1 +
>  drivers/ram/k3-ddrss/k3-ddrss.c               |    1 +
>  drivers/soc/soc_ti_k3.c                       |    4 +
>  include/configs/am62ax_evm.h                  |   68 +
>  include/dt-bindings/pinctrl/k3.h              |    3 +
>  include/k3-clk.h                              |    1 +
>  include/k3-dev.h                              |    1 +
>  38 files changed, 7906 insertions(+), 9 deletions(-)
>  create mode 100644 arch/arm/dts/k3-am62a-ddr-1866mhz-32bit.dtsi
>  create mode 100644 arch/arm/dts/k3-am62a-ddr.dtsi
>  create mode 100644 arch/arm/dts/k3-am62a-main.dtsi
>  create mode 100644 arch/arm/dts/k3-am62a-mcu.dtsi
>  create mode 100644 arch/arm/dts/k3-am62a-wakeup.dtsi
>  create mode 100644 arch/arm/dts/k3-am62a.dtsi
>  create mode 100644 arch/arm/dts/k3-am62a7-r5-sk.dts
>  create mode 100644 arch/arm/dts/k3-am62a7-sk-u-boot.dtsi
>  create mode 100644 arch/arm/dts/k3-am62a7-sk.dts
>  create mode 100644 arch/arm/dts/k3-am62a7.dtsi
>  create mode 100644 arch/arm/mach-k3/am62a7_init.c
>  create mode 100644 arch/arm/mach-k3/am62ax/Makefile
>  create mode 100644 arch/arm/mach-k3/am62ax/clk-data.c
>  create mode 100644 arch/arm/mach-k3/am62ax/dev-data.c
>  create mode 100644 arch/arm/mach-k3/include/mach/am62a_hardware.h
>  create mode 100644 arch/arm/mach-k3/include/mach/am62a_spl.h
>  create mode 100644 board/ti/am62ax/Kconfig
>  create mode 100644 board/ti/am62ax/MAINTAINERS
>  create mode 100644 board/ti/am62ax/Makefile
>  create mode 100644 board/ti/am62ax/evm.c
>  create mode 100644 configs/am62ax_evm_a53_defconfig
>  create mode 100644 configs/am62ax_evm_r5_defconfig
>  create mode 100644 include/configs/am62ax_evm.h
>
> --
> 2.38.1
>

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

* Re: [PATCH 1/8] arm: dts: introduce am62a7 dtbs from linux kernel
  2022-11-04  0:13 ` [PATCH 1/8] arm: dts: introduce am62a7 dtbs from linux kernel Bryan Brattlof
@ 2022-11-04 13:08   ` Tom Rini
  2022-11-08 21:50     ` Bryan Brattlof
  2022-12-09 22:53   ` Tom Rini
  1 sibling, 1 reply; 26+ messages in thread
From: Tom Rini @ 2022-11-04 13:08 UTC (permalink / raw)
  To: Bryan Brattlof
  Cc: Lukasz Majewski, Sean Anderson, Jaehoon Chung, Nishanth Menon,
	Georgi Vlaev, Andrew Davis, Vignesh Raghavendra,
	UBoot Mailing List

[-- Attachment #1: Type: text/plain, Size: 320 bytes --]

On Thu, Nov 03, 2022 at 07:13:51PM -0500, Bryan Brattlof wrote:

> Introduce the basic am62a7 SoC dtbs from the linux kernel along with the
> new am62a specific pinmux definition that we will use to generate the
> dtbs for the u-boot-spl and u-boot binaries

Please note what tag this is synced from.

-- 
Tom

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 659 bytes --]

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

* Re: [PATCH 3/8] ram: k3-ddrss: add am62a controller support
  2022-11-04  0:13 ` [PATCH 3/8] ram: k3-ddrss: add am62a controller support Bryan Brattlof
@ 2022-11-04 13:08   ` Tom Rini
  2022-12-09 22:53   ` Tom Rini
  1 sibling, 0 replies; 26+ messages in thread
From: Tom Rini @ 2022-11-04 13:08 UTC (permalink / raw)
  To: Bryan Brattlof
  Cc: Lukasz Majewski, Sean Anderson, Jaehoon Chung, Nishanth Menon,
	Georgi Vlaev, Andrew Davis, Vignesh Raghavendra,
	UBoot Mailing List

[-- Attachment #1: Type: text/plain, Size: 406 bytes --]

On Thu, Nov 03, 2022 at 07:13:53PM -0500, Bryan Brattlof wrote:

> TI's am62a family of SoCs uses a new 32bit DDR controller that shares
> much of the same functionality with the existing am64 and j721e
> controllers.
> 
> Select this controller by default when u-boot is build for the am62a
> 
> Signed-off-by: Bryan Brattlof <bb@ti.com>

Reviewed-by: Tom Rini <trini@konsulko.com>

-- 
Tom

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 659 bytes --]

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

* Re: [PATCH 4/8] soc: ti: k3-socinfo: add am62a SoC entry
  2022-11-04  0:13 ` [PATCH 4/8] soc: ti: k3-socinfo: add am62a SoC entry Bryan Brattlof
@ 2022-11-04 13:08   ` Tom Rini
  2022-12-09 22:53   ` Tom Rini
  1 sibling, 0 replies; 26+ messages in thread
From: Tom Rini @ 2022-11-04 13:08 UTC (permalink / raw)
  To: Bryan Brattlof
  Cc: Lukasz Majewski, Sean Anderson, Jaehoon Chung, Nishanth Menon,
	Georgi Vlaev, Andrew Davis, Vignesh Raghavendra,
	UBoot Mailing List

[-- Attachment #1: Type: text/plain, Size: 235 bytes --]

On Thu, Nov 03, 2022 at 07:13:54PM -0500, Bryan Brattlof wrote:

> Add identification support for TI's am62ax family of SoCs
> 
> Signed-off-by: Bryan Brattlof <bb@ti.com>

Reviewed-by: Tom Rini <trini@konsulko.com>

-- 
Tom

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 659 bytes --]

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

* Re: [PATCH 7/8] board: ti: introduce the basic files needed to support the am62a
  2022-11-04  0:13 ` [PATCH 7/8] board: ti: introduce the basic files needed to support the am62a Bryan Brattlof
@ 2022-11-04 13:08   ` Tom Rini
  2022-12-09 22:54   ` Tom Rini
  1 sibling, 0 replies; 26+ messages in thread
From: Tom Rini @ 2022-11-04 13:08 UTC (permalink / raw)
  To: Bryan Brattlof
  Cc: Lukasz Majewski, Sean Anderson, Jaehoon Chung, Nishanth Menon,
	Georgi Vlaev, Andrew Davis, Vignesh Raghavendra,
	UBoot Mailing List

[-- Attachment #1: Type: text/plain, Size: 242 bytes --]

On Thu, Nov 03, 2022 at 07:13:57PM -0500, Bryan Brattlof wrote:

> Introduce the bare minimum SD and UART support for the am62a sk.
> 
> Signed-off-by: Bryan Brattlof <bb@ti.com>

Reviewed-by: Tom Rini <trini@konsulko.com>

-- 
Tom

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 659 bytes --]

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

* Re: [PATCH 0/8] Introduce initial TI's am62a support
  2022-11-04 11:49 ` [PATCH 0/8] Introduce initial TI's am62a support Peter Robinson
@ 2022-11-04 13:08   ` Tom Rini
  2022-11-04 15:02     ` Andrew Davis
  0 siblings, 1 reply; 26+ messages in thread
From: Tom Rini @ 2022-11-04 13:08 UTC (permalink / raw)
  To: Peter Robinson
  Cc: Bryan Brattlof, Lukasz Majewski, Sean Anderson, Jaehoon Chung,
	Nishanth Menon, Georgi Vlaev, Andrew Davis, Vignesh Raghavendra,
	UBoot Mailing List

[-- Attachment #1: Type: text/plain, Size: 1294 bytes --]

On Fri, Nov 04, 2022 at 11:49:39AM +0000, Peter Robinson wrote:
> Hi Bryan,
> 
> > This series will introduce basic support (SD and UART) support for Texas
> > Instruments AM62Ax SK EVM.
> >
> > The am62ax shares many of the same features as the am62x however it uses
> > a new 32bit controller and therefore depends on the patch I sent last
> > week updating the macros used by the k3-ddrss ram driver[0].
> >
> > Here is some proof of life & more documentation if you're interested :)
> >
> > Bootlog:https://paste.sr.ht/~bryanb/e0a418ba7dd452749d2dd1efb5e91b2875a01708
> > Technical Reference Manual:https://www.ti.com/lit/zip/spruj16
> > Schematics:https://www.ti.com/lit/zip/sprr459
> 
> Does this board need a readme for how to build the firmware, these
> days there generally needs to be ATF and probably a slew of other
> firmwares linked into a FIT image or similar to build the entire
> firmware bundle, a readme would likely be a useful addition for people
> getting started if there's not a generic TI 64 bit build doc, and if
> there is that likely needs an update to include this SoC/board. I
> didn't see anything that looked like that in the file list below.

Agreed, something under doc/board/ti/ is needed as well for the series,
thanks!

-- 
Tom

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 659 bytes --]

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

* Re: [PATCH 0/8] Introduce initial TI's am62a support
  2022-11-04 13:08   ` Tom Rini
@ 2022-11-04 15:02     ` Andrew Davis
  2022-11-08 21:53       ` Bryan Brattlof
  0 siblings, 1 reply; 26+ messages in thread
From: Andrew Davis @ 2022-11-04 15:02 UTC (permalink / raw)
  To: Tom Rini, Peter Robinson
  Cc: Bryan Brattlof, Lukasz Majewski, Sean Anderson, Jaehoon Chung,
	Nishanth Menon, Georgi Vlaev, Vignesh Raghavendra,
	UBoot Mailing List

On 11/4/22 8:08 AM, Tom Rini wrote:
> On Fri, Nov 04, 2022 at 11:49:39AM +0000, Peter Robinson wrote:
>> Hi Bryan,
>>
>>> This series will introduce basic support (SD and UART) support for Texas
>>> Instruments AM62Ax SK EVM.
>>>
>>> The am62ax shares many of the same features as the am62x however it uses
>>> a new 32bit controller and therefore depends on the patch I sent last
>>> week updating the macros used by the k3-ddrss ram driver[0].
>>>
>>> Here is some proof of life & more documentation if you're interested :)
>>>
>>> Bootlog:https://paste.sr.ht/~bryanb/e0a418ba7dd452749d2dd1efb5e91b2875a01708
>>> Technical Reference Manual:https://www.ti.com/lit/zip/spruj16
>>> Schematics:https://www.ti.com/lit/zip/sprr459
>>
>> Does this board need a readme for how to build the firmware, these
>> days there generally needs to be ATF and probably a slew of other
>> firmwares linked into a FIT image or similar to build the entire
>> firmware bundle, a readme would likely be a useful addition for people
>> getting started if there's not a generic TI 64 bit build doc, and if
>> there is that likely needs an update to include this SoC/board. I
>> didn't see anything that looked like that in the file list below.
> 
> Agreed, something under doc/board/ti/ is needed as well for the series,
> thanks!
> 

I see we do have some files at board/ti/{j721e,j721s2}/README with some
good info on all this firmware source/building. Much of that info is
common and could be factored out into a "generic TI 64 bit build doc".

Andrew

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

* Re: [PATCH 1/8] arm: dts: introduce am62a7 dtbs from linux kernel
  2022-11-04 13:08   ` Tom Rini
@ 2022-11-08 21:50     ` Bryan Brattlof
  0 siblings, 0 replies; 26+ messages in thread
From: Bryan Brattlof @ 2022-11-08 21:50 UTC (permalink / raw)
  To: Tom Rini
  Cc: Lukasz Majewski, Sean Anderson, Jaehoon Chung, Nishanth Menon,
	Georgi Vlaev, Andrew Davis, Vignesh Raghavendra,
	UBoot Mailing List

On November  4, 2022 thus sayeth Tom Rini:
> On Thu, Nov 03, 2022 at 07:13:51PM -0500, Bryan Brattlof wrote:
> 
> > Introduce the basic am62a7 SoC dtbs from the linux kernel along with the
> > new am62a specific pinmux definition that we will use to generate the
> > dtbs for the u-boot-spl and u-boot binaries
> 
> Please note what tag this is synced from.
>

Ah! I'll update the commit msg in v2. I pulled these from v6.1-rc3

Thanks for reviewing
~Bryan

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

* Re: [PATCH 0/8] Introduce initial TI's am62a support
  2022-11-04 15:02     ` Andrew Davis
@ 2022-11-08 21:53       ` Bryan Brattlof
  0 siblings, 0 replies; 26+ messages in thread
From: Bryan Brattlof @ 2022-11-08 21:53 UTC (permalink / raw)
  To: Andrew Davis
  Cc: Tom Rini, Peter Robinson, Lukasz Majewski, Sean Anderson,
	Jaehoon Chung, Nishanth Menon, Georgi Vlaev, Vignesh Raghavendra,
	UBoot Mailing List

On November  4, 2022 thus sayeth Andrew Davis:
> On 11/4/22 8:08 AM, Tom Rini wrote:
> > On Fri, Nov 04, 2022 at 11:49:39AM +0000, Peter Robinson wrote:
> > > Hi Bryan,
> > > 
> > > > This series will introduce basic support (SD and UART) support for Texas
> > > > Instruments AM62Ax SK EVM.
> > > > 
> > > > The am62ax shares many of the same features as the am62x however it uses
> > > > a new 32bit controller and therefore depends on the patch I sent last
> > > > week updating the macros used by the k3-ddrss ram driver[0].
> > > > 
> > > > Here is some proof of life & more documentation if you're interested :)
> > > > 
> > > > Bootlog:https://paste.sr.ht/~bryanb/e0a418ba7dd452749d2dd1efb5e91b2875a01708
> > > > Technical Reference Manual:https://www.ti.com/lit/zip/spruj16
> > > > Schematics:https://www.ti.com/lit/zip/sprr459
> > > 
> > > Does this board need a readme for how to build the firmware, these
> > > days there generally needs to be ATF and probably a slew of other
> > > firmwares linked into a FIT image or similar to build the entire
> > > firmware bundle, a readme would likely be a useful addition for people
> > > getting started if there's not a generic TI 64 bit build doc, and if
> > > there is that likely needs an update to include this SoC/board. I
> > > didn't see anything that looked like that in the file list below.
> > 
> > Agreed, something under doc/board/ti/ is needed as well for the series,
> > thanks!
> > 
> 
> I see we do have some files at board/ti/{j721e,j721s2}/README with some
> good info on all this firmware source/building. Much of that info is
> common and could be factored out into a "generic TI 64 bit build doc".
> 

Cool! I can add this to the series :)

Thanks for reviewing everyone
~Bryan

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

* Re: [PATCH 2/8] arm: dts: introduce am62a7 u-boot dtbs
  2022-11-04  0:13 ` [PATCH 2/8] arm: dts: introduce am62a7 u-boot dtbs Bryan Brattlof
@ 2022-12-09 22:53   ` Tom Rini
  0 siblings, 0 replies; 26+ messages in thread
From: Tom Rini @ 2022-12-09 22:53 UTC (permalink / raw)
  To: Bryan Brattlof
  Cc: Lukasz Majewski, Sean Anderson, Jaehoon Chung, Nishanth Menon,
	Georgi Vlaev, Andrew Davis, Vignesh Raghavendra,
	UBoot Mailing List

[-- Attachment #1: Type: text/plain, Size: 347 bytes --]

On Thu, Nov 03, 2022 at 07:13:52PM -0500, Bryan Brattlof wrote:

> Introduce the base dts files needed for u-boot or to augment the
> linux dtbs for use in the u-boot-spl and u-boot binaries
> 
> Signed-off-by: Vignesh Raghavendra <vigneshr@ti.com>
> Signed-off-by: Bryan Brattlof <bb@ti.com>

Applied to u-boot/next, thanks!

-- 
Tom

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 659 bytes --]

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

* Re: [PATCH 1/8] arm: dts: introduce am62a7 dtbs from linux kernel
  2022-11-04  0:13 ` [PATCH 1/8] arm: dts: introduce am62a7 dtbs from linux kernel Bryan Brattlof
  2022-11-04 13:08   ` Tom Rini
@ 2022-12-09 22:53   ` Tom Rini
  1 sibling, 0 replies; 26+ messages in thread
From: Tom Rini @ 2022-12-09 22:53 UTC (permalink / raw)
  To: Bryan Brattlof
  Cc: Lukasz Majewski, Sean Anderson, Jaehoon Chung, Nishanth Menon,
	Georgi Vlaev, Andrew Davis, Vignesh Raghavendra,
	UBoot Mailing List

[-- Attachment #1: Type: text/plain, Size: 593 bytes --]

On Thu, Nov 03, 2022 at 07:13:51PM -0500, Bryan Brattlof wrote:

> Introduce the basic am62a7 SoC dtbs from the v6.1-rc3 tag of the linux
> kernel along with the new am62a specific pinmux definition that we will
> use to generate the dtbs for the u-boot-spl and u-boot binaries
> 
> Co-developed-by: Vignesh Raghavendra <vigneshr@ti.com>
> Signed-off-by: Vignesh Raghavendra <vigneshr@ti.com>
> Signed-off-by: Bryan Brattlof <bb@ti.com>

As seen above, I just reworded things slightly to include the tag the
dts files came from and then applied to u-boot/next, thanks!

-- 
Tom

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 659 bytes --]

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

* Re: [PATCH 3/8] ram: k3-ddrss: add am62a controller support
  2022-11-04  0:13 ` [PATCH 3/8] ram: k3-ddrss: add am62a controller support Bryan Brattlof
  2022-11-04 13:08   ` Tom Rini
@ 2022-12-09 22:53   ` Tom Rini
  1 sibling, 0 replies; 26+ messages in thread
From: Tom Rini @ 2022-12-09 22:53 UTC (permalink / raw)
  To: Bryan Brattlof
  Cc: Lukasz Majewski, Sean Anderson, Jaehoon Chung, Nishanth Menon,
	Georgi Vlaev, Andrew Davis, Vignesh Raghavendra,
	UBoot Mailing List

[-- Attachment #1: Type: text/plain, Size: 441 bytes --]

On Thu, Nov 03, 2022 at 07:13:53PM -0500, Bryan Brattlof wrote:

> TI's am62a family of SoCs uses a new 32bit DDR controller that shares
> much of the same functionality with the existing am64 and j721e
> controllers.
> 
> Select this controller by default when u-boot is build for the am62a
> 
> Signed-off-by: Bryan Brattlof <bb@ti.com>
> Reviewed-by: Tom Rini <trini@konsulko.com>

Applied to u-boot/next, thanks!

-- 
Tom

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 659 bytes --]

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

* Re: [PATCH 4/8] soc: ti: k3-socinfo: add am62a SoC entry
  2022-11-04  0:13 ` [PATCH 4/8] soc: ti: k3-socinfo: add am62a SoC entry Bryan Brattlof
  2022-11-04 13:08   ` Tom Rini
@ 2022-12-09 22:53   ` Tom Rini
  1 sibling, 0 replies; 26+ messages in thread
From: Tom Rini @ 2022-12-09 22:53 UTC (permalink / raw)
  To: Bryan Brattlof
  Cc: Lukasz Majewski, Sean Anderson, Jaehoon Chung, Nishanth Menon,
	Georgi Vlaev, Andrew Davis, Vignesh Raghavendra,
	UBoot Mailing List

[-- Attachment #1: Type: text/plain, Size: 270 bytes --]

On Thu, Nov 03, 2022 at 07:13:54PM -0500, Bryan Brattlof wrote:

> Add identification support for TI's am62ax family of SoCs
> 
> Signed-off-by: Bryan Brattlof <bb@ti.com>
> Reviewed-by: Tom Rini <trini@konsulko.com>

Applied to u-boot/next, thanks!

-- 
Tom

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 659 bytes --]

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

* Re: [PATCH 5/8] arm: mach-k3: introduce basic files to support the am62a
  2022-11-04  0:13 ` [PATCH 5/8] arm: mach-k3: introduce basic files to support the am62a Bryan Brattlof
@ 2022-12-09 22:53   ` Tom Rini
  0 siblings, 0 replies; 26+ messages in thread
From: Tom Rini @ 2022-12-09 22:53 UTC (permalink / raw)
  To: Bryan Brattlof
  Cc: Lukasz Majewski, Sean Anderson, Jaehoon Chung, Nishanth Menon,
	Georgi Vlaev, Andrew Davis, Vignesh Raghavendra,
	UBoot Mailing List

[-- Attachment #1: Type: text/plain, Size: 254 bytes --]

On Thu, Nov 03, 2022 at 07:13:55PM -0500, Bryan Brattlof wrote:

> Introduce the mach-k3 files needed to properly boot TI's am62a SoC
> family of devices
> 
> Signed-off-by: Bryan Brattlof <bb@ti.com>

Applied to u-boot/next, thanks!

-- 
Tom

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 659 bytes --]

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

* Re: [PATCH 6/8] arm: mach-k3: am62a: introduce auto-generated SoC data
  2022-11-04  0:13 ` [PATCH 6/8] arm: mach-k3: am62a: introduce auto-generated SoC data Bryan Brattlof
@ 2022-12-09 22:54   ` Tom Rini
  0 siblings, 0 replies; 26+ messages in thread
From: Tom Rini @ 2022-12-09 22:54 UTC (permalink / raw)
  To: Bryan Brattlof
  Cc: Lukasz Majewski, Sean Anderson, Jaehoon Chung, Nishanth Menon,
	Georgi Vlaev, Andrew Davis, Vignesh Raghavendra,
	UBoot Mailing List

[-- Attachment #1: Type: text/plain, Size: 310 bytes --]

On Thu, Nov 03, 2022 at 07:13:56PM -0500, Bryan Brattlof wrote:

> Introduce the auto-generated clock tree and power domain data needed to
> attach the am62a into the power-domain and clock frameworks of uboot
> 
> Signed-off-by: Bryan Brattlof <bb@ti.com>

Applied to u-boot/next, thanks!

-- 
Tom

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 659 bytes --]

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

* Re: [PATCH 7/8] board: ti: introduce the basic files needed to support the am62a
  2022-11-04  0:13 ` [PATCH 7/8] board: ti: introduce the basic files needed to support the am62a Bryan Brattlof
  2022-11-04 13:08   ` Tom Rini
@ 2022-12-09 22:54   ` Tom Rini
  1 sibling, 0 replies; 26+ messages in thread
From: Tom Rini @ 2022-12-09 22:54 UTC (permalink / raw)
  To: Bryan Brattlof
  Cc: Lukasz Majewski, Sean Anderson, Jaehoon Chung, Nishanth Menon,
	Georgi Vlaev, Andrew Davis, Vignesh Raghavendra,
	UBoot Mailing List

[-- Attachment #1: Type: text/plain, Size: 277 bytes --]

On Thu, Nov 03, 2022 at 07:13:57PM -0500, Bryan Brattlof wrote:

> Introduce the bare minimum SD and UART support for the am62a sk.
> 
> Signed-off-by: Bryan Brattlof <bb@ti.com>
> Reviewed-by: Tom Rini <trini@konsulko.com>

Applied to u-boot/next, thanks!

-- 
Tom

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 659 bytes --]

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

* Re: [PATCH 8/8] configs: introduce configs for the am62a
  2022-11-04  0:13 ` [PATCH 8/8] configs: introduce configs for " Bryan Brattlof
@ 2022-12-09 22:54   ` Tom Rini
  0 siblings, 0 replies; 26+ messages in thread
From: Tom Rini @ 2022-12-09 22:54 UTC (permalink / raw)
  To: Bryan Brattlof
  Cc: Lukasz Majewski, Sean Anderson, Jaehoon Chung, Nishanth Menon,
	Georgi Vlaev, Andrew Davis, Vignesh Raghavendra,
	UBoot Mailing List

[-- Attachment #1: Type: text/plain, Size: 325 bytes --]

On Thu, Nov 03, 2022 at 07:13:58PM -0500, Bryan Brattlof wrote:

> Introduce the minimum configs, only SD-MMC and UART boot related
> settings, to serve as a good starting point for the am62a as we add more
> functionality.
> 
> Signed-off-by: Bryan Brattlof <bb@ti.com>

Applied to u-boot/next, thanks!

-- 
Tom

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 659 bytes --]

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

end of thread, other threads:[~2022-12-09 22:55 UTC | newest]

Thread overview: 26+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2022-11-04  0:13 [PATCH 0/8] Introduce initial TI's am62a support Bryan Brattlof
2022-11-04  0:13 ` [PATCH 1/8] arm: dts: introduce am62a7 dtbs from linux kernel Bryan Brattlof
2022-11-04 13:08   ` Tom Rini
2022-11-08 21:50     ` Bryan Brattlof
2022-12-09 22:53   ` Tom Rini
2022-11-04  0:13 ` [PATCH 2/8] arm: dts: introduce am62a7 u-boot dtbs Bryan Brattlof
2022-12-09 22:53   ` Tom Rini
2022-11-04  0:13 ` [PATCH 3/8] ram: k3-ddrss: add am62a controller support Bryan Brattlof
2022-11-04 13:08   ` Tom Rini
2022-12-09 22:53   ` Tom Rini
2022-11-04  0:13 ` [PATCH 4/8] soc: ti: k3-socinfo: add am62a SoC entry Bryan Brattlof
2022-11-04 13:08   ` Tom Rini
2022-12-09 22:53   ` Tom Rini
2022-11-04  0:13 ` [PATCH 5/8] arm: mach-k3: introduce basic files to support the am62a Bryan Brattlof
2022-12-09 22:53   ` Tom Rini
2022-11-04  0:13 ` [PATCH 6/8] arm: mach-k3: am62a: introduce auto-generated SoC data Bryan Brattlof
2022-12-09 22:54   ` Tom Rini
2022-11-04  0:13 ` [PATCH 7/8] board: ti: introduce the basic files needed to support the am62a Bryan Brattlof
2022-11-04 13:08   ` Tom Rini
2022-12-09 22:54   ` Tom Rini
2022-11-04  0:13 ` [PATCH 8/8] configs: introduce configs for " Bryan Brattlof
2022-12-09 22:54   ` Tom Rini
2022-11-04 11:49 ` [PATCH 0/8] Introduce initial TI's am62a support Peter Robinson
2022-11-04 13:08   ` Tom Rini
2022-11-04 15:02     ` Andrew Davis
2022-11-08 21:53       ` Bryan Brattlof

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.