All of lore.kernel.org
 help / color / mirror / Atom feed
From: "Russell King (Oracle)" <linux@armlinux.org.uk>
To: Andrew Lunn <andrew@lunn.ch>
Cc: "Maxime Chevallier" <maxime.chevallier@bootlin.com>,
	"Jakub Kicinski" <kuba@kernel.org>,
	davem@davemloft.net, netdev@vger.kernel.org,
	linux-kernel@vger.kernel.org, thomas.petazzoni@bootlin.com,
	"Eric Dumazet" <edumazet@google.com>,
	"Paolo Abeni" <pabeni@redhat.com>,
	linux-arm-kernel@lists.infradead.org,
	"Christophe Leroy" <christophe.leroy@csgroup.eu>,
	"Herve Codina" <herve.codina@bootlin.com>,
	"Florian Fainelli" <f.fainelli@gmail.com>,
	"Heiner Kallweit" <hkallweit1@gmail.com>,
	"Vladimir Oltean" <vladimir.oltean@nxp.com>,
	"Köry Maincent" <kory.maincent@bootlin.com>,
	"Jesse Brandeburg" <jesse.brandeburg@intel.com>,
	"Marek Behún" <kabel@kernel.org>,
	"Piergiorgio Beruto" <piergiorgio.beruto@gmail.com>,
	"Oleksij Rempel" <o.rempel@pengutronix.de>,
	"Nicolò Veronese" <nicveronese@gmail.com>,
	"Simon Horman" <horms@kernel.org>,
	mwojtas@chromium.org, "Nathan Chancellor" <nathan@kernel.org>,
	"Antoine Tenart" <atenart@kernel.org>
Subject: Re: [PATCH net-next v13 05/13] net: ethtool: Allow passing a phy index for some commands
Date: Sun, 16 Jun 2024 17:07:08 +0100	[thread overview]
Message-ID: <Zm8NrEproHTPzo+O@shell.armlinux.org.uk> (raw)
In-Reply-To: <9dbd5b23-c59d-4200-ab9c-f8a9d736fea6@lunn.ch>

On Sun, Jun 16, 2024 at 05:21:25PM +0200, Andrew Lunn wrote:
> On Sun, Jun 16, 2024 at 06:02:31PM +0200, Maxime Chevallier wrote:
> > Hello Jakub,
> > 
> > On Thu, 13 Jun 2024 18:26:13 -0700
> > Jakub Kicinski <kuba@kernel.org> wrote:
> > 
> > > On Fri,  7 Jun 2024 09:18:18 +0200 Maxime Chevallier wrote:
> > > > +		if (tb[ETHTOOL_A_HEADER_PHY_INDEX]) {
> > > > +			struct nlattr *phy_id;
> > > > +
> > > > +			phy_id = tb[ETHTOOL_A_HEADER_PHY_INDEX];
> > > > +			phydev = phy_link_topo_get_phy(dev,
> > > > +						       nla_get_u32(phy_id));  
> > > 
> > > Sorry for potentially repeating question (please put the answer in the
> > > commit message) - are phys guaranteed not to disappear, even if the
> > > netdev gets closed? this has no rtnl protection
> > 
> > I'll answer here so that people can correct me if I'm wrong, but I'll
> > also add it in the commit logs as well (and possibly with some fixes
> > depending on how this discussion goes)
> > 
> > While a PHY can be attached to/detached from a netdevice at open/close,
> > the phy_device itself will keep on living, as its lifetime is tied to
> > the underlying mdio_device (however phy_attach/detach take a ref on the
> > phy_device, preventing it from vanishing while it's attached to a
> > netdev)
> 
> It gets interesting with copper SFP. They contain a PHY, and that PHY
> can physically disappear at any time. What i don't know is when the
> logical representation of the PHY will disappear after the hotunplug
> event.

On a SFP module unplug, the following upstream device methods will be
called in order:
1. link_down
2. module_stop
3. disconnect_phy

At this point, the PHY device will be removed (phy_device_remove()) and
freed (phy_device_free()), and shortly thereafter, the MDIO bus is
unregistered and thus destroyed.

In response to the above, phylink will, respectively for each method:

1. disable the netdev carrier and call mac_link_down()
2. call phy_stop() on the attached PHY
3. remove the PHY from phylink, and then call phy_disconnect(),
   disconnecting it from the netdev.

Thus, when a SFP PHY is being removed, phylib will see in order the
following calls:

	phy_disconnect()
	phy_device_remove()
	phy_device_free()

Provided the topology linkage is removed on phy_disconnect() which
disassociates the PHY from the netdev, SFP PHYs should be fine.

-- 
RMK's Patch system: https://www.armlinux.org.uk/developer/patches/
FTTP is here! 80Mbps down 10Mbps up. Decent connectivity at last!


  reply	other threads:[~2024-06-16 16:09 UTC|newest]

Thread overview: 43+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2024-06-07  7:18 [PATCH net-next v13 00/13] Introduce PHY listing and link_topology tracking Maxime Chevallier
2024-06-07  7:18 ` Maxime Chevallier
2024-06-07  7:18 ` [PATCH net-next v13 01/13] net: phy: Introduce ethernet link topology representation Maxime Chevallier
2024-06-07  7:18   ` Maxime Chevallier
2024-06-14  0:58   ` Jakub Kicinski
2024-06-14  9:20     ` Maxime Chevallier
2024-06-07  7:18 ` [PATCH net-next v13 02/13] net: sfp: pass the phy_device when disconnecting an sfp module's PHY Maxime Chevallier
2024-06-07  7:18   ` Maxime Chevallier
2024-06-07  7:18 ` [PATCH net-next v13 03/13] net: phy: add helpers to handle sfp phy connect/disconnect Maxime Chevallier
2024-06-07  7:18   ` Maxime Chevallier
2024-06-07  7:18 ` [PATCH net-next v13 04/13] net: sfp: Add helper to return the SFP bus name Maxime Chevallier
2024-06-07  7:18   ` Maxime Chevallier
2024-06-14  1:13   ` Jakub Kicinski
2024-06-07  7:18 ` [PATCH net-next v13 05/13] net: ethtool: Allow passing a phy index for some commands Maxime Chevallier
2024-06-07  7:18   ` Maxime Chevallier
2024-06-14  1:26   ` Jakub Kicinski
2024-06-16 16:02     ` Maxime Chevallier
2024-06-16 15:21       ` Andrew Lunn
2024-06-16 16:07         ` Russell King (Oracle) [this message]
2024-06-16 21:31           ` Maxime Chevallier
2024-06-16 16:15       ` Russell King (Oracle)
2024-06-23  1:21     ` Maxime Chevallier
2024-06-07  7:18 ` [PATCH net-next v13 06/13] netlink: specs: add phy-index as a header parameter Maxime Chevallier
2024-06-07  7:18   ` Maxime Chevallier
2024-06-07  7:18 ` [PATCH net-next v13 07/13] net: ethtool: Introduce a command to list PHYs on an interface Maxime Chevallier
2024-06-07  7:18   ` Maxime Chevallier
2024-06-14  1:18   ` Jakub Kicinski
2024-06-20  3:50     ` Maxime Chevallier
2024-06-07  7:18 ` [PATCH net-next v13 08/13] netlink: specs: add ethnl PHY_GET command set Maxime Chevallier
2024-06-07  7:18   ` Maxime Chevallier
2024-06-07  7:18 ` [PATCH net-next v13 09/13] net: ethtool: plca: Target the command to the requested PHY Maxime Chevallier
2024-06-07  7:18   ` Maxime Chevallier
2024-06-07  7:18 ` [PATCH net-next v13 10/13] net: ethtool: pse-pd: " Maxime Chevallier
2024-06-07  7:18   ` Maxime Chevallier
2024-06-07  7:18 ` [PATCH net-next v13 11/13] net: ethtool: cable-test: " Maxime Chevallier
2024-06-07  7:18   ` Maxime Chevallier
2024-06-07  7:18 ` [PATCH net-next v13 12/13] net: ethtool: strset: Allow querying phy stats by index Maxime Chevallier
2024-06-07  7:18   ` Maxime Chevallier
2024-06-07  7:18 ` [PATCH net-next v13 13/13] Documentation: networking: document phy_link_topology Maxime Chevallier
2024-06-07  7:18   ` Maxime Chevallier
2024-06-26  9:47 ` [PATCH net-next v13 00/13] Introduce PHY listing and link_topology tracking Marc Kleine-Budde
2024-06-26 10:01   ` Maxime Chevallier
2024-06-26 10:15     ` Marc Kleine-Budde

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=Zm8NrEproHTPzo+O@shell.armlinux.org.uk \
    --to=linux@armlinux.org.uk \
    --cc=andrew@lunn.ch \
    --cc=atenart@kernel.org \
    --cc=christophe.leroy@csgroup.eu \
    --cc=davem@davemloft.net \
    --cc=edumazet@google.com \
    --cc=f.fainelli@gmail.com \
    --cc=herve.codina@bootlin.com \
    --cc=hkallweit1@gmail.com \
    --cc=horms@kernel.org \
    --cc=jesse.brandeburg@intel.com \
    --cc=kabel@kernel.org \
    --cc=kory.maincent@bootlin.com \
    --cc=kuba@kernel.org \
    --cc=linux-arm-kernel@lists.infradead.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=maxime.chevallier@bootlin.com \
    --cc=mwojtas@chromium.org \
    --cc=nathan@kernel.org \
    --cc=netdev@vger.kernel.org \
    --cc=nicveronese@gmail.com \
    --cc=o.rempel@pengutronix.de \
    --cc=pabeni@redhat.com \
    --cc=piergiorgio.beruto@gmail.com \
    --cc=thomas.petazzoni@bootlin.com \
    --cc=vladimir.oltean@nxp.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.