Commit e0a7328f authored by Andrew Lunn's avatar Andrew Lunn Committed by David S. Miller

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: 424ca4c5 ("net: phy: marvell: fix paged access races")
Reported-by: default avatarÅke Rehnman <ake.rehnman@gmail.com>
Signed-off-by: default avatarAndrew Lunn <andrew@lunn.ch>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 8cbcdc1a
...@@ -1435,7 +1435,7 @@ static int m88e1318_set_wol(struct phy_device *phydev, ...@@ -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,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment