From mboxrd@z Thu Jan 1 00:00:00 1970 From: Dmitry Torokhov Subject: Re: [PATCH v7 1/3] power-domain: add power domain drivers for Rockchip platform Date: Mon, 27 Oct 2014 16:39:04 -0700 Message-ID: <20141027233904.GD7594@dtor-ws> References: <1414135761-3406-1-git-send-email-jinkun.hong@rock-chips.com> <1414135761-3406-2-git-send-email-jinkun.hong@rock-chips.com> <20141024164431.GE19933@dtor-ws> Mime-Version: 1.0 Content-Type: text/plain; charset=us-ascii Return-path: Content-Disposition: inline In-Reply-To: <20141024164431.GE19933@dtor-ws> Sender: linux-doc-owner@vger.kernel.org To: "jinkun.hong" Cc: linus.walleij@linaro.org, linux-arm-kernel@lists.infradead.org, Russell King , Rob Herring , Pawel Moll , Mark Rutland , Ian Campbell , Kumar Gala , Grant Likely , linux-kernel@vger.kernel.org, devicetree@vger.kernel.org, Randy Dunlap , linux-doc@vger.kernel.org, dianders@chromium.org, Heiko Stuebner , linux-rockchip@lists.infradead.org, Ulf Hansson , Jack Dai List-Id: devicetree@vger.kernel.org On Fri, Oct 24, 2014 at 09:44:31AM -0700, Dmitry Torokhov wrote: > Hi Jinkun, > > On Fri, Oct 24, 2014 at 12:29:19AM -0700, jinkun.hong wrote: > > +static int rockchip_pd_power(struct rockchip_domain *pd, bool power_on) > > +{ > > + int ret = 0; > > + struct rockchip_dev_entry *de; > > + > > + mutex_lock(&pd->dev_lock); > > + /* no clk, set power domain will fail */ > > + if (list_empty(&pd->dev_list)) { > > + pr_err("%s: no devices in %s power domain\n", __func__, > > + pd->base.name); > > + goto out; > > + } > > + > > + list_for_each_entry(de, &pd->dev_list, node) { > > + pm_clk_resume(de->dev); > > + } > > + > > + ret = rockchip_pmu_set_power_domain(pd, power_on); > > + > > + list_for_each_entry(de, &pd->dev_list, node) { > > + pm_clk_suspend(de->dev); > > + } > > +out: > > + mutex_unlock(&pd->dev_lock); > > + return ret; > > +} > > For my education, could you please tell me why we need to enable all > clocks of all devices in a power domain when we are talking to the PMU > and then turn them immediately off? Would not we want to enable clocks > in start()) callbacks, like Ulf mentioned? Jinkun, any update on this question? Thanks. -- Dmitry