]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
net: pcs: xpcs: convert to use read_poll_timeout()
authorRussell King (Oracle) <rmk+kernel@armlinux.org.uk>
Fri, 4 Oct 2024 10:21:27 +0000 (11:21 +0100)
committerDavid S. Miller <davem@davemloft.net>
Wed, 9 Oct 2024 11:13:11 +0000 (12:13 +0100)
Convert the xpcs driver to use read_poll_timeout() when waiting for
reset to complete, rather than open-coding this.

Signed-off-by: Russell King (Oracle) <rmk+kernel@armlinux.org.uk>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/pcs/pcs-xpcs.c

index 5ac8262ac264e957cf95646b2775b1ff5121a3ec..06a4951354184e4564251b401e35bd9c07149955 100644 (file)
@@ -220,18 +220,15 @@ static int xpcs_modify_vpcs(struct dw_xpcs *xpcs, int reg, u16 mask, u16 val)
 
 static int xpcs_poll_reset(struct dw_xpcs *xpcs, int dev)
 {
-       /* Poll until the reset bit clears (50ms per retry == 0.6 sec) */
-       unsigned int retries = 12;
-       int ret;
+       int ret, val;
 
-       do {
-               msleep(50);
-               ret = xpcs_read(xpcs, dev, MDIO_CTRL1);
-               if (ret < 0)
-                       return ret;
-       } while (ret & MDIO_CTRL1_RESET && --retries);
+       ret = read_poll_timeout(xpcs_read, val,
+                               val < 0 || !(val & MDIO_CTRL1_RESET),
+                               50000, 600000, true, xpcs, dev, MDIO_CTRL1);
+       if (val < 0)
+               ret = val;
 
-       return (ret & MDIO_CTRL1_RESET) ? -ETIMEDOUT : 0;
+       return ret;
 }
 
 static int xpcs_soft_reset(struct dw_xpcs *xpcs,