mirror of
https://github.com/AuxXxilium/linux_dsm_epyc7002.git
synced 2024-12-03 18:06:40 +07:00
net: phy: marvell: Fix deadlock from wrong locking
m88e1318_set_wol() takes the lock as part of phy_select_page(). Don't
take the lock again with phy_read(), use the unlocked __phy_read().
Fixes: 424ca4c551
("net: phy: marvell: fix paged access races")
Reported-by: Åke Rehnman <ake.rehnman@gmail.com>
Signed-off-by: Andrew Lunn <andrew@lunn.ch>
Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
8cbcdc1a51
commit
e0a7328fad
@ -1435,7 +1435,7 @@ static int m88e1318_set_wol(struct phy_device *phydev,
|
|||||||
* before enabling it if !phy_interrupt_is_valid()
|
* before enabling it if !phy_interrupt_is_valid()
|
||||||
*/
|
*/
|
||||||
if (!phy_interrupt_is_valid(phydev))
|
if (!phy_interrupt_is_valid(phydev))
|
||||||
phy_read(phydev, MII_M1011_IEVENT);
|
__phy_read(phydev, MII_M1011_IEVENT);
|
||||||
|
|
||||||
/* Enable the WOL interrupt */
|
/* Enable the WOL interrupt */
|
||||||
err = __phy_modify(phydev, MII_88E1318S_PHY_CSIER, 0,
|
err = __phy_modify(phydev, MII_88E1318S_PHY_CSIER, 0,
|
||||||
|
Loading…
Reference in New Issue
Block a user