From mboxrd@z Thu Jan 1 00:00:00 1970 From: Stefan Agner Date: Mon, 22 Feb 2016 21:12:53 -0800 Subject: [U-Boot] [PATCH] net: phy: atheros: Fix problem with phy_reset() clearing BMCR In-Reply-To: References: <1455868348-3088-1-git-send-email-b18965@freescale.com> Message-ID: <73b41c1fc960d172bb763caca0a2a362@agner.ch> List-Id: MIME-Version: 1.0 Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit To: u-boot@lists.denx.de On 2016-02-19 13:24, Fabio Estevam wrote: > On Fri, Feb 19, 2016 at 5:52 AM, Alison Wang wrote: >> In commit [net: phy: do not read configuration register on >> reset], phy_reset() will clear the BMCR register. Bit 12(AUTO_NEGOTIATION) >> is cleared too. It causes auto-negotiation timeout error on Atheros's >> PHY AR8033. >> >> To fix this problem, genphy_config_aneg() and genphy_restart_aneg() >> needs to be called in ar8035_config() to enable and restart >> auto-negotiation. > > It is always a good idea to put the author of the offending patch on Cc. > > Added Stefan. > Thanks. Hm, even more fallout from my change, sorry about that. I guess explicitly reconfigure and restart autonegotiation makes sense. Acked-by: Stefan Agner -- Stefan >> >> Signed-off-by: Alison Wang >> --- >> drivers/net/phy/atheros.c | 3 +++ >> 1 file changed, 3 insertions(+) >> >> diff --git a/drivers/net/phy/atheros.c b/drivers/net/phy/atheros.c >> index ba57b1a..e57c412 100644 >> --- a/drivers/net/phy/atheros.c >> +++ b/drivers/net/phy/atheros.c >> @@ -33,6 +33,9 @@ static int ar8035_config(struct phy_device *phydev) >> >> phydev->supported = phydev->drv->features; >> >> + genphy_config_aneg(phydev); >> + genphy_restart_aneg(phydev); >> + >> return 0; >> } >> >> -- >> 2.1.0.27.g96db324 >> >> _______________________________________________ >> U-Boot mailing list >> U-Boot at lists.denx.de >> http://lists.denx.de/mailman/listinfo/u-boot