Hi, Madalin On 2017/6/27 19:48, Madalin-cristian Bucur wrote: >> -----Original Message----- >> From: netdev-ow...@vger.kernel.org [mailto:netdev-ow...@vger.kernel.org] >> On Behalf Of Lin Yun Sheng >> Sent: Tuesday, June 27, 2017 2:01 PM >> To: da...@davemloft.net; and...@lunn.ch; f.faine...@gmail.com >> Cc: huangda...@hisilicon.com; xuw...@hisilicon.com; >> liguo...@hisilicon.com; yisen.zhu...@huawei.com; >> gabriele.paol...@huawei.com; john.ga...@huawei.com; linux...@huawei.com; >> yisen.zhu...@huawei.com; salil.me...@huawei.com; lipeng...@huawei.com; >> trem...@gmail.com; netdev@vger.kernel.org; linux-ker...@vger.kernel.org >> Subject: [PATCH NET V6 1/2] net: phy: Add phy loopback support in net phy >> framework >> >> This patch add set_loopback in phy_driver, which is used by Mac >> driver to enable or disable a phy. it also add a generic >> genphy_loopback function, which use BMCR loopback bit to enable >> or disable a phy. > > "disable a phy" or disable the PHY loopback function? It should be disable the PHY loopback function, thanks for pointing out.
> >> @@ -1123,6 +1123,39 @@ int phy_resume(struct phy_device *phydev) >> } >> EXPORT_SYMBOL(phy_resume); >> >> +int phy_loopback(struct phy_device *phydev, bool enable) >> +{ >> + struct phy_driver *phydrv = to_phy_driver(phydev->mdio.dev.driver); >> + int ret = 0; >> + >> + mutex_lock(&phydev->lock); >> + >> + if (enable && phydev->loopback_enabled) { >> + ret = -EBUSY; >> + goto out; >> + } >> + >> + if (!enable && !phydev->loopback_enabled) { >> + ret = -EINVAL; >> + goto out; >> + } >> + > > if (enable == phydev->loopback_enabled) One if statement don't work here, it returns different error code. > >> + if (phydev->drv && phydrv->set_loopback) >> + ret = phydrv->set_loopback(phydev, enable); >> + else >> + ret = -EOPNOTSUPP; >> + >> + if (ret) >> + goto out; >> + >> + phydev->loopback_enabled = enable; >> + >> +out: >> + mutex_unlock(&phydev->lock); >> + return ret; >> +} >> +EXPORT_SYMBOL(phy_loopback); >> + > Best Regards Yunsheng