[PATCH] clk: sunxi: Accept a greater rate when setting a parent clock

Maxime Ripard maxime.ripard at free-electrons.com
Thu Apr 14 10:24:00 PDT 2016


On Wed, Mar 30, 2016 at 05:49:47PM -0300, Emilio López wrote:
> [Sorry for the delay, I meant to reply to this post a while back but I
> forgot]
> 
> El 21/03/16 a las 05:25, Jean-Francois Moine escribió:
> > On Mon, 21 Mar 2016 08:25:46 +0100
> > Maxime Ripard <maxime.ripard at free-electrons.com> wrote:
> > 
> >>> -	/* find the parent that can help provide the fastest rate <= rate */
> >>> +	/* find the parent that can help provide the fastest rate */
> >>>  	num_parents = clk_hw_get_num_parents(hw);
> >>>  	for (i = 0; i < num_parents; i++) {
> >>>  		parent = clk_hw_get_parent_by_index(hw, i);
> >>> @@ -100,7 +100,7 @@ static int clk_factors_determine_rate(struct clk_hw *hw,
> >>>  		child_rate = clk_factors_round_rate(hw, req->rate,
> >>>  						    &parent_rate);
> >>>  
> >>> -		if (child_rate <= req->rate && child_rate > best_child_rate) {
> >>> +		if (child_rate > best_child_rate) {
> >>
> >> I'm not sure this would work, since you'll end up picking the fastest
> >> rate without considering whether it is the closest or not.
> >>
> >> I guess what you want here is using the absolute difference between
> >> the requested rate and the rate you're evaluating.
> >>
> >> That being said, we had a similar discussion for SPI around a month
> >> ago where we wanted a rate strictly lower than the requested one. I
> >> guess it's time to add a flag to tell how you want to round.
> > 
> > You are right, I just removed half of the constraint, but I still wonder
> > why does this sequence introduced by the commit 862b728387aef3a37
> > (clk: sunxi: factors: automatic reparenting support) do
> > 	"provide the fastest rate <= rate"
> > instead of
> > 	"provide the closest rate" ?
> > 
> > Emilio?
> 
> Overclocking components is usually not a good default in my opinion. I
> don't recall at the moment if there was some other justification apart
> from playing it safe.

Yeah, I'd agree, it should be the exception rather than the norm. In
some cases that are very timings sensitive (audio or video), we
probably want to enforce something as close as possible to the
expected rate, even if it trips above the rate.

For all the other, I'd prefer to keep the current behaviour.

Maxime

-- 
Maxime Ripard, Free Electrons
Embedded Linux, Kernel and Android engineering
http://free-electrons.com
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 819 bytes
Desc: Digital signature
URL: <http://lists.infradead.org/pipermail/linux-arm-kernel/attachments/20160414/c292b61a/attachment.sig>


More information about the linux-arm-kernel mailing list