Received: by 2002:a05:6358:9144:b0:117:f937:c515 with SMTP id r4csp1650453rwr; Fri, 5 May 2023 18:33:39 -0700 (PDT) X-Google-Smtp-Source: ACHHUZ7JtTYo6dwLhIGRUWM5sOgjT6TdlM3Kueh1JpC/cxRzUEU+Gwm+3v26OSnl7BCc179wZkh/ X-Received: by 2002:a17:90a:b908:b0:250:4876:26a8 with SMTP id p8-20020a17090ab90800b00250487626a8mr1029835pjr.13.1683336818921; Fri, 05 May 2023 18:33:38 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1683336818; cv=none; d=google.com; s=arc-20160816; b=ByXb0/ClgNRZchBcd0HFiTDZTnkYzw9z70qwCXMVpA6p/JKPCwcY3XOjKX3DR7cZeo AllMtaMidSuYmbeSCasigdxejw5AuJy6FX4OMAULOv0f0aDOg0qMa7KYpIeyCrjPQcgp LdpLY/s1wGdcdDOym2AxG0fxNWEViaB6ZFYPC1F8bytaNzXEfnVtQG69ZvaM+mKTN346 vsgZ63oHki+k++szcBIc5cRITbQ2ZjKNy9NP/ycnofEriZqbGruecQaUu4tcuRSe+NP6 XmnV0rTPJu+Yn8HwIWMMwMXQT5lA72ZFrSJTRCPhH0ipQl+su8kVW6cb8nhV78Pr2O+3 e6uw== 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=LcksdYxtYT+g/VUg8PkaNLDhMbtjlSTLbkxe2XA1QcA=; b=qMpalipDctvJVl6n1E3naRpl0Yoo3mM94J5modwrknJHq5FydLsw4zCU9Oj2hVLrSh YUlVT9It+92eFQO+13xrIjI3islWFQfedr+qquv+vhJX7/Agv+rkIdmq9qI1k6ktBFzI AGeojA/QxBkPyCLVJ+4dNYPYnBnyXW37R/p7EqpEEl5I11I9tdbvY2cwcfgyHU1iX3T5 7X65gaWNurt3sfyxfsBGpFjKFs2otEyuV9u8kofjsgEfIb9YT6vWsKr+pOeTFsOX+YHI U/1p8e0sn2c+yqjamL3uY/wU9wjpdNXVF26z5/2wcghmFfDXgbqdNamYBOCiRx/SOjd7 KoQA== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=motor-comm.com Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id j9-20020a170903024900b0019ca54e71e4si3112750plh.224.2023.05.05.18.33.26; Fri, 05 May 2023 18:33:38 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=motor-comm.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230009AbjEFBa2 (ORCPT + 99 others); Fri, 5 May 2023 21:30:28 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:53012 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229698AbjEFBa1 (ORCPT ); Fri, 5 May 2023 21:30:27 -0400 Received: from out28-4.mail.aliyun.com (out28-4.mail.aliyun.com [115.124.28.4]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 08CCF1991; Fri, 5 May 2023 18:30:23 -0700 (PDT) X-Alimail-AntiSpam: AC=CONTINUE;BC=0.1096482|-1;CH=green;DM=|CONTINUE|false|;DS=CONTINUE|ham_system_inform|0.122501-0.00138785-0.876111;FP=0|0|0|0|0|-1|-1|-1;HT=ay29a033018047208;MF=frank.sae@motor-comm.com;NM=1;PH=DS;RN=15;RT=15;SR=0;TI=SMTPD_---.SZWUQ06_1683336615; Received: from 10.0.2.15(mailfrom:Frank.Sae@motor-comm.com fp:SMTPD_---.SZWUQ06_1683336615) by smtp.aliyun-inc.com; Sat, 06 May 2023 09:30:16 +0800 Message-ID: Date: Sat, 6 May 2023 09:29:28 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:102.0) Gecko/20100101 Thunderbird/102.10.0 Subject: Re: [PATCH v2 2/2] net: phy: motorcomm: Add pad drive strength cfg support To: Samin Guo , linux-kernel@vger.kernel.org, devicetree@vger.kernel.org, netdev@vger.kernel.org, Peter Geis Cc: "David S . Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Rob Herring , Krzysztof Kozlowski , Andrew Lunn , Heiner Kallweit , Russell King , Yanhong Wang References: <20230505090558.2355-1-samin.guo@starfivetech.com> <20230505090558.2355-3-samin.guo@starfivetech.com> Content-Language: en-US From: Frank Sae In-Reply-To: <20230505090558.2355-3-samin.guo@starfivetech.com> Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 7bit X-Spam-Status: No, score=-6.2 required=5.0 tests=BAYES_00,NICE_REPLY_A, RCVD_IN_DNSWL_NONE,RCVD_IN_MSPIKE_H2,SPF_HELO_NONE,SPF_PASS, T_SCC_BODY_TEXT_LINE,UNPARSEABLE_RELAY autolearn=ham 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 2023/5/5 17:05, Samin Guo wrote: > The motorcomm phy (YT8531) supports the ability to adjust the drive > strength of the rx_clk/rx_data, and the default strength may not be > suitable for all boards. So add configurable options to better match > the boards.(e.g. StarFive VisionFive 2) > > Signed-off-by: Samin Guo > --- > drivers/net/phy/motorcomm.c | 46 +++++++++++++++++++++++++++++++++++++ > 1 file changed, 46 insertions(+) > > diff --git a/drivers/net/phy/motorcomm.c b/drivers/net/phy/motorcomm.c > index 2fa5a90e073b..191650bb1454 100644 > --- a/drivers/net/phy/motorcomm.c > +++ b/drivers/net/phy/motorcomm.c > @@ -236,6 +236,7 @@ > */ > #define YTPHY_WCR_TYPE_PULSE BIT(0) > > +#define YTPHY_PAD_DRIVE_STRENGTH_REG 0xA010 > #define YTPHY_SYNCE_CFG_REG 0xA012 > #define YT8521_SCR_SYNCE_ENABLE BIT(5) > /* 1b0 output 25m clock > @@ -260,6 +261,14 @@ > #define YT8531_SCR_CLK_SRC_REF_25M 4 > #define YT8531_SCR_CLK_SRC_SSC_25M 5 > > +#define YT8531_RGMII_RXC_DS_DEFAULT 0x3 > +#define YT8531_RGMII_RXC_DS_MAX 0x7 > +#define YT8531_RGMII_RXC_DS GENMASK(15, 13) > +#define YT8531_RGMII_RXD_DS_DEFAULT 0x3 > +#define YT8531_RGMII_RXD_DS_MAX 0x7 > +#define YT8531_RGMII_RXD_DS_LOW GENMASK(5, 4) /* Bit 1/0 of rxd_ds */ > +#define YT8531_RGMII_RXD_DS_HI BIT(12) /* Bit 2 of rxd_ds */ YT8531_RGMII_xxx is bit define for YTPHY_PAD_DRIVE_STRENGTH_REG, so it is better to put it under the define of YTPHY_PAD_DRIVE_STRENGTH_REG. YT8531_RGMII_xxx bit define as reverse order: #define YTPHY_PAD_DRIVE_STRENGTH_REG 0xA010 #define YT8531_RGMII_RXC_DS GENMASK(15, 13) #define YT8531_RGMII_RXD_DS_HI BIT(12) /* Bit 2 of rxd_ds */ <------- #define YT8531_RGMII_RXD_DS_LOW GENMASK(5, 4) /* Bit 1/0 of rxd_ds */ ... > + > /* Extended Register end */ > > #define YTPHY_DTS_OUTPUT_CLK_DIS 0 > @@ -1495,6 +1504,7 @@ static int yt8531_config_init(struct phy_device *phydev) > { > struct device_node *node = phydev->mdio.dev.of_node; > int ret; > + u32 ds, val; > > ret = ytphy_rgmii_clk_delay_config_with_lock(phydev); > if (ret < 0) > @@ -1518,6 +1528,42 @@ static int yt8531_config_init(struct phy_device *phydev) > return ret; > } > > + ds = YT8531_RGMII_RXC_DS_DEFAULT; > + if (!of_property_read_u32(node, "motorcomm,rx-clk-driver-strength", &val)) { > + if (val > YT8531_RGMII_RXC_DS_MAX) > + return -EINVAL; > + > + ds = val; > + } > + > + ret = ytphy_modify_ext_with_lock(phydev, > + YTPHY_PAD_DRIVE_STRENGTH_REG, > + YT8531_RGMII_RXC_DS, > + FIELD_PREP(YT8531_RGMII_RXC_DS, ds)); > + if (ret < 0) > + return ret; > + > + ds = FIELD_PREP(YT8531_RGMII_RXD_DS_LOW, YT8531_RGMII_RXD_DS_DEFAULT); > + if (!of_property_read_u32(node, "motorcomm,rx-data-driver-strength", &val)) { > + if (val > YT8531_RGMII_RXD_DS_MAX) > + return -EINVAL; > + > + if (val > FIELD_MAX(YT8531_RGMII_RXD_DS_LOW)) { > + ds = val & FIELD_MAX(YT8531_RGMII_RXD_DS_LOW); > + ds = FIELD_PREP(YT8531_RGMII_RXD_DS_LOW, ds); > + ds |= YT8531_RGMII_RXD_DS_HI; > + } else { > + ds = FIELD_PREP(YT8531_RGMII_RXD_DS_LOW, val); > + } > + } > + > + ret = ytphy_modify_ext_with_lock(phydev, > + YTPHY_PAD_DRIVE_STRENGTH_REG, > + YT8531_RGMII_RXD_DS_LOW | YT8531_RGMII_RXD_DS_HI, > + ds); > + if (ret < 0) > + return ret; > + > return 0; > } >