]> www.infradead.org Git - users/willy/pagecache.git/commit
net: phy: Remove LED entry from LEDs list on unregister
authorChristian Marangi <ansuelsmth@gmail.com>
Fri, 4 Oct 2024 18:27:58 +0000 (20:27 +0200)
committerJakub Kicinski <kuba@kernel.org>
Tue, 8 Oct 2024 00:15:50 +0000 (17:15 -0700)
commitf50b5d74c68e551667e265123659b187a30fe3a5
treedda3c9913993aa2707eb23634a8efdd71ee8bd41
parentf61060fb29e552e089be973c9fb44ebf03d7e6ae
net: phy: Remove LED entry from LEDs list on unregister

Commit c938ab4da0eb ("net: phy: Manual remove LEDs to ensure correct
ordering") correctly fixed a problem with using devm_ but missed
removing the LED entry from the LEDs list.

This cause kernel panic on specific scenario where the port for the PHY
is torn down and up and the kmod for the PHY is removed.

On setting the port down the first time, the assosiacted LEDs are
correctly unregistered. The associated kmod for the PHY is now removed.
The kmod is now added again and the port is now put up, the associated LED
are registered again.
On putting the port down again for the second time after these step, the
LED list now have 4 elements. With the first 2 already unregistered
previously and the 2 new one registered again.

This cause a kernel panic as the first 2 element should have been
removed.

Fix this by correctly removing the element when LED is unregistered.

Reported-by: Daniel Golle <daniel@makrotopia.org>
Tested-by: Daniel Golle <daniel@makrotopia.org>
Cc: stable@vger.kernel.org
Fixes: c938ab4da0eb ("net: phy: Manual remove LEDs to ensure correct ordering")
Signed-off-by: Christian Marangi <ansuelsmth@gmail.com>
Reviewed-by: Andrew Lunn <andrew@lunn.ch>
Link: https://patch.msgid.link/20241004182759.14032-1-ansuelsmth@gmail.com
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/net/phy/phy_device.c