From mboxrd@z Thu Jan 1 00:00:00 1970 From: Andrew Lunn Subject: Re: [PATCH] net: phy: DP83TC811: Introduce support for the DP83TC811 phy Date: Wed, 9 May 2018 15:58:26 +0200 Message-ID: <20180509135826.GG14276@lunn.ch> References: <20180509120559.12725-1-dmurphy@ti.com> <20180509134315.GE14276@lunn.ch> <382b9d52-7cfd-ae37-244a-32c7245cb27e@ti.com> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Cc: f.fainelli@gmail.com, netdev@vger.kernel.org, linux-kernel@vger.kernel.org To: Dan Murphy Return-path: Content-Disposition: inline In-Reply-To: <382b9d52-7cfd-ae37-244a-32c7245cb27e@ti.com> Sender: linux-kernel-owner@vger.kernel.org List-Id: netdev.vger.kernel.org On Wed, May 09, 2018 at 08:50:58AM -0500, Dan Murphy wrote: > Andrew > > Thanks for the review > > On 05/09/2018 08:43 AM, Andrew Lunn wrote: > >> +static int dp83811_config_aneg(struct phy_device *phydev) > >> +{ > >> + int err; > >> + int value; > >> + > >> + value = phy_read(phydev, MII_DP83811_SGMII_CTRL); > >> + if (phydev->autoneg == AUTONEG_ENABLE) { > >> + err = phy_write(phydev, MII_DP83811_SGMII_CTRL, > >> + (DP83811_SGMII_AUTO_NEG_EN | value)); > >> + if (err < 0) > >> + return err; > >> + } else { > >> + err = phy_write(phydev, MII_DP83811_SGMII_CTRL, > >> + (~DP83811_SGMII_AUTO_NEG_EN & value)); > >> + if (err < 0) > >> + return err; > >> + } > >> + > > > > Hi Dan > > > > You say SGMII is unreliable on one of these devices. Should you check > > phydev->interface before enabling SGMII autoneg? > > > If SGMII enable bit(12) is not set in the device then setting auto neg has no affect on the device. Ah, O.K. Maybe add a comment about this. > >> + > >> +static int dp83811_config_init(struct phy_device *phydev) > >> +{ > >> + int err; > >> + int value; > >> + > >> + err = genphy_config_init(phydev); > >> + if (err < 0) > >> + return err; > >> + > >> + if (phydev->interface == PHY_INTERFACE_MODE_SGMII) { > >> + value = phy_read(phydev, MII_DP83811_SGMII_CTRL); > >> + if (!(value & DP83811_SGMII_EN)) { > >> + err = phy_write(phydev, MII_DP83811_SGMII_CTRL, > >> + (DP83811_SGMII_EN | value)); > >> + if (err < 0) > >> + return err; > >> + } else { > >> + err = phy_write(phydev, MII_DP83811_SGMII_CTRL, > >> + (~DP83811_SGMII_EN & value)); > >> + if (err < 0) > >> + return err; > >> + } > > > > This looks to be a duplicate of dp83811_config_aneg()? > > It is almost the same but this function sets bit 12 and aneg function sets bit 13. > We can have SGMII with or without auto neg. Yep, i missed the difference. Andrew