From: Auke Kok <auke-jan.h.kok@intel.com>
To: "Anders Grafström" <grfstrm@users.sourceforge.net>
Cc: Francois Romieu <romieu@fr.zoreil.com>,
netdev@vger.kernel.org,
Jesse Brandeburg <jesse.brandeburg@intel.com>
Subject: Re: e100: Wait for PHY reset to complete?
Date: Mon, 30 Oct 2006 11:05:49 -0800 [thread overview]
Message-ID: <45464D0D.50802@intel.com> (raw)
In-Reply-To: <45400A6D.4020704@intel.com>
Auke Kok wrote:
> Anders Grafström wrote:
>> Auke Kok wrote:
>>> Allthough the spec itself didn't talk about phy reset times, I've ran
>>> this
>>> patch with
>>> some debugging output on a few boxes and did some speed/duplex settings,
>>> and the PHY
>>> reset returned succesfull after the very first mdio_read, which is
>>> before
>>> any msleep(10)
>>> is executed. That is also expected behaviour.
>>>
>>> I think you might be confusing this with a MAC reset, which has a
>>> documented 10usec
>>> timeout (see 8255x developers manual). The driver already adheres to
>>> this
>>> by doing a
>>> 20usec delay after software/selective resets.
>>>
>>> which gets us back to the original problem: how did your driver end
>>> up in
>>> loopback mode?
>>> (and, how did you figure out that it did??).
>>
>>
>> This is what the 2.4.33.3 driver does:
>>
>> void
>> e100_phy_reset(struct e100_private *bdp)
>> {
>> u16 ctrl_reg;
>> ctrl_reg = BMCR_RESET;
>> e100_mdi_write(bdp, MII_BMCR, bdp->phy_addr, ctrl_reg);
>> /* ieee 802.3 : The reset process shall be completed */
>> /* within 0.5 seconds from the settting of PHY reset bit. */
>> set_current_state(TASK_UNINTERRUPTIBLE);
>> schedule_timeout(HZ / 2);
>> }
>>
>> And here
>> http://www.cs.helsinki.fi/linux/linux-kernel/2003-23/1245.html
>> I found this entry:
>>
>> <scott.feldman@intel.com> (03/06/08 1.1218)
>> [e100] misc
>> <...>
>> * Add 1/2 second delay after PHY reset to allow link partner to
>> see and respond to reset, per IEEE 802.3.
>>
>>
>> I ran mii-diag when the LEDs went out and the register dump
>> said it was in loopback. It is somewhat difficult reproduce.
>> It seems to be timing dependent, something else has to occur
>> at the same time.
>> I must confess I have only seen it with the 2.6.13 kernel.
>> I have not been able to reproduce it with 2.6.18.
>> But I have found no change in the driver that would fix it so
>> I suspect the problem is still there.
>>
>> I have tried adding debug output to see if I can read back the
>> RESET bit in set state, but then the problem refuses to show
>> so I don't think I can rule out an unfinished PHY reset.
>
> theoretically, yes, the ieee spec PHY reset timeout is kind of silly: in
> no way do we assume that we have re-negotiated link after 1/2 a second!
> Other code in the driver should take care of that, and since it works
> I'll assume it does ;)
>
> the mdio_read probably acts as a flush to the hardware too -
> masquerading problems, more goodness. Perhaps we should do a single read
> in all cases and forget about the timeout (is there an mdio_write_flush?)
Anders,
It appears that there isn't such a thing as an mdio_write_flush in e100 but we can force
a flush by reading the status register. Not sure if it works 100% so please give this a
try and let me know if this fixes the problem for you.
Basically, we're preventing mdio writes that might happen after our reset write from
being reordered. This might have caused an undefined state.
Auke
---
e100: force mdio write flush after PHY reset
Make sure the PHY reset happens without delay by flushing the reset write.
Signed-off-by: Auke Kok <auke-jan.h.kok@intel.com>
diff --git a/drivers/net/e100.c b/drivers/net/e100.c
index 815eb29..04a52cd 100644
--- a/drivers/net/e100.c
+++ b/drivers/net/e100.c
@@ -2197,6 +2197,8 @@ static int e100_set_settings(struct net_
int err;
mdio_write(netdev, nic->mii.phy_id, MII_BMCR, BMCR_RESET);
+ /* flush MDIO write */
+ mdio_read(netdev, nic->mii.phy_id, MII_BMSR);
err = mii_ethtool_sset(&nic->mii, cmd);
e100_exec_cb(nic, NULL, e100_configure);
next prev parent reply other threads:[~2006-10-30 19:06 UTC|newest]
Thread overview: 10+ messages / expand[flat|nested] mbox.gz Atom feed top
2006-10-25 17:22 e100: Wait for PHY reset to complete? Anders Grafstrom
2006-10-25 18:56 ` Francois Romieu
2006-10-25 20:18 ` Auke Kok
2006-10-25 21:26 ` Auke Kok
2006-10-25 21:57 ` Francois Romieu
2006-10-25 23:36 ` Anders Grafström
2006-10-26 1:07 ` Auke Kok
2006-10-30 19:05 ` Auke Kok [this message]
2006-10-31 18:10 ` Anders Grafström
2006-10-31 18:34 ` Auke Kok
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=45464D0D.50802@intel.com \
--to=auke-jan.h.kok@intel.com \
--cc=grfstrm@users.sourceforge.net \
--cc=jesse.brandeburg@intel.com \
--cc=netdev@vger.kernel.org \
--cc=romieu@fr.zoreil.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).