arm64: dts: ti: k3-j784s4-main: Add WIZ and SERDES PHY nodes
authorSiddharth Vadapalli <s-vadapalli@ti.com>
Thu, 19 Oct 2023 05:40:19 +0000 (11:10 +0530)
committerVignesh Raghavendra <vigneshr@ti.com>
Thu, 19 Oct 2023 10:16:32 +0000 (15:46 +0530)
J784S4 SoC has 4 Serdes instances along with their respective WIZ
instances. Add device-tree nodes for them and disable them by default
as the node is incomplete and phy link properties will be added in
the platform dt file.

Signed-off-by: Siddharth Vadapalli <s-vadapalli@ti.com>
[j-choudhary@ti.com: fix serdes_wiz clock order & disable serdes refclk]
Signed-off-by: Jayesh Choudhary <j-choudhary@ti.com>
Reviewed-by: Roger Quadros <rogerq@kernel.org>
Link: https://lore.kernel.org/r/20231019054022.175163-3-j-choudhary@ti.com
Signed-off-by: Vignesh Raghavendra <vigneshr@ti.com>
arch/arm64/boot/dts/ti/k3-j784s4-main.dtsi

index d65788d16e225b61c57162037ac4fb47de381616..a8642453b710af32ec95ef67ad8e0b17b7353f90 100644 (file)
@@ -6,9 +6,20 @@
  */
 
 #include <dt-bindings/mux/mux.h>
+#include <dt-bindings/phy/phy.h>
+#include <dt-bindings/phy/phy-ti.h>
 
 #include "k3-serdes.h"
 
+/ {
+       serdes_refclk: clock-serdes {
+               #clock-cells = <0>;
+               compatible = "fixed-clock";
+               /* To be enabled when serdes_wiz* is functional */
+               status = "disabled";
+       };
+};
+
 &cbass_main {
        msmc_ram: sram@70000000 {
                compatible = "mmio-sram";
                status = "disabled";
        };
 
+       serdes_wiz0: wiz@5060000 {
+               compatible = "ti,j784s4-wiz-10g";
+               #address-cells = <1>;
+               #size-cells = <1>;
+               power-domains = <&k3_pds 404 TI_SCI_PD_EXCLUSIVE>;
+               clocks = <&k3_clks 404 2>, <&k3_clks 404 6>, <&serdes_refclk>, <&k3_clks 404 5>;
+               clock-names = "fck", "core_ref_clk", "ext_ref_clk", "core_ref1_clk";
+               assigned-clocks = <&k3_clks 404 6>;
+               assigned-clock-parents = <&k3_clks 404 10>;
+               num-lanes = <4>;
+               #reset-cells = <1>;
+               #clock-cells = <1>;
+               ranges = <0x5060000 0x00 0x5060000 0x10000>;
+               status = "disabled";
+
+               serdes0: serdes@5060000 {
+                       compatible = "ti,j721e-serdes-10g";
+                       reg = <0x05060000 0x010000>;
+                       reg-names = "torrent_phy";
+                       resets = <&serdes_wiz0 0>;
+                       reset-names = "torrent_reset";
+                       clocks = <&serdes_wiz0 TI_WIZ_PLL0_REFCLK>,
+                                <&serdes_wiz0 TI_WIZ_PHY_EN_REFCLK>;
+                       clock-names = "refclk", "phy_en_refclk";
+                       assigned-clocks = <&serdes_wiz0 TI_WIZ_PLL0_REFCLK>,
+                                         <&serdes_wiz0 TI_WIZ_PLL1_REFCLK>,
+                                         <&serdes_wiz0 TI_WIZ_REFCLK_DIG>;
+                       assigned-clock-parents = <&k3_clks 404 6>,
+                                                <&k3_clks 404 6>,
+                                                <&k3_clks 404 6>;
+                       #address-cells = <1>;
+                       #size-cells = <0>;
+                       #clock-cells = <1>;
+                       status = "disabled";
+               };
+       };
+
+       serdes_wiz1: wiz@5070000 {
+               compatible = "ti,j784s4-wiz-10g";
+               #address-cells = <1>;
+               #size-cells = <1>;
+               power-domains = <&k3_pds 405 TI_SCI_PD_EXCLUSIVE>;
+               clocks = <&k3_clks 405 2>, <&k3_clks 405 6>, <&serdes_refclk>, <&k3_clks 405 5>;
+               clock-names = "fck", "core_ref_clk", "ext_ref_clk", "core_ref1_clk";
+               assigned-clocks = <&k3_clks 405 6>;
+               assigned-clock-parents = <&k3_clks 405 10>;
+               num-lanes = <4>;
+               #reset-cells = <1>;
+               #clock-cells = <1>;
+               ranges = <0x05070000 0x00 0x05070000 0x10000>;
+               status = "disabled";
+
+               serdes1: serdes@5070000 {
+                       compatible = "ti,j721e-serdes-10g";
+                       reg = <0x05070000 0x010000>;
+                       reg-names = "torrent_phy";
+                       resets = <&serdes_wiz1 0>;
+                       reset-names = "torrent_reset";
+                       clocks = <&serdes_wiz1 TI_WIZ_PLL0_REFCLK>,
+                                <&serdes_wiz1 TI_WIZ_PHY_EN_REFCLK>;
+                       clock-names = "refclk", "phy_en_refclk";
+                       assigned-clocks = <&serdes_wiz1 TI_WIZ_PLL0_REFCLK>,
+                                         <&serdes_wiz1 TI_WIZ_PLL1_REFCLK>,
+                                         <&serdes_wiz1 TI_WIZ_REFCLK_DIG>;
+                       assigned-clock-parents = <&k3_clks 405 6>,
+                                                <&k3_clks 405 6>,
+                                                <&k3_clks 405 6>;
+                       #address-cells = <1>;
+                       #size-cells = <0>;
+                       #clock-cells = <1>;
+                       status = "disabled";
+               };
+       };
+
+       serdes_wiz2: wiz@5020000 {
+               compatible = "ti,j784s4-wiz-10g";
+               #address-cells = <1>;
+               #size-cells = <1>;
+               power-domains = <&k3_pds 406 TI_SCI_PD_EXCLUSIVE>;
+               clocks = <&k3_clks 406 2>, <&k3_clks 406 6>, <&serdes_refclk>, <&k3_clks 406 5>;
+               clock-names = "fck", "core_ref_clk", "ext_ref_clk", "core_ref1_clk";
+               assigned-clocks = <&k3_clks 406 6>;
+               assigned-clock-parents = <&k3_clks 406 10>;
+               num-lanes = <4>;
+               #reset-cells = <1>;
+               #clock-cells = <1>;
+               ranges = <0x05020000 0x00 0x05020000 0x10000>;
+               status = "disabled";
+
+               serdes2: serdes@5020000 {
+                       compatible = "ti,j721e-serdes-10g";
+                       reg = <0x05020000 0x010000>;
+                       reg-names = "torrent_phy";
+                       resets = <&serdes_wiz2 0>;
+                       reset-names = "torrent_reset";
+                       clocks = <&serdes_wiz2 TI_WIZ_PLL0_REFCLK>,
+                                <&serdes_wiz2 TI_WIZ_PHY_EN_REFCLK>;
+                       clock-names = "refclk", "phy_en_refclk";
+                       assigned-clocks = <&serdes_wiz2 TI_WIZ_PLL0_REFCLK>,
+                                         <&serdes_wiz2 TI_WIZ_PLL1_REFCLK>,
+                                         <&serdes_wiz2 TI_WIZ_REFCLK_DIG>;
+                       assigned-clock-parents = <&k3_clks 406 6>,
+                                                <&k3_clks 406 6>,
+                                                <&k3_clks 406 6>;
+                       #address-cells = <1>;
+                       #size-cells = <0>;
+                       #clock-cells = <1>;
+                       status = "disabled";
+               };
+       };
+
+       serdes_wiz4: wiz@5050000 {
+               compatible = "ti,j784s4-wiz-10g";
+               #address-cells = <1>;
+               #size-cells = <1>;
+               power-domains = <&k3_pds 407 TI_SCI_PD_EXCLUSIVE>;
+               clocks = <&k3_clks 407 2>, <&k3_clks 407 6>, <&serdes_refclk>, <&k3_clks 407 5>;
+               clock-names = "fck", "core_ref_clk", "ext_ref_clk", "core_ref1_clk";
+               assigned-clocks = <&k3_clks 407 6>;
+               assigned-clock-parents = <&k3_clks 407 10>;
+               num-lanes = <4>;
+               #reset-cells = <1>;
+               #clock-cells = <1>;
+               ranges = <0x05050000 0x00 0x05050000 0x10000>,
+                        <0xa030a00 0x00 0xa030a00 0x40>; /* DPTX PHY */
+               status = "disabled";
+
+               serdes4: serdes@5050000 {
+                       /*
+                        * Note: we also map DPTX PHY registers as the Torrent
+                        * needs to manage those.
+                        */
+                       compatible = "ti,j721e-serdes-10g";
+                       reg = <0x05050000 0x010000>,
+                             <0x0a030a00 0x40>; /* DPTX PHY */
+                       reg-names = "torrent_phy";
+                       resets = <&serdes_wiz4 0>;
+                       reset-names = "torrent_reset";
+                       clocks = <&serdes_wiz4 TI_WIZ_PLL0_REFCLK>,
+                                <&serdes_wiz4 TI_WIZ_PHY_EN_REFCLK>;
+                       clock-names = "refclk", "phy_en_refclk";
+                       assigned-clocks = <&serdes_wiz4 TI_WIZ_PLL0_REFCLK>,
+                                         <&serdes_wiz4 TI_WIZ_PLL1_REFCLK>,
+                                         <&serdes_wiz4 TI_WIZ_REFCLK_DIG>;
+                       assigned-clock-parents = <&k3_clks 407 6>,
+                                                <&k3_clks 407 6>,
+                                                <&k3_clks 407 6>;
+                       #address-cells = <1>;
+                       #size-cells = <0>;
+                       #clock-cells = <1>;
+                       status = "disabled";
+               };
+       };
+
        main_navss: bus@30000000 {
                bootph-all;
                compatible = "simple-bus";