Message ID | 20230201145845.2312060-1-o.rempel@pengutronix.de |
---|---|
Headers |
Return-Path: <linux-kernel-owner@vger.kernel.org> Delivered-To: ouuuleilei@gmail.com Received: by 2002:adf:eb09:0:0:0:0:0 with SMTP id s9csp325179wrn; Wed, 1 Feb 2023 07:01:16 -0800 (PST) X-Google-Smtp-Source: AK7set9rCAR1+H2AcLkgEO4BnPO0iih5C+JPzSCOocZ6UzHBxJGQosThEosPvlGfoPuS6bE5fLYk X-Received: by 2002:a17:90b:4b04:b0:22c:5f97:f69b with SMTP id lx4-20020a17090b4b0400b0022c5f97f69bmr2703659pjb.10.1675263676350; Wed, 01 Feb 2023 07:01:16 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1675263676; cv=none; d=google.com; s=arc-20160816; b=xDBFc9jJzcInZB5I2JyIIPDpsfMwzGL3Wii+gLkxqfBxjVNh936kT6bN3/Aq398LAO 5TvSqHzF8LIKhRn+eOATZa8nvu8DjMDosxKBej65xW+oNPr45KUud0YoblXFIOTyJlcu EBR54ar2Ns9r8fTQiVBxOrk20redBG/VqC2Zm5vpXXfTw8HNT2AfX32aD2MwZVa1/VJa MsxZh7iO3aTuGMMvYrXkwTXIk/v9K96KbtPJUwpK/Pqk7cG4dmAiQA951aKxfEDQXcWm JHQkdJ0TwC7Y7pKPpmbY3cfQ/sB4cWCS8FcKVZYiSAGmxXSI3M561Mrl3TyWHZni8qtP q/Sg== 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 :message-id:date:subject:cc:to:from; bh=mZhO1Ag8lcjxebqbAuXkQXd0xnrjyYwXlJIU6soYoF0=; b=HY/AIvBUhh1Hr5XVA7isTNE0KGipH++q/fcO0LgWxDhGuc4RO/44DVz58FFoOKcfZD LgNSdosK38bsS6hpkXhIMhxDyAUhbcodMW4f1p+zLDXP2IeDItR6U5ntO8Gf6Qu3uUAZ Eb4lPG38w2kdtVUmU9N5iZAU2Z1xLc+8aikMh1BdGR4sWXIyYoO08z3739qfs/yyA8eJ NNZ+2asHxxQbJ88X51em/ihCUnaGH6ENwSE75QLpt4+psHwCCPUhC1ad4cuM9z646lH2 HCwLVp71iw3+/f1DGoibiaT1vWkpUzMEdyB8kFpPZ/XrebQMUkekUdgu/jgy2PvOwgCC z3bw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id fu1-20020a17090ad18100b0022c9cb7662csi1945504pjb.159.2023.02.01.07.01.02; Wed, 01 Feb 2023 07:01:16 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231827AbjBAO7W (ORCPT <rfc822;duw91626@gmail.com> + 99 others); Wed, 1 Feb 2023 09:59:22 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:33604 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231735AbjBAO7E (ORCPT <rfc822;linux-kernel@vger.kernel.org>); Wed, 1 Feb 2023 09:59:04 -0500 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 41BF269B36 for <linux-kernel@vger.kernel.org>; Wed, 1 Feb 2023 06:59:03 -0800 (PST) Received: from drehscheibe.grey.stw.pengutronix.de ([2a0a:edc0:0:c01:1d::a2]) by metis.ext.pengutronix.de with esmtps (TLS1.3:ECDHE_RSA_AES_256_GCM_SHA384:256) (Exim 4.92) (envelope-from <ore@pengutronix.de>) id 1pNEZY-0002ra-0C; Wed, 01 Feb 2023 15:58:52 +0100 Received: from [2a0a:edc0:0:1101:1d::ac] (helo=dude04.red.stw.pengutronix.de) by drehscheibe.grey.stw.pengutronix.de with esmtp (Exim 4.94.2) (envelope-from <ore@pengutronix.de>) id 1pNEZW-001w1G-Ih; Wed, 01 Feb 2023 15:58:49 +0100 Received: from ore by dude04.red.stw.pengutronix.de with local (Exim 4.94.2) (envelope-from <ore@pengutronix.de>) id 1pNEZT-009hUY-6r; Wed, 01 Feb 2023 15:58:47 +0100 From: Oleksij Rempel <o.rempel@pengutronix.de> To: Woojung Huh <woojung.huh@microchip.com>, UNGLinuxDriver@microchip.com, Andrew Lunn <andrew@lunn.ch>, Vivien Didelot <vivien.didelot@gmail.com>, Florian Fainelli <f.fainelli@gmail.com>, Vladimir Oltean <olteanv@gmail.com>, "David S. Miller" <davem@davemloft.net>, Eric Dumazet <edumazet@google.com>, Jakub Kicinski <kuba@kernel.org>, Paolo Abeni <pabeni@redhat.com>, Wei Fang <wei.fang@nxp.com>, Heiner Kallweit <hkallweit1@gmail.com> Cc: Oleksij Rempel <o.rempel@pengutronix.de>, kernel@pengutronix.de, linux-kernel@vger.kernel.org, netdev@vger.kernel.org, Arun.Ramadoss@microchip.com, intel-wired-lan@lists.osuosl.org Subject: [PATCH net-next v4 00/23] net: add EEE support for KSZ9477 and AR8035 with i.MX6 Date: Wed, 1 Feb 2023 15:58:22 +0100 Message-Id: <20230201145845.2312060-1-o.rempel@pengutronix.de> X-Mailer: git-send-email 2.30.2 MIME-Version: 1.0 Content-Transfer-Encoding: 8bit X-SA-Exim-Connect-IP: 2a0a:edc0:0:c01:1d::a2 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 X-Spam-Status: No, score=-4.2 required=5.0 tests=BAYES_00,RCVD_IN_DNSWL_MED, SPF_HELO_NONE,SPF_PASS autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: <linux-kernel.vger.kernel.org> X-Mailing-List: linux-kernel@vger.kernel.org X-getmail-retrieved-from-mailbox: =?utf-8?q?INBOX?= X-GMAIL-THRID: =?utf-8?q?1756641284492886035?= X-GMAIL-MSGID: =?utf-8?q?1756641284492886035?= |
Series |
net: add EEE support for KSZ9477 and AR8035 with i.MX6
|
|
Message
Oleksij Rempel
Feb. 1, 2023, 2:58 p.m. UTC
changes v4: - remove following helpers: mmd_eee_cap_to_ethtool_sup_t mmd_eee_adv_to_ethtool_adv_t ethtool_adv_to_mmd_eee_adv_t and port drivers from this helpers to linkmode helpers. - rebase against latest net-next - port phy_init_eee() to genphy_c45_eee_is_active() changes v3: - rework some parts of EEE infrastructure and move it to c45 code. - add supported_eee storage and start using it in EEE code and by the micrel driver. - add EEE support for ar8035 PHY - add SmartEEE support to FEC i.MX series. changes v2: - use phydev->supported instead of reading MII_BMSR regiaster - fix @get_eee > @set_eee With this patch series we provide EEE control for KSZ9477 family of switches and AR8035 with i.MX6 configuration. According to my tests, on a system with KSZ8563 switch and 100Mbit idle link, we consume 0,192W less power per port if EEE is enabled. Oleksij Rempel (23): net: dsa: microchip: enable EEE support net: phy: add genphy_c45_read_eee_abilities() function net: phy: micrel: add ksz9477_get_features() net: phy: export phy_check_valid() function net: phy: add genphy_c45_ethtool_get/set_eee() support net: phy: c22: migrate to genphy_c45_write_eee_adv() net: phy: c45: migrate to genphy_c45_write_eee_adv() net: phy: migrate phy_init_eee() to genphy_c45_eee_is_active() net: phy: start using genphy_c45_ethtool_get/set_eee() net: phy: add driver specific get/set_eee support net: phy: at803x: implement ethtool access to SmartEEE functionality net: phy: at803x: ar8035: fix EEE support for half duplex links net: phy: add PHY specifica flag to signal SmartEEE support net: phy: at803x: add PHY_SMART_EEE flag to AR8035 net: phy: add phy_has_smarteee() helper net: fec: add support for PHYs with SmartEEE support e1000e: replace EEE ethtool helpers to linkmode variants igb: replace EEE ethtool helpers to linkmode variants igc: replace EEE ethtool helpers to linkmode variants tg3: replace EEE ethtool helpers to linkmode variants r8152: replace EEE ethtool helpers to linkmode variants net: usb: ax88179_178a: replace EEE ethtool helpers to linkmode variants net: mdio: drop EEE ethtool helpers in favor to linkmode variants drivers/net/dsa/microchip/ksz_common.c | 66 ++++ drivers/net/ethernet/broadcom/tg3.c | 9 +- drivers/net/ethernet/freescale/fec_main.c | 22 +- drivers/net/ethernet/intel/e1000e/ethtool.c | 16 +- drivers/net/ethernet/intel/igb/igb_ethtool.c | 23 +- drivers/net/ethernet/intel/igc/igc_ethtool.c | 12 +- drivers/net/phy/at803x.c | 142 ++++++++- drivers/net/phy/micrel.c | 21 ++ drivers/net/phy/phy-c45.c | 298 ++++++++++++++++++- drivers/net/phy/phy.c | 155 ++-------- drivers/net/phy/phy_device.c | 26 +- drivers/net/usb/ax88179_178a.c | 24 +- drivers/net/usb/r8152.c | 34 ++- include/linux/mdio.h | 136 ++++----- include/linux/phy.h | 28 ++ include/uapi/linux/mdio.h | 8 + 16 files changed, 760 insertions(+), 260 deletions(-)
Comments
On Wed, Feb 01, 2023 at 03:58:22PM +0100, Oleksij Rempel wrote: > With this patch series we provide EEE control for KSZ9477 family of switches and > AR8035 with i.MX6 configuration. > According to my tests, on a system with KSZ8563 switch and 100Mbit idle link, > we consume 0,192W less power per port if EEE is enabled. What is the code flow through the kernel with EEE? I wasn't able to find a good explanation about it. Is it advertised by default, if supported? I guess phy_advertise_supported() does that. But is that desirable? Doesn't EEE cause undesired latency for MAC-level PTP timestamping on an otherwise idle link?
On Sat, Feb 04, 2023 at 02:13:32AM +0200, Vladimir Oltean wrote: > On Wed, Feb 01, 2023 at 03:58:22PM +0100, Oleksij Rempel wrote: > > With this patch series we provide EEE control for KSZ9477 family of switches and > > AR8035 with i.MX6 configuration. > > According to my tests, on a system with KSZ8563 switch and 100Mbit idle link, > > we consume 0,192W less power per port if EEE is enabled. > > What is the code flow through the kernel with EEE? I wasn't able to find > a good explanation about it. > > Is it advertised by default, if supported? I guess phy_advertise_supported() > does that. Ack. > But is that desirable? Doesn't EEE cause undesired latency for MAC-level > PTP timestamping on an otherwise idle link? Theoretically, MAC controls Low Power Idle states and even with some "Wake" latency should be fully aware of actual ingress and egress time stamps. Practically, right now I do not have such HW to confirm it. My project is affected by EEE in different ways: - with EEE PTP has too much jitter - without EEE, the devices consumes too much power in standby mode with WoL enabled. Even switching to 10BaseT less power as 100BaseTX with EEE would do. My view is probably biased by my environment - PTP is relatively rare use case. EEE saves power (0,2W+0,2W per link in my case). Summary power saving of all devices is potentially equal to X amount of power plants. So, EEE should be enabled by default. Beside, flow control (enabled by default) affects PTP in some cases too. May be ptp4l should warn about this options? We should be able to detect it from user space. Regards, Oleksij
On Mon, Feb 06, 2023 at 06:47:13AM +0100, Oleksij Rempel wrote: > On Sat, Feb 04, 2023 at 02:13:32AM +0200, Vladimir Oltean wrote: > > On Wed, Feb 01, 2023 at 03:58:22PM +0100, Oleksij Rempel wrote: > > > With this patch series we provide EEE control for KSZ9477 family of switches and > > > AR8035 with i.MX6 configuration. > > > According to my tests, on a system with KSZ8563 switch and 100Mbit idle link, > > > we consume 0,192W less power per port if EEE is enabled. > > > > What is the code flow through the kernel with EEE? I wasn't able to find > > a good explanation about it. > > > > Is it advertised by default, if supported? I guess phy_advertise_supported() > > does that. > > Ack. > > > But is that desirable? Doesn't EEE cause undesired latency for MAC-level > > PTP timestamping on an otherwise idle link? > > Theoretically, MAC controls Low Power Idle states and even with some > "Wake" latency should be fully aware of actual ingress and egress time > stamps. I'm not sure if this is also true with Atheros SmartEEE, where the PHY is the one who enters LPI mode and buffers packets until it wakes up? > > Practically, right now I do not have such HW to confirm it. My project > is affected by EEE in different ways: Doesn't FEC support PTP? > - with EEE PTP has too much jitter > - without EEE, the devices consumes too much power in standby mode with > WoL enabled. Even switching to 10BaseT less power as 100BaseTX with > EEE would do. > > My view is probably biased by my environment - PTP is relatively rare > use case. EEE saves power (0,2W+0,2W per link in my case). Summary power > saving of all devices is potentially equal to X amount of power plants. > So, EEE should be enabled by default. I'm not contesting the value of EEE. Just wondering whether it's best for the kernel, rather than user space, to enable it by default. > > Beside, flow control (enabled by default) affects PTP in some cases too. You are probably talking about the fact that flow control may affect end-to-end delay measurements (across switches in a LAN). Yes, but EEE (or at least SmartEEE) may affect peer-to-peer delay measurements, which I see as worse. > > May be ptp4l should warn about this options? We should be able to detect > it from user space. This isn't necessarily a bad idea, even though it would end up renegotiating and losing the link. Maybe it would be good to drag Richard Cochran into the discussion too. After all he's the one who should agree what should and what shouldn't ptp4l be concerned with. > > Regards, > Oleksij > -- > Pengutronix e.K. | | > Steuerwalder Str. 21 | http://www.pengutronix.de/ | > 31137 Hildesheim, Germany | Phone: +49-5121-206917-0 | > Amtsgericht Hildesheim, HRA 2686 | Fax: +49-5121-206917-5555 |
> > > What is the code flow through the kernel with EEE? I wasn't able to find > > > a good explanation about it. > > > > > > Is it advertised by default, if supported? I guess phy_advertise_supported() > > > does that. The old flow is poorly defined. If the MAC supports EEE, it should call phy_init_eee(). That looks at the results of auto-neg and returns if EEE has been negotiated or not. However, i'm not aware of any code which disables by default the advertisement of EEE, or actually enables the negotiation of EEE. So there are probably a number of PHYs which are EEE capable, connected to a MAC driver which does not call phy_init_eee() and are advertising EEE and negotiating EEE. There might also be a subset of that which are actually doing EEE, despite not calling phy_init_eee(). So the current code is not good, and there is a danger we introduce power regressions as we sort this out. The current MAC/PHY API is pretty broken. We probably should be handling this similar to pause. A MAC which supports pause should call phy_support_asym_pause() or phy_support_sym_pause() which will cause the PHY to advertise its supported Pause modes. So we might want to add a phy_support_eee()? We then want the result of EEE negotiation available in phydev for when the link_adjust() callback is called. A quick look at a few MAC drivers seems to indicate many are getting it wrong and don't actually wait for the result of the auto-neg.... Andrew
On Mon, Feb 06, 2023 at 04:10:38PM +0200, Vladimir Oltean wrote: > On Mon, Feb 06, 2023 at 06:47:13AM +0100, Oleksij Rempel wrote: > > On Sat, Feb 04, 2023 at 02:13:32AM +0200, Vladimir Oltean wrote: > > > On Wed, Feb 01, 2023 at 03:58:22PM +0100, Oleksij Rempel wrote: > > > > With this patch series we provide EEE control for KSZ9477 family of switches and > > > > AR8035 with i.MX6 configuration. > > > > According to my tests, on a system with KSZ8563 switch and 100Mbit idle link, > > > > we consume 0,192W less power per port if EEE is enabled. > > > > > > What is the code flow through the kernel with EEE? I wasn't able to find > > > a good explanation about it. > > > > > > Is it advertised by default, if supported? I guess phy_advertise_supported() > > > does that. > > > > Ack. > > > > > But is that desirable? Doesn't EEE cause undesired latency for MAC-level > > > PTP timestamping on an otherwise idle link? > > > > Theoretically, MAC controls Low Power Idle states and even with some > > "Wake" latency should be fully aware of actual ingress and egress time > > stamps. > > I'm not sure if this is also true with Atheros SmartEEE, where the PHY > is the one who enters LPI mode and buffers packets until it wakes up? Yes, you right. With SmartEEE without MAC assistance, PTP will be broken. At the same time, if MAC is PTP and EEE capable, the same PHY with SmartEEE disabled should work just fine. > > Practically, right now I do not have such HW to confirm it. My project > > is affected by EEE in different ways: > > Doesn't FEC support PTP? FEC do supports PTP, but do not support EEE on i.MX6/7 variants. > > - with EEE PTP has too much jitter > > - without EEE, the devices consumes too much power in standby mode with > > WoL enabled. Even switching to 10BaseT less power as 100BaseTX with > > EEE would do. > > > > My view is probably biased by my environment - PTP is relatively rare > > use case. EEE saves power (0,2W+0,2W per link in my case). Summary power > > saving of all devices is potentially equal to X amount of power plants. > > So, EEE should be enabled by default. > > I'm not contesting the value of EEE. Just wondering whether it's best > for the kernel, rather than user space, to enable it by default. I woulds say, at the end the switch will decide what functionality will be advertised. Other nodes should just tell what capabilities they support. > > > > Beside, flow control (enabled by default) affects PTP in some cases too. > > You are probably talking about the fact that flow control may affect > end-to-end delay measurements (across switches in a LAN). Yes, but EEE > (or at least SmartEEE) may affect peer-to-peer delay measurements, which > I see as worse. I agree. User space should be notified some how about SmartEEE functionality. Especially if it is incompatible with some other functionality like PTP. It took me some time to understand why my PTP sync was so unstable. SmartEEE was just silently enabled by HW and no EEE related information was provided to user space. > > May be ptp4l should warn about this options? We should be able to detect > > it from user space. > > This isn't necessarily a bad idea, even though it would end up > renegotiating and losing the link. My idea was to inform the user, not actively do what ever is needed. It can conflict with other services or make system administrator scratch the head without understanding why things magically happen. > Maybe it would be good to drag Richard Cochran into the discussion too. > After all he's the one who should agree what should and what shouldn't > ptp4l be concerned with. ACK. Regards, Oleksij
On Mon, Feb 06, 2023 at 04:39:52PM +0100, Andrew Lunn wrote: > > > > What is the code flow through the kernel with EEE? I wasn't able to find > > > > a good explanation about it. > > > > > > > > Is it advertised by default, if supported? I guess phy_advertise_supported() > > > > does that. > > The old flow is poorly defined. If the MAC supports EEE, it should > call phy_init_eee(). That looks at the results of auto-neg and returns > if EEE has been negotiated or not. > > However, i'm not aware of any code which disables by default the > advertisement of EEE, or actually enables the negotiation of EEE. So > there are probably a number of PHYs which are EEE capable, connected > to a MAC driver which does not call phy_init_eee() and are advertising > EEE and negotiating EEE. There might also be a subset of that which > are actually doing EEE, despite not calling phy_init_eee(). > > So the current code is not good, and there is a danger we introduce > power regressions as we sort this out. > > The current MAC/PHY API is pretty broken. We probably should be > handling this similar to pause. A MAC which supports pause should call > phy_support_asym_pause() or phy_support_sym_pause() which will cause > the PHY to advertise its supported Pause modes. So we might want to > add a phy_support_eee()? We then want the result of EEE negotiation > available in phydev for when the link_adjust() callback is called. Good point. SmartEEE will be probably a bit more challenging. If MAC do not advertise EEE support, SmartEEE can be enabled. But it would break PTP if SmartEEE is active. Except SmartEEE capable PHY implements own PTP support. In any case, user space will need extra information to identify potential issues. > A quick look at a few MAC drivers seems to indicate many are getting > it wrong and don't actually wait for the result of the auto-neg.... Some ethernet driver trying to do own EEE state detection, and doing false positive detection on not supported states - for example half duplex.
> SmartEEE will be probably a bit more challenging. If MAC do not > advertise EEE support, SmartEEE can be enabled. But it would break PTP > if SmartEEE is active. Except SmartEEE capable PHY implements own PTP > support. In any case, user space will need extra information to > identify potential issues. If we have a MAC driver which does not implement the ethtool set_eee() and get_eee() ops, and a dev->phydev with the SmartEEE flag set, we could have net/ethtool/eee.c call direct into phylib. As for PTP and EEE, maybe we want the core PTP code to try calling get_eee() and at minimum issue a warning if it is enabled, if it thinks MAC PTP is being used? Andrew