Received: by 2002:a05:6358:11c7:b0:104:8066:f915 with SMTP id i7csp4305704rwl; Mon, 3 Apr 2023 03:04:42 -0700 (PDT) X-Google-Smtp-Source: AKy350bfct+Hwut6D2jH6JQ+FVT9+g9tNWyG3Zc26QfaAPm84Lasq6KgGdwu8IVOT2oVase1T+Oj X-Received: by 2002:a17:903:2308:b0:1a1:c7b2:e7c7 with SMTP id d8-20020a170903230800b001a1c7b2e7c7mr41452706plh.49.1680516282247; Mon, 03 Apr 2023 03:04:42 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1680516282; cv=none; d=google.com; s=arc-20160816; b=Byh/KD+SK+oGvwtW2mrKyM/NuXrByiWsJY9gdLtg+YWQuj3mJ2X8kLrgdzyQqLtvas yqP8hmjyXp23UwWFA4EaRuxPF0IwvDvPrfGCWak+RF0SohHnuQiSwgRa12E4dT58dyJj Sw5fBG1MV0yDe9UIJLld6oZ6oEb+F/ggqLwysArho7oTNv1RH7Mco8TUA58nj1ks+nfB r616wIGQY206VHFoM61g+qKPiVlhC0GwrvZovaynkhoAffPt8FoSKruSiuqq2kZOlDGv 0jJTKNxkrCwSmmOMdQzpPdJpVFD+lpK5ytCq8jA+UlqfSJ/S/TtMXlRbbkEIcS11emmS QFig== 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 :references:to:content-language:subject:cc:user-agent:mime-version :date:message-id:dkim-signature; bh=hOOnSCDMsEtKS/hy/QafgFLTNITROy9fX/zerQe1dZM=; b=Ll6u6okV4Bp2ewlIf8IIrhQbiDG5zYQ486oBgSBbBqcF5VECDUOp0xwKYEyB8PhMrV Zgz5eMnTe+93MKcbebNbalEYKgAwSLPWLMkg0eRDfD+fcwWBk99PcmXDluE5Xz3rhRzg psOIX4xJE+bfDDvKd3dgWJCLtU9+14wpfRvVeunFtUaEEbAbjxm+SntRIpm75y36rEhh yrGNChRn970mUmC2cQi1zQ/0FeRFROLM3QKzKCHZ92tKJydUjlkNSLXDxhsk7S+NAdjJ pyzJlYXqIVUhOmntvU5Js1Kc879m9XIY+EPP1G/ip1DyWVkDhgiCUPG4uU9R3KdohsFY V5CQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=wfOLp10m; 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=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id a10-20020a63d40a000000b004e850715f99si7961702pgh.259.2023.04.03.03.04.30; Mon, 03 Apr 2023 03:04:42 -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=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=wfOLp10m; 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=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231918AbjDCKAz (ORCPT + 99 others); Mon, 3 Apr 2023 06:00:55 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:51158 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231837AbjDCKAs (ORCPT ); Mon, 3 Apr 2023 06:00:48 -0400 Received: from fllv0016.ext.ti.com (fllv0016.ext.ti.com [198.47.19.142]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id D039F1B6; Mon, 3 Apr 2023 03:00:43 -0700 (PDT) Received: from fllv0035.itg.ti.com ([10.64.41.0]) by fllv0016.ext.ti.com (8.15.2/8.15.2) with ESMTP id 333A0RJQ004570; Mon, 3 Apr 2023 05:00:27 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ti.com; s=ti-com-17Q1; t=1680516027; bh=hOOnSCDMsEtKS/hy/QafgFLTNITROy9fX/zerQe1dZM=; h=Date:CC:Subject:To:References:From:In-Reply-To; b=wfOLp10mexZZPICRqlra3Th32jY3kQ95UhRonEhv5DwK6KSRd5wEsq8AtBgw7yEXQ W6svJE5nLq56UOdZXl7JwgHzczVNZY1ROSpUBsQBoo5o4/I+5+rCYjVF6yxzd3Ia9j 6hPCcGz8N8BfxSvJReETYhN3l2GQvIBhO99xjHig= Received: from DLEE104.ent.ti.com (dlee104.ent.ti.com [157.170.170.34]) by fllv0035.itg.ti.com (8.15.2/8.15.2) with ESMTPS id 333A0Rce126569 (version=TLSv1.2 cipher=AES256-GCM-SHA384 bits=256 verify=FAIL); Mon, 3 Apr 2023 05:00:27 -0500 Received: from DLEE102.ent.ti.com (157.170.170.32) by DLEE104.ent.ti.com (157.170.170.34) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.2507.16; Mon, 3 Apr 2023 05:00:27 -0500 Received: from lelv0327.itg.ti.com (10.180.67.183) by DLEE102.ent.ti.com (157.170.170.32) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.2507.16 via Frontend Transport; Mon, 3 Apr 2023 05:00:27 -0500 Received: from [172.24.145.61] (ileaxei01-snat2.itg.ti.com [10.180.69.6]) by lelv0327.itg.ti.com (8.15.2/8.15.2) with ESMTP id 333A0NQY049202; Mon, 3 Apr 2023 05:00:24 -0500 Message-ID: <76f3ac82-461d-4571-3189-501d96781bb0@ti.com> Date: Mon, 3 Apr 2023 15:30:22 +0530 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.9.0 CC: , , , , , , , , , Subject: Re: [PATCH net-next 2/2] net: ethernet: ti: am65-cpsw: Enable USXGMII mode for J784S4 CPSW9G Content-Language: en-US To: "Russell King (Oracle)" 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> From: Siddharth Vadapalli In-Reply-To: Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 7bit X-EXCLAIMER-MD-CONFIG: e1e8a2fd-e40a-4ac6-ac9b-f7e9cc9ee180 X-Spam-Status: No, score=-3.9 required=5.0 tests=DKIMWL_WL_HIGH,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,NICE_REPLY_A,RCVD_IN_DNSWL_MED, SPF_HELO_PASS,SPF_PASS 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 03/04/23 15:27, Russell King (Oracle) wrote: > 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. Sure, thank you. I will add a TODO in that section, indicating that it needs to be verified and fixed. Regards, Siddharth.