Received: by 2002:a05:6a10:2785:0:0:0:0 with SMTP id ia5csp850879pxb; Wed, 13 Jan 2021 18:18:07 -0800 (PST) X-Google-Smtp-Source: ABdhPJzsIhwGxixMTPIWH/+XjwawUbRhwnYlsk7i46cODG7FbPyK8yZr4lc+U3gN/RATMHIPTnaa X-Received: by 2002:a50:998f:: with SMTP id m15mr4046446edb.342.1610590687093; Wed, 13 Jan 2021 18:18:07 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1610590687; cv=none; d=google.com; s=arc-20160816; b=ElntOCtfZlfiCj9calW1QlQDFM/ZmZE+/U+YKAd4+kd9s/L0AQwMSGCgjKB//VxJMa 34JURmeLCeKVlcsyLsBD4ljgvvZbB3aOl9WT+SDzbGvSF1uaUifBt+pnm99f0dEh6SVe NLid0K8ow9yqeBh+x+SglXa1Rib9WO+HJjr3/YWNqpO1CLm7PlqzBkdpvTSXIJ8f86wu gmGuTUIWOSFDqvOjjGCzeijet+5hdZWdJ1TnIojGbciTfNcIETKMF/sVnQJ4hK8Mwzj5 iGlEwaU6mOm4s8vf4Hsqz5NPtiXPqS+qg8UsiLd525ySzdi11GgGH2Oa6HNKf/U1R9mq Rpzg== 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; bh=HIEL9n43LaQrdGknUUHt5n48v5Ra8aOTnos/Yn8wRqU=; b=e9kVFI3eSlUm5mVWwB9+4tGzV6LhPNi1WcLF5yX3ZNd7oX3quiQxRxwHWaKYsE4nRZ fPx8c4iTX5HNaUXok8vgkAFpXgmaUoB2Av7El8soxHgzMcU7O/c8xKx+TTJr835qCGui QGpHuof9YklU8XwFn8efJhw3NwsnzcE3hWstBueJJafIpekLSofTc485zSDG1w2UKLrJ w01lXYXfpSYNufa5OSg0S/qFeuaYoXj//w8Tq30n2tQOzAzEl5QgyMweEPE3BzSuAhQQ 4YQFTfLAaf3i0OAOCWq8kdBwgVZGYnzr1Apq12bh9R60CVidewGbFVjjt2PRooy5qfR2 cy3w== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=collabora.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id dk23si1981189edb.17.2021.01.13.18.17.43; Wed, 13 Jan 2021 18:18:07 -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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=collabora.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727920AbhANCQZ (ORCPT + 99 others); Wed, 13 Jan 2021 21:16:25 -0500 Received: from bhuna.collabora.co.uk ([46.235.227.227]:38516 "EHLO bhuna.collabora.co.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729053AbhAMVQi (ORCPT ); Wed, 13 Jan 2021 16:16:38 -0500 Received: from [127.0.0.1] (localhost [127.0.0.1]) (Authenticated sender: eballetbo) with ESMTPSA id 0176C1F44F75 Subject: Re: [PATCH 2/3] soc: mediatek: pm-domains: Add domain regulator supply To: Nicolas Boichat , Hsin-Yi Wang Cc: linux-arm Mailing List , Devicetree List , Weiyi Lu , lkml , Rob Herring , Mark Brown , "moderated list:ARM/Mediatek SoC support" , Matthias Brugger References: <20210107104915.2888408-1-hsinyi@chromium.org> <20210107104915.2888408-3-hsinyi@chromium.org> From: Enric Balletbo i Serra Message-ID: Date: Wed, 13 Jan 2021 22:16:43 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:78.0) Gecko/20100101 Thunderbird/78.6.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Hsin-Yi, Thank you for the patch. On 10/1/21 2:49, Nicolas Boichat wrote: > On Thu, Jan 7, 2021 at 6:49 PM Hsin-Yi Wang wrote: >> >> Some power domains (eg. mfg) needs to turn on power supply before power >> on. >> >> Signed-off-by: Hsin-Yi Wang > > Reviewed-by: Nicolas Boichat > Reviewed-by: Enric Balletbo i Serra >> --- >> drivers/soc/mediatek/mt8183-pm-domains.h | 1 + >> drivers/soc/mediatek/mtk-pm-domains.c | 36 +++++++++++++++++++++++- >> drivers/soc/mediatek/mtk-pm-domains.h | 1 + >> 3 files changed, 37 insertions(+), 1 deletion(-) >> >> diff --git a/drivers/soc/mediatek/mt8183-pm-domains.h b/drivers/soc/mediatek/mt8183-pm-domains.h >> index 8d996c5d2682d..aa5230e6c12f8 100644 >> --- a/drivers/soc/mediatek/mt8183-pm-domains.h >> +++ b/drivers/soc/mediatek/mt8183-pm-domains.h >> @@ -38,6 +38,7 @@ static const struct scpsys_domain_data scpsys_domain_data_mt8183[] = { >> .ctl_offs = 0x0338, >> .sram_pdn_bits = GENMASK(8, 8), >> .sram_pdn_ack_bits = GENMASK(12, 12), >> + .caps = MTK_SCPD_DOMAIN_SUPPLY, >> }, >> [MT8183_POWER_DOMAIN_MFG_CORE0] = { >> .sta_mask = BIT(7), >> diff --git a/drivers/soc/mediatek/mtk-pm-domains.c b/drivers/soc/mediatek/mtk-pm-domains.c >> index fb70cb3b07b36..ae255aa7b1a97 100644 >> --- a/drivers/soc/mediatek/mtk-pm-domains.c >> +++ b/drivers/soc/mediatek/mtk-pm-domains.c > [snip] >> @@ -275,6 +295,7 @@ generic_pm_domain *scpsys_add_one_domain(struct scpsys *scpsys, struct device_no >> { >> const struct scpsys_domain_data *domain_data; >> struct scpsys_domain *pd; >> + struct device_node *np = scpsys->dev->of_node; >> struct property *prop; >> const char *clk_name; >> int i, ret, num_clks; >> @@ -307,6 +328,19 @@ generic_pm_domain *scpsys_add_one_domain(struct scpsys *scpsys, struct device_no >> pd->data = domain_data; >> pd->scpsys = scpsys; >> >> + if (MTK_SCPD_CAPS(pd, MTK_SCPD_DOMAIN_SUPPLY)) { >> + /* Find regulator in current power domain node */ >> + scpsys->dev->of_node = node; >> + pd->supply = devm_regulator_get(scpsys->dev, "domain"); >> + scpsys->dev->of_node = np; > > This pattern is a bit strange to me. But Hsin-Yi pointed out that > there are precedents: > https://elixir.bootlin.com/linux/v5.11-rc2/source/drivers/iio/adc/rcar-gyroadc.c#L397 > . nit: Strange to me too. Maybe it needs a better comment/explanation and/or use child/parent as a temporal of_node names to make a bit more readable. Looks like [devm_]regulator_get only accepts a device as argument and will look into child nodes. > >> + if (IS_ERR(pd->supply)) { >> + dev_err_probe(scpsys->dev, PTR_ERR(pd->supply), >> + "%pOF: failed to get power supply.\n", >> + node); >> + return ERR_CAST(pd->supply); >> + } >> + } >> + >> pd->infracfg = syscon_regmap_lookup_by_phandle_optional(node, "mediatek,infracfg"); >> if (IS_ERR(pd->infracfg)) >> return ERR_CAST(pd->infracfg); >> diff --git a/drivers/soc/mediatek/mtk-pm-domains.h b/drivers/soc/mediatek/mtk-pm-domains.h >> index a2f4d8f97e058..b2770b5266dba 100644 >> --- a/drivers/soc/mediatek/mtk-pm-domains.h >> +++ b/drivers/soc/mediatek/mtk-pm-domains.h >> @@ -7,6 +7,7 @@ >> #define MTK_SCPD_FWAIT_SRAM BIT(1) >> #define MTK_SCPD_SRAM_ISO BIT(2) >> #define MTK_SCPD_KEEP_DEFAULT_OFF BIT(3) >> +#define MTK_SCPD_DOMAIN_SUPPLY BIT(4) >> #define MTK_SCPD_CAPS(_scpd, _x) ((_scpd)->data->caps & (_x)) >> >> #define SPM_VDE_PWR_CON 0x0210 >> -- >> 2.29.2.729.g45daf8777d-goog >> >> >> _______________________________________________ >> Linux-mediatek mailing list >> Linux-mediatek@lists.infradead.org >> http://lists.infradead.org/mailman/listinfo/linux-mediatek