openwrt/target/linux/layerscape/patches-5.4/302-dts-0112-arm64-dts-fsl-ls1028a-prepare-dts-for-overlay.patch
Hauke Mehrtens 9501ce909f layerscape: Fix build in dtb
This fixes a kernel build problem.
The removed parts of the patch are already applied upstream.

Fixes: 9ad3ef27b9 ("kernel: bump 5.4 to 5.4.153")
Signed-off-by: Hauke Mehrtens <hauke@hauke-m.de>
2021-10-22 22:12:24 +02:00

453 lines
9.8 KiB
Diff

From a5009b362d65c24e7b2a40824e351903d75a47dc Mon Sep 17 00:00:00 2001
From: Alex Marginean <alexandru.marginean@nxp.com>
Date: Mon, 6 Jan 2020 16:36:44 +0200
Subject: [PATCH] arm64: dts: fsl-ls1028a: prepare dts for overlay
Named the ports node of the Felix Eth switch so it can be used in DT
overlays to associate the ports with proper PHYs.
Ports are now by default disabled in dtsi, so if the board dts doesn't
do anything about them they stay disabled.
Updated RDB and QDS dts files to match.
Replaced all 'phy-connection-type' with 'phy-mode'.
The set-up for protocol 7777 on QDS was changed to a single quad port card
in slot 1. This requires a QDS board with no lane B rework and a AQR412
or similar PHY card without any lane rework done on it.
Signed-off-by: Alex Marginean <alexandru.marginean@nxp.com>
---
.../boot/dts/freescale/fsl-ls1028a-qds-7777.dtsi | 58 ++++++++++-----------
.../boot/dts/freescale/fsl-ls1028a-qds-9999.dtsi | 59 ++++++++++------------
.../boot/dts/freescale/fsl-ls1028a-qds-x3xx.dtsi | 51 ++++++++++++-------
.../boot/dts/freescale/fsl-ls1028a-qds-x5xx.dtsi | 43 ++++++++++------
arch/arm64/boot/dts/freescale/fsl-ls1028a-rdb.dts | 44 +++++++++-------
arch/arm64/boot/dts/freescale/fsl-ls1028a.dtsi | 27 +++++++---
6 files changed, 161 insertions(+), 121 deletions(-)
--- a/arch/arm64/boot/dts/freescale/fsl-ls1028a-qds-7777.dtsi
+++ b/arch/arm64/boot/dts/freescale/fsl-ls1028a-qds-7777.dtsi
@@ -7,50 +7,50 @@
*/
&mdio_slot1 {
- /* two ports on AQR412 */
- slot1_sxgmii2: ethernet-phy@2 {
- reg = <0x2>;
+ slot1_sxgmii0: ethernet-phy@0 {
+ reg = <0x0>;
compatible = "ethernet-phy-ieee802.3-c45";
};
- slot1_sxgmii3: ethernet-phy@3 {
- reg = <0x3>;
+
+ slot1_sxgmii1: ethernet-phy@1 {
+ reg = <0x1>;
compatible = "ethernet-phy-ieee802.3-c45";
};
-};
-&mdio_slot2 {
- slot2_sxgmii0: ethernet-phy@2 {
- /* AQR112 */
+ slot1_sxgmii2: ethernet-phy@2 {
reg = <0x2>;
compatible = "ethernet-phy-ieee802.3-c45";
};
-};
-&mdio_slot3 {
- slot3_sxgmii0: ethernet-phy@2 {
- /* AQR112 */
- reg = <0x2>;
+ slot1_sxgmii3: ethernet-phy@3 {
+ reg = <0x3>;
compatible = "ethernet-phy-ieee802.3-c45";
};
};
/* l2switch ports */
-&switch_port0 {
- phy-handle = <&slot1_sxgmii2>;
- phy-connection-type = "2500base-x";
-};
+&mscc_felix_ports {
+ port@0 {
+ status = "okay";
+ phy-handle = <&slot1_sxgmii0>;
+ phy-mode = "2500base-x";
+ };
-&switch_port1 {
- phy-handle = <&slot2_sxgmii0>;
- phy-connection-type = "2500base-x";
-};
+ port@1 {
+ status = "okay";
+ phy-handle = <&slot1_sxgmii1>;
+ phy-mode = "2500base-x";
+ };
-&switch_port2 {
- phy-handle = <&slot3_sxgmii0>;
- phy-connection-type = "2500base-x";
-};
+ port@2 {
+ status = "okay";
+ phy-handle = <&slot1_sxgmii2>;
+ phy-mode = "2500base-x";
+ };
-&switch_port3 {
- phy-handle = <&slot1_sxgmii3>;
- phy-connection-type = "2500base-x";
+ port@3 {
+ status = "okay";
+ phy-handle = <&slot1_sxgmii3>;
+ phy-mode = "2500base-x";
+ };
};
--- a/arch/arm64/boot/dts/freescale/fsl-ls1028a-qds-9999.dtsi
+++ b/arch/arm64/boot/dts/freescale/fsl-ls1028a-qds-9999.dtsi
@@ -11,50 +11,47 @@
slot1_sgmii0: ethernet-phy@1c {
reg = <0x1c>;
};
+
slot1_sgmii1: ethernet-phy@1d {
reg = <0x1d>;
};
+
slot1_sgmii2: ethernet-phy@1e {
reg = <0x1e>;
};
- slot1_sgmii3: ethernet-phy@1f {
- reg = <0x1f>;
- };
-};
-&mdio_slot2 {
- /* VSC8234 */
- slot2_sgmii0: ethernet-phy@1c {
- reg = <0x1c>;
- };
- slot2_sgmii1: ethernet-phy@1d {
- reg = <0x1d>;
- };
- slot2_sgmii2: ethernet-phy@1e {
- reg = <0x1e>;
- };
- slot2_sgmii3: ethernet-phy@1f {
+ slot1_sgmii3: ethernet-phy@1f {
reg = <0x1f>;
};
};
/* l2switch ports */
-&switch_port0 {
- phy-handle = <&slot1_sgmii0>;
- phy-connection-type = "sgmii";
-};
+&mscc_felix_ports {
+ port@0 {
+ status = "okay";
+ phy-handle = <&slot1_sgmii0>;
+ phy-mode = "sgmii";
+ managed = "in-band-status";
+ };
-&switch_port1 {
- phy-handle = <&slot2_sgmii0>;
- phy-connection-type = "sgmii";
-};
+ port@1 {
+ status = "okay";
+ phy-handle = <&slot1_sgmii1>;
+ phy-mode = "sgmii";
+ managed = "in-band-status";
+ };
-&switch_port2 {
- phy-handle = <&slot1_sgmii2>;
- phy-connection-type = "sgmii";
-};
+ port@2 {
+ status = "okay";
+ phy-handle = <&slot1_sgmii2>;
+ phy-mode = "sgmii";
+ managed = "in-band-status";
+ };
-&switch_port3 {
- phy-handle = <&slot1_sgmii3>;
- phy-connection-type = "sgmii";
+ port@3 {
+ status = "okay";
+ phy-handle = <&slot1_sgmii3>;
+ phy-mode = "sgmii";
+ managed = "in-band-status";
+ };
};
--- a/arch/arm64/boot/dts/freescale/fsl-ls1028a-qds-x3xx.dtsi
+++ b/arch/arm64/boot/dts/freescale/fsl-ls1028a-qds-x3xx.dtsi
@@ -8,41 +8,54 @@
&mdio_slot2 {
/* 4 ports on AQR412 */
- slot2_qsgmii0: ethernet-phy@0 {
+ slot2_qxgmii0: ethernet-phy@0 {
reg = <0x0>;
compatible = "ethernet-phy-ieee802.3-c45";
};
- slot2_qsgmii1: ethernet-phy@1 {
+
+ slot2_qxgmii1: ethernet-phy@1 {
reg = <0x1>;
compatible = "ethernet-phy-ieee802.3-c45";
};
- slot2_qsgmii2: ethernet-phy@2 {
+
+ slot2_qxgmii2: ethernet-phy@2 {
reg = <0x2>;
compatible = "ethernet-phy-ieee802.3-c45";
};
- slot2_qsgmii3: ethernet-phy@3 {
+
+ slot2_qxgmii3: ethernet-phy@3 {
reg = <0x3>;
compatible = "ethernet-phy-ieee802.3-c45";
};
};
/* l2switch ports */
-&switch_port0 {
- phy-handle = <&slot2_qsgmii0>;
- phy-connection-type = "usxgmii";
-};
+&mscc_felix_ports {
+ port@0 {
+ status = "okay";
+ phy-handle = <&slot2_qxgmii0>;
+ phy-mode = "usxgmii";
+ managed = "in-band-status";
+ };
-&switch_port1 {
- phy-handle = <&slot2_qsgmii1>;
- phy-connection-type = "usxgmii";
-};
+ port@1 {
+ status = "okay";
+ phy-handle = <&slot2_qxgmii1>;
+ phy-mode = "usxgmii";
+ managed = "in-band-status";
+ };
-&switch_port2 {
- phy-handle = <&slot2_qsgmii2>;
- phy-connection-type = "usxgmii";
-};
+ port@2 {
+ status = "okay";
+ phy-handle = <&slot2_qxgmii2>;
+ phy-mode = "usxgmii";
+ managed = "in-band-status";
+ };
-&switch_port3 {
- phy-handle = <&slot2_qsgmii3>;
- phy-connection-type = "usxgmii";
+ port@3 {
+ status = "okay";
+ phy-handle = <&slot2_qxgmii3>;
+ phy-mode = "usxgmii";
+ managed = "in-band-status";
+ };
};
--- a/arch/arm64/boot/dts/freescale/fsl-ls1028a-qds-x5xx.dtsi
+++ b/arch/arm64/boot/dts/freescale/fsl-ls1028a-qds-x5xx.dtsi
@@ -11,34 +11,47 @@
slot2_qsgmii0: ethernet-phy@8 {
reg = <0x8>;
};
+
slot2_qsgmii1: ethernet-phy@9 {
reg = <0x9>;
};
+
slot2_qsgmii2: ethernet-phy@a {
reg = <0xa>;
};
+
slot2_qsgmii3: ethernet-phy@b {
reg = <0xb>;
};
};
/* l2switch ports */
-&switch_port0 {
- phy-handle = <&slot2_qsgmii0>;
- phy-connection-type = "qsgmii";
-};
+&mscc_felix_ports {
+ port@0 {
+ status = "okay";
+ phy-handle = <&slot2_qsgmii0>;
+ phy-mode = "qsgmii";
+ managed = "in-band-status";
+ };
-&switch_port1 {
- phy-handle = <&slot2_qsgmii1>;
- phy-connection-type = "qsgmii";
-};
+ port@1 {
+ status = "okay";
+ phy-handle = <&slot2_qsgmii1>;
+ phy-mode = "qsgmii";
+ managed = "in-band-status";
+ };
-&switch_port2 {
- phy-handle = <&slot2_qsgmii2>;
- phy-connection-type = "qsgmii";
-};
+ port@2 {
+ status = "okay";
+ phy-handle = <&slot2_qsgmii2>;
+ phy-mode = "qsgmii";
+ managed = "in-band-status";
+ };
-&switch_port3 {
- phy-handle = <&slot2_qsgmii3>;
- phy-connection-type = "qsgmii";
+ port@3 {
+ status = "okay";
+ phy-handle = <&slot2_qsgmii3>;
+ phy-mode = "qsgmii";
+ managed = "in-band-status";
+ };
};
--- a/arch/arm64/boot/dts/freescale/fsl-ls1028a-rdb.dts
+++ b/arch/arm64/boot/dts/freescale/fsl-ls1028a-rdb.dts
@@ -233,28 +233,34 @@
};
/* l2switch ports */
-&switch_port0 {
- phy-handle = <&qsgmii_phy1>;
- phy-connection-type = "qsgmii";
- managed = "in-band-status";
-};
+&mscc_felix_ports {
+ port@0 {
+ status = "okay";
+ phy-handle = <&qsgmii_phy1>;
+ phy-mode = "qsgmii";
+ managed = "in-band-status";
+ };
-&switch_port1 {
- phy-handle = <&qsgmii_phy2>;
- phy-connection-type = "qsgmii";
- managed = "in-band-status";
-};
+ port@1 {
+ status = "okay";
+ phy-handle = <&qsgmii_phy2>;
+ phy-mode = "qsgmii";
+ managed = "in-band-status";
+ };
-&switch_port2 {
- phy-handle = <&qsgmii_phy3>;
- phy-connection-type = "qsgmii";
- managed = "in-band-status";
-};
+ port@2 {
+ status = "okay";
+ phy-handle = <&qsgmii_phy3>;
+ phy-mode = "qsgmii";
+ managed = "in-band-status";
+ };
-&switch_port3 {
- phy-handle = <&qsgmii_phy4>;
- phy-connection-type = "qsgmii";
- managed = "in-band-status";
+ port@3 {
+ status = "okay";
+ phy-handle = <&qsgmii_phy4>;
+ phy-mode = "qsgmii";
+ managed = "in-band-status";
+ };
};
&sai4 {
--- a/arch/arm64/boot/dts/freescale/fsl-ls1028a.dtsi
+++ b/arch/arm64/boot/dts/freescale/fsl-ls1028a.dtsi
@@ -772,30 +772,39 @@
clocks = <&clockgen 2 3>;
little-endian;
};
- switch@0,5 {
+
+ ethernet-switch@0,5 {
reg = <0x000500 0 0 0 0>;
/* IEP INT_B */
interrupts = <GIC_SPI 95 IRQ_TYPE_LEVEL_HIGH>;
- ports {
+ mscc_felix_ports: ports {
#address-cells = <1>;
#size-cells = <0>;
/* external ports */
- switch_port0: port@0 {
+ mscc_felix_port0: port@0 {
reg = <0>;
+ status = "disabled";
};
- switch_port1: port@1 {
+
+ mscc_felix_port1: port@1 {
reg = <1>;
+ status = "disabled";
};
- switch_port2: port@2 {
+
+ mscc_felix_port2: port@2 {
reg = <2>;
+ status = "disabled";
};
- switch_port3: port@3 {
+
+ mscc_felix_port3: port@3 {
reg = <3>;
+ status = "disabled";
};
+
/* internal to-cpu ports */
- port@4 {
+ mscc_felix_port4: port@4 {
reg = <4>;
ethernet = <&enetc_port2>;
phy-mode = "gmii";
@@ -805,7 +814,8 @@
full-duplex;
};
};
- port@5 {
+
+ mscc_felix_port5: port@5 {
reg = <5>;
phy-mode = "gmii";
status = "disabled";
@@ -817,6 +827,7 @@
};
};
};
+
enetc_port3: ethernet@0,6 {
compatible = "fsl,enetc";
reg = <0x000600 0 0 0 0>;