On Fri, May 03, 2024 at 11:41:03PM +0100, Russell King (Oracle) wrote: > On Fri, May 03, 2024 at 06:35:53PM +0200, Stefan Eichenberger wrote: > > On Thu, May 02, 2024 at 03:14:13PM +0100, Russell King (Oracle) wrote: > > > On Thu, May 02, 2024 at 03:44:24PM +0200, Stefan Eichenberger wrote: > > > > Hi Russell, > > > > > > > > Sorry for the late reply but I wanted to give you some update after > > > > testing with the latest version of your patches on net-queue. > > > > > > I've also been randomly distracted, and I've been meaning to ping you > > > to test some of the updates. > > > > > > http://git.armlinux.org.uk/cgit/linux-arm.git/log/?h=net-queue > > > > > > The current set begins with: > > > > > > "net: sfp-bus: constify link_modes to sfp_select_interface()" which is > > > now in net-next, then the patches between and including: > > > > > > "net: phylink: validate sfp_select_interface() returned interface" to > > > "net: phylink: clean up phylink_resolve()" > > > > > > That should get enough together for the PCS "neg" mode to be consistent > > > with what the MAC driver sees. > > > > > > The remaining bits that I still need to sort out is the contents of > > > phylink_pcs_neg_mode() for the 802.3z mode with PHY, and also working > > > out some way of handling the SGMII case where the PHY and PCS disagree > > > (one only supporting inband the other not supporting inband.) > > > > > > I'm not sure when I'll be able to get to that - things are getting > > > fairly chaotic again, meaning I have again less time to spend on > > > mainline... and I'd like to take some vacation time very soon (I really > > > need some time off!) > > > > No problem, I'm also quite busy at the moment and I have the workaround > > to test the hardware, so it is nothing urgent for me. > > > > > > I think I see the problem you are describing. > > > > > > > > When the driver starts it will negotiate MLO_AN_PHY based on the > > > > capabilities of the PHY and of the PCS. However when I switch to 1GBit/s > > > > it should switch to MLO_AN_INBAND but this does not work. Here the > > > > output of phylink: > > > > > > I'm designing this to work the other way - inband being able to fall > > > back to PHY (out of band) mode rather than PHY mode being able to fall > > > forwards to inband mode. > > > > I tested again with 89e0a87ef79db9f3ce879e9d977429ba89ca8229 and I think > > in my setup the problem is that it doesn't fall back to PHY mode but > > takes it as default mode. Here what happens when I have the mxl-gpy PHY > > connected to a 1000 GBit/s port: > > [ 9.331179] mvpp2 f2000000.ethernet eth1: Using firmware node mac address 00:51:82:11:22:02 > > [ 14.674836] mvpp2 f2000000.ethernet eth1: PHY f212a600.mdio-mii:11 doesn't supply possible interfaces > > [ 14.674853] mvpp2 f2000000.ethernet eth1: interface 2 (mii) rate match none supports 0-3,6,13-14 > > [ 14.674864] mvpp2 f2000000.ethernet eth1: interface 4 (sgmii) rate match none supports 0-3,5-6,13-14 > > [ 14.674871] mvpp2 f2000000.ethernet eth1: interface 9 (rgmii) rate match none supports 0-3,5-6,13-14 > > [ 14.674877] mvpp2 f2000000.ethernet eth1: interface 10 (rgmii-id) rate match none supports 0-3,5-6,13-14 > > [ 14.674883] mvpp2 f2000000.ethernet eth1: interface 11 (rgmii-rxid) rate match none supports 0-3,5-6,13-14 > > [ 14.674889] mvpp2 f2000000.ethernet eth1: interface 12 (rgmii-txid) rate match none supports 0-3,5-6,13-14 > > [ 14.674895] mvpp2 f2000000.ethernet eth1: interface 22 (1000base-x) rate match none supports 5-6,13-14 > > [ 14.674900] mvpp2 f2000000.ethernet eth1: interface 23 (2500base-x) rate match none supports 6,13-14,47 > > [ 14.674907] mvpp2 f2000000.ethernet eth1: PHY [f212a600.mdio-mii:11] driver [Maxlinear Ethernet GPY215C] (irq=POLL) > > [ 14.685444] mvpp2 f2000000.ethernet eth1: phy: 2500base-x setting supported 00,00000000,00008000,0000606f advertising 00,00000000,00008000,0000606f > > [ 14.686635] mvpp2 f2000000.ethernet eth1: configuring for phy/2500base-x link mode > > [ 14.694263] mvpp2 f2000000.ethernet eth1: major config, requested phy/2500base-x > > ^^^ > > You're still requesting (from firmware) for PHY mode, and phylink will > _always_ use out-of-band if firmware requests that. > > > [ 14.700402] mvpp2 f2000000.ethernet eth1: major config, active phy/outband/2500base-x > > So it uses PHY mode for 2500base-X, which is correct. > > > [ 17.768370] mvpp2 f2000000.ethernet eth1: major config, requested phy/sgmii > > Still requesting PHY mode with SGMII, which historically we've always > used out-of-band mode for, so we preserve that behaviour. > > > [ 17.774602] mvpp2 f2000000.ethernet eth1: firmware wants phy mode, but PHY requires inband > > So we complain about it with an error, because it is wrong... > > > [ 17.782976] mvpp2 f2000000.ethernet eth1: major config, active phy/outband/sgmii > > and we still try to use it (correctly, because that's what phylink > has always done in this case.) > > As I tried to explain, there is fall-back from MLO_AN_INBAND to > MLO_AN_PHY, but there won't be fall-forward from MLO_AN_PHY to > MLO_AN_INBAND. I still don't get it, sorry. So the mxl-gpy driver currently has two modes: 2500 MBit/s -> PHY_INTERFACE_MODE_2500BASEX -> (0 no inband) 1000 MBit/s -> PHY_INTERFACE_MODE_SGMII -> LINK_INBAND_ENABLE If I use this configureation it will not work because there is no fallback from MLO_AN_PHY to MLO_AN_INBAND. Now if I understand everyting correctly, this happens for 1000 MBit/s and SGMII because the firmware decides to use PHY mode. I modified the PHY driver to use 1000BASEX instead: 2500 MBit/s -> PHY_INTERFACE_MODE_2500BASEX -> (0 no inband) 1000 MBit/s -> PHY_INTERFACE_MODE_1000BASEX -> LINK_INBAND_ENABLE However, the same thing happens: [ 14.635831] mvpp2 f2000000.ethernet eth1: PHY [f212a600.mdio-mii:11] driver [Maxlinear Ethernet GPY215C] (irq=POLL) [ 14.646742] mvpp2 f2000000.ethernet eth1: phy: 2500base-x setting supported 00,00000000,00008000,0000606f advertising 00,00000000,00008000,0000606f [ 14.647986] mvpp2 f2000000.ethernet eth1: configuring for phy/2500base-x link mode [ 14.655784] mvpp2 f2000000.ethernet eth1: major config, requested phy/2500base-x [ 14.663313] mvpp2 f2000000.ethernet eth1: major config, active phy/outband/2500base-x [ 14.663323] mvpp2 f2000000.ethernet eth1: phylink_mac_config: mode=phy/2500base-x/none adv=00,00000000,00000000,00000000 pause=00 [ 14.666098] mvpp2 f2000000.ethernet eth1: phy link down 2500base-x/2.5Gbps/Full/none/rx/tx [ 18.760959] mvpp2 f2000000.ethernet eth1: phy link up 2500base-x/2.5Gbps/Full/none/rx/tx [ 18.760977] mvpp2 f2000000.ethernet eth1: pcs link up [ 18.761211] mvpp2 f2000000.ethernet eth1: can LPI, EEE enabled, inactive [ 18.761231] mvpp2 f2000000.ethernet eth1: Link is Up - 2.5Gbps/Full - flow control rx/tx [ 70.983936] mvpp2 f2000000.ethernet eth1: phy link down 2500base-x/Unknown/Full/none/rx/tx [ 70.983965] mvpp2 f2000000.ethernet eth1: deactivating EEE, was inactive [ 70.984017] mvpp2 f2000000.ethernet eth1: pcs link down [ 70.985000] mvpp2 f2000000.ethernet eth1: Link is Down [ 74.057088] mvpp2 f2000000.ethernet eth1: phy link up 1000base-x/1Gbps/Full/none/rx/tx [ 74.057109] mvpp2 f2000000.ethernet eth1: major config, requested phy/1000base-x [ 74.063342] mvpp2 f2000000.ethernet eth1: firmware wants phy mode, but PHY requires inband [ 74.071706] mvpp2 f2000000.ethernet eth1: major config, active phy/outband/1000base-x [ 74.072902] mvpp2 f2000000.ethernet eth1: phylink_mac_config: mode=phy/1000base-x/none adv=00,00000000,00000000,00000000 pause=03 [ 74.072976] mvpp2 f2000000.ethernet eth1: pcs link up [ 74.073225] mvpp2 f2000000.ethernet eth1: can LPI, EEE enabled, active [ 74.073245] mvpp2 f2000000.ethernet eth1: enabling tx_lpi, timer 250us [ 74.073279] mvpp2 f2000000.ethernet eth1: Link is Up - 1Gbps/Full - flow control rx/tx If I then request inband by setting managed = "in-band-status" in the device tree the logic will fail because there is not phydev and therefore the link will never be configured for phy mode (it falls back to "Legacy, so determine inband depending on the advertising bit"): [ 9.299037] mvpp2 f2000000.ethernet eth1: Using firmware node mac address 00:51:82:11:22:02 [ 14.586343] mvpp2 f2000000.ethernet eth1: configuring for inband/2500base-x link mode [ 14.595669] mvpp2 f2000000.ethernet eth1: major config, requested inband/2500base-x [ 14.631876] mvpp2 f2000000.ethernet eth1: major config, active inband/inband/an-enabled/2500base-x [ 14.631887] mvpp2 f2000000.ethernet eth1: phylink_mac_config: mode=inband/2500base-x/none adv=00,00000000,00008000,0000e240 pause=04 [ 14.633208] mvpp2 f2000000.ethernet eth1: pcs link up [ 14.633241] mvpp2 f2000000.ethernet eth1: can LPI, EEE enabled, inactive [ 14.633262] mvpp2 f2000000.ethernet eth1: Link is Up - 2.5Gbps/Full - flow control off [ 60.713862] mvpp2 f2000000.ethernet eth1: pcs link down [ 60.713947] mvpp2 f2000000.ethernet eth1: deactivating EEE, was inactive [ 60.714978] mvpp2 f2000000.ethernet eth1: Link is Down [ 60.720200] mvpp2 f2000000.ethernet eth1: pcs link up [ 60.720586] mvpp2 f2000000.ethernet eth1: can LPI, EEE enabled, inactive [ 60.720619] mvpp2 f2000000.ethernet eth1: Link is Up - 2.5Gbps/Full - flow control off [ 63.012413] mvpp2 f2000000.ethernet eth1: pcs link down [ 63.012444] mvpp2 f2000000.ethernet eth1: deactivating EEE, was inactive [ 63.013480] mvpp2 f2000000.ethernet eth1: Link is Down Or is there a way to configure the firmware to use inband by default but sill having a phydev device? For me it is not entirely clear which scenario should work for the mxl-gpy in the end? Scenario A: 2500 MBit/s -> PHY_INTERFACE_MODE_2500BASEX -> (0 no inband) 1000 MBit/s -> PHY_INTERFACE_MODE_SGMII -> LINK_INBAND_ENABLE Then I would need a way to tell that the default mode is inband but that there is still a phydev device available. Maybe this is possible and I simply don't know how to do it? Scenario B: 2500 MBit/s -> PHY_INTERFACE_MODE_2500BASEX -> LINK_INBAND_DISABLE 1000 MBit/s -> PHY_INTERFACE_MODE_1000BASEX -> LINK_INBAND_ENABLE Then the phylink logic should change the firmwares mode depending on the speed. Would this also work with 100MBit/s and 10MBit/s? Scenario C (which I understand is not wanted): 2500 MBit/s -> PHY_INTERFACE_MODE_2500BASEX -> (0 no inband) 1000 MBit/s -> PHY_INTERFACE_MODE_SGMII -> (0 no inband) This would already work but would require me to change the phy driver and is not the desired behaviour anyways. Sorry for my confusion, regards, Stefan