summaryrefslogtreecommitdiffstats
path: root/arch/arm/boot/dts/sun7i-a20-hummingbird.dts
diff options
context:
space:
mode:
authorChen-Yu Tsai <wens@csie.org>2019-08-14 06:22:08 +0200
committerMaxime Ripard <maxime.ripard@bootlin.com>2019-08-23 09:14:48 +0200
commit968f2c9169399fce43c11a89cbf4ac697f86de6e (patch)
tree2be7690eae204ccb2620fc9f4635284648be3be7 /arch/arm/boot/dts/sun7i-a20-hummingbird.dts
parentarm64: dts: allwinner: Enable DDC regulator for Beelink GS1 (diff)
downloadlinux-968f2c9169399fce43c11a89cbf4ac697f86de6e.tar.xz
linux-968f2c9169399fce43c11a89cbf4ac697f86de6e.zip
ARM: dts: sunxi: Add mdio bus sub-node to GMAC
The DWMAC binding never supported having the Ethernet PHY node as a direct child to the controller, nor did it support the "phy" property as a way to specify which Ethernet PHY to use. What seemed to work was simply the implementation ignoring the "phy" property and instead probing all addresses on the MDIO bus and using the first available one. The recent switch from "phy" to "phy-handle" breaks the assumptions of the implementation, and does not match what the binding requires. The binding requires that if an MDIO bus is described, it shall be a sub-node with the "snps,dwmac-mdio" compatible string. Add a device node for the MDIO bus, and move the Ethernet PHY node under it. Also fix up the #address-cells and #size-cells properties where needed. Fixes: de332de26d19 ("ARM: dts: sunxi: Switch from phy to phy-handle") Signed-off-by: Chen-Yu Tsai <wens@csie.org> Signed-off-by: Maxime Ripard <maxime.ripard@bootlin.com>
Diffstat (limited to 'arch/arm/boot/dts/sun7i-a20-hummingbird.dts')
-rw-r--r--arch/arm/boot/dts/sun7i-a20-hummingbird.dts18
1 files changed, 10 insertions, 8 deletions
diff --git a/arch/arm/boot/dts/sun7i-a20-hummingbird.dts b/arch/arm/boot/dts/sun7i-a20-hummingbird.dts
index 322717cb0b9a..3def2a330598 100644
--- a/arch/arm/boot/dts/sun7i-a20-hummingbird.dts
+++ b/arch/arm/boot/dts/sun7i-a20-hummingbird.dts
@@ -104,14 +104,6 @@
phy-mode = "rgmii";
phy-supply = <&reg_gmac_vdd>;
status = "okay";
-
- phy1: ethernet-phy@1 {
- reg = <1>;
- reset-gpios = <&pio 0 17 GPIO_ACTIVE_LOW>; /* PA17 */
- reset-assert-us = <10000>;
- /* wait 1s after reset, otherwise fail to read phy id */
- reset-deassert-us = <1000000>;
- };
};
&i2c0 {
@@ -145,6 +137,16 @@
status = "okay";
};
+&gmac_mdio {
+ phy1: ethernet-phy@1 {
+ reg = <1>;
+ reset-gpios = <&pio 0 17 GPIO_ACTIVE_LOW>; /* PA17 */
+ reset-assert-us = <10000>;
+ /* wait 1s after reset, otherwise fail to read phy id */
+ reset-deassert-us = <1000000>;
+ };
+};
+
&mmc0 {
vmmc-supply = <&reg_vcc3v0>;
bus-width = <4>;