Received: by 2002:a05:6358:11c7:b0:104:8066:f915 with SMTP id i7csp4225134rwl; Mon, 3 Apr 2023 01:35:48 -0700 (PDT) X-Google-Smtp-Source: AKy350YKL6jAhR/N7Qp9qqX5umwuzQ5axFmAiRYXzISxxG7sKmJrH/5QMumwejNB15dwsAaRWig3 X-Received: by 2002:a17:902:c401:b0:1a1:b9e6:2896 with SMTP id k1-20020a170902c40100b001a1b9e62896mr49589710plk.45.1680510948083; Mon, 03 Apr 2023 01:35:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1680510948; cv=none; d=google.com; s=arc-20160816; b=k8Kf+/xuUpvgc9AWUoBfgNwuCiVDVbgAy/mnS8XZ1ykBb2lR+SdVOhSlCv68L59CZH LjhKhmVkteQT/ik/kusa7CXWbTsDB63OR2inj8oB9O+wb8FfQvH7FSJA4opigdpmVKqT TVPcHa7ANZ82hNrhor4b78Llw/1AU2opDNaJd7YLuqTwQ/V+bXn0Lg+mBOOimAxPB+aJ yKu77nuFvoyVI4djOBH4olv+yMDGSZFo07Nk+xP+bkBPOQ/zTanUoqTr0EVAHgx/5OBv RNtYgJdRUfgdmkCO7NbG4RKKVb3Bd+vCG9TA85U/KYBoukUFL5gQxbWMQmThcHFN9Fzo 2VFQ== 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=01gayVV3++Wf58D2nrigu1LyEW250ZpuC9pqh/U9RlA=; b=rdbD38/qoV8neDgbK/9j+FQYnZz8NcVOPbAvfN8r3Z2p1A1N8ORsa2+5gouzuHpcyx rMh4eCwBaoYx6qs96+Nq38eoBXnLOq5UcafOXPp0HIgbHXBCEyT6vlcNijAJWgm09Q2v n3rEZReffRCKppU2wSStt1S7C79+in+U6BAoSq2R/HXdmRrNBfg7WZyFk3CHYPRfvWLM fKdJbzGkIcNK3qLFujG19PERNDKl92GzUQ4Vo1GDTZ3Ofn8wI+Qkdq9O4Kyfi97e5u8I A11Khr/aa+kjfTIK90xAa9DF2415Pc4L3Fue5bU25mEKmdBL0k1vTgBgyWXPiRygJPvo 49OA== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail (test mode) header.i=@armlinux.org.uk header.s=pandora-2019 header.b=mtoKptTH; 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 t21-20020a6564d5000000b004fb961e0592si7484693pgv.565.2023.04.03.01.35.36; Mon, 03 Apr 2023 01:35:48 -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=mtoKptTH; 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 S231876AbjDCIcx (ORCPT + 99 others); Mon, 3 Apr 2023 04:32:53 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51720 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231855AbjDCIco (ORCPT ); Mon, 3 Apr 2023 04:32:44 -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 0D2FD5BB9; Mon, 3 Apr 2023 01:32:39 -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=01gayVV3++Wf58D2nrigu1LyEW250ZpuC9pqh/U9RlA=; b=mtoKptTHdC8YSa2GcFbmSs0PhN uf2NXfVTDV+4bzJ2P7+iarjijbx/r5Tx//zCtL030LbKB2SxHY/2yvGeje/QW1s5SvhH7mdTCyNZU 7EyoODvszE6IMXoECN+HvNvgtwcnpWES5Up7VsDFAyEYmafZrXz9s7BIZEPcezKr+z8guK0+oI6Sb wpr0Af4+ZSbfW+nPRbqUGni7zsqlM0WS6LRgi3Dcn6ZMpKOxF+dw2+iwJ5x8vnclu2XKVJ8a0evhd OGVLjdHYgL9DmAKI8L99FeD0YRkev8r9Sr6h3AQbITut4KZn6IjR9gyqgkSEOosFe7C6weBKiRlBC Ot9TSWag==; Received: from shell.armlinux.org.uk ([fd8f:7570:feb6:1:5054:ff:fe00:4ec]:55416) 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 1pjFc5-0002OO-P7; Mon, 03 Apr 2023 09:32:29 +0100 Received: from linux by shell.armlinux.org.uk with local (Exim 4.94.2) (envelope-from ) id 1pjFc4-00044E-2P; Mon, 03 Apr 2023 09:32:28 +0100 Date: Mon, 3 Apr 2023 09:32:28 +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: <20230331065110.604516-3-s-vadapalli@ti.com> <54c3964b-5dd8-c55e-08db-61df4a07797c@ti.com> <7a9c96f4-6a94-4a2c-18f5-95f7246e10d5@ti.com> <1477e0c3-bb92-72b0-9804-0393c34571d3@ti.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: 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 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? -- RMK's Patch system: https://www.armlinux.org.uk/developer/patches/ FTTP is here! 80Mbps down 10Mbps up. Decent connectivity at last!