Received: by 2002:a05:6358:11c7:b0:104:8066:f915 with SMTP id i7csp4310241rwl; Mon, 3 Apr 2023 03:08:40 -0700 (PDT) X-Google-Smtp-Source: AKy350Y7zBJUP/IG7QnW0wnEk47iUq1cv5baRy2ZRKfesMhqWLj5FhGmtcqYpGLPaWy3PKEHdSx1 X-Received: by 2002:a05:6402:1110:b0:4fb:6357:f393 with SMTP id u16-20020a056402111000b004fb6357f393mr31174862edv.1.1680516519811; Mon, 03 Apr 2023 03:08:39 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1680516519; cv=none; d=google.com; s=arc-20160816; b=DZTSVPjnzKKk/+pyBNuQENmqIMhPTbmJn5ojxwOknNYPA+MorDkojOPG2XZIwaD1u2 j6SNpKnr7xYRMXog9U/VKgLVLN7mXoFCUfo93EW1OhDKGCntvKyLI5n03E/gmCp6FmiL Hx65dJ6RfuI9j+myXEVrFbXPGhjGZkwYSALvk+9k9tB5lYDnvYMkZw5Y3b1ayXSItPZB NHebhOOakeCyGGOFsaz98KLhq1Y2ASr+NSklgrV5VDGFrDakyubPxIXooLbd+I/90uvv 9cjJfx9XaOiR3mwDsO31PjPy9yh+4M/z7lJaWwwuEJ6j2gkQRvKPqfHqjXBw7bs6hg0R +yfA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:in-reply-to:content-disposition :mime-version:references:message-id:subject:cc:to:from:date :dkim-signature; bh=pyhFn0jdoTsobZNce510NjqyzM5IANwDA98xSOqOsFI=; b=fBQV3PrsTzXOOnbMaMpYlepSEplItjD0gmtp50TrcqEVEhWRFdvmDi0YmctDQLbPeh 8jWAQsoKNKelfTS7WtaRZzRJp7sxX8OwhihyJoqfmqg4X0/y2y7Zq0qI3JmeQo8btjby A041b34PvxF1uTYugyXQzboIrPVNp/4OWupDENZI9IXUFkVAmmrqTOlW02/J3xtAXE// xs3k6v/ttEWIpevnTkrvZsjTAWjpZD/RblR3bzUMFG4a4MDx6RhwGuqUO1xVf1+tXYWl kS88IIvSPr24NKsln1A5copFeGYpWUkn+4PWGlHFJGNhmSrATn/UayjpibAwa6XfAd7c Gr9w== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail (test mode) header.i=@armlinux.org.uk header.s=pandora-2019 header.b=FUPU0WGX; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=armlinux.org.uk Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id l18-20020aa7c3d2000000b004acb2c92ba6si3085688edr.79.2023.04.03.03.08.15; Mon, 03 Apr 2023 03:08:39 -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; dkim=fail (test mode) header.i=@armlinux.org.uk header.s=pandora-2019 header.b=FUPU0WGX; 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=armlinux.org.uk Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S232008AbjDCJ5u (ORCPT + 99 others); Mon, 3 Apr 2023 05:57:50 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44878 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231918AbjDCJ5R (ORCPT ); Mon, 3 Apr 2023 05:57:17 -0400 Received: from pandora.armlinux.org.uk (pandora.armlinux.org.uk [IPv6:2001:4d48:ad52:32c8:5054:ff:fe00:142]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 2AE131116C; Mon, 3 Apr 2023 02:57:15 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=armlinux.org.uk; s=pandora-2019; h=Sender:In-Reply-To:Content-Type: MIME-Version:References:Message-ID:Subject:Cc:To:From:Date:Reply-To: Content-Transfer-Encoding:Content-ID:Content-Description:Resent-Date: Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID:List-Id: List-Help:List-Unsubscribe:List-Subscribe:List-Post:List-Owner:List-Archive; bh=pyhFn0jdoTsobZNce510NjqyzM5IANwDA98xSOqOsFI=; b=FUPU0WGXLPjAHQKKNI0UjcvDvd jU33r3l/K85aM/Y68NCv4XtVAorwnRukivHvmWAzqXc47PHj99UBjDX5RUTnlHtozhW54UF3sOyCk HTVvnvvcSCdy8uyPNtJ+l++pXk8TOTowxFhdHDkHrfWXTChEuBujuEPLruvxG5IfvFG/bhRtdV+9H 19tnuaHdbdhkRMQHxCw8MdhF0RHJOu+Fq66RfXhMoqJ/MbsJf/gs7G3/LgIRhJ6m2XSrMeLlD1A+e D2/Qq6G4ASzmItKzo+ytODCzPJUU+pMbQTUoZyi4MtJYPq35ooTtICKYBuCTzQqIICxf4Ki3CsQF6 v9PKtlhQ==; Received: from shell.armlinux.org.uk ([fd8f:7570:feb6:1:5054:ff:fe00:4ec]:39976) by pandora.armlinux.org.uk with esmtpsa (TLS1.3) tls TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384 (Exim 4.94.2) (envelope-from ) id 1pjGw0-0002Yf-GN; Mon, 03 Apr 2023 10:57:08 +0100 Received: from linux by shell.armlinux.org.uk with local (Exim 4.94.2) (envelope-from ) id 1pjGvw-00047W-7c; Mon, 03 Apr 2023 10:57:04 +0100 Date: Mon, 3 Apr 2023 10:57:04 +0100 From: "Russell King (Oracle)" To: Siddharth Vadapalli Cc: davem@davemloft.net, edumazet@google.com, kuba@kernel.org, pabeni@redhat.com, rogerq@kernel.org, netdev@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org, srk@ti.com Subject: Re: [PATCH net-next 2/2] net: ethernet: ti: am65-cpsw: Enable USXGMII mode for J784S4 CPSW9G Message-ID: References: <7a9c96f4-6a94-4a2c-18f5-95f7246e10d5@ti.com> <1477e0c3-bb92-72b0-9804-0393c34571d3@ti.com> <5114b342-6727-b27c-bc8c-c770ed4baa31@ti.com> <37ec04db-3ed2-49a4-9c0d-b9a00f49a0a4@ti.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <37ec04db-3ed2-49a4-9c0d-b9a00f49a0a4@ti.com> Sender: Russell King (Oracle) X-Spam-Status: No, score=-2.5 required=5.0 tests=DKIM_SIGNED,DKIM_VALID, DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_MED,SPF_HELO_NONE,SPF_NONE 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 On Mon, Apr 03, 2023 at 03:19:24PM +0530, Siddharth Vadapalli wrote: > > > On 03/04/23 14:29, Russell King (Oracle) wrote: > > On Mon, Apr 03, 2023 at 02:11:08PM +0530, Siddharth Vadapalli wrote: > >> > >> > >> On 03/04/23 14:02, Russell King (Oracle) wrote: > >>> On Mon, Apr 03, 2023 at 11:57:21AM +0530, Siddharth Vadapalli wrote: > >>>> Hello Russell, > >>>> > >>>> On 31/03/23 19:16, Siddharth Vadapalli wrote: > >>>>> > >>>>> > >>>>> On 31-03-2023 16:42, Russell King (Oracle) wrote: > >>>>>> On Fri, Mar 31, 2023 at 04:23:16PM +0530, Siddharth Vadapalli wrote: > >>>>>>> > >>>>>>> > >>>>>>> On 31/03/23 15:16, Russell King (Oracle) wrote: > >>>>>>>> On Fri, Mar 31, 2023 at 02:55:56PM +0530, Siddharth Vadapalli wrote: > >>>>>>>>> Russell, > >>>>>>>>> > >>>>>>>>> On 31/03/23 13:54, Russell King (Oracle) wrote: > >>>>>>>>>> On Fri, Mar 31, 2023 at 01:35:10PM +0530, Siddharth Vadapalli wrote: > >>>>>>>>>>> Hello Russell, > >>>>>>>>>>> > >>>>>>>>>>> Thank you for reviewing the patch. > >>>>>>>>>>> > >>>>>>>>>>> On 31/03/23 13:27, Russell King (Oracle) wrote: > >>>>>>>>>>>> On Fri, Mar 31, 2023 at 12:21:10PM +0530, Siddharth Vadapalli wrote: > >>>>>>>>>>>>> TI's J784S4 SoC supports USXGMII mode. Add USXGMII mode to the > >>>>>>>>>>>>> extra_modes member of the J784S4 SoC data. Additionally, configure the > >>>>>>>>>>>>> MAC Control register for supporting USXGMII mode. Also, for USXGMII > >>>>>>>>>>>>> mode, include MAC_5000FD in the "mac_capabilities" member of struct > >>>>>>>>>>>>> "phylink_config". > >>>>>>>>>>>> > >>>>>>>>>>>> I don't think TI "get" phylink at all... > >>>>>>>>>>>> > >>>>>>>>>>>>> diff --git a/drivers/net/ethernet/ti/am65-cpsw-nuss.c b/drivers/net/ethernet/ti/am65-cpsw-nuss.c > >>>>>>>>>>>>> index 4b4d06199b45..ab33e6fe5b1a 100644 > >>>>>>>>>>>>> --- a/drivers/net/ethernet/ti/am65-cpsw-nuss.c > >>>>>>>>>>>>> +++ b/drivers/net/ethernet/ti/am65-cpsw-nuss.c > >>>>>>>>>>>>> @@ -1555,6 +1555,8 @@ static void am65_cpsw_nuss_mac_link_up(struct phylink_config *config, struct phy > >>>>>>>>>>>>> mac_control |= CPSW_SL_CTL_GIG; > >>>>>>>>>>>>> if (interface == PHY_INTERFACE_MODE_SGMII) > >>>>>>>>>>>>> mac_control |= CPSW_SL_CTL_EXT_EN; > >>>>>>>>>>>>> + if (interface == PHY_INTERFACE_MODE_USXGMII) > >>>>>>>>>>>>> + mac_control |= CPSW_SL_CTL_XGIG | CPSW_SL_CTL_XGMII_EN; > >>>>>>>>>>>> > >>>>>>>>>>>> The configuration of the interface mode should *not* happen in > >>>>>>>>>>>> mac_link_up(), but should happen in e.g. mac_config(). > >>>>>>>>>>> > >>>>>>>>>>> I will move all the interface mode associated configurations to mac_config() in > >>>>>>>>>>> the v2 series. > >>>>>>>>>> > >>>>>>>>>> Looking at the whole of mac_link_up(), could you please describe what > >>>>>>>>>> effect these bits are having: > >>>>>>>>>> > >>>>>>>>>> CPSW_SL_CTL_GIG > >>>>>>>>>> CPSW_SL_CTL_EXT_EN > >>>>>>>>>> CPSW_SL_CTL_IFCTL_A > >>>>>>>>> > >>>>>>>>> CPSW_SL_CTL_GIG corresponds to enabling Gigabit mode (full duplex only). > >>>>>>>>> CPSW_SL_CTL_EXT_EN when set enables in-band mode of operation and when cleared > >>>>>>>>> enables forced mode of operation. > >>>>>>>>> CPSW_SL_CTL_IFCTL_A is used to set the RMII link speed (0=10 mbps, 1=100 mbps). > >>>>>>>> > >>>>>>>> Okay, so I would do in mac_link_up(): > >>>>>>>> > >>>>>>>> /* RMII needs to be manually configured for 10/100Mbps */ > >>>>>>>> if (interface == PHY_INTERFACE_MODE_RMII && speed == SPEED_100) > >>>>>>>> mac_control |= CPSW_SL_CTL_IFCTL_A; > >>>>>>>> > >>>>>>>> if (speed == SPEED_1000) > >>>>>>>> mac_control |= CPSW_SL_CTL_GIG; > >>>>>>>> if (duplex) > >>>>>>>> mac_control |= CPSW_SL_CTL_FULLDUPLEX; > >>>>>>>> > >>>>>>>> I would also make mac_link_up() do a read-modify-write operation to > >>>>>>>> only affect the bits that it is changing. > >>>>>>> > >>>>>>> This is the current implementation except for the SGMII mode associated > >>>>>>> operation that I had recently added. I will fix that. Also, the > >>>>>>> cpsw_sl_ctl_set() function which writes the mac_control value performs a read > >>>>>>> modify write operation. > >>>>>>> > >>>>>>>> > >>>>>>>> Now, for SGMII, I would move setting CPSW_SL_CTL_EXT_EN to mac_config() > >>>>>>>> to enable in-band mode - don't we want in-band mode enabled all the > >>>>>>>> time while in SGMII mode so the PHY gets the response from the MAC? > >>>>>>> > >>>>>>> Thank you for pointing it out. I will move that to mac_config(). > >>>>>>> > >>>>>>>> > >>>>>>>> Lastly, for RGMII at 10Mbps, you seem to suggest that you need RGMII > >>>>>>>> in-band mode enabled for that - but if you need RGMII in-band for > >>>>>>>> 10Mbps, wouldn't it make sense for the other speeds as well? If so, > >>>>>>>> wouldn't that mean that CPSW_SL_CTL_EXT_EN can always be set for > >>>>>>>> RGMII no matter what speed is being used? > >>>>>>> > >>>>>>> The CPSW MAC does not support forced mode at 10 Mbps RGMII. For this reason, if > >>>>>>> RGMII 10 Mbps is requested, it is set to in-band mode. > >>>>>> > >>>>>> What I'm saying is that if we have in-band signalling that is reliable > >>>>>> for a particular interface mode, why not always use it, rather than > >>>>>> singling out one specific speed as an exception? Does it not work in > >>>>>> 100Mbps and 1Gbps? > >>>> > >>>> While the CPSW MAC supports RGMII in-band status operation, the link partner > >>>> might not support it. I have also observed that forced mode is preferred to > >>>> in-band mode as implemented for another driver: > >>>> commit ade64eb5be9768e40c90ecb01295416abb2ddbac > >>>> net: dsa: microchip: Disable RGMII in-band status on KSZ9893 > >>>> > >>>> and in the mail thread at: > >>>> https://lore.kernel.org/netdev/20200905160647.GJ3164319@lunn.ch/ > >>>> based on Andrew's suggestion, using forced mode appears to be better. > >>>> > >>>> Additionally, I have verified that switching to in-band status causes a > >>>> regression. Thus, I will prefer keeping it in forced mode for 100 and 1000 Mbps > >>>> RGMII mode which is the existing implementation in the driver. Please let me know. > >>> > >>> Okay, so what this seems to mean is if you have a PHY that does not > >>> support in-band status in RGMII mode, then 10Mbps isn't possible - > >>> because the MAC requires in-band status mode to select 10Mbps. > >>> To put it another way, in such a combination, 10Mbps link modes > >>> should not be advertised, nor should they be reported to userspace > >>> as being supported. > >>> > >>> Is that correct? > >> > >> Yes, if the PHY does not support in-band status, 10 Mbps RGMII will not work, > >> despite the MAC supporting 10 Mbps in-band RGMII. However, I notice the following: > >> If the RGMII interface speed is set to 10 Mbps via ethtool, but the: > >> managed = "in-band-status"; > >> property is not mentioned in the device-tree, the interface is able to work with > >> 10 Mbps mode with the PHY. This is with the CPSW MAC configured for in-band mode > >> of operation at 10 Mbps RGMII mode. Please let me know what this indicates, > >> since it appears to me that 10 Mbps is functional in this special case (It might > >> be an erroneous configuration). > > > > I think you need to check carefully what is going on. > > > > Firstly, if you as the MAC is choosing to enable in-band status mode, > > but phylink isn't using in-band status mode, that is entirely a matter > > for your MAC driver. > > > > Secondly, you need to research what the PHY does during the inter-frame > > time (when in-band status would be transferred). This is when RX_CTL > > is 0,0, RX_DV is 0, RX_ER is 0. > > > > For in-band 10Mbps mode to work, RXD nibbles would need to be x001 > > (middle two bits indicate RX clock = 2.5MHz clock for 10Mbps, lsb > > indicates link up). MSB determines duplex. Remember that 10Mbps can > > appear to work with mismatched duplex settings but can cause chaos on > > networks when it disagrees with what the rest of the network is doing. > > > > So, I think before one says "setting in-band mode for 10Mbps with a > > PHY that doesn't support in-band" really needs caution and research > > to check what _actually_ ends up happening, and whether it is really > > correct to do this. > > Thank you for the detailed explanation. I will analyze it and fix this. In the > meanwhile, is it acceptable for me to post the v2 of this series, with the other > suggestions implemented, while maintaining the status quo for the 10 Mbps RGMII > configuration in the driver? Please let me know. Yes, but I would like a comment against the bit of code that enables in-band mode indicating that it's questionable whether it is correct. Thanks. -- RMK's Patch system: https://www.armlinux.org.uk/developer/patches/ FTTP is here! 80Mbps down 10Mbps up. Decent connectivity at last!