summaryrefslogtreecommitdiff
path: root/drivers/net
diff options
context:
space:
mode:
authorTimo Teräs <timo.teras@iki.fi>2010-07-05 22:05:02 -0700
committerGreg Kroah-Hartman <gregkh@suse.de>2010-08-02 10:26:25 -0700
commit2d99271ad7754c30d3b1a51a5c010fe325964064 (patch)
treea40ba7f19a39e1d06c76e2a0c222bf5b1340139d /drivers/net
parent6468dd3e5de409cae58859bf574ad3a18887e24f (diff)
downloadlwn-2d99271ad7754c30d3b1a51a5c010fe325964064.tar.gz
lwn-2d99271ad7754c30d3b1a51a5c010fe325964064.zip
r8169: fix mdio_read and update mdio_write according to hw specs
[ Upstream commit 81a95f049962ec20a9aed888e676208b206f0f2e ] Realtek confirmed that a 20us delay is needed after mdio_read and mdio_write operations. Reduce the delay in mdio_write, and add it to mdio_read too. Also add a comment that the 20us is from hw specs. Signed-off-by: Timo Teräs <timo.teras@iki.fi> Acked-by: Francois Romieu <romieu@fr.zoreil.com> Signed-off-by: David S. Miller <davem@davemloft.net> Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Diffstat (limited to 'drivers/net')
-rw-r--r--drivers/net/r8169.c12
1 files changed, 9 insertions, 3 deletions
diff --git a/drivers/net/r8169.c b/drivers/net/r8169.c
index 2cbfa04144af..69f84c8e5cb0 100644
--- a/drivers/net/r8169.c
+++ b/drivers/net/r8169.c
@@ -558,10 +558,10 @@ static void mdio_write(void __iomem *ioaddr, int reg_addr, int value)
udelay(25);
}
/*
- * Some configurations require a small delay even after the write
- * completed indication or the next write might fail.
+ * According to hardware specs a 20us delay is required after write
+ * complete indication, but before sending next command.
*/
- udelay(25);
+ udelay(20);
}
static int mdio_read(void __iomem *ioaddr, int reg_addr)
@@ -581,6 +581,12 @@ static int mdio_read(void __iomem *ioaddr, int reg_addr)
}
udelay(25);
}
+ /*
+ * According to hardware specs a 20us delay is required after read
+ * complete indication, but before sending next command.
+ */
+ udelay(20);
+
return value;
}