mirror of
https://github.com/openwrt/openwrt.git
synced 2026-04-23 17:58:43 +04:00
This corrects the WRV54G device tree and adds patches for MI424WR alongh with GPIO MMIO support for the same. Link: https://github.com/openwrt/openwrt/pull/20066 Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
157 lines
3.9 KiB
Diff
157 lines
3.9 KiB
Diff
From c9cc6b6a7d23eea7ada69a9185a550c4f0b62319 Mon Sep 17 00:00:00 2001
|
|
From: Linus Walleij <linus.walleij@linaro.org>
|
|
Date: Wed, 25 Jun 2025 08:51:25 +0200
|
|
Subject: [PATCH] ARM: dts: Fix up wrv54g device tree
|
|
|
|
Fix up the KS8995 switch and PHYs the way that is most likely:
|
|
|
|
- Phy 1-4 is certainly the PHYs of the KS8995 (mask 0x1e in
|
|
the outoftree code masks PHYs 1,2,3,4).
|
|
- Phy 5 is the MII-P5 separate WAN phy of the KS8995 directly
|
|
connected to EthC.
|
|
- The EthB MII is probably connected as CPU interface to the
|
|
KS8995.
|
|
|
|
Properly integrate the KS8995 switch using the new bindings.
|
|
|
|
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
|
|
Reviewed-by: Andrew Lunn <andrew@lunn.ch>
|
|
Link: https://patch.msgid.link/20250625-ks8995-dsa-bindings-v2-2-ce71dce9be0b@linaro.org
|
|
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
|
|
---
|
|
.../intel/ixp/intel-ixp42x-linksys-wrv54g.dts | 92 ++++++++++++++++---
|
|
1 file changed, 78 insertions(+), 14 deletions(-)
|
|
|
|
--- a/arch/arm/boot/dts/intel/ixp/intel-ixp42x-linksys-wrv54g.dts
|
|
+++ b/arch/arm/boot/dts/intel/ixp/intel-ixp42x-linksys-wrv54g.dts
|
|
@@ -72,10 +72,55 @@
|
|
cs-gpios = <&gpio0 5 GPIO_ACTIVE_LOW>;
|
|
num-chipselects = <1>;
|
|
|
|
- switch@0 {
|
|
+ ethernet-switch@0 {
|
|
compatible = "micrel,ks8995";
|
|
reg = <0>;
|
|
spi-max-frequency = <50000000>;
|
|
+
|
|
+ /*
|
|
+ * The PHYs are accessed over the external MDIO
|
|
+ * bus and not internally through the switch control
|
|
+ * registers.
|
|
+ */
|
|
+ ethernet-ports {
|
|
+ #address-cells = <1>;
|
|
+ #size-cells = <0>;
|
|
+
|
|
+ ethernet-port@0 {
|
|
+ reg = <0>;
|
|
+ label = "1";
|
|
+ phy-mode = "mii";
|
|
+ phy-handle = <&phy1>;
|
|
+ };
|
|
+ ethernet-port@1 {
|
|
+ reg = <1>;
|
|
+ label = "2";
|
|
+ phy-mode = "mii";
|
|
+ phy-handle = <&phy2>;
|
|
+ };
|
|
+ ethernet-port@2 {
|
|
+ reg = <2>;
|
|
+ label = "3";
|
|
+ phy-mode = "mii";
|
|
+ phy-handle = <&phy3>;
|
|
+ };
|
|
+ ethernet-port@3 {
|
|
+ reg = <3>;
|
|
+ label = "4";
|
|
+ phy-mode = "mii";
|
|
+ phy-handle = <&phy4>;
|
|
+ };
|
|
+ ethernet-port@4 {
|
|
+ reg = <4>;
|
|
+ ethernet = <ðb>;
|
|
+ phy-mode = "mii";
|
|
+ fixed-link {
|
|
+ speed = <100>;
|
|
+ full-duplex;
|
|
+ };
|
|
+ };
|
|
+
|
|
+ };
|
|
};
|
|
};
|
|
|
|
@@ -135,40 +180,59 @@
|
|
};
|
|
|
|
/*
|
|
- * EthB - connected to the KS8995 switch ports 1-4
|
|
- * FIXME: the boardfile defines .phy_mask = 0x1e for this port to enable output to
|
|
- * all four switch ports, also using an out of tree multiphy patch.
|
|
- * Do we need a new binding and property for this?
|
|
+ * EthB connects to the KS8995 CPU port and faces ports 1-4
|
|
+ * through the switch fabric.
|
|
+ *
|
|
+ * To complicate things, the MDIO channel is also only
|
|
+ * accessible through EthB, but used independently for PHY
|
|
+ * control.
|
|
*/
|
|
- ethernet@c8009000 {
|
|
+ ethb: ethernet@c8009000 {
|
|
status = "okay";
|
|
queue-rx = <&qmgr 3>;
|
|
queue-txready = <&qmgr 20>;
|
|
- phy-mode = "rgmii";
|
|
- phy-handle = <&phy4>;
|
|
+ phy-mode = "mii";
|
|
+ fixed-link {
|
|
+ speed = <100>;
|
|
+ full-duplex;
|
|
+ };
|
|
|
|
mdio {
|
|
#address-cells = <1>;
|
|
#size-cells = <0>;
|
|
|
|
- /* Should be ports 1-4 on the KS8995 switch */
|
|
+ /*
|
|
+ * LAN ports 1-4 on the KS8995 switch
|
|
+ * and PHY5 for WAN need to be accessed
|
|
+ * through this external MDIO channel.
|
|
+ */
|
|
+ phy1: ethernet-phy@1 {
|
|
+ reg = <1>;
|
|
+ };
|
|
+ phy2: ethernet-phy@2 {
|
|
+ reg = <2>;
|
|
+ };
|
|
+ phy3: ethernet-phy@3 {
|
|
+ reg = <3>;
|
|
+ };
|
|
phy4: ethernet-phy@4 {
|
|
reg = <4>;
|
|
};
|
|
-
|
|
- /* Should be port 5 on the KS8995 switch */
|
|
phy5: ethernet-phy@5 {
|
|
reg = <5>;
|
|
};
|
|
};
|
|
};
|
|
|
|
- /* EthC - connected to KS8995 switch port 5 */
|
|
- ethernet@c800a000 {
|
|
+ /*
|
|
+ * EthC connects to MII-P5 on the KS8995 bypassing
|
|
+ * all of the switch logic and facing PHY5
|
|
+ */
|
|
+ ethc: ethernet@c800a000 {
|
|
status = "okay";
|
|
queue-rx = <&qmgr 4>;
|
|
queue-txready = <&qmgr 21>;
|
|
- phy-mode = "rgmii";
|
|
+ phy-mode = "mii";
|
|
phy-handle = <&phy5>;
|
|
};
|
|
};
|