On 07/29/2018 06:40 PM, Andrew Lunn wrote: >> I am thinking about merging this into the switch driver, then we do not >> have to configure the dependency any more. > > Hi Hauke > > Are there any PHYs which are not part of the switch? The embedded PHYs are only connected to the switch in this SoC and on all other SoCs from this line I am aware of. > Making it part of the switch driver would make sense. Are there any > backwards compatibility issues? I don't actually see any boards in > mailine using the compatible strings. There is currently no device tree file added for any board in mainline. I would then prefer to add this to the switch driver. I have to make sure the firmware gets loaded before we scan the MDIO bus. When no FW is loaded they do not get detected. More recent SoC have more embedded Ethernet PHYs so I would like to support a variable number of these PHYs. The firmware is 64KBytes big and we have to load that into continuous memory which is then used by the PHY itself. When we are late in the boot process we could run into memory problems, most devices have 64MB or 128MB of RAM. How should the device tree binding should look like? Should I create an extra sub node: gswip: gswip@E108000 { #address-cells = <1>; #size-cells = <0>; compatible = "lantiq,xrx200-gswip"; reg = < 0xE108000 0x3000 /* switch */ 0xE10B100 0x70 /* mdio */ 0xE10B1D8 0x30 /* mii */ >; dsa,member = <0 0>; ports { #address-cells = <1>; #size-cells = <0>; port@0 { reg = <0>; label = "lan3"; phy-mode = "rgmii"; phy-handle = <&phy0>; }; .... }; mdio@0 { #address-cells = <1>; #size-cells = <0>; compatible = "lantiq,xrx200-mdio"; reg = <0>; phy0: ethernet-phy@0 { reg = <0x0>; }; .... }; # this would be the new part phys { gphy0: gphy@20 { compatible = "lantiq,xrx200a2x-gphy"; reg = <0x20 0x4>; rcu = <&rcu0>; resets = <&reset0 31 30>, <&reset1 7 7>; reset-names = "gphy", "gphy2"; clocks = <&pmu0 XRX200_PMU_GATE_GPHY>; lantiq,gphy-mode = <GPHY_MODE_GE>; }; .... }; }; > Another option would be to write an independent mdio driver, and make > firmware download part of that. That gives the advantage of supporting > PHYs which are not part of the switch. > > Andrew >