Received: by 2002:a05:6358:700f:b0:131:369:b2a3 with SMTP id 15csp559321rwo; Tue, 1 Aug 2023 23:49:49 -0700 (PDT) X-Google-Smtp-Source: APBJJlEzH2pqwMg4wALIZNrYfzaCISa9pD8kZSdfwh5dDYWwcfNOmhZ0AFoAT8w/OwbWZRa4fK0O X-Received: by 2002:a17:902:b68f:b0:1b8:9b17:f63d with SMTP id c15-20020a170902b68f00b001b89b17f63dmr11365867pls.23.1690958989081; Tue, 01 Aug 2023 23:49:49 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1690958989; cv=none; d=google.com; s=arc-20160816; b=Deio13AjTR0h2CdagTjL3AXWONf6s0vAOsENChQzBau0SkUy6AzjGxPt4fQN5A4CQL GnI+yeQO1OpH3HoLUWHQ2ltY7AC3NYYuuYnipIE4gBzJx2HTyyINCmx/drh+zsyDsc34 Fipv46NX/toiH7JHzkchefXE+fU0mEWa4d/6VkOXEhM+pwFRDGWXJuk8vJiz+yrqCdGn xFDOhbL/awqa6SnIe9z1BK9rdQaRHyGNgEzq666817kae2n6IpsznviZ6lWBtgzSU4Zn v/LuEiWO/0q6nDIK1pSzr5sCNxfU+YWFDu1gXC92fqcynf8rH/LmGshBmyCYlSjoh6ig LRUQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:in-reply-to:from :content-language:references:cc:to:subject:user-agent:mime-version :date:message-id; bh=piAbf3EMNwXmrHvfodkM7qOAP+bg2Jgp1hKxnOnPel4=; fh=UoPIrUR/AAgVsIwa8LCh7oqlYM7Rj3BlEVaBt8nygWo=; b=QOsnunS2eQRxylQwLZkZDxaw5+LQxDihtreb5FB/Z5YagSZDNeBhAKcMmY6dOvRl25 lRS7e7mWk/KSUKjIYOuGJXRrlFJZ/4jTlOb8M7prvz9dbVpQovf/xA+D6QGHKuFMYm07 3cznVDCkq3F7wA7sPWdFoTrTEw3lSp04UIEWq28K18IwgKh7p/ITOezkd06LFS2EoeAO 4Ig41pXty9EmB/a5KXTiaP2KGQ4iSk1mLYuJTz3ZCxIzytcIoJrVJ3Wy6Oh1vBnY2nbg 89ZNGBKJPG0Syz1//I3RvMsD1VTcwgZEDT6D6VM4c2TbI/twj7qhAGY4BmI/M6YxTFaJ Bozg== 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 Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id h9-20020a170902f54900b001bb98357332si10721542plf.365.2023.08.01.23.49.37; Tue, 01 Aug 2023 23:49:49 -0700 (PDT) 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 S232326AbjHBG0u (ORCPT + 99 others); Wed, 2 Aug 2023 02:26:50 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:59252 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231455AbjHBG0t (ORCPT ); Wed, 2 Aug 2023 02:26:49 -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 85BED26A3 for ; Tue, 1 Aug 2023 23:26:45 -0700 (PDT) Received: from ptz.office.stw.pengutronix.de ([2a0a:edc0:0:900:1d::77] helo=[127.0.0.1]) by metis.ext.pengutronix.de with esmtp (Exim 4.92) (envelope-from ) id 1qR5J2-0004uw-OL; Wed, 02 Aug 2023 08:26:00 +0200 Message-ID: Date: Wed, 2 Aug 2023 08:25:46 +0200 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.13.1 Subject: Re: [EXT] Re: [PATCH v3 net 2/2] net: stmmac: dwmac-imx: pause the TXC clock in fixed-link To: Shenwei Wang , Russell King , "David S. Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Maxime Coquelin , Shawn Guo , Sascha Hauer , Neil Armstrong , Kevin Hilman , Vinod Koul , Chen-Yu Tsai , Jernej Skrabec , Samuel Holland Cc: Giuseppe Cavallaro , Alexandre Torgue , Jose Abreu , Pengutronix Kernel Team , Fabio Estevam , dl-linux-imx , Jerome Brunet , Martin Blumenstingl , Bhupesh Sharma , Nobuhiro Iwamatsu , Simon Horman , Andrew Halaney , Bartosz Golaszewski , Wong Vee Khee , Revanth Kumar Uppala , Jochen Henneberg , "netdev@vger.kernel.org" , "linux-stm32@st-md-mailman.stormreply.com" , "linux-arm-kernel@lists.infradead.org" , "linux-kernel@vger.kernel.org" , "linux-amlogic@lists.infradead.org" , "imx@lists.linux.dev" , Frank Li References: <20230731161929.2341584-1-shenwei.wang@nxp.com> <20230731161929.2341584-3-shenwei.wang@nxp.com> Content-Language: en-US, de-DE From: Johannes Zink In-Reply-To: Content-Type: text/plain; charset=UTF-8; format=flowed Content-Transfer-Encoding: 7bit X-SA-Exim-Connect-IP: 2a0a:edc0:0:900:1d::77 X-SA-Exim-Mail-From: j.zink@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=-2.0 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_BLOCKED,SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE, URIBL_BLOCKED autolearn=unavailable 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: X-Mailing-List: linux-kernel@vger.kernel.org Hi Shenwei, On 8/1/23 19:10, Shenwei Wang wrote: > > >> -----Original Message----- >> From: Johannes Zink >> Sent: Tuesday, August 1, 2023 7:48 AM >> To: Shenwei Wang ; Russell King >> ; David S. Miller ; Eric >> Dumazet ; Jakub Kicinski ; Paolo >> Abeni ; Maxime Coquelin >> ; Shawn Guo ; Sascha >> Hauer ; Neil Armstrong ; >> Kevin Hilman ; Vinod Koul ; Chen- >> Yu Tsai ; Jernej Skrabec ; Samuel >> Holland >> Cc: Giuseppe Cavallaro ; Alexandre Torgue >> ; Jose Abreu ; >> Pengutronix Kernel Team ; Fabio Estevam >> ; dl-linux-imx ; Jerome Brunet >> ; Martin Blumenstingl >> ; Bhupesh Sharma >> ; Nobuhiro Iwamatsu >> ; Simon Horman >> ; Andrew Halaney ; >> Bartosz Golaszewski ; Wong Vee Khee >> ; Revanth Kumar Uppala ; Jochen >> Henneberg ; netdev@vger.kernel.org; linux- >> stm32@st-md-mailman.stormreply.com; linux-arm-kernel@lists.infradead.org; >> linux-kernel@vger.kernel.org; linux-amlogic@lists.infradead.org; >> imx@lists.linux.dev; Frank Li >> Subject: [EXT] Re: [PATCH v3 net 2/2] net: stmmac: dwmac-imx: pause the TXC >> clock in fixed-link >> >> Caution: This is an external email. Please take care when clicking links or >> opening attachments. When in doubt, report the message using the 'Report this >> email' button >> >> >> Hi Shenwei, >> >> thanks for your patch. >> >> On 7/31/23 18:19, Shenwei Wang wrote: >>> When using a fixed-link setup, certain devices like the SJA1105 >>> require a small pause in the TXC clock line to enable their internal >>> tunable delay line (TDL). >> >> If this is only required for some devices, is it safe to enforce this behaviour >> unconditionally for any kind of fixed link devices connected to the MX93 EQOS >> or could this possibly break for other devices? >> > > It won't impact normal devices. The link layer hasn't built up yet. > As Russel suggested in [1] - maybe you could rephrase your commit message for your v4 to point this out to future reviewers (apparently multiple people have had questions about this...) and have this fact also recorded in the git log later on. Also: does this only apply to i.MX93, or would we have to test and enable it on e.g. i.MX8MP as well? Thanks Johannes [1] ZMk/xqRP67zXHNrf@shell.armlinux.org.uk > Thanks, > Shenwei > >> Best regards >> Johannes >> >>> >>> To satisfy this requirement, this patch temporarily disables the TX >>> clock, and restarts it after a required period. This provides the >>> required silent interval on the clock line for SJA1105 to complete the >>> frequency transition and enable the internal TDLs. >>> >>> So far we have only enabled this feature on the i.MX93 platform. >>> >>> Signed-off-by: Shenwei Wang >>> Reviewed-by: Frank Li >>> --- >>> .../net/ethernet/stmicro/stmmac/dwmac-imx.c | 42 +++++++++++++++++++ >>> 1 file changed, 42 insertions(+) >>> >>> diff --git a/drivers/net/ethernet/stmicro/stmmac/dwmac-imx.c >>> b/drivers/net/ethernet/stmicro/stmmac/dwmac-imx.c >>> index 53ee5a42c071..2e4173d099f3 100644 >>> --- a/drivers/net/ethernet/stmicro/stmmac/dwmac-imx.c >>> +++ b/drivers/net/ethernet/stmicro/stmmac/dwmac-imx.c >>> @@ -32,6 +32,7 @@ >>> #define GPR_ENET_QOS_RGMII_EN (0x1 << 21) >>> >>> #define MX93_GPR_ENET_QOS_INTF_MODE_MASK GENMASK(3, 0) >>> +#define MX93_GPR_ENET_QOS_INTF_MASK GENMASK(3, 1) >>> #define MX93_GPR_ENET_QOS_INTF_SEL_MII (0x0 << 1) >>> #define MX93_GPR_ENET_QOS_INTF_SEL_RMII (0x4 << 1) >>> #define MX93_GPR_ENET_QOS_INTF_SEL_RGMII (0x1 << 1) >>> @@ -40,6 +41,7 @@ >>> #define DMA_BUS_MODE 0x00001000 >>> #define DMA_BUS_MODE_SFT_RESET (0x1 << 0) >>> #define RMII_RESET_SPEED (0x3 << 14) >>> +#define CTRL_SPEED_MASK GENMASK(15, 14) >>> >>> struct imx_dwmac_ops { >>> u32 addr_width; >>> @@ -56,6 +58,7 @@ struct imx_priv_data { >>> struct regmap *intf_regmap; >>> u32 intf_reg_off; >>> bool rmii_refclk_ext; >>> + void __iomem *base_addr; >>> >>> const struct imx_dwmac_ops *ops; >>> struct plat_stmmacenet_data *plat_dat; @@ -212,6 +215,42 @@ >>> static void imx_dwmac_fix_speed(void *priv, uint speed, uint mode) >>> dev_err(dwmac->dev, "failed to set tx rate %lu\n", rate); >>> } >>> >>> +static void imx_dwmac_fix_speed_mx93(void *priv, uint speed, uint >>> +mode) { >>> + struct imx_priv_data *dwmac = priv; >>> + int ctrl, old_ctrl, iface; >>> + >>> + imx_dwmac_fix_speed(priv, speed, mode); >>> + >>> + if (!dwmac || mode != MLO_AN_FIXED) >>> + return; >>> + >>> + if (regmap_read(dwmac->intf_regmap, dwmac->intf_reg_off, &iface)) >>> + return; >>> + >>> + iface &= MX93_GPR_ENET_QOS_INTF_MASK; >>> + if (iface != MX93_GPR_ENET_QOS_INTF_SEL_RGMII) >>> + return; >>> + >>> + old_ctrl = readl(dwmac->base_addr + MAC_CTRL_REG); >>> + ctrl = old_ctrl & ~CTRL_SPEED_MASK; >>> + regmap_update_bits(dwmac->intf_regmap, dwmac->intf_reg_off, >>> + MX93_GPR_ENET_QOS_INTF_MODE_MASK, 0); >>> + writel(ctrl, dwmac->base_addr + MAC_CTRL_REG); >>> + >>> + /* Ensure the settings for CTRL are applied and avoid CPU/Compiler >>> + * reordering. >>> + */ >>> + wmb(); >>> + >>> + usleep_range(10, 20); >>> + iface |= MX93_GPR_ENET_QOS_CLK_GEN_EN; >>> + regmap_update_bits(dwmac->intf_regmap, dwmac->intf_reg_off, >>> + MX93_GPR_ENET_QOS_INTF_MODE_MASK, iface); >>> + >>> + writel(old_ctrl, dwmac->base_addr + MAC_CTRL_REG); } >>> + >>> static int imx_dwmac_mx93_reset(void *priv, void __iomem *ioaddr) >>> { >>> struct plat_stmmacenet_data *plat_dat = priv; @@ -317,8 +356,11 >>> @@ static int imx_dwmac_probe(struct platform_device *pdev) >>> plat_dat->exit = imx_dwmac_exit; >>> plat_dat->clks_config = imx_dwmac_clks_config; >>> plat_dat->fix_mac_speed = imx_dwmac_fix_speed; >>> + if (of_machine_is_compatible("fsl,imx93")) >>> + plat_dat->fix_mac_speed = imx_dwmac_fix_speed_mx93; >>> plat_dat->bsp_priv = dwmac; >>> dwmac->plat_dat = plat_dat; >>> + dwmac->base_addr = stmmac_res.addr; >>> >>> ret = imx_dwmac_clks_config(dwmac, true); >>> if (ret) >> >> -- >> Pengutronix e.K. | Johannes Zink | >> Steuerwalder Str. 21 | >> https://www.pe/ >> ngutronix.de%2F&data=05%7C01%7Cshenwei.wang%40nxp.com%7C761fbb75c >> 1c24cfe091508db928d8ade%7C686ea1d3bc2b4c6fa92cd99c5c301635%7C0%7C >> 0%7C638264908852977732%7CUnknown%7CTWFpbGZsb3d8eyJWIjoiMC4wLjA >> wMDAiLCJQIjoiV2luMzIiLCJBTiI6Ik1haWwiLCJXVCI6Mn0%3D%7C3000%7C%7C% >> 7C&sdata=2l2zNfIaNnRJENmERehNae8g%2F%2BQqlxD2YRx7ksY2X%2BE%3D&r >> eserved=0 | >> 31137 Hildesheim, Germany | Phone: +49-5121-206917-0 | >> Amtsgericht Hildesheim, HRA 2686| Fax: +49-5121-206917-5555 | > > -- Pengutronix e.K. | Johannes Zink | Steuerwalder Str. 21 | https://www.pengutronix.de/ | 31137 Hildesheim, Germany | Phone: +49-5121-206917-0 | Amtsgericht Hildesheim, HRA 2686| Fax: +49-5121-206917-5555 |