linux-clk.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Rhyland Klein <rklein@nvidia.com>
To: Benson Leung <bleung@chromium.org>
Cc: Peter De Schrijver <pdeschrijver@nvidia.com>,
	Mike Turquette <mturquette@linaro.org>,
	Stephen Warren <swarren@wwwdotorg.org>,
	Stephen Boyd <sboyd@codeaurora.org>,
	Thierry Reding <thierry.reding@gmail.com>,
	Alexandre Courbot <gnurou@gmail.com>,
	Bill Huang <bilhuang@nvidia.com>,
	Paul Walmsley <pwalmsley@nvidia.com>, Jim Lin <jilin@nvidia.com>,
	<linux-clk@vger.kernel.org>, <linux-tegra@vger.kernel.org>,
	"linux-kernel@vger.kernel.org" <linux-kernel@vger.kernel.org>
Subject: Re: [PATCH v5 16/21] clk: tegra: pll: Add Set_default logic
Date: Wed, 20 May 2015 13:20:55 -0400	[thread overview]
Message-ID: <555CC277.1040402@nvidia.com> (raw)
In-Reply-To: <CANLzEkv2rO63083RxEFWU0a_qm+7QOx0mCD8ya8hDmp5QMmkgQ@mail.gmail.com>

On 5/13/2015 8:04 PM, Benson Leung wrote:
> On Tue, May 12, 2015 at 10:23 AM, Rhyland Klein <rklein@nvidia.com> wrote:
>> From: Bill Huang <bilhuang@nvidia.com>
>>
>> Add logic which (if specified for a pll) can verify that a PLL is set
>> to the proper default value and if not can set it. This can be
>> specified per PLL as each will have different default values.
>>
>> Based on original work by Aleksandr Frid <afrid@nvidia.com>
>>
>> Signed-off-by: Bill Huang <bilhuang@nvidia.com>
>> ---
>> v2:
>>   - Remove MACRO for PLL_MISC_CHECK_DEFAULT as suggested, and instead
>>     the tegra210 driver will include an inline version of this function.
>>
>>  drivers/clk/tegra/clk-pll.c |   46 ++++++++++++++++++++++++++++++++-----------
>>  drivers/clk/tegra/clk.h     |    2 ++
>>  2 files changed, 37 insertions(+), 11 deletions(-)
>>
>> diff --git a/drivers/clk/tegra/clk-pll.c b/drivers/clk/tegra/clk-pll.c
>> index 626466665dde..36aa2a95fac0 100644
>> --- a/drivers/clk/tegra/clk-pll.c
>> +++ b/drivers/clk/tegra/clk-pll.c
>> @@ -652,13 +652,26 @@ static int _program_pll(struct clk_hw *hw, struct tegra_clk_pll_freq_table *cfg,
>>                         unsigned long rate)
>>  {
>>         struct tegra_clk_pll *pll = to_clk_pll(hw);
>> +       struct tegra_clk_pll_freq_table old_cfg;
>>         int state, ret = 0;
>>
>>         state = clk_pll_is_enabled(hw);
>>
>> +       _get_pll_mnp(pll, &old_cfg);
>> +
>> +       if (state && pll->params->defaults_set && pll->params->dyn_ramp &&
>> +                       (cfg->m == old_cfg.m) && (cfg->p == old_cfg.p)) {
>> +               ret = pll->params->dyn_ramp(pll, cfg);
>> +               if (!ret)
>> +                       return 0;
>> +       }
>> +
> 
> This block above depends on defaults_set, but seems to be some
> additional dyn_ramp logic that is different from what the commit
> message describes of this patch, namely, setting defaults if
> defaults_set is not true.
> 
> Could you perhaps reverse the order of this patch [16/21] and the
> preceding one [15/21] clk: tegra: pll: Add dyn_ramp callback, and move
> this chunk of code into the dyn_ramp patch?

Will do.

> 
>>         if (state)
>>                 _clk_pll_disable(hw);
>>
>> +       if (!pll->params->defaults_set && pll->params->set_defaults)
>> +               pll->params->set_defaults(pll);
>> +
>>         _update_pll_mnp(pll, cfg);
>>
>>         if (pll->params->flags & TEGRA_PLL_HAS_CPCON)
>> @@ -1517,6 +1530,9 @@ static struct clk *_tegra_clk_register_pll(struct tegra_clk_pll *pll,
>>         if (!pll->params->calc_rate)
>>                 pll->params->calc_rate = _calc_rate;
>>
>> +       if (pll->params->set_defaults)
>> +               pll->params->set_defaults(pll);
>> +
>>         /* Data in .init is copied by clk_register(), so stack variable OK */
>>         pll->hw.init = &init;
>>
>> @@ -1636,7 +1652,6 @@ struct clk *tegra_clk_register_pllxc(const char *name, const char *parent_name,
>>         struct tegra_clk_pll *pll;
>>         struct clk *clk, *parent;
>>         unsigned long parent_rate;
>> -       int err;
>>         u32 val, val_iddq;
>>
>>         parent = __clk_lookup(parent_name);
>> @@ -1657,18 +1672,27 @@ struct clk *tegra_clk_register_pllxc(const char *name, const char *parent_name,
>>                 pll_params->vco_min = pll_params->adjust_vco(pll_params,
>>                                                              parent_rate);
>>
>> -       err = _setup_dynamic_ramp(pll_params, clk_base, parent_rate);
>> -       if (err)
>> -               return ERR_PTR(err);
>> +       /*
>> +        * If the pll has a set_defaults callback, it will take care of
>> +        * configuring dynamic ramping and setting IDDQ in that path.
>> +        */
>> +       if (!pll_params->set_defaults) {
>> +               int err;
>>
>> -       val = readl_relaxed(clk_base + pll_params->base_reg);
>> -       val_iddq = readl_relaxed(clk_base + pll_params->iddq_reg);
>> +               err = _setup_dynamic_ramp(pll_params, clk_base, parent_rate);
>> +               if (err)
>> +                       return ERR_PTR(err);
>>
>> -       if (val & PLL_BASE_ENABLE)
>> -               WARN_ON(val_iddq & BIT(pll_params->iddq_bit_idx));
>> -       else {
>> -               val_iddq |= BIT(pll_params->iddq_bit_idx);
>> -               writel_relaxed(val_iddq, clk_base + pll_params->iddq_reg);
>> +               val = readl_relaxed(clk_base + pll_params->base_reg);
>> +               val_iddq = readl_relaxed(clk_base + pll_params->iddq_reg);
>> +
>> +               if (val & PLL_BASE_ENABLE)
>> +                       WARN_ON(val_iddq & BIT(pll_params->iddq_bit_idx));
>> +               else {
>> +                       val_iddq |= BIT(pll_params->iddq_bit_idx);
>> +                       writel_relaxed(val_iddq,
>> +                                      clk_base + pll_params->iddq_reg);
>> +               }
>>         }
>>
>>         pll = _tegra_init_pll(clk_base, pmc, pll_params, lock);
>> diff --git a/drivers/clk/tegra/clk.h b/drivers/clk/tegra/clk.h
>> index a61d388364b3..38b4c95cfb2f 100644
>> --- a/drivers/clk/tegra/clk.h
>> +++ b/drivers/clk/tegra/clk.h
>> @@ -261,6 +261,7 @@ struct tegra_clk_pll_params {
>>         int             stepb_shift;
>>         int             lock_delay;
>>         int             max_p;
>> +       bool            defaults_set;
>>         struct pdiv_map *pdiv_tohw;
>>         struct div_nmp  *div_nmp;
>>         struct tegra_clk_pll_freq_table *freq_table;
>> @@ -275,6 +276,7 @@ struct tegra_clk_pll_params {
>>                                 unsigned long parent_rate);
>>         int     (*dyn_ramp)(struct tegra_clk_pll *pll,
>>                         struct tegra_clk_pll_freq_table *cfg);
>> +       void    (*set_defaults)(struct tegra_clk_pll *pll);
> 
> Kerneldoc for the two members, please. This is especially useful since
> the two members have such similar names, but they mean different
> things.
> 

Yah I thought I got all the new members, but apparently I got distracted
part way through the series and missed some. I'll double check for v6
that ALL members are kerneldoc'd.

-rhyland

-- 
nvpublic

  reply	other threads:[~2015-05-20 17:20 UTC|newest]

Thread overview: 46+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-05-12 17:23 [PATCH v5 00/21] Tegra210 Clock Support Rhyland Klein
2015-05-12 17:23 ` [PATCH v5 01/21] clk: tegra: Update struct tegra_clk_pll_params kerneldoc Rhyland Klein
2015-05-12 17:23 ` [PATCH v5 01/21] FROMLIST: " Rhyland Klein
2015-05-12 17:23 ` [PATCH v5 02/21] clk: tegra: Modify tegra_audio_clk_init to accept more plls Rhyland Klein
2015-05-12 17:23 ` [PATCH v5 03/21] clk: tegra: periph: add new periph clks and muxes for Tegra210 Rhyland Klein
2015-05-12 17:23 ` [PATCH v5 04/21] clk: tegra: pll: add tegra_pll_wait_for_lock to clk header Rhyland Klein
2015-05-12 21:52   ` Benson Leung
2015-05-12 17:23 ` [PATCH v5 05/21] clk: tegra: pll: simplify clk_enable_path Rhyland Klein
2015-05-12 17:23 ` [PATCH v5 06/21] clk: tegra: pll: update warning msg Rhyland Klein
2015-05-12 17:23 ` [PATCH v5 07/21] clk: tegra: pll-params: change misc_reg count from 3 -> 6 Rhyland Klein
2015-05-12 17:23 ` [PATCH v5 08/21] clk: tegra: pll: Don't unconditionally set LOCK flags Rhyland Klein
2015-05-12 17:23 ` [PATCH v5 09/21] clk: tegra: pll: Add logic for handling SDM data Rhyland Klein
2015-05-18 22:35   ` Benson Leung
2015-05-12 17:23 ` [PATCH v5 10/21] clk: tegra: pll: Add logic for out-of-table rates for T210 Rhyland Klein
2015-05-13  0:01   ` Benson Leung
2015-05-12 17:23 ` [PATCH v5 11/21] clk: tegra: pll: Add code to handle if resets are supported by PLL Rhyland Klein
2015-05-12 17:23 ` [PATCH v5 12/21] clk: tegra: pll: Add specialized logic for T210 Rhyland Klein
2015-05-13 20:59   ` Benson Leung
2015-05-20 17:24     ` Rhyland Klein
2015-05-20 17:26       ` Benson Leung
2015-05-12 17:23 ` [PATCH v5 13/21] clk: tegra: pll: Add support for PLLMB " Rhyland Klein
2015-05-13 22:04   ` Benson Leung
2015-05-12 17:23 ` [PATCH v5 14/21] clk: tegra: pll: Adjust vco_min if SDM present Rhyland Klein
2015-05-13 22:11   ` Benson Leung
2015-06-04 18:52   ` Stephen Boyd
2015-05-12 17:23 ` [PATCH v5 15/21] clk: tegra: pll: Add dyn_ramp callback Rhyland Klein
2015-05-13 22:20   ` Benson Leung
2015-05-12 17:23 ` [PATCH v5 16/21] clk: tegra: pll: Add Set_default logic Rhyland Klein
2015-05-14  0:04   ` Benson Leung
2015-05-20 17:20     ` Rhyland Klein [this message]
2015-05-12 17:24 ` [PATCH v5 17/21] clk: tegra: pll: Add logic for SS Rhyland Klein
2015-05-14  0:25   ` Benson Leung
2015-05-20 17:19     ` Rhyland Klein
2015-05-12 17:24 ` [PATCH v5 18/21] clk: tegra: pll: Fix _pll_ramp_calc_pll logic and _calc_dynamic_ramp_rate Rhyland Klein
2015-05-14  0:29   ` Benson Leung
2015-05-12 17:24 ` [PATCH v5 19/21] clk: tegra: Add Super Gen5 Logic Rhyland Klein
2015-05-13 20:36   ` Benson Leung
2015-05-14 19:37   ` Benson Leung
2015-05-25  8:19     ` Bill Huang
2015-05-12 17:24 ` [PATCH v5 20/21] clk: tegra210: add support for Tegra210 clocks Rhyland Klein
2015-05-14 20:23   ` Benson Leung
2015-05-20 17:17     ` Rhyland Klein
2015-05-20  9:47   ` Jim Lin
2015-05-20 17:16     ` Rhyland Klein
2015-05-12 17:24 ` [PATCH v5 21/21] clk: tegra: pll: Fix issues with rates for VCO PLLs Rhyland Klein
2015-05-14 20:02   ` Benson Leung

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=555CC277.1040402@nvidia.com \
    --to=rklein@nvidia.com \
    --cc=bilhuang@nvidia.com \
    --cc=bleung@chromium.org \
    --cc=gnurou@gmail.com \
    --cc=jilin@nvidia.com \
    --cc=linux-clk@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=linux-tegra@vger.kernel.org \
    --cc=mturquette@linaro.org \
    --cc=pdeschrijver@nvidia.com \
    --cc=pwalmsley@nvidia.com \
    --cc=sboyd@codeaurora.org \
    --cc=swarren@wwwdotorg.org \
    --cc=thierry.reding@gmail.com \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).