Received: by 2002:a05:6358:11c7:b0:104:8066:f915 with SMTP id i7csp882110rwl; Fri, 31 Mar 2023 03:57:51 -0700 (PDT) X-Google-Smtp-Source: AKy350b2QTm0Gh/laT96NIPFKU1kKdx+uHgV0GfBHbF5N9Kn1OUtnj1JI5rDervW36uI/gpoDyCE X-Received: by 2002:a17:906:1001:b0:93f:e5e4:8c13 with SMTP id 1-20020a170906100100b0093fe5e48c13mr16911239ejm.5.1680260271473; Fri, 31 Mar 2023 03:57:51 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1680260271; cv=none; d=google.com; s=arc-20160816; b=zOT+EP6gU1OdyM+LRzmdEBzUcHAiSTEirYaS3b0DYxfvBQIFkJu2WBfkx6WngSla3S bEdNw4M1f3zTu1d8PpaFaSv6SYZQf2prY94kNZAETk0AxYH5HXnvWlSY4Ay0rZRokWsu dftquKyPPCHFXLC9W80JnIhevLJ5nxPFXIU8XXBS+rgQkcjZbU9a+2k9Pg3Nep7+OnrK GJOy8S4hckwGs0DCAOrSyr6hKNwN9MiYJZtcG14udjjL4qA2EASzmoyp+3khiO2Mbj3U J0ewPENsEvHKFRQKrR8tY4xb/JOrkCha8vSMGkZFRNVO6RXHNUpp07sLXt99rHcMuVnn cAkQ== 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=vGibYf51DWXfnAFd3gkctzksFbFQJfSosSZkNqZy8SI=; b=tNEGr7J764VuEmuRqPzk/KYKPyGzBwuw+H/Nxi9oOANe/wFf8BZiKYpy6b6hUE8QJZ JqpJ3QGkbsG2+HC/LgefW8jgd81k8iSrHCRVJh3Zv2Z9Vt65BuGNTMR6I4QpM1mJ11qt AwxaLcOfUDrwHFVOUOqpvpOWdAW9lub217lzpxVPLmQ3B2LdLTZzew9mCE1VmWbHDPe4 vgdbN13REKArjqkQwhd3Ehtxs7/sCTZRrQyBWK06ebopK6e4CCOQiXAqd11v7CFdluxc GiHJl5u1XVLj4Zrj6XQRH0W2rZvk63AnHyiwUVEsNNmYjqBfqYt6ZQUrzgjVDwDciNj7 H+PA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=ZZfP6X2h; 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 se1-20020a170906ce4100b0093cf8c96422si1743235ejb.719.2023.03.31.03.57.26; Fri, 31 Mar 2023 03:57:51 -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=ZZfP6X2h; 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 S231718AbjCaKyB (ORCPT + 99 others); Fri, 31 Mar 2023 06:54:01 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:56482 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231751AbjCaKxt (ORCPT ); Fri, 31 Mar 2023 06:53:49 -0400 Received: from lelv0142.ext.ti.com (lelv0142.ext.ti.com [198.47.23.249]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 46FE71D863; Fri, 31 Mar 2023 03:53:36 -0700 (PDT) Received: from fllv0035.itg.ti.com ([10.64.41.0]) by lelv0142.ext.ti.com (8.15.2/8.15.2) with ESMTP id 32VArKSF029463; Fri, 31 Mar 2023 05:53:20 -0500 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ti.com; s=ti-com-17Q1; t=1680260000; bh=vGibYf51DWXfnAFd3gkctzksFbFQJfSosSZkNqZy8SI=; h=Date:CC:Subject:To:References:From:In-Reply-To; b=ZZfP6X2hdB2j2SE3fgYE4GOVuwA3MJRbQvO6tcdkmtpQxZeeBwsZIROd2rfSJ7xi7 usDOIhhpm51pjzd6Uv3AMN+UGEXBzuYHG2vnAcy3bmxj2nlc2si29rglytfA85UpKZ 8+6euLqLLq4grnu4EBomISLIsKPDNqEavaVHey/o= Received: from DLEE106.ent.ti.com (dlee106.ent.ti.com [157.170.170.36]) by fllv0035.itg.ti.com (8.15.2/8.15.2) with ESMTPS id 32VArKFd067525 (version=TLSv1.2 cipher=AES256-GCM-SHA384 bits=256 verify=FAIL); Fri, 31 Mar 2023 05:53:20 -0500 Received: from DLEE108.ent.ti.com (157.170.170.38) by DLEE106.ent.ti.com (157.170.170.36) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.2507.16; Fri, 31 Mar 2023 05:53:20 -0500 Received: from fllv0039.itg.ti.com (10.64.41.19) by DLEE108.ent.ti.com (157.170.170.38) 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; Fri, 31 Mar 2023 05:53:20 -0500 Received: from [172.24.145.61] (ileaxei01-snat.itg.ti.com [10.180.69.5]) by fllv0039.itg.ti.com (8.15.2/8.15.2) with ESMTP id 32VArGJs114355; Fri, 31 Mar 2023 05:53:17 -0500 Message-ID: Date: Fri, 31 Mar 2023 16:23:16 +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: <20230331065110.604516-1-s-vadapalli@ti.com> <20230331065110.604516-3-s-vadapalli@ti.com> <54c3964b-5dd8-c55e-08db-61df4a07797c@ti.com> <7a9c96f4-6a94-4a2c-18f5-95f7246e10d5@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=-2.5 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 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. Regards, Siddharth.