[PATCH] clk: sunxi: Accept a greater rate when setting a parent clock
Emilio López
emilio at elopez.com.ar
Wed Mar 30 13:49:47 PDT 2016
[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.
Cheers,
Emilio
More information about the linux-arm-kernel
mailing list