[PATCH v4 02/15] clk: Allow drivers to pass in a regmap
Mike Turquette
mturquette at linaro.org
Wed Jan 15 04:36:41 EST 2014
Quoting Saravana Kannan (2014-01-13 19:54:42)
> On 01/08/2014 05:51 PM, Mike Turquette wrote:
> > Quoting Stephen Boyd (2013-12-23 17:12:26)
> >> Add support to the clock core so that drivers can pass in a
> >> regmap. If no regmap is specified try to query the device that's
> >> registering the clock for its regmap. This should allow drivers
> >> to use the core regmap helpers. This is based on a similar design
> >> in the regulator framework.
> >>
> >> Cc: Mark Brown <broonie at kernel.org>
> >> Signed-off-by: Stephen Boyd <sboyd at codeaurora.org>
> >> ---
> >> drivers/clk/clk.c | 8 ++++++++
> >> include/linux/clk-provider.h | 7 +++++++
> >> 2 files changed, 15 insertions(+)
> >>
> >> diff --git a/drivers/clk/clk.c b/drivers/clk/clk.c
> >> index 9ad7b71..5e71f5c 100644
> >> --- a/drivers/clk/clk.c
> >> +++ b/drivers/clk/clk.c
> >> @@ -20,6 +20,7 @@
> >> #include <linux/device.h>
> >> #include <linux/init.h>
> >> #include <linux/sched.h>
> >> +#include <linux/regmap.h>
> >>
> >> static DEFINE_SPINLOCK(enable_lock);
> >> static DEFINE_MUTEX(prepare_lock);
> >> @@ -1834,6 +1835,13 @@ static int _clk_register(struct device *dev, struct clk_hw *hw, struct clk *clk)
> >> clk->num_parents = hw->init->num_parents;
> >> hw->clk = clk;
> >>
> >> + if (hw->init->regmap)
> >> + hw->regmap = hw->init->regmap;
> >
> > Hi Stephen,
> >
> > The whole series looks good to me except for the placement of the regmap
> > details inside struct clk_hw. That structure exists only to hide struct
> > clk from the hardware-specific clock structure and I'd not like to set
> > the precedent of shoving per-clock data into it.
> >
> > As an alternative, how about finding a way to put these per-clock regmap
> > details into the hardware-specific clock structure? I understand that
> > you want to make these ops available to others, which is why they are in
> > the public struct clk_hw. I'm just wondering if that is the right way to
> > do it...
> >
> > Patch #3 illustrates the sort of struct-member-creep that worries me.
> > What is to stop someone from putting "unsigned int divider_reg" or
> > "unsigned int mux_reg", and then the thing just keeps growing.
>
> I agree with Mike here. This definitely encourages struct field creep if
> more people want to use it.
>
> I talked to Stephen is person and my recommendation is to not have any
> new fields other than struct regmap in clk_hw and remove the above 2
> lines of code.
>
> >> + else if (dev && dev_get_regmap(dev, NULL))
> >> + hw->regmap = dev_get_regmap(dev, NULL);
>
> Move "struct regmap *regmap" into struct clk_hw (since it's truly
> reusable across clock types and is technically purely HW related) and
> update it from the device's regmap like above.
Hi Saravana,
Thanks for your comments. In the paragraph above you mean "struct
clk_hw" or do you mean the hardware-specific structure(s) defined in a
clock driver?
>
> We can then provide __clk_regmap_enable(regmap, offset, enable_mask)
> helper functions. Then clock specific functions can use the helper. We
> can even a simple macro to generate these wrappers.
>
> #define DEFINE_REGMAP_EN_DIS(clktype) \
>
> int clk_type##_enable(clktype *c, ....) { }
> int clk_type##_disable(clktype *c, ....) { }
>
>
> That to me seems like a reasonable compromise.
Providing common functions for the basic case (e.g. read-modify-write on
a register using a known mask) is reasonable. But that is exactly what
the existing basic clock types do (sans regmap) and they have all become
pretty ugly over time. And the clk-composite implementation just makes
me a sad panda.
I'm not opposed to providing public implementations of clk_ops callbacks
that use regmap, but I will be very mindful of any feature creep in the
future.
I am still unconvinced that adding struct regmap to struct clk_hw is a
good idea. The regmap data is a function of hardware-specific details
and those details always have and always will belong in the clock
driver.
Regards,
Mike
>
> Thanks,
> Saravana
> --
> The Qualcomm Innovation Center, Inc. is a member of the Code Aurora Forum,
> hosted by The Linux Foundation
More information about the linux-arm-kernel
mailing list