Hi Geert, Thanks for your patch. On 2019-08-30 15:45:10 +0200, Geert Uytterhoeven wrote: > The .set_rate() callback for the SD clocks is always called with a valid > clock rate, returned by .round_rate(). Hence there is no need to > iterate through the divider table twice: once to repeat the work done by > .round_rate(), and a second time to find the corresponding divider > entry. > > Just iterate once, looking for the divider that matches the passed clock > rate. > > Signed-off-by: Geert Uytterhoeven <geert+renesas@xxxxxxxxx> Clever :-) Reviewed-by: Niklas Söderlund <niklas.soderlund+renesas@xxxxxxxxxxxx> > --- > v2: > - No changes. > --- > drivers/clk/renesas/rcar-gen3-cpg.c | 6 +++--- > 1 file changed, 3 insertions(+), 3 deletions(-) > > diff --git a/drivers/clk/renesas/rcar-gen3-cpg.c b/drivers/clk/renesas/rcar-gen3-cpg.c > index 3480284a08308134..9f457411984b1ca4 100644 > --- a/drivers/clk/renesas/rcar-gen3-cpg.c > +++ b/drivers/clk/renesas/rcar-gen3-cpg.c > @@ -339,14 +339,14 @@ static long cpg_sd_clock_round_rate(struct clk_hw *hw, unsigned long rate, > } > > static int cpg_sd_clock_set_rate(struct clk_hw *hw, unsigned long rate, > - unsigned long parent_rate) > + unsigned long parent_rate) > { > struct sd_clock *clock = to_sd_clock(hw); > - unsigned int div = cpg_sd_clock_calc_div(clock, rate, parent_rate); > unsigned int i; > > for (i = 0; i < clock->div_num; i++) > - if (div == clock->div_table[i].div) > + if (rate == DIV_ROUND_CLOSEST(parent_rate, > + clock->div_table[i].div)) > break; > > if (i >= clock->div_num) > -- > 2.17.1 > -- Regards, Niklas Söderlund