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. On Thu, Apr 25, 2024 at 09:15:54PM +0100, Russell King (Oracle) wrote: > On Thu, Apr 25, 2024 at 07:33:59PM +0200, Stefan Eichenberger wrote: > > Now I got it, thanks a lot for the explanation. So the issue is that > > MLO_AN_INBAND + PHYLINK_PCS_NEG_OUTBAND is happening in my use case and > > therefore the link is not forced up because for that MLO_AN_PHY would be > > needed. I will also try to think about it. > > Now that I've moved the setting of PortType and InBandAutoNegMode into > the pcs_config() method, I now have (on mvneta): > > Value at address 0xf1036c00: 0x00008bfd - PortType = 0 > (SGMII, necessary to be able > to set InBandAnEn=0 below) > > Value at address 0xf1036c08: 0x0000c018 - InBandAutoNegMode = 0 > (1000Base-X mode) > > Value at address 0xf1036c0c: 0x00009240 - 1000M, FD, unforced link > InBandAnEn = 0 > > Value at address 0xf1036c10: 0x0000600a - Sync, 1000M, FD, but no link > > The reason that the link isn't being forced is because > mvneta_mac_link_up() is being called with mode = MLO_AN_INBAND > which expects the link to be controlled as a result of autoneg, > but we've configured autoneg to be off. > > I'm wondering whether we need pl->cur_link_an_mode to be the desired > mode for selecting the result from phylink_pcs_neg_mode(), but also > maintain a separate pl->act_link_an_mode which phylink_pcs_neg_mode() > chooses, dependent on whether the PCS is using inband or outband > mode - and pl->act_link_an_mode is what gets passed to the MAC layer. > That would at least keep the MAC MLO_AN_* consistent with what the > PCS layer is using - and also has the advantage that it makes it > clear that pl->act_link_an_mode only gets updated in the "major > config" path. > > A quick test of that... seems to work: > > mvneta f1034000.ethernet eno2: PHY [i2c:sfp:16] driver [Broadcom BCM84881] (irq=POLL) > mvneta f1034000.ethernet eno2: phy: 2500base-x setting supported 00,00000000,00008000,0000206c advertising 00,00000000,00008000,0000206c > mvneta f1034000.ethernet eno2: major config 2500base-x > mvneta f1034000.ethernet eno2: link modes: pcs=02 phy=01 > mvneta f1034000.ethernet eno2: phylink_mac_config: mode=inband/2500base-x/none adv=00,00000000,00008000,0000206c pause=04 > mvneta f1034000.ethernet eno2: phylink_sfp_module_start() > mvneta f1034000.ethernet eno2: phylink_sfp_link_up() > mvneta f1034000.ethernet eno2: phy link down 2500base-x/Unknown/Unknown/none/off > mvneta f1034000.ethernet eno2: phy link up sgmii/1Gbps/Full/none/off > mvneta f1034000.ethernet eno2: major config sgmii > mvneta f1034000.ethernet eno2: link modes: pcs=03 phy=01 > mvneta f1034000.ethernet eno2: phylink_mac_config: mode=phy/sgmii/none adv=00,00000000,00008000,0000206c pause=00 > mvneta f1034000.ethernet eno2: pcs link down > mvneta f1034000.ethernet eno2: pcs link down > mvneta f1034000.ethernet eno2: can LPI, EEE enabled, active > mvneta f1034000.ethernet eno2: enabling tx_lpi, timer 250us > mvneta f1034000.ethernet eno2: Link is Up - 1Gbps/Full - flow control off > > Value at address 0xf1036c00: 0x00008bfd > Value at address 0xf1036c08: 0x0000c018 > Value at address 0xf1036c0c: 0x00009242 > Value at address 0xf1036c10: 0x0000600b > > So we can see in the two phylink_mac_config calls that the mode has > switched from "inband" to "phy" with this PHY (BCM84881) which > doesn't support inband in any interface modes. > > However, there's still the issue with: > > link modes: pcs=02 phy=01 > phylink_mac_config: mode=inband/2500base-x/none adv=00,00000000,00008000,0000206c pause=04 > > and this is because of the missing code in this part: > > /* PHY present, inband mode depends on the capabilities > * of both. > */ > > but there's also the issue that the PCS and PHY capabilities like that > are incompatible. In this case, we're saved by the fact that if we do > this act_link_an_mode thing: > > pl->act_link_an_mode = pl->cur_link_an_mode; > if (pl->pcs_neg_mode == PHYLINK_PCS_NEG_OUTBAND && > pl->act_link_an_mode == MLO_AN_INBAND) > pl->act_link_an_mode = MLO_AN_PHY; > > coupled with the new _behaviour_ of mvneta/mvpp2, we don't actually > end up in the "1000base-X must have AN enabled" trap... but that is > no basis to basing decisions at the phylink layer on. > > So, I'm wondering whether we need to be a little more creative here. > Instead of simply passing a few bits, maybe something like: > > 31-24: bitfield of "partner" capabilities that are supported > for inband enabled mode > 23-16: bitfield of "partner" capabilities that are supported > for inband disabled mode > 15-8: bitfield of "partner" capabilities that are supported > for outband mode > 2: bypass mode supported > 1: inband enabled mode supported > 0: inband disabled mode supported > > Now, a question will come up... what is different between inband > disabled and outband mode? > > Consider 1000base-X fibre. 1000base-X is the media interface, and we > need to be able to configure autoneg there, enabling or disabling it. > If we don't support disabling autoneg (as is the case with mvneta > et.al. over fibre) then being able to use ethtool to disable autoneg > can't be used. In both these modes, the 1000base-X is the media side. > > However, 1000base-X can be used to connect to a PHY, and the PHY > could do rate matching, so the we need to use an outband way to > access the media side (we need to talk to the PHY.) > > Hence why PCS have a distinction between OUTBAND and INBAND_DISABLED. > > Now, with 2500base-X we run into the problem that e.g. mvneta > operating in 1000base-X mode upclocked to 2.5G can only support > INBAND_ENABLED and not INBAND_DISABLED (we can't just turn off the > InBandAnEn bit). The change between INBAND_ENABLED and INBAND_DISABLED > can happen with the link up. > > However, it can support OUTBAND by disabling the PortType bit and then > turning off InBandAnEn (which can only be done with the link *down* > and that is only guaranteed during a "major config" not through the > ethtool settings API - which is why pcs_config() can't do this for > INBAND_DISABLED.) > > So, a little bit of progress but not at a usable solution yet. > > I'm afraid my current tree is in a hacky mess at the moment, I'll see > about updating the published patches as soon as I can. 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: [ 14.695170] mvpp2 f2000000.ethernet eth1: PHY [f212a600.mdio-mii:11] driver [Maxlinear Ethernet GPY215C] (irq=POLL) [ 14.706541] mvpp2 f2000000.ethernet eth1: phy: sgmii setting supported 00,00000000,00008000,0000606f advertising 00,00000000,00008000,0000606f [ 14.707770] mvpp2 f2000000.ethernet eth1: configuring for phy/sgmii link mode [ 14.716437] mvpp2 f2000000.ethernet eth1: major config, requested phy/sgmii [ 14.723260] mvpp2 f2000000.ethernet eth1: firmware wants phy mode, but PHY requires inband [ 14.731623] mvpp2 f2000000.ethernet eth1: major config, active phy/outband/sgmii [ 14.731630] mvpp2 f2000000.ethernet eth1: phylink_mac_config: mode=phy/sgmii/none adv=00,00000000,00000000,00000000 pause=00 [ 14.733905] mvpp2 f2000000.ethernet eth1: phy link down sgmii/2.5Gbps/Full/none/rx/tx [ 18.825056] mvpp2 f2000000.ethernet eth1: phy link up 2500base-x/2.5Gbps/Full/none/rx/tx [ 18.825083] mvpp2 f2000000.ethernet eth1: major config, requested phy/2500base-x [ 18.831331] mvpp2 f2000000.ethernet eth1: major config, active phy/outband/2500base-x [ 18.832568] mvpp2 f2000000.ethernet eth1: phylink_mac_config: mode=phy/2500base-x/none adv=00,00000000,00000000,00000000 pause=03 [ 18.832638] mvpp2 f2000000.ethernet eth1: pcs link up [ 18.832905] mvpp2 f2000000.ethernet eth1: can LPI, EEE enabled, inactive [ 18.832936] mvpp2 f2000000.ethernet eth1: Link is Up - 2.5Gbps/Full - flow control rx/tx [ 60.808001] mvpp2 f2000000.ethernet eth1: phy link down 2500base-x/Unknown/Full/none/rx/tx [ 60.808038] mvpp2 f2000000.ethernet eth1: deactivating EEE, was inactive [ 60.808090] mvpp2 f2000000.ethernet eth1: pcs link down [ 60.809075] mvpp2 f2000000.ethernet eth1: Link is Down [ 62.857142] mvpp2 f2000000.ethernet eth1: phy link up sgmii/1Gbps/Full/none/rx/tx [ 62.857163] mvpp2 f2000000.ethernet eth1: major config, requested phy/sgmii [ 62.863412] mvpp2 f2000000.ethernet eth1: firmware wants phy mode, but PHY requires inband [ 62.871786] mvpp2 f2000000.ethernet eth1: major config, active phy/outband/sgmii [ 62.872987] mvpp2 f2000000.ethernet eth1: phylink_mac_config: mode=phy/sgmii/none adv=00,00000000,00000000,00000000 pause=03 [ 62.873059] mvpp2 f2000000.ethernet eth1: pcs link up [ 62.873362] mvpp2 f2000000.ethernet eth1: can LPI, EEE enabled, active [ 62.873379] mvpp2 f2000000.ethernet eth1: enabling tx_lpi, timer 250us [ 62.873414] mvpp2 f2000000.ethernet eth1: Link is Up - 1Gbps/Full - flow control rx/tx The problem is that the PCS continues to be in phy mode but the PHY driver currently only supports LINK_INBAND_ENABLE and SGMII for 1GBit/s. What I'm wondering is if it wouldn't make sense to adapt the phy driver to support MLO_AN_PHY in SGMII/1000BASE-X mode. However, I don't know how I could do this because I can't get the information in the PHY driver (I can't use phylink_autoneg_inband to querry if inband should be enabled or disabled). I know we would still have the problem you described above. However, it would allow us to configure the phy to what phylink decided works best. Maybe this would also solve other issues where e.g. the PCS is not as flexible as it is for mvpp2 and mvneta? Currently the mxl-gpy phy driver can only support: 10/100/1000 MBit/s: SGMII with MLO_AN_INBAND 2500MBit/s 2500Base-X with MLO_AN_PHY However, the PHY would also support the following mode: 10/100/1000 MBit/s: SGMII with MLO_AN_PHY I just don't know how the PHY driver could know about what it should configure. Regards, Stefan