Quoting Taniya Das (2018-05-04 03:02:38) > diff --git a/drivers/clk/qcom/clk-rpmh.c b/drivers/clk/qcom/clk-rpmh.c > new file mode 100644 > index 0000000..944fe04 > --- /dev/null > +++ b/drivers/clk/qcom/clk-rpmh.c > @@ -0,0 +1,334 @@ > +// SPDX-License-Identifier: GPL-2.0 > +/* > + * Copyright (c) 2018, The Linux Foundation. All rights reserved. > + */ > + > +}; > + > +struct clk_rpmh_desc { > + struct clk_hw **clks; > + size_t num_clks; > +}; This could be replaced with the clk_hw_onecell_data struct and then the only problem becomes the const part which seems pretty impossible to fix at this point. One "workaround" is to memdup the structure. Ugh. > + > +static DEFINE_MUTEX(rpmh_clk_lock); > + > +#define __DEFINE_CLK_RPMH(_platform, _name, _name_active, _res_name, \ > + _res_en_offset, _res_on, _div) \ > + static struct clk_rpmh _platform##_##_name_active; \ > + static struct clk_rpmh _platform##_##_name = { \ [..] > + > +static unsigned long clk_rpmh_recalc_rate(struct clk_hw *hw, > + unsigned long prate) > +{ > + struct clk_rpmh *r = to_clk_rpmh(hw); > + unsigned long rate = prate; > + > + /* > + * RPMh clocks have a fixed rate. Return static rate. > + */ > + do_div(rate, r->div); Integer division won't suffice? > + return rate; > +} [...] > + > +static struct clk_hw *of_clk_rpmh_hw_get(struct of_phandle_args *clkspec, > + void *data) > +{ > + struct clk_hw *hw_clks = data; > + unsigned int idx = clkspec->args[0]; > + > + if (idx < 0) { It can't be less than 0 though because it's unsigned. > + pr_err("%s: invalid index %u\n", __func__, idx); > + return ERR_PTR(-EINVAL); > + } > + > + return &hw_clks[idx]; > +} -- To unsubscribe from this list: send the line "unsubscribe linux-soc" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html