On Thu, Oct 10, 2013 at 12:39:16PM +0200, Thierry Reding wrote: > * PGP Signed by an unknown key > > On Fri, Oct 04, 2013 at 12:12:40PM +0300, Peter De Schrijver wrote: > > Signed-off-by: Peter De Schrijver <pdeschrijver@xxxxxxxxxx> > > This is missing a commit description. > > > diff --git a/drivers/clk/tegra/clk-pll.c b/drivers/clk/tegra/clk-pll.c > [...] > > +const struct clk_ops tegra_clk_pllss_ops = { > > static? > > > +struct clk *tegra_clk_register_pllss(const char *name, const char *parent_name, > > + void __iomem *clk_base, unsigned long flags, > > + unsigned long fixed_rate, > > + struct tegra_clk_pll_params *pll_params, > > + struct tegra_clk_pll_freq_table *freq_table, > > + spinlock_t *lock) > > +{ > [...] > > + pll = _tegra_init_pll(clk_base, NULL, fixed_rate, pll_params, > > + pll_flags, freq_table, lock); > > + > > + if (IS_ERR(pll)) > > I'd leave out the blank line separating the assignment of pll and the > check for validity. Grouping them together like that makes it > immediately clear that they belong together. > > > + return ERR_CAST(pll); > > + > > + val = pll_readl_base(pll); > > + > > + if (val & (3 << 25)) { > > Same here. Also 3 << 25 could probably be a symbolic constant, something > like PLLSS_REF_SRC_SEL_MASK perhaps? > > > + WARN(1, "Unknown parent selected for %s: %d\n", name, > > + val >> 25); > > Similarly, this should be something like: > > (val & PLLSS_REF_SRC_SEL_MASK) >> PLLSS_REF_SRC_SEL_SHIFT > > > + kfree(pll); > > + return ERR_PTR(-EINVAL); > > + } > > + _get_pll_mnp(pll, &cfg); > > Nit: I'd put a blank line before this, to separate the block and the > function call. That is: > > } > > _get_pll_mnp(...); > > > + > > + if (cfg.n > 1) { > > + WARN(1, "%s should not be initialized\n", name); > > + kfree(pll); > > + return ERR_PTR(-EINVAL); > > + } > > Is this really fatal? Can't we just configure the PLL from scratch? > > > + parent_rate = __clk_get_rate(parent); > > + > > + pll_params->vco_min = _clip_vco_min(pll_params->vco_min, parent_rate); > > + > > + cfg.m = _pll_fixed_mdiv(pll_params, parent_rate); > > + cfg.n = cfg.m * pll_params->vco_min / parent_rate; > > + > > + for (i = 0; pll_params->pdiv_tohw[i].pdiv; i++) > > + ; > > + cfg.p = pll_params->pdiv_tohw[i-1].hw_val; > > Could use a blank line to separate them. Also what if .pdiv of the first > entry is 0? The loop will terminate on the first run and i will be 0, so > this would try to access pdiv_tohw[-1]. Can that ever happen? > That would be an error. This PLL type always has a post divider table. I will add a check. Cheers, Peter. -- To unsubscribe from this list: send the line "unsubscribe devicetree" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html