Received: by 2002:a05:6a10:17d3:0:0:0:0 with SMTP id hz19csp2452544pxb; Mon, 19 Apr 2021 06:10:57 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxTCpxfnoKdibWZ3jpYkqOLSmBw/EQ1eYoAoPIaODRJJkdXlxihwJJsEdVwI1TN3khGNwpT X-Received: by 2002:a17:906:bcc2:: with SMTP id lw2mr21543985ejb.470.1618837856871; Mon, 19 Apr 2021 06:10:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1618837856; cv=none; d=google.com; s=arc-20160816; b=zUaPQulbAbmdR93Qn+ugE8K9+yvBaXpPG7ZV4QEac3TuEvWJPrQK1Ct6x8/u2k8pFp u9QZudnabM1UPqe83ecNPRwgKsrp1pNRgBgfWl/Z04AdrebXkypdyWAoHfP8EjCNTyf+ bAr0HxUJbBjfZBhsQMv/Qi6oW4OYtp/errRQ8mvvLyr7iOoxPsu0gVbRb3D6lSd489aH i3H5slO8wcGiv1JJH8FwVMrJipxtwsbn23zIGIBpSxd3KSDDJXPVC8Q0Q/jt/b4Q4LTt hXM3zorHJmGBzysWRL+sgQ0DK+5zZtg6Os1hcgXMT3yjpxOXNeusHhWzEtOq6r4NrNIQ WALg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from; bh=ygTgqB602Eyn+Oo8RPiAxBpnsJ/aHj207TRc5SW0kqI=; b=VowuOdyHHOJf4UzvwOyXj60Qd3CFjWWuZTF1m8pKXLVM+iz8XlojkPKhfk18Dq9GdX s5fE6XhskGoI03rX/BjIy3fFM9zcZrjlXYw+3jBbbCXp6wd1s6t1FaYKIa5lqaoXz64x F2dMW2x35y6AYyD1FP4PTXSjS+bbUC0yESIntoQjmG16MHOLxG5dp7gqlIdpmLpbOzQd g64BEWgfwoZVsvjpk1sgyZz1joBjTqPSPt3PGHFBSYAYVm68TshgsNOhMR0cHvo7e/Ak sNx+30d/uEYxoCr94gMed9SkKkp/ukAmMaRsI8YcjkZK2Y19druZCEiMS5Nc5xF/2P3l 0Y6Q== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id u12si12683219eda.121.2021.04.19.06.10.33; Mon, 19 Apr 2021 06:10:56 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S239378AbhDSNCP (ORCPT + 99 others); Mon, 19 Apr 2021 09:02:15 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:54572 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S239299AbhDSNBz (ORCPT ); Mon, 19 Apr 2021 09:01:55 -0400 Received: from metis.ext.pengutronix.de (metis.ext.pengutronix.de [IPv6:2001:67c:670:201:290:27ff:fe1d:cc33]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 9496EC06138A for ; Mon, 19 Apr 2021 06:01:25 -0700 (PDT) Received: from dude.hi.pengutronix.de ([2001:67c:670:100:1d::7]) by metis.ext.pengutronix.de with esmtps (TLS1.3:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from ) id 1lYTWa-0003tf-VR; Mon, 19 Apr 2021 15:01:12 +0200 Received: from ore by dude.hi.pengutronix.de with local (Exim 4.92) (envelope-from ) id 1lYTWX-0001lz-0L; Mon, 19 Apr 2021 15:01:09 +0200 From: Oleksij Rempel To: Shawn Guo , Sascha Hauer , Andrew Lunn , Florian Fainelli , Heiner Kallweit , Fugang Duan Cc: Oleksij Rempel , kernel@pengutronix.de, netdev@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, linux-imx@nxp.com, Fabio Estevam , David Jander , Russell King , Philippe Schenker Subject: [PATCH net-next v3 2/6] net: phy: genphy_loopback: add link speed configuration Date: Mon, 19 Apr 2021 15:01:02 +0200 Message-Id: <20210419130106.6707-3-o.rempel@pengutronix.de> X-Mailer: git-send-email 2.29.2 In-Reply-To: <20210419130106.6707-1-o.rempel@pengutronix.de> References: <20210419130106.6707-1-o.rempel@pengutronix.de> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-SA-Exim-Connect-IP: 2001:67c:670:100:1d::7 X-SA-Exim-Mail-From: ore@pengutronix.de X-SA-Exim-Scanned: No (on metis.ext.pengutronix.de); SAEximRunCond expanded to false X-PTX-Original-Recipient: linux-kernel@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org In case of loopback, in most cases we need to disable autoneg support and force some speed configuration. Otherwise, depending on currently active auto negotiated link speed, the loopback may or may not work. This patch was tested with following PHYs: TJA1102, KSZ8081, KSZ9031, AT8035, AR9331. Signed-off-by: Oleksij Rempel --- drivers/net/phy/phy.c | 3 ++- drivers/net/phy/phy_device.c | 28 ++++++++++++++++++++++++++-- include/linux/phy.h | 1 + 3 files changed, 29 insertions(+), 3 deletions(-) diff --git a/drivers/net/phy/phy.c b/drivers/net/phy/phy.c index fc2e7cb5b2e5..1f0512e39c65 100644 --- a/drivers/net/phy/phy.c +++ b/drivers/net/phy/phy.c @@ -701,7 +701,7 @@ int phy_start_cable_test_tdr(struct phy_device *phydev, } EXPORT_SYMBOL(phy_start_cable_test_tdr); -static int phy_config_aneg(struct phy_device *phydev) +int phy_config_aneg(struct phy_device *phydev) { if (phydev->drv->config_aneg) return phydev->drv->config_aneg(phydev); @@ -714,6 +714,7 @@ static int phy_config_aneg(struct phy_device *phydev) return genphy_config_aneg(phydev); } +EXPORT_SYMBOL(phy_config_aneg); /** * phy_check_link_status - check link status and set state accordingly diff --git a/drivers/net/phy/phy_device.c b/drivers/net/phy/phy_device.c index 320a3e5cd10a..0a2d8bedf73d 100644 --- a/drivers/net/phy/phy_device.c +++ b/drivers/net/phy/phy_device.c @@ -2565,8 +2565,32 @@ EXPORT_SYMBOL(genphy_resume); int genphy_loopback(struct phy_device *phydev, bool enable) { - return phy_modify(phydev, MII_BMCR, BMCR_LOOPBACK, - enable ? BMCR_LOOPBACK : 0); + if (enable) { + u16 val, ctl = BMCR_LOOPBACK; + int ret; + + if (phydev->speed == SPEED_1000) + ctl |= BMCR_SPEED1000; + else if (phydev->speed == SPEED_100) + ctl |= BMCR_SPEED100; + + if (phydev->duplex == DUPLEX_FULL) + ctl |= BMCR_FULLDPLX; + + phy_modify(phydev, MII_BMCR, ~0, ctl); + + ret = phy_read_poll_timeout(phydev, MII_BMSR, val, + val & BMSR_LSTATUS, + 5000, 500000, true); + if (ret) + return ret; + } else { + phy_modify(phydev, MII_BMCR, BMCR_LOOPBACK, 0); + + phy_config_aneg(phydev); + } + + return 0; } EXPORT_SYMBOL(genphy_loopback); diff --git a/include/linux/phy.h b/include/linux/phy.h index 98fb441dd72e..98e351bb0964 100644 --- a/include/linux/phy.h +++ b/include/linux/phy.h @@ -1410,6 +1410,7 @@ void phy_disconnect(struct phy_device *phydev); void phy_detach(struct phy_device *phydev); void phy_start(struct phy_device *phydev); void phy_stop(struct phy_device *phydev); +int phy_config_aneg(struct phy_device *phydev); int phy_start_aneg(struct phy_device *phydev); int phy_aneg_done(struct phy_device *phydev); int phy_speed_down(struct phy_device *phydev, bool sync); -- 2.29.2