Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp41950pxb; Fri, 5 Mar 2021 13:53:16 -0800 (PST) X-Google-Smtp-Source: ABdhPJxGHGY9LXzaYo4WDBusgh6igpzfDISXBDBsmEkUFYPA8sRClEbZb9enXUadTWkq1MfudH8q X-Received: by 2002:a05:6402:203:: with SMTP id t3mr11273561edv.306.1614981195879; Fri, 05 Mar 2021 13:53:15 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1614981195; cv=none; d=google.com; s=arc-20160816; b=LxBZgNemIhuFuY4QMyP0NG1uUqfspjW+qroAqKr8GS8MIvR/ut0DaTwDABASYEybkS gaAOcw2m+ZS2tM8BzGEkOaGWBIR1AfdeN0ketazvsOVHSBSl7XVotpbZtrq2OptaQuZb WUGGemqLp9UoCCYvfPMEz8bNfEOMa1vLX7/pXTNJimBAIUCl4LEwLFNwdfK21n8mMRdL H0QfvOEu3fPBVxbLdVPkteIneHD79JqXGwPRnlin5gz35FwIwUNg9yQwau7PQM45kD3P 7PX89mW7quqI1lp1QNcYzGT3+6Hvcf/VEuNMqpMyV4Yvn0UNW/cKdJrDl0Xc6agzAjKf dvPw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:content-language :in-reply-to:mime-version:user-agent:date:message-id:from:references :cc:to:subject:dkim-signature; bh=/NFlc8/2M/Pmm6oLgkw8VYwZK7FquOGJoZ7lGyC1UMY=; b=cfk0Ol+NhnOa3FoLX5HGLW/xgnQAYcsClOQy2UAa0f7Z/4J1ggsXL45/ZIfx5Swuvy 4fbeSv6eUYFW04JEGKms2KTganF+oif1hPVatHIEGrOzUgdBiLo3wdVzqrD/ZNx9Pnb8 d0sJabsC6FPE6Xye+bwF4ebJHPy46P136TE4XQUkAbzrWaaaRFuK4hJBunWzn0/SvEg4 Q8QlUkD+7gYojJ19iBoOJqwSDEdMiSeruBx4CZr/mlyMwW0Sr7CqaheY9/vCmx4JyE5z hbqce4sGkis/ofQznyjXcCaxX11TJifHtAlxzi6Wnj7/plqO5efUOLr2zk/3gA/u+Znn 1SbA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=jj1EUJo2; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id g10si2288218edq.430.2021.03.05.13.52.43; Fri, 05 Mar 2021 13:53:15 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=jj1EUJo2; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229821AbhCEVvU (ORCPT + 99 others); Fri, 5 Mar 2021 16:51:20 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44758 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229591AbhCEVu6 (ORCPT ); Fri, 5 Mar 2021 16:50:58 -0500 Received: from mail-lf1-x12e.google.com (mail-lf1-x12e.google.com [IPv6:2a00:1450:4864:20::12e]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id CCF9DC06175F; Fri, 5 Mar 2021 13:50:57 -0800 (PST) Received: by mail-lf1-x12e.google.com with SMTP id b1so6094437lfb.7; Fri, 05 Mar 2021 13:50:57 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=/NFlc8/2M/Pmm6oLgkw8VYwZK7FquOGJoZ7lGyC1UMY=; b=jj1EUJo2oT1asageCMml/fbLjInZ6rXRjKa69vXHraNGp+4PE1zJZ96QqLGqCZmyj/ yPiMjHd6TzxPdbjEAsczkOTJczq4mSRiRynKjYEy+TYzy1xgdE1zIJXy2/9vYGoApqn5 bABzq6Qw62DWUeozayarTw2nwoXVqF+ECzSjEGxQ19hVouAYlfvOm/mbatC11WTgZPid waG+oHukmK/adJCtFcV14MeWk+LC+4tXhZ4BBSLYNESQvNqjzWH9WeCqwnmcVVP8a0RM NWVcLJ9IOf6o0T8NJBUZpD6Ent+/d52Mgq0FGPsjY6bVTWmIDm8xJGDVbXGQdYhHETiS kBaw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=/NFlc8/2M/Pmm6oLgkw8VYwZK7FquOGJoZ7lGyC1UMY=; b=qnpu+6eRnruy+H9FTO0tWHb3tfF2/zbLIKzcOA/q+57l08dFKh4GZabeQ6Z359R6lz jXgmly8e3V2b4GfB9vbvrQiBchyxb83cS3oajlH/O+jkgAb7bilJuCtdgaizjzAfKYun wJAMFsqCUFVkd6nR5s7Mw5jG8alIqeKrXTn/YYMmCV6RD/+UYD0dnHQwaY4RmwumdUWP 8wao+J4ypapg7ZvgPmcDGnJ5BRDEaMgDgVBurHyBttq4oP9nxCt32e1swtMgaaETBAX5 wwmtplClIgunHnAZVpzHdymzyTvCimlcrr5Cqp6RzDNyxPQ+vk9Ittdr6koqEBQVCNpI ws3A== X-Gm-Message-State: AOAM533TKP+b7UwSblcAFNvcFf7EYOoMiUE6sixj50nckj3gAVWpvyeW 0ddRPxwOwyTdInTRs1f2GvnNuAn5hyg= X-Received: by 2002:ac2:4151:: with SMTP id c17mr6475369lfi.416.1614981056391; Fri, 05 Mar 2021 13:50:56 -0800 (PST) Received: from localhost.localdomain (ip-194-187-74-233.konfederacka.maverick.com.pl. [194.187.74.233]) by smtp.googlemail.com with ESMTPSA id y10sm464796lfl.240.2021.03.05.13.50.55 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Fri, 05 Mar 2021 13:50:55 -0800 (PST) Subject: Re: [PATCH 3/3] phy: bcm-ns-usb2: support updated single CRU reg DT binding To: Kishon Vijay Abraham I , Vinod Koul , Rob Herring Cc: linux-kernel@vger.kernel.org, devicetree@vger.kernel.org, Florian Fainelli , Vivek Unune , bcm-kernel-feedback-list@broadcom.com, =?UTF-8?B?UmFmYcWCIE1pxYJlY2tp?= , linux-phy@lists.infradead.org References: <20210226114501.31086-1-zajec5@gmail.com> <20210226114501.31086-3-zajec5@gmail.com> From: =?UTF-8?B?UmFmYcWCIE1pxYJlY2tp?= Message-ID: <068064d6-23f6-e02e-9bc9-5b5970a0744e@gmail.com> Date: Fri, 5 Mar 2021 22:50:54 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.6.1 MIME-Version: 1.0 In-Reply-To: <20210226114501.31086-3-zajec5@gmail.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Cc linux-phy@ again (after fixing recipients ML limit) On 26.02.2021 12:45, Rafał Miłecki wrote: > From: Rafał Miłecki > > Updated DT binding maps a single CRU register that is directly used for > the PHY control. Accessing common CRU reg is handled using syscon & > regmap. > > The old binding has been deprecated and stays as a fallback method. > > Signed-off-by: Rafał Miłecki > --- > It's a reworked version of my abonded 2019 patch: > [PATCH V2 2/2] phy: bcm-ns-usb2: support updated DT binding with the CRU syscon > https://lore.kernel.org/patchwork/patch/1029863/ > --- > drivers/phy/broadcom/phy-bcm-ns-usb2.c | 52 +++++++++++++++++++++----- > 1 file changed, 43 insertions(+), 9 deletions(-) > > diff --git a/drivers/phy/broadcom/phy-bcm-ns-usb2.c b/drivers/phy/broadcom/phy-bcm-ns-usb2.c > index 4b015b8a71c3..98d32729a45d 100644 > --- a/drivers/phy/broadcom/phy-bcm-ns-usb2.c > +++ b/drivers/phy/broadcom/phy-bcm-ns-usb2.c > @@ -9,17 +9,23 @@ > #include > #include > #include > +#include > #include > #include > #include > #include > #include > +#include > #include > > struct bcm_ns_usb2 { > struct device *dev; > struct clk *ref_clk; > struct phy *phy; > + struct regmap *clkset; > + void __iomem *base; > + > + /* Deprecated binding */ > void __iomem *dmu; > }; > > @@ -27,7 +33,6 @@ static int bcm_ns_usb2_phy_init(struct phy *phy) > { > struct bcm_ns_usb2 *usb2 = phy_get_drvdata(phy); > struct device *dev = usb2->dev; > - void __iomem *dmu = usb2->dmu; > u32 ref_clk_rate, usb2ctl, usb_pll_ndiv, usb_pll_pdiv; > int err = 0; > > @@ -44,7 +49,10 @@ static int bcm_ns_usb2_phy_init(struct phy *phy) > goto err_clk_off; > } > > - usb2ctl = readl(dmu + BCMA_DMU_CRU_USB2_CONTROL); > + if (usb2->base) > + usb2ctl = readl(usb2->base); > + else > + usb2ctl = readl(usb2->dmu + BCMA_DMU_CRU_USB2_CONTROL); > > if (usb2ctl & BCMA_DMU_CRU_USB2_CONTROL_USB_PLL_PDIV_MASK) { > usb_pll_pdiv = usb2ctl; > @@ -58,15 +66,24 @@ static int bcm_ns_usb2_phy_init(struct phy *phy) > usb_pll_ndiv = (1920000000 * usb_pll_pdiv) / ref_clk_rate; > > /* Unlock DMU PLL settings with some magic value */ > - writel(0x0000ea68, dmu + BCMA_DMU_CRU_CLKSET_KEY); > + if (usb2->clkset) > + regmap_write(usb2->clkset, 0, 0x0000ea68); > + else > + writel(0x0000ea68, usb2->dmu + BCMA_DMU_CRU_CLKSET_KEY); > > /* Write USB 2.0 PLL control setting */ > usb2ctl &= ~BCMA_DMU_CRU_USB2_CONTROL_USB_PLL_NDIV_MASK; > usb2ctl |= usb_pll_ndiv << BCMA_DMU_CRU_USB2_CONTROL_USB_PLL_NDIV_SHIFT; > - writel(usb2ctl, dmu + BCMA_DMU_CRU_USB2_CONTROL); > + if (usb2->base) > + writel(usb2ctl, usb2->base); > + else > + writel(usb2ctl, usb2->dmu + BCMA_DMU_CRU_USB2_CONTROL); > > /* Lock DMU PLL settings */ > - writel(0x00000000, dmu + BCMA_DMU_CRU_CLKSET_KEY); > + if (usb2->clkset) > + regmap_write(usb2->clkset, 0, 0x00000000); > + else > + writel(0x00000000, usb2->dmu + BCMA_DMU_CRU_CLKSET_KEY); > > err_clk_off: > clk_disable_unprepare(usb2->ref_clk); > @@ -90,10 +107,27 @@ static int bcm_ns_usb2_probe(struct platform_device *pdev) > return -ENOMEM; > usb2->dev = dev; > > - usb2->dmu = devm_platform_ioremap_resource_byname(pdev, "dmu"); > - if (IS_ERR(usb2->dmu)) { > - dev_err(dev, "Failed to map DMU regs\n"); > - return PTR_ERR(usb2->dmu); > + if (of_find_property(dev->of_node, "brcm,syscon-clkset", NULL)) { > + usb2->base = devm_platform_ioremap_resource(pdev, 0); > + if (IS_ERR(usb2->base)) { > + dev_err(dev, "Failed to map control reg\n"); > + return PTR_ERR(usb2->base); > + } > + > + usb2->clkset = syscon_regmap_lookup_by_phandle(dev->of_node, > + "brcm,syscon-clkset"); > + if (IS_ERR(usb2->clkset)) { > + dev_err(dev, "Failed to lookup clkset regmap\n"); > + return PTR_ERR(usb2->clkset); > + } > + } else { > + usb2->dmu = devm_platform_ioremap_resource_byname(pdev, "dmu"); > + if (IS_ERR(usb2->dmu)) { > + dev_err(dev, "Failed to map DMU regs\n"); > + return PTR_ERR(usb2->dmu); > + } > + > + dev_warn(dev, "using deprecated DT binding\n"); > } > > usb2->ref_clk = devm_clk_get(dev, "phy-ref-clk"); >