clk: meson: dualdiv: switch from .round_rate to .determine_rate
authorMartin Blumenstingl <martin.blumenstingl@googlemail.com>
Sun, 25 Dec 2022 21:26:30 +0000 (22:26 +0100)
committerJerome Brunet <jbrunet@baylibre.com>
Fri, 13 Jan 2023 14:14:12 +0000 (15:14 +0100)
clk_ops.round_rate will be removed at some point. It's replacement is
.determine_rate. Switch clk-dualdiv over to use .determine_rate.

Signed-off-by: Martin Blumenstingl <martin.blumenstingl@googlemail.com>
Acked-by: Stephen Boyd <sboyd@kernel.org>
Link: https://lore.kernel.org/r/20221225212632.2760126-3-martin.blumenstingl@googlemail.com
Signed-off-by: Jerome Brunet <jbrunet@baylibre.com>
drivers/clk/meson/clk-dualdiv.c

index c5ca23a..feae49a 100644 (file)
@@ -86,18 +86,23 @@ __dualdiv_get_setting(unsigned long rate, unsigned long parent_rate,
        return (struct meson_clk_dualdiv_param *)&table[best_i];
 }
 
-static long meson_clk_dualdiv_round_rate(struct clk_hw *hw, unsigned long rate,
-                                        unsigned long *parent_rate)
+static int meson_clk_dualdiv_determine_rate(struct clk_hw *hw,
+                                           struct clk_rate_request *req)
 {
        struct clk_regmap *clk = to_clk_regmap(hw);
        struct meson_clk_dualdiv_data *dualdiv = meson_clk_dualdiv_data(clk);
-       const struct meson_clk_dualdiv_param *setting =
-               __dualdiv_get_setting(rate, *parent_rate, dualdiv);
+       const struct meson_clk_dualdiv_param *setting;
 
-       if (!setting)
-               return meson_clk_dualdiv_recalc_rate(hw, *parent_rate);
+       setting = __dualdiv_get_setting(req->rate, req->best_parent_rate,
+                                       dualdiv);
+       if (setting)
+               req->rate = __dualdiv_param_to_rate(req->best_parent_rate,
+                                                   setting);
+       else
+               req->rate = meson_clk_dualdiv_recalc_rate(hw,
+                                                         req->best_parent_rate);
 
-       return __dualdiv_param_to_rate(*parent_rate, setting);
+       return 0;
 }
 
 static int meson_clk_dualdiv_set_rate(struct clk_hw *hw, unsigned long rate,
@@ -122,7 +127,7 @@ static int meson_clk_dualdiv_set_rate(struct clk_hw *hw, unsigned long rate,
 
 const struct clk_ops meson_clk_dualdiv_ops = {
        .recalc_rate    = meson_clk_dualdiv_recalc_rate,
-       .round_rate     = meson_clk_dualdiv_round_rate,
+       .determine_rate = meson_clk_dualdiv_determine_rate,
        .set_rate       = meson_clk_dualdiv_set_rate,
 };
 EXPORT_SYMBOL_GPL(meson_clk_dualdiv_ops);