Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp3185467pxk; Mon, 5 Oct 2020 03:29:43 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyTC7fc+47gic1bpOKABn2xS1e4OnJ3jxGYTNgRLlEC+LgW5aWSq03wxy3oUPN2CVN+yxal X-Received: by 2002:aa7:ccd9:: with SMTP id y25mr15911949edt.375.1601893783014; Mon, 05 Oct 2020 03:29:43 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1601893783; cv=none; d=google.com; s=arc-20160816; b=eheb+gw6cl6J7o2M6h8hFAjQQadWQTRhkJ+G8jiYpXp4bUGawgSc3YQDXexiBQmS+h DE7w2KufDl4MSZSb/0c26pwl5EaHg3AqikflRJbE5cqrOmL5IM831lo4zwssCdgFB8q8 AX+/CbVRrFDCLWvLGeldm3VtcRJ4tlb9WW1AsDKRgqpTWPyBo94uQnx1uH5LrHCoBCsL 5YoN68IzeT6uN/Xu1/LqX1t2cVqk6v+ksrihgiUyUPBLf4gjaB1a3iN+w0vxhzVvKFUh J2nXQHNc3g17Dbh9cArmqcOgfZH4i9RNAd9gayRgUytxEHp67eh2lEkz/TUY0vFROQIK roFg== 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=6/JqGd6PalEdATCzl9yAiTh7H5Y1eBidoPeAq7PeqNM=; b=CwSynbDngiOhlfy1m5HPJ0PjaOqb5RuLm8yd7EhQGU12m9b9IpdPTZukQF9SrC8BZ2 9px2On9lbQwjqQA8DICB1ubTVg0pbwKfQEUf5G8HWgjeWoHeQg+504ssoi6Wk+u0QSp5 JjZ2s+YljAqfzHWsZdCMB6Bz4Ov56MkZ0uj4KM5mnXwdovoy3f+K0BDMNxDpNxKJckaL B5P8wKDFxTiqrSP73wEmYRlvykMK5wG+8pO5eWRLgcUb7I53KhFTmneLqaDZSm2I8/Yw uCwQj+FHbJ5g7dPTuIzpOZF9z92BVwNndtUI42OdjoS9HG7CSssCgiw67PcOKvm9V3xo O8qQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@suse.com header.s=susede1 header.b=Rr9JK0Fa; 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=NONE dis=NONE) header.from=suse.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id v14si7018283eja.230.2020.10.05.03.29.19; Mon, 05 Oct 2020 03:29:43 -0700 (PDT) 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=@suse.com header.s=susede1 header.b=Rr9JK0Fa; 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=NONE dis=NONE) header.from=suse.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1725946AbgJEK2P (ORCPT + 99 others); Mon, 5 Oct 2020 06:28:15 -0400 Received: from mx2.suse.de ([195.135.220.15]:58894 "EHLO mx2.suse.de" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725843AbgJEK2P (ORCPT ); Mon, 5 Oct 2020 06:28:15 -0400 X-Virus-Scanned: by amavisd-new at test-mx.suse.de DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=suse.com; s=susede1; t=1601893693; h=from:from:reply-to:subject:subject:date:date:message-id:message-id: to:to:cc:cc:mime-version:mime-version:content-type:content-type: content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=6/JqGd6PalEdATCzl9yAiTh7H5Y1eBidoPeAq7PeqNM=; b=Rr9JK0FaMCuS2y4bd4R/YOEGd+voVVRfYx8iRODdcq+ryBjTzQM3+LpUdtSB+dxUCCpV93 0H0im4IMg/ZYoh3tqRpLSwXgLaGaDDKEVY6Xgg/aqP1H7vkH2WE4922ouoL3NZt3OgfFEP ZJzveXys+olPX8oJo9V7ODLWDh21jJw= Received: from relay2.suse.de (unknown [195.135.221.27]) by mx2.suse.de (Postfix) with ESMTP id 997A0AEEF; Mon, 5 Oct 2020 10:28:13 +0000 (UTC) Subject: Re: [PATCH v2 06/12] soc: mediatek: pm-domains: Add SMI block as bus protection block To: Nicolas Boichat , Matthias Brugger Cc: Enric Balletbo i Serra , lkml , Collabora Kernel ML , Fabien Parent , Hsin-Yi Wang , Weiyi Lu , linux-arm Mailing List , "moderated list:ARM/Mediatek SoC support" References: <20201001160154.3587848-1-enric.balletbo@collabora.com> <20201001160154.3587848-7-enric.balletbo@collabora.com> From: Matthias Brugger Message-ID: <8b007805-5fd5-aebe-2ac3-014514173263@suse.com> Date: Mon, 5 Oct 2020 12:28:12 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.12.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 05/10/2020 03:48, Nicolas Boichat wrote: > On Fri, Oct 2, 2020 at 4:56 PM Matthias Brugger wrote: >> >> >> >> On 01/10/2020 18:01, Enric Balletbo i Serra wrote: >>> From: Matthias Brugger >>> >>> Apart from the infracfg block, the SMI block is used to enable the bus >>> protection for some power domains. Add support for this block. >>> >>> Signed-off-by: Matthias Brugger >>> Signed-off-by: Enric Balletbo i Serra >>> --- >>> >>> Changes in v2: None >>> >>> drivers/soc/mediatek/mtk-pm-domains.c | 64 ++++++++++++++++++++------- >>> include/linux/soc/mediatek/infracfg.h | 6 +++ >>> 2 files changed, 53 insertions(+), 17 deletions(-) >>> >>> diff --git a/drivers/soc/mediatek/mtk-pm-domains.c b/drivers/soc/mediatek/mtk-pm-domains.c >>> index b5e7c9846c34..38f2630bdd0a 100644 >>> --- a/drivers/soc/mediatek/mtk-pm-domains.c >>> +++ b/drivers/soc/mediatek/mtk-pm-domains.c >>> @@ -56,8 +56,25 @@ >>> >>> #define SPM_MAX_BUS_PROT_DATA 3 >>> >>> +#define _BUS_PROT(_mask, _set, _clr, _sta, _update) { \ >>> + .bus_prot_mask = (_mask), \ >>> + .bus_prot_set = _set, \ >>> + .bus_prot_clr = _clr, \ >>> + .bus_prot_sta = _sta, \ >>> + .bus_prot_reg_update = _update, \ >>> + } >>> + >>> +#define BUS_PROT_WR(_mask, _set, _clr, _sta) \ >>> + _BUS_PROT(_mask, _set, _clr, _sta, false) >>> + >>> +#define BUS_PROT_UPDATE(_mask, _set, _clr, _sta) \ >>> + _BUS_PROT(_mask, _set, _clr, _sta, true) >>> + >>> struct scpsys_bus_prot_data { >>> u32 bus_prot_mask; >>> + u32 bus_prot_set; >>> + u32 bus_prot_clr; >>> + u32 bus_prot_sta; >>> bool bus_prot_reg_update; >>> }; >>> >>> @@ -69,6 +86,7 @@ struct scpsys_bus_prot_data { >>> * @sram_pdn_ack_bits: The mask for sram power control acked bits. >>> * @caps: The flag for active wake-up action. >>> * @bp_infracfg: bus protection for infracfg subsystem >>> + * @bp_smi: bus protection for smi subsystem >>> */ >>> struct scpsys_domain_data { >>> u32 sta_mask; >>> @@ -77,6 +95,7 @@ struct scpsys_domain_data { >>> u32 sram_pdn_ack_bits; >>> u8 caps; >>> const struct scpsys_bus_prot_data bp_infracfg[SPM_MAX_BUS_PROT_DATA]; >>> + const struct scpsys_bus_prot_data bp_smi[SPM_MAX_BUS_PROT_DATA]; >>> }; >>> >>> struct scpsys_domain { >>> @@ -86,6 +105,7 @@ struct scpsys_domain { >>> int num_clks; >>> struct clk_bulk_data *clks; >>> struct regmap *infracfg; >>> + struct regmap *smi; >>> }; >>> >>> struct scpsys_soc_data { >>> @@ -175,9 +195,9 @@ static int _scpsys_bus_protect_enable(const struct scpsys_bus_prot_data *bpd, st >>> if (bpd[i].bus_prot_reg_update) >>> regmap_update_bits(regmap, INFRA_TOPAXI_PROTECTEN, mask, mask); >>> else >>> - regmap_write(regmap, INFRA_TOPAXI_PROTECTEN_SET, mask); >>> + regmap_write(regmap, bpd[i].bus_prot_set, mask); >>> >>> - ret = regmap_read_poll_timeout(regmap, INFRA_TOPAXI_PROTECTSTA1, >>> + ret = regmap_read_poll_timeout(regmap, bpd[i].bus_prot_sta, >>> val, (val & mask) == mask, >>> MTK_POLL_DELAY_US, MTK_POLL_TIMEOUT); >>> if (ret) >>> @@ -193,7 +213,11 @@ static int scpsys_bus_protect_enable(struct scpsys_domain *pd) >>> int ret; >>> >>> ret = _scpsys_bus_protect_enable(bpd, pd->infracfg); >>> - return ret; >>> + if (ret) >>> + return ret; >>> + >>> + bpd = pd->data->bp_smi; >>> + return _scpsys_bus_protect_enable(bpd, pd->smi); > > Not a huge fan or reusing bpd for 2 different things. > > I think this is easier to follow: > > _scpsys_bus_protect_enable(pd->data->bp_infracfg, pd->infracfg); > ... > _scpsys_bus_protect_enable(pd->data->bp_smi, pd->smi); > Sounds reasonable, yes :)