From: Maxime Chevallier <maxime.chevallier@bootlin.com>
To: Wei Fang <wei.fang@nxp.com>
Cc: "imx@lists.linux.dev" <imx@lists.linux.dev>,
"netdev@vger.kernel.org" <netdev@vger.kernel.org>,
"linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>,
"andrew@lunn.ch" <andrew@lunn.ch>,
"hkallweit1@gmail.com" <hkallweit1@gmail.com>,
"linux@armlinux.org.uk" <linux@armlinux.org.uk>,
"davem@davemloft.net" <davem@davemloft.net>,
"edumazet@google.com" <edumazet@google.com>,
"kuba@kernel.org" <kuba@kernel.org>,
"pabeni@redhat.com" <pabeni@redhat.com>,
"florian.fainelli@broadcom.com" <florian.fainelli@broadcom.com>,
"xiaolei.wang" <xiaolei.wang@windriver.com>,
"quic_abchauha@quicinc.com" <quic_abchauha@quicinc.com>,
"quic_sarohasa@quicinc.com" <quic_sarohasa@quicinc.com>
Subject: Re: [PATCH net] net: phy: add device link between MAC device and MDIO device
Date: Thu, 29 Jan 2026 11:18:16 +0100 [thread overview]
Message-ID: <7c37c518-fb6d-4f78-8e83-663e2518e5fd@bootlin.com> (raw)
In-Reply-To: <PAXPR04MB85100B7C2C6738CEA80C3C7D889EA@PAXPR04MB8510.eurprd04.prod.outlook.com>
On 29/01/2026 11:00, Wei Fang wrote:
>>> @@ -1768,12 +1768,21 @@ int phy_attach_direct(struct net_device *dev,
>> struct phy_device *phydev,
>>>
>>> /**
>>> * If the external phy used by current mac interface is managed by
>>> - * another mac interface, so we should create a device link between
>>> - * phy dev and mac dev.
>>> + * another MDIO controller, which means that the MAC and MDIO are
>>> + * separated devices, then we should create a device link between
>>> + * the MAC device and the MDIO device.
>>> */
>>
>> I was confused by the use of the "MDIO device" terminology here, which
>> refers to a device sitting on an mdio bus, such as a PHY. I think though
>> that what you actually refer to is the MDIO controller itself, right ?
>
> Yes, you are right, I was referring to the MDIO controller.
>
>>
>>> - if (dev && phydev->mdio.bus->parent && dev->dev.parent !=
>> phydev->mdio.bus->parent)
>>> - phydev->devlink = device_link_add(dev->dev.parent,
>> &phydev->mdio.dev,
>>> - DL_FLAG_PM_RUNTIME |
>> DL_FLAG_STATELESS);
>>> + if (dev && phydev->mdio.bus->parent &&
>>> + dev->dev.parent != phydev->mdio.bus->parent) {
>>> + if (!device_link_add(dev->dev.parent, phydev->mdio.bus->parent,
>>> + DL_FLAG_PM_RUNTIME |
>>> + DL_FLAG_AUTOREMOVE_SUPPLIER)) {
>>
>> Don't we have the same problem with SFP ? The struct mii_bus for SFP
>> PHYs also completely disappears when you remove the module.
>
> Sorry, I'm not familiar with SFP and I do not have a board with SPF
> module. So I'm not sure whether the MDIO bus will be removed if
> the SFP module is unplugged. But if the multiple SPF modules share
> the same MDIO controller, unplugging one SFP module will cause the
> MDIO bus to be removed. Won't this cause the other SFP modules to
> stop working?
For SFP, it's not a physical mdiobus that connects to the SFP module, but
rather an i2c bus. When the module is inserted, we create an mdiobus that
will perform the mdio transfers over i2c :
https://elixir.bootlin.com/linux/v6.19-rc5/source/drivers/net/mdio/mdio-i2c.c#L461
The mdio bus is created when the SFP module is inserted, and we found a
PHY device in it :
https://elixir.bootlin.com/linux/v6.19-rc5/source/drivers/net/phy/sfp.c#L791
It is dynamically created and destroyed, its lifetime isn't correlated to
the netdevice.
>
>>
>> That being said, I ran some tests with SFP and this patch, and the
>> netdev actually didn't dissapear under my feet.
>>
>> I'm a total noob with fw_devlink, but I can see there seems to already
>> be a link between MAC devices and the associated SFP bus :
>>
>> on cyclone V :
>>
>> # ls /sys/class/devlink
>> [...]
>> platform:sfp--platform:ff702000.ethernet
>>
>> on macchiatobin :
>>
>> # ls /sys/class/devlink
>> [...]
>> platform:sfp-eth3--platform:f4000000.ethernet
>>
>> So I guess this is what's preventing the netdev from going away.
>>
>> Now, these seems to be automagically populated based on DT, but I don't
>> know if it also works with non-DT platforms. If this is DT-specific,
>> then I guess we still can't use DL_FLAG_AUTOREMOVE_SUPPLIER.
>>
>
> Previously, when Sorash attempted to add
> DL_FLAG_AUTOREMOVE_SUPPLIER to the devlink between the MAC
> controller and the PHY, you reported that unplugging the PHY would
> cause the MAC to be removed as well, resulting in system hangs.
>
> https://lore.kernel.org/imx/20250704142138.3f1a4ec1@fedora.home/
>
> If your guess is correct, removing the SPF module will cause the
> MDIO bus to be removed, then I think the MAC driver should also
> be removed. Therefore, based on this patch, you should be able
> to reproduce the same problem caused by the Sorash's patch.
> However, your current results seem different from before. Perhaps
> the MDIO bus was not removed along with the SFP module.
>
It is removed :
https://elixir.bootlin.com/linux/v6.19-rc5/source/drivers/net/phy/sfp.c#L2648
This line above is called when we unplug the SFP module.
What I am seeing is that there are other devlink links that apply to
the net_device, unrelated to the MDIO bus, at least on the devices I am
testing this on, and they prevent the net_device from going away.
One of these devlinks is a link between the sfp cage (compatible "sff,sfp") and
the netdev. This devlink seems to be automatically populated when OF is
parsed.
To solve this, I think we need something more granular that this approach,
and make a distinction between when it's OK for a phy_device to dissapear
when attached to a MAC (SFP phys), and when it's not (PHYs hardwired to
the MAC).
Adding this devlink in phy_attach_direct() is too generic IMO. It's likely
that this link should be populated by phylink then.
Maxime
next prev parent reply other threads:[~2026-01-29 10:18 UTC|newest]
Thread overview: 15+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-01-26 10:44 [PATCH net] net: phy: add device link between MAC device and MDIO device Wei Fang
2026-01-26 14:13 ` Andrew Lunn
2026-01-26 14:19 ` Russell King (Oracle)
2026-01-27 3:01 ` Wei Fang
2026-01-29 4:15 ` Jakub Kicinski
2026-01-29 10:06 ` Russell King (Oracle)
2026-01-30 3:41 ` Wei Fang
2026-01-30 8:29 ` Maxime Chevallier
2026-01-30 8:45 ` Wei Fang
2026-01-30 9:12 ` Maxime Chevallier
2026-01-30 10:09 ` Wei Fang
2026-01-29 9:10 ` Maxime Chevallier
2026-01-29 10:00 ` Wei Fang
2026-01-29 10:18 ` Maxime Chevallier [this message]
2026-01-29 10:47 ` Wei Fang
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=7c37c518-fb6d-4f78-8e83-663e2518e5fd@bootlin.com \
--to=maxime.chevallier@bootlin.com \
--cc=andrew@lunn.ch \
--cc=davem@davemloft.net \
--cc=edumazet@google.com \
--cc=florian.fainelli@broadcom.com \
--cc=hkallweit1@gmail.com \
--cc=imx@lists.linux.dev \
--cc=kuba@kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux@armlinux.org.uk \
--cc=netdev@vger.kernel.org \
--cc=pabeni@redhat.com \
--cc=quic_abchauha@quicinc.com \
--cc=quic_sarohasa@quicinc.com \
--cc=wei.fang@nxp.com \
--cc=xiaolei.wang@windriver.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox