Received: by 2002:a05:6a10:9e8c:0:0:0:0 with SMTP id y12csp277258pxx; Mon, 26 Oct 2020 08:22:17 -0700 (PDT) X-Google-Smtp-Source: ABdhPJxSiAWtr1R2V+CBKj05rWk4zJFPqR3wAhvgR+TCrpTiJV2F01ZLaJ2cM+IWBz3l8gTvZSTv X-Received: by 2002:a17:906:1614:: with SMTP id m20mr16006411ejd.258.1603725737358; Mon, 26 Oct 2020 08:22:17 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1603725737; cv=none; d=google.com; s=arc-20160816; b=eUVO4edE1Etq5KlbBe6QRLHUvuzEXupUkUannppqARpfAfwi8cRqnYHdUlG9iQkF4b RYu24wrCl0+rkl9NNwW6A1EBRo4ONYx+icu0on0VrOxCTMQeq1Su8MVxYpT9PkwjHbi1 JV4reNSGBZwdoojbXH0z3I4PT3LicqUJ5oNhbwhvpoDXmrtE2OHw1eQoGdMU5SCyiKJb BB5+4my0g5U16bWdv7v0QC4bhV4G0GUnP4nk7ybRyTDl46qmCl5FDCeR/leV66unqa8Y TzsUIybMhHmO3mZuZl4Odi2Csh87mBd8Od8dKxp2pvJUqBmIom5KBBj4vCNpGPrRIWKT O6DA== 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:references:cc :to:subject:from; bh=axBJQpaKL2SuLBPCd9TgTabWYL96LV8+m23/R0fvwhM=; b=VE6Vr76Bb4wQZzGVadX5c0yCDtnhRJephxyakrYeXzgZu0+uDzWuwVqD0W/4ETfl8l NroB7WWlezZ5aTymPTFnGL6myG035D2dW2PuZIApk+djXP0iq8rZw0fhlz4wiV3bXHrk 7FClIoXjTi7rPeo92U+VVq7yy+XlbRaSdygM6N22VBKY7CHPkokeImwXT1aEIwl0BKFy eHw6bpDRVl9liUWuFWbFBNi2Mpx9teEIXeJdwecNDTEWuI8v+h5Ld0IH8nGnrE6PTcDk eKKZqTDSUM6SRHk9CQ4TWJbxgidpWQWw1GmIUoLB2Wee0+q/IOTIlSvkW/KZgGlTQTDL h2sA== 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 m3si7268029edb.600.2020.10.26.08.21.53; Mon, 26 Oct 2020 08:22:17 -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; 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 S1783598AbgJZPRs (ORCPT + 99 others); Mon, 26 Oct 2020 11:17:48 -0400 Received: from bhuna.collabora.co.uk ([46.235.227.227]:60442 "EHLO bhuna.collabora.co.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1783154AbgJZPRs (ORCPT ); Mon, 26 Oct 2020 11:17:48 -0400 Received: from [127.0.0.1] (localhost [127.0.0.1]) (Authenticated sender: eballetbo) with ESMTPSA id 513961F44A65 From: Enric Balletbo i Serra Subject: Re: [PATCH v2 08/12] soc: mediatek: pm-domains: Add subsystem clocks To: Matthias Brugger , linux-kernel@vger.kernel.org Cc: Collabora Kernel ML , fparent@baylibre.com, drinkcat@chromium.org, hsinyi@chromium.org, weiyi.lu@mediatek.com, Matthias Brugger , linux-arm-kernel@lists.infradead.org, linux-mediatek@lists.infradead.org References: <20201001160154.3587848-1-enric.balletbo@collabora.com> <20201001160154.3587848-9-enric.balletbo@collabora.com> Message-ID: Date: Mon, 26 Oct 2020 16:17:43 +0100 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 Content-Language: en-US Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Matthias, Thank you for your review. On 2/10/20 11:04, Matthias Brugger wrote: > > > On 01/10/2020 18:01, Enric Balletbo i Serra wrote: >> From: Matthias Brugger >> >> For the bus protection operations, some subsystem clocks need to be enabled >> before releasing the protection. This patch identifies the subsystem clocks >> by it's name. >> >> Suggested-by: Weiyi Lu >> [Adapted the patch to the mtk-pm-domains driver] >> Signed-off-by: Matthias Brugger >> Signed-off-by: Enric Balletbo i Serra >> --- >> >> Changes in v2: >> - Use dev_err_probe if getting clocks fails, so an error is not printed >>    if is deferred. >> >>   drivers/soc/mediatek/mtk-pm-domains.c | 89 ++++++++++++++++++++++----- >>   1 file changed, 75 insertions(+), 14 deletions(-) >> >> diff --git a/drivers/soc/mediatek/mtk-pm-domains.c >> b/drivers/soc/mediatek/mtk-pm-domains.c >> index e0a52d489fea..2075072f16da 100644 >> --- a/drivers/soc/mediatek/mtk-pm-domains.c >> +++ b/drivers/soc/mediatek/mtk-pm-domains.c > [...] >>   +    for (i = 0; i < pd->num_subsys_clks; i++) { >> +        struct clk *clk = of_clk_get(node, i + clk_ind); >> + >> +        if (IS_ERR(clk)) { >> +            ret = PTR_ERR(clk); >> +            dev_err_probe(scpsys->dev, PTR_ERR(clk), >> +                      "%pOFn: failed to get clk at index %d: %d\n", >> +                      node, i + clk_ind, ret); >> +            goto err_put_subsys_clocks; >> +        } >> + >> +        pd->subsys_clks[i].clk = clk; >> +    } >> + >> +    ret = clk_bulk_prepare(pd->num_subsys_clks, pd->subsys_clks); >> +    if (ret) >> +        goto err_put_subsys_clocks; >> + > > Not sure if it really matters, but logically we should prepare the basic clocks > before we prepare the subsystem clocks. And fix the error handling accordingly. > Changed in next version. > Regards, > Matthias > >>       ret = clk_bulk_prepare(pd->num_clks, pd->clks); >>       if (ret) >> -        goto err_put_clocks; >> +        goto err_unprepare_subsys_clocks; >>         /* >>        * Initially turn on all domains to make the domains usable >> @@ -462,6 +513,12 @@ static int scpsys_add_one_domain(struct scpsys *scpsys, >> struct device_node *node >>     err_unprepare_clocks: >>       clk_bulk_unprepare(pd->num_clks, pd->clks); >> +err_unprepare_subsys_clocks: >> +    clk_bulk_unprepare(pd->num_subsys_clks, pd->subsys_clks); >> +err_put_subsys_clocks: >> +    clk_bulk_put(pd->num_subsys_clks, pd->subsys_clks); >> +    devm_kfree(scpsys->dev, pd->subsys_clks); >> +    pd->num_subsys_clks = 0; >>   err_put_clocks: >>       clk_bulk_put(pd->num_clks, pd->clks); >>       devm_kfree(scpsys->dev, pd->clks); >> @@ -541,6 +598,10 @@ static void scpsys_remove_one_domain(struct scpsys_domain >> *pd) >>       clk_bulk_unprepare(pd->num_clks, pd->clks); >>       clk_bulk_put(pd->num_clks, pd->clks); >>       pd->num_clks = 0; >> + >> +    clk_bulk_unprepare(pd->num_subsys_clks, pd->subsys_clks); >> +    clk_bulk_put(pd->num_subsys_clks, pd->subsys_clks); >> +    pd->num_subsys_clks = 0; >>   } >>     static void scpsys_domain_cleanup(struct scpsys *scpsys) >>