Received: by 2002:a05:6358:11c7:b0:104:8066:f915 with SMTP id i7csp1522578rwl; Fri, 7 Apr 2023 18:33:41 -0700 (PDT) X-Google-Smtp-Source: AKy350ZCCe9a4voFwZ7oCwpBOO9H+h3ajrwpZ6wn1dGdjzAr8Uq4KIZ3/vLajIv3M7+g9GTmp/Ze X-Received: by 2002:a05:6a20:4f21:b0:cc:5f8f:4f7a with SMTP id gi33-20020a056a204f2100b000cc5f8f4f7amr4546246pzb.27.1680917620800; Fri, 07 Apr 2023 18:33:40 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1680917620; cv=none; d=google.com; s=arc-20160816; b=G70RUZRksQAWt0BbiKLkRvx8V+Ma8oKoG676N3QKJqwxbr/bMvD2rleHI8VkGTOSO4 GIa0gb0WL2diWwDf0wFn2U5gfMW4tDhihq67ASmQF2lExeSGL07AdySNI7j5ECty+fmI xBVHnyZAIP8DVIXt9a2uIRuuzw25rmZlO0pNdmuKAxhh6qb4jzlMoxBejWp+4/v6bxmK FAfJCrEOe09CgDlyEX4aYANN/EAJQDlGrg3rTI5LzbyaixnwsYnDbQqLmMDmM+O8Q0Y3 fVXhrOGzMy9whqESuoVnsr3pbExIUNSl8CPwktNKvgbU6LKFXVHzCWK/xr299MDauOzx Zyxg== 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:cc:to:content-language:subject:user-agent:mime-version :date:message-id; bh=JGypKocCCoSpar+on3m1Ru0/FYH5a4wr04lo+DhNEEU=; b=kk0WCWnR0Dbx9RYMEU4HE6Lbn9K2Lvz0QfevCpLly+Fb4mCY94bN3/L5t4jJWhPuKG A0qH02gvwqvRGxpEdsweHmt7+3doCw52LVc401LoJT2eAt5LRJeycS/SzOvgG6fYP9YF a6Rds+viU4lwCv0QPwzm2UPePtbt9XuAiewTjbSGXOldOaQJCx9884IV/11lf4JUL/24 hpCzpegmwHdnuuFJJm40nYph2ZHXN3wI/+G+2Oysp4CIMAPTb3gp0XV9Vi+9RLwe7obq QLNCw6z/F5E0i2gFakOuyy6R+USuX/9LMYb4Gk3LsyXL7fhRD8hw4KsBv0J4l/mCG2sX I16w== 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 Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id w4-20020a656944000000b0051323bc5056si229520pgq.860.2023.04.07.18.33.28; Fri, 07 Apr 2023 18:33:40 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229568AbjDHBYK (ORCPT + 99 others); Fri, 7 Apr 2023 21:24:10 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:37466 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229437AbjDHBYI (ORCPT ); Fri, 7 Apr 2023 21:24:08 -0400 Received: from ex01.ufhost.com (ex01.ufhost.com [61.152.239.75]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 40C2E10247; Fri, 7 Apr 2023 18:24:07 -0700 (PDT) Received: from EXMBX165.cuchost.com (unknown [175.102.18.54]) (using TLSv1 with cipher DHE-RSA-AES256-SHA (256/256 bits)) (Client CN "EXMBX165", Issuer "EXMBX165" (not verified)) by ex01.ufhost.com (Postfix) with ESMTP id 7995A24E3F4; Sat, 8 Apr 2023 09:24:05 +0800 (CST) Received: from EXMBX162.cuchost.com (172.16.6.72) by EXMBX165.cuchost.com (172.16.6.75) with Microsoft SMTP Server (TLS) id 15.0.1497.42; Sat, 8 Apr 2023 09:24:05 +0800 Received: from [192.168.120.42] (171.223.208.138) by EXMBX162.cuchost.com (172.16.6.72) with Microsoft SMTP Server (TLS) id 15.0.1497.42; Sat, 8 Apr 2023 09:24:04 +0800 Message-ID: <152393bc-7d21-d19e-0800-fc4231a208b0@starfivetech.com> Date: Sat, 8 Apr 2023 09:24:01 +0800 MIME-Version: 1.0 User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:102.0) Gecko/20100101 Thunderbird/102.9.0 Subject: Re: [-net-next v11 6/6] net: stmmac: starfive-dmac: Add phy interface settings Content-Language: en-US To: Emil Renner Berthing CC: , , , , "David S . Miller" , Eric Dumazet , Jakub Kicinski , Paolo Abeni , Rob Herring , Krzysztof Kozlowski , Emil Renner Berthing , Pedro Moreira , Richard Cochran , Conor Dooley , Paul Walmsley , Palmer Dabbelt , Albert Ou , Andrew Lunn , Heiner Kallweit , Peter Geis , Yanhong Wang , Tommaso Merciai References: <20230407110356.8449-1-samin.guo@starfivetech.com> <20230407110356.8449-7-samin.guo@starfivetech.com> From: Guo Samin In-Reply-To: Content-Type: text/plain; charset="UTF-8" Content-Transfer-Encoding: 7bit X-Originating-IP: [171.223.208.138] X-ClientProxiedBy: EXCAS066.cuchost.com (172.16.6.26) To EXMBX162.cuchost.com (172.16.6.72) X-YovoleRuleAgent: yovoleflag X-Spam-Status: No, score=-2.0 required=5.0 tests=NICE_REPLY_A,SPF_HELO_NONE, 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 Re: [-net-next v11 6/6] net: stmmac: starfive-dmac: Add phy interface settings From: Emil Renner Berthing to: Samin Guo data: 2023/4/8 > Hi Samin, > > If you're respinning this series anyway, please use "net: stmmac: > dwmac-starfive:" to match the filename. > Thanks, will fix. > On Fri, 7 Apr 2023 at 13:05, Samin Guo wrote: >> >> dwmac supports multiple modess. When working under rmii and rgmii, >> you need to set different phy interfaces. >> >> According to the dwmac document, when working in rmii, it needs to be >> set to 0x4, and rgmii needs to be set to 0x1. >> >> The phy interface needs to be set in syscon, the format is as follows: >> starfive,syscon: <&syscon, offset, shift> >> >> Tested-by: Tommaso Merciai >> Signed-off-by: Samin Guo >> --- >> .../ethernet/stmicro/stmmac/dwmac-starfive.c | 48 +++++++++++++++++++ >> 1 file changed, 48 insertions(+) >> >> diff --git a/drivers/net/ethernet/stmicro/stmmac/dwmac-starfive.c b/drivers/net/ethernet/stmicro/stmmac/dwmac-starfive.c >> index 4963d4008485..d6a1eddb51e8 100644 >> --- a/drivers/net/ethernet/stmicro/stmmac/dwmac-starfive.c >> +++ b/drivers/net/ethernet/stmicro/stmmac/dwmac-starfive.c >> @@ -13,6 +13,10 @@ >> >> #include "stmmac_platform.h" >> >> +#define STARFIVE_DWMAC_PHY_INFT_RGMII 0x1 >> +#define STARFIVE_DWMAC_PHY_INFT_RMII 0x4 >> +#define STARFIVE_DWMAC_PHY_INFT_FIELD 0x7U >> + >> struct starfive_dwmac { >> struct device *dev; >> struct clk *clk_tx; >> @@ -46,6 +50,46 @@ static void starfive_dwmac_fix_mac_speed(void *priv, unsigned int speed) >> dev_err(dwmac->dev, "failed to set tx rate %lu\n", rate); >> } >> >> +static int starfive_dwmac_set_mode(struct plat_stmmacenet_data *plat_dat) >> +{ >> + struct starfive_dwmac *dwmac = plat_dat->bsp_priv; >> + struct regmap *regmap; >> + unsigned int args[2]; >> + unsigned int mode; >> + int err; >> + >> + switch (plat_dat->interface) { >> + case PHY_INTERFACE_MODE_RMII: >> + mode = STARFIVE_DWMAC_PHY_INFT_RMII; >> + break; >> + >> + case PHY_INTERFACE_MODE_RGMII: >> + case PHY_INTERFACE_MODE_RGMII_ID: >> + mode = STARFIVE_DWMAC_PHY_INFT_RGMII; >> + break; >> + >> + default: >> + dev_err(dwmac->dev, "unsupported interface %d\n", >> + plat_dat->interface); >> + return -EINVAL; >> + } >> + >> + regmap = syscon_regmap_lookup_by_phandle_args(dwmac->dev->of_node, >> + "starfive,syscon", >> + 2, args); >> + if (IS_ERR(regmap)) >> + return dev_err_probe(dwmac->dev, PTR_ERR(regmap), "syscon regmap failed\n"); > > This message is a bit misleading. It's not actually that the regmap > failed, but getting/looking up the regmap failed. Will fix. Best regards, Samin > >> + /* args[0]:offset args[1]: shift */ >> + err = regmap_update_bits(regmap, args[0], >> + STARFIVE_DWMAC_PHY_INFT_FIELD << args[1], >> + mode << args[1]); >> + if (err) >> + return dev_err_probe(dwmac->dev, err, "error setting phy mode\n"); >> + >> + return 0; >> +} >> + >> static int starfive_dwmac_probe(struct platform_device *pdev) >> { >> struct plat_stmmacenet_data *plat_dat; >> @@ -91,6 +135,10 @@ static int starfive_dwmac_probe(struct platform_device *pdev) >> plat_dat->bsp_priv = dwmac; >> plat_dat->dma_cfg->dche = true; >> >> + err = starfive_dwmac_set_mode(plat_dat); >> + if (err) >> + return err; >> + >> err = stmmac_dvr_probe(&pdev->dev, plat_dat, &stmmac_res); >> if (err) { >> stmmac_remove_config_dt(pdev, plat_dat); >> -- >> 2.17.1 >> >> >> _______________________________________________ >> linux-riscv mailing list >> linux-riscv@lists.infradead.org >> http://lists.infradead.org/mailman/listinfo/linux-riscv