Commit ee1eec36 authored by Paul Walmsley's avatar Paul Walmsley Committed by Russell King

[ARM] OMAP2/3 clock: clean up mach-omap2/clock.c

This patch rolls up several cleanup patches.

1. Some unnecessarily verbose variable names are used in several clock.c
functions; clean these up per CodingStyle.

2. Remove omap2_get_clksel() and just use clk->clksel_reg and
clk->clksel_mask directly.

3. Get rid of void __iomem * usage in omap2_clksel_get_src_field.
Prepend the function name with an underscore to highlight that it is a
static function.

linux-omap source commits are 7fa95e00,
af0ea23f, and
91c0c979.
Signed-off-by: default avatarPaul Walmsley <paul@pwsan.com>
Signed-off-by: default avatarTony Lindgren <tony@atomide.com>
Signed-off-by: default avatarRussell King <rmk+kernel@arm.linux.org.uk>
parent 416db864
...@@ -298,7 +298,7 @@ static void omap2_clk_wait_ready(struct clk *clk) ...@@ -298,7 +298,7 @@ static void omap2_clk_wait_ready(struct clk *clk)
static int omap2_dflt_clk_enable(struct clk *clk) static int omap2_dflt_clk_enable(struct clk *clk)
{ {
u32 regval32; u32 v;
if (unlikely(clk->enable_reg == NULL)) { if (unlikely(clk->enable_reg == NULL)) {
printk(KERN_ERR "clock.c: Enable for %s without enable code\n", printk(KERN_ERR "clock.c: Enable for %s without enable code\n",
...@@ -306,12 +306,12 @@ static int omap2_dflt_clk_enable(struct clk *clk) ...@@ -306,12 +306,12 @@ static int omap2_dflt_clk_enable(struct clk *clk)
return 0; /* REVISIT: -EINVAL */ return 0; /* REVISIT: -EINVAL */
} }
regval32 = __raw_readl(clk->enable_reg); v = __raw_readl(clk->enable_reg);
if (clk->flags & INVERT_ENABLE) if (clk->flags & INVERT_ENABLE)
regval32 &= ~(1 << clk->enable_bit); v &= ~(1 << clk->enable_bit);
else else
regval32 |= (1 << clk->enable_bit); v |= (1 << clk->enable_bit);
__raw_writel(regval32, clk->enable_reg); __raw_writel(v, clk->enable_reg);
wmb(); wmb();
return 0; return 0;
...@@ -335,7 +335,7 @@ static int omap2_dflt_clk_enable_wait(struct clk *clk) ...@@ -335,7 +335,7 @@ static int omap2_dflt_clk_enable_wait(struct clk *clk)
static void omap2_dflt_clk_disable(struct clk *clk) static void omap2_dflt_clk_disable(struct clk *clk)
{ {
u32 regval32; u32 v;
if (!clk->enable_reg) { if (!clk->enable_reg) {
/* /*
...@@ -347,12 +347,12 @@ static void omap2_dflt_clk_disable(struct clk *clk) ...@@ -347,12 +347,12 @@ static void omap2_dflt_clk_disable(struct clk *clk)
return; return;
} }
regval32 = __raw_readl(clk->enable_reg); v = __raw_readl(clk->enable_reg);
if (clk->flags & INVERT_ENABLE) if (clk->flags & INVERT_ENABLE)
regval32 |= (1 << clk->enable_bit); v |= (1 << clk->enable_bit);
else else
regval32 &= ~(1 << clk->enable_bit); v &= ~(1 << clk->enable_bit);
__raw_writel(regval32, clk->enable_reg); __raw_writel(v, clk->enable_reg);
wmb(); wmb();
} }
...@@ -643,23 +643,6 @@ u32 omap2_divisor_to_clksel(struct clk *clk, u32 div) ...@@ -643,23 +643,6 @@ u32 omap2_divisor_to_clksel(struct clk *clk, u32 div)
return clkr->val; return clkr->val;
} }
/**
* omap2_get_clksel - find clksel register addr & field mask for a clk
* @clk: struct clk to use
* @field_mask: ptr to u32 to store the register field mask
*
* Returns the address of the clksel register upon success or NULL on error.
*/
static void __iomem *omap2_get_clksel(struct clk *clk, u32 *field_mask)
{
if (!clk->clksel_reg || (clk->clksel_mask == 0))
return NULL;
*field_mask = clk->clksel_mask;
return clk->clksel_reg;
}
/** /**
* omap2_clksel_get_divisor - get current divider applied to parent clock. * omap2_clksel_get_divisor - get current divider applied to parent clock.
* @clk: OMAP struct clk to use. * @clk: OMAP struct clk to use.
...@@ -668,40 +651,36 @@ static void __iomem *omap2_get_clksel(struct clk *clk, u32 *field_mask) ...@@ -668,40 +651,36 @@ static void __iomem *omap2_get_clksel(struct clk *clk, u32 *field_mask)
*/ */
u32 omap2_clksel_get_divisor(struct clk *clk) u32 omap2_clksel_get_divisor(struct clk *clk)
{ {
u32 field_mask, field_val; u32 v;
void __iomem *div_addr;
div_addr = omap2_get_clksel(clk, &field_mask); if (!clk->clksel_mask)
if (!div_addr)
return 0; return 0;
field_val = __raw_readl(div_addr) & field_mask; v = __raw_readl(clk->clksel_reg) & clk->clksel_mask;
field_val >>= __ffs(field_mask); v >>= __ffs(clk->clksel_mask);
return omap2_clksel_to_divisor(clk, field_val); return omap2_clksel_to_divisor(clk, v);
} }
int omap2_clksel_set_rate(struct clk *clk, unsigned long rate) int omap2_clksel_set_rate(struct clk *clk, unsigned long rate)
{ {
u32 field_mask, field_val, reg_val, validrate, new_div = 0; u32 v, field_val, validrate, new_div = 0;
void __iomem *div_addr;
validrate = omap2_clksel_round_rate_div(clk, rate, &new_div); if (!clk->clksel_mask)
if (validrate != rate)
return -EINVAL; return -EINVAL;
div_addr = omap2_get_clksel(clk, &field_mask); validrate = omap2_clksel_round_rate_div(clk, rate, &new_div);
if (!div_addr) if (validrate != rate)
return -EINVAL; return -EINVAL;
field_val = omap2_divisor_to_clksel(clk, new_div); field_val = omap2_divisor_to_clksel(clk, new_div);
if (field_val == ~0) if (field_val == ~0)
return -EINVAL; return -EINVAL;
reg_val = __raw_readl(div_addr); v = __raw_readl(clk->clksel_reg);
reg_val &= ~field_mask; v &= ~clk->clksel_mask;
reg_val |= (field_val << __ffs(field_mask)); v |= field_val << __ffs(clk->clksel_mask);
__raw_writel(reg_val, div_addr); __raw_writel(v, clk->clksel_reg);
wmb(); wmb();
clk->rate = clk->parent->rate / new_div; clk->rate = clk->parent->rate / new_div;
...@@ -737,18 +716,14 @@ int omap2_clk_set_rate(struct clk *clk, unsigned long rate) ...@@ -737,18 +716,14 @@ int omap2_clk_set_rate(struct clk *clk, unsigned long rate)
/* /*
* Converts encoded control register address into a full address * Converts encoded control register address into a full address
* On error, *src_addr will be returned as 0. * On error, the return value (parent_div) will be 0.
*/ */
static u32 omap2_clksel_get_src_field(void __iomem **src_addr, static u32 _omap2_clksel_get_src_field(struct clk *src_clk, struct clk *clk,
struct clk *src_clk, u32 *field_mask, u32 *field_val)
struct clk *clk, u32 *parent_div)
{ {
const struct clksel *clks; const struct clksel *clks;
const struct clksel_rate *clkr; const struct clksel_rate *clkr;
*parent_div = 0;
*src_addr = NULL;
clks = omap2_get_clksel_by_parent(clk, src_clk); clks = omap2_get_clksel_by_parent(clk, src_clk);
if (!clks) if (!clks)
return 0; return 0;
...@@ -768,17 +743,14 @@ static u32 omap2_clksel_get_src_field(void __iomem **src_addr, ...@@ -768,17 +743,14 @@ static u32 omap2_clksel_get_src_field(void __iomem **src_addr,
/* Should never happen. Add a clksel mask to the struct clk. */ /* Should never happen. Add a clksel mask to the struct clk. */
WARN_ON(clk->clksel_mask == 0); WARN_ON(clk->clksel_mask == 0);
*field_mask = clk->clksel_mask; *field_val = clkr->val;
*src_addr = clk->clksel_reg;
*parent_div = clkr->div;
return clkr->val; return clkr->div;
} }
int omap2_clk_set_parent(struct clk *clk, struct clk *new_parent) int omap2_clk_set_parent(struct clk *clk, struct clk *new_parent)
{ {
void __iomem *src_addr; u32 field_val, v, parent_div;
u32 field_val, field_mask, reg_val, parent_div;
if (clk->flags & CONFIG_PARTICIPANT) if (clk->flags & CONFIG_PARTICIPANT)
return -EINVAL; return -EINVAL;
...@@ -786,18 +758,18 @@ int omap2_clk_set_parent(struct clk *clk, struct clk *new_parent) ...@@ -786,18 +758,18 @@ int omap2_clk_set_parent(struct clk *clk, struct clk *new_parent)
if (!clk->clksel) if (!clk->clksel)
return -EINVAL; return -EINVAL;
field_val = omap2_clksel_get_src_field(&src_addr, new_parent, parent_div = _omap2_clksel_get_src_field(new_parent, clk, &field_val);
&field_mask, clk, &parent_div); if (!parent_div)
if (!src_addr)
return -EINVAL; return -EINVAL;
if (clk->usecount > 0) if (clk->usecount > 0)
_omap2_clk_disable(clk); _omap2_clk_disable(clk);
/* Set new source value (previous dividers if any in effect) */ /* Set new source value (previous dividers if any in effect) */
reg_val = __raw_readl(src_addr) & ~field_mask; v = __raw_readl(clk->clksel_reg);
reg_val |= (field_val << __ffs(field_mask)); v &= ~clk->clksel_mask;
__raw_writel(reg_val, src_addr); v |= field_val << __ffs(clk->clksel_mask);
__raw_writel(v, clk->clksel_reg);
wmb(); wmb();
if (clk->flags & DELAYED_APP && cpu_is_omap24xx()) { if (clk->flags & DELAYED_APP && cpu_is_omap24xx()) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment