From: Cyril Chemparathy <cyril@ti.com>
To: "Chemparathy, Cyril" <cyril@ti.com>
Cc: Michael Williamson <michael.williamson@criticallink.com>,
"davinci-linux-open-source@linux.davincidsp.com"
<davinci-linux-open-source@linux.davincidsp.com>,
"netdev@vger.kernel.org" <netdev@vger.kernel.org>,
"tony@atomide.com" <tony@atomide.com>,
"linux-omap@vger.kernel.org" <linux-omap@vger.kernel.org>,
"davem@davemloft.net" <davem@davemloft.net>
Subject: Re: [PATCH v3 00/10] split out emac cpdma and mdio for reuse
Date: Thu, 09 Sep 2010 17:24:14 -0400 [thread overview]
Message-ID: <4C89507E.9040407@ti.com> (raw)
In-Reply-To: <4C893ADE.809@ti.com>
[-- Attachment #1: Type: text/plain, Size: 1080 bytes --]
Hi Mike,
[...]
> An EMAC soft-reset clobbering the MDIO controller state is a
> possibility. I will poll TI designers to see if this could be the case.
To test this theory out, I hacked up a crude
beat-it-to-death-and-see-if-it-breaks kinda patch (attached). This
tests 10000 mdio read cycles while constantly doing an emac soft-reset.
I ran this on a dm365 evm, and the test didn't raise a single failed read:
> davinci_mdio davinci_mdio.0: davinci mdio revision 1.4
> davinci_mdio davinci_mdio.0: detected phy mask fffffffc
> 10000 test loops completed, 10000 reads ok
The failure in question seems to be limited to the da8xx family (tested
da830 evm), where:
> davinci_mdio davinci_mdio.0: davinci mdio revision 1.5
> davinci_mdio davinci_mdio.0: detected phy mask fffffff1
> idle triggered!!
The MDIO module upgrade (rev 1.4 -> 1.5) could have something to do with
this behavior. Even so, I can't explain why this issue wasn't seen on
da8xx prior to this series. The original code should (at least in
theory) have sporadically locked up on emac open.
Regards
Cyril.
[-- Attachment #2: beat-emac-soft-reset.patch --]
[-- Type: text/x-patch, Size: 1935 bytes --]
diff --git a/drivers/net/davinci_mdio.c b/drivers/net/davinci_mdio.c
index d34a53a..8cd6d28 100644
--- a/drivers/net/davinci_mdio.c
+++ b/drivers/net/davinci_mdio.c
@@ -157,6 +157,56 @@ static int davinci_mdio_write(struct mii_bus *bus, int phy_id,
return 0;
}
+#if 0 /* DM365 */
+#define EMAC_BASE (0x01D07000)
+#define EMAC_CNTRL_OFFSET (0x0000)
+#define PHY_ADDR 1
+#endif
+
+#if 1 /* DA8XX */
+#define EMAC_BASE (0x01e20000)
+#define EMAC_CNTRL_OFFSET (0x3000)
+#define PHY_ADDR 1 /* 1-3 is ok on da830 evm */
+#endif
+
+#define EMAC_SOFTRESET (0x174)
+#define PHY_REG MII_PHYSID1
+
+static void mdio_emac_soft_reset_test(struct davinci_mdio_data *data)
+{
+ struct davinci_mdio_regs __iomem *regs = data->regs;
+ int loops = 0, status_ok = 0;
+ void __iomem *emac;
+ u32 reg;
+
+ emac = ioremap(EMAC_BASE + EMAC_CNTRL_OFFSET, SZ_4K);
+ if (WARN_ON(!emac))
+ return;
+
+ for (loops = 0; loops < 10000; loops++) {
+ while (__raw_readl(®s->user[0].access) &
+ USERACCESS_GO)
+ ;
+
+ reg = (USERACCESS_GO | USERACCESS_READ |
+ (PHY_REG << 21) | (PHY_ADDR << 16));
+ __raw_writel(reg, ®s->user[0].access);
+
+ while (__raw_readl(®s->user[0].access) &
+ USERACCESS_GO) {
+ __raw_writel(1, emac + EMAC_SOFTRESET);
+ if (__raw_readl(®s->control) & CONTROL_IDLE) {
+ printk(KERN_ERR "idle triggered!!\n");
+ return;
+ }
+ }
+ if (__raw_readl(®s->user[0].access) & USERACCESS_ACK)
+ status_ok++;
+ }
+ printk(KERN_ERR "%d test loops completed, %d reads ok\n", loops,
+ status_ok);
+}
+
static int __devinit davinci_mdio_probe(struct platform_device *pdev)
{
struct mdio_platform_data *pdata = pdev->dev.platform_data;
@@ -262,6 +312,8 @@ static int __devinit davinci_mdio_probe(struct platform_device *pdev)
}
data->bus->phy_mask = phy_mask;
+ mdio_emac_soft_reset_test(data);
+
/* register the mii bus */
ret = mdiobus_register(data->bus);
if (ret)
next prev parent reply other threads:[~2010-09-09 21:24 UTC|newest]
Thread overview: 29+ messages / expand[flat|nested] mbox.gz Atom feed top
2010-09-07 20:25 [PATCH v3 00/10] split out emac cpdma and mdio for reuse Cyril Chemparathy
2010-09-07 20:25 ` [PATCH v3 01/10] net: davinci_emac: separate out davinci mdio Cyril Chemparathy
2010-09-07 20:25 ` [PATCH v3 02/10] davinci: add mdio platform devices Cyril Chemparathy
2010-09-07 20:25 ` [PATCH v3 03/10] omap: " Cyril Chemparathy
2010-09-08 1:00 ` Tony Lindgren
2010-09-07 20:25 ` [PATCH v3 04/10] net: davinci_emac: switch to new mdio Cyril Chemparathy
2010-09-07 20:25 ` [PATCH v3 05/10] davinci: cleanup unused davinci mdio arch code Cyril Chemparathy
2010-09-07 20:25 ` [PATCH v3 06/10] omap: " Cyril Chemparathy
2010-09-08 1:00 ` Tony Lindgren
2010-09-07 20:25 ` [PATCH v3 07/10] net: davinci_emac: cleanup unused mdio emac code Cyril Chemparathy
2010-09-07 20:25 ` [PATCH v3 08/10] net: davinci_emac: separate out cpdma code Cyril Chemparathy
2010-09-07 20:25 ` [PATCH v3 09/10] net: davinci_emac: switch to new cpdma layer Cyril Chemparathy
2010-09-07 20:25 ` [PATCH v3 10/10] net: davinci_emac: cleanup unused cpdma code Cyril Chemparathy
2010-09-08 1:18 ` [PATCH v3 00/10] split out emac cpdma and mdio for reuse Kevin Hilman
2010-09-08 2:22 ` Michael Williamson
2010-09-08 21:59 ` Cyril Chemparathy
2010-09-09 0:47 ` Michael Williamson
2010-09-09 18:43 ` Michael Williamson
2010-09-09 19:51 ` Cyril Chemparathy
2010-09-09 21:24 ` Cyril Chemparathy [this message]
2010-09-09 21:45 ` Michael Williamson
2010-09-09 21:25 ` Michael Williamson
2010-09-10 15:23 ` Caglar Akyuz
2010-09-11 8:54 ` Caglar Akyuz
2010-09-13 14:09 ` Cyril Chemparathy
2010-09-13 15:46 ` Cyril Chemparathy
2010-09-13 17:51 ` Caglar Akyuz
2010-09-10 22:59 ` Cyril Chemparathy
2010-09-11 13:14 ` Michael Williamson
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=4C89507E.9040407@ti.com \
--to=cyril@ti.com \
--cc=davem@davemloft.net \
--cc=davinci-linux-open-source@linux.davincidsp.com \
--cc=linux-omap@vger.kernel.org \
--cc=michael.williamson@criticallink.com \
--cc=netdev@vger.kernel.org \
--cc=tony@atomide.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).