linux-arm-kernel.lists.infradead.org archive mirror
 help / color / mirror / Atom feed
From: Stephen Boyd <sboyd@kernel.org>
To: Claudiu.Beznea@microchip.com, Ludovic.Desroches@microchip.com,
	Nicolas.Ferre@microchip.com, alexandre.belloni@bootlin.com,
	mturquette@baylibre.com, robh+dt@kernel.org
Cc: Eugen.Hristev@microchip.com, devicetree@vger.kernel.org,
	linux-clk@vger.kernel.org, linux-arm-kernel@lists.infradead.org,
	linux-kernel@vger.kernel.org
Subject: Re: [PATCH v4 06/11] clk: at91: clk-sam9x60-pll: allow runtime changes for pll
Date: Tue, 17 Nov 2020 17:49:30 -0800	[thread overview]
Message-ID: <160566417078.60232.18106288530854376790@swboyd.mtv.corp.google.com> (raw)
In-Reply-To: <24d975ca-1942-5f7f-ae89-7b572f48812c@microchip.com>

Quoting Claudiu.Beznea@microchip.com (2020-11-16 03:24:54)
> 
> 
> On 14.11.2020 23:14, Stephen Boyd wrote:
> > EXTERNAL EMAIL: Do not click links or open attachments unless you know the content is safe
> > 
> > Quoting Claudiu Beznea (2020-11-06 01:46:23)
> >> diff --git a/drivers/clk/at91/clk-sam9x60-pll.c b/drivers/clk/at91/clk-sam9x60-pll.c
> >> index 78f458a7b2ef..6fe5d8530a0c 100644
> >> --- a/drivers/clk/at91/clk-sam9x60-pll.c
> >> +++ b/drivers/clk/at91/clk-sam9x60-pll.c
> >> @@ -225,8 +225,51 @@ static int sam9x60_frac_pll_set_rate(struct clk_hw *hw, unsigned long rate,
> >>                                      unsigned long parent_rate)
> >>  {
> >>         struct sam9x60_pll_core *core = to_sam9x60_pll_core(hw);
> >> +       struct sam9x60_frac *frac = to_sam9x60_frac(core);
> >> +       struct regmap *regmap = core->regmap;
> >> +       unsigned long irqflags, clkflags = clk_hw_get_flags(hw);
> >> +       unsigned int val, cfrac, cmul;
> >> +       long ret;
> >> +
> >> +       ret = sam9x60_frac_pll_compute_mul_frac(core, rate, parent_rate, true);
> >> +       if (ret <= 0 || (clkflags & CLK_SET_RATE_GATE))
> > 
> > Is this function being called when the clk is enabled and it has the
> > CLK_SET_RATE_GATE flag set?
> 
> Yes, this function could be called when CLK_SET_RATE_GATE is set.
> On SAMA7G5 there are multiple PLL blocks of the same type. All these PLLs
> are controlled by clk-sam9x60-pll.c driver. One of this PLL block fed the
> CPU who's frequency could be changed at run time. At the same time there
> are PLLs that fed hardware block not glitch free aware or that we don't
> want to allow the rate change (this is the case of SAM9X60's CPU PLL, or
> the DDR PLL on SAMA7G5).
> 
> I'm confused why this driver needs to check
> > this flag.
> 
> Because we have multiple PLLs of the same type, some of them feed hardware
> blocks that are glitch free aware of these PLLs' frequencies changes, some
> feed hardware blocks that are not glitch free aware of PLLs' frequencies
> changes or for some of them we don't want the frequency changes at all.

Can we have different clk_ops for the different types of PLLs? It looks
like the flag is being used to overload this function to do different
things depending on how the flags are set. What happens if we decide to
change the semantics of this clk flag? How does it map to this driver?
Ideally this driver shouldn't need to worry about this flag, at least
not in this function, except to figure out if it should do something
different like not write the value to the hardware or something like
that.

The flag indicates to the clk framework that this clk should be gated
when clk_set_rate() is called on it. The driver should be able to figure
out that the clk is disabled by reading the hardware here and checking
the enable state, or it could just have different clk_ops for the
different type of PLL and do something different without checking the
flag. Either way, checking the flag looks wrong.

> >> -                 .c = 1,
> >> +                 .f = CLK_IS_CRITICAL | CLK_SET_RATE_GATE,
> > 
> > Please indicate why clks are critical.
> 
> Sure! I'll do it in next version. I chose it like this because they are
> feeding critical parts of the system like CPU or memory.
> 
> > Whenever the CLK_IS_CRITICAL flag
> > is used we should have a comment indicating why.
> 
> I was not aware of this rule. I'll update the code accordingly.

Sorry. I should put a document comment next to the flag.

_______________________________________________
linux-arm-kernel mailing list
linux-arm-kernel@lists.infradead.org
http://lists.infradead.org/mailman/listinfo/linux-arm-kernel

  reply	other threads:[~2020-11-18  1:50 UTC|newest]

Thread overview: 16+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2020-11-06  9:46 [PATCH v4 00/11] clk: at91: adapt for dvfs Claudiu Beznea
2020-11-06  9:46 ` [PATCH v4 01/11] clk: at91: sama7g5: fix compilation error Claudiu Beznea
2020-11-06  9:46 ` [PATCH v4 02/11] dt-bindings: clock: at91: add sama7g5 pll defines Claudiu Beznea
2020-11-06  9:46 ` [PATCH v4 03/11] clk: at91: sama7g5: allow SYS and CPU PLLs to be exported and referenced in DT Claudiu Beznea
2020-11-06  9:46 ` [PATCH v4 04/11] clk: at91: clk-master: add 5th divisor for mck master Claudiu Beznea
2020-11-06  9:46 ` [PATCH v4 05/11] clk: at91: sama7g5: add 5th divisor for mck0 layout and characteristics Claudiu Beznea
2020-11-06  9:46 ` [PATCH v4 06/11] clk: at91: clk-sam9x60-pll: allow runtime changes for pll Claudiu Beznea
2020-11-14 21:14   ` Stephen Boyd
2020-11-16 11:24     ` Claudiu.Beznea
2020-11-18  1:49       ` Stephen Boyd [this message]
2020-11-18  8:58         ` Claudiu.Beznea
2020-11-06  9:46 ` [PATCH v4 07/11] clk: at91: sama7g5: remove mck0 from parent list of other clocks Claudiu Beznea
2020-11-06  9:46 ` [PATCH v4 08/11] clk: at91: sama7g5: decrease lower limit for MCK0 rate Claudiu Beznea
2020-11-06  9:46 ` [PATCH v4 09/11] clk: at91: sama7g5: do not allow cpu pll to go higher than 1GHz Claudiu Beznea
2020-11-06  9:46 ` [PATCH v4 10/11] clk: at91: clk-master: re-factor master clock Claudiu Beznea
2020-11-06  9:46 ` [PATCH v4 11/11] clk: at91: sama7g5: register cpu clock Claudiu Beznea

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=160566417078.60232.18106288530854376790@swboyd.mtv.corp.google.com \
    --to=sboyd@kernel.org \
    --cc=Claudiu.Beznea@microchip.com \
    --cc=Eugen.Hristev@microchip.com \
    --cc=Ludovic.Desroches@microchip.com \
    --cc=Nicolas.Ferre@microchip.com \
    --cc=alexandre.belloni@bootlin.com \
    --cc=devicetree@vger.kernel.org \
    --cc=linux-arm-kernel@lists.infradead.org \
    --cc=linux-clk@vger.kernel.org \
    --cc=linux-kernel@vger.kernel.org \
    --cc=mturquette@baylibre.com \
    --cc=robh+dt@kernel.org \
    /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).