Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 137341
b: refs/heads/master
c: ee1eec3
h: refs/heads/master
i:
  137339: c27b229
v: v3
  • Loading branch information
Paul Walmsley authored and Russell King committed Feb 8, 2009
1 parent efa54ba commit 2d2ccc1
Show file tree
Hide file tree
Showing 2 changed files with 36 additions and 64 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 416db864c18343c6dcc5e9768c902460c8f8777c
refs/heads/master: ee1eec36345871955730e36232937c9d814a6e20
98 changes: 35 additions & 63 deletions trunk/arch/arm/mach-omap2/clock.c
Original file line number Diff line number Diff line change
Expand Up @@ -298,20 +298,20 @@ static void omap2_clk_wait_ready(struct clk *clk)

static int omap2_dflt_clk_enable(struct clk *clk)
{
u32 regval32;
u32 v;

if (unlikely(clk->enable_reg == NULL)) {
printk(KERN_ERR "clock.c: Enable for %s without enable code\n",
clk->name);
return 0; /* REVISIT: -EINVAL */
}

regval32 = __raw_readl(clk->enable_reg);
v = __raw_readl(clk->enable_reg);
if (clk->flags & INVERT_ENABLE)
regval32 &= ~(1 << clk->enable_bit);
v &= ~(1 << clk->enable_bit);
else
regval32 |= (1 << clk->enable_bit);
__raw_writel(regval32, clk->enable_reg);
v |= (1 << clk->enable_bit);
__raw_writel(v, clk->enable_reg);
wmb();

return 0;
Expand All @@ -335,7 +335,7 @@ static int omap2_dflt_clk_enable_wait(struct clk *clk)

static void omap2_dflt_clk_disable(struct clk *clk)
{
u32 regval32;
u32 v;

if (!clk->enable_reg) {
/*
Expand All @@ -347,12 +347,12 @@ static void omap2_dflt_clk_disable(struct clk *clk)
return;
}

regval32 = __raw_readl(clk->enable_reg);
v = __raw_readl(clk->enable_reg);
if (clk->flags & INVERT_ENABLE)
regval32 |= (1 << clk->enable_bit);
v |= (1 << clk->enable_bit);
else
regval32 &= ~(1 << clk->enable_bit);
__raw_writel(regval32, clk->enable_reg);
v &= ~(1 << clk->enable_bit);
__raw_writel(v, clk->enable_reg);
wmb();
}

Expand Down Expand Up @@ -643,23 +643,6 @@ u32 omap2_divisor_to_clksel(struct clk *clk, u32 div)
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.
* @clk: OMAP struct clk to use.
Expand All @@ -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 field_mask, field_val;
void __iomem *div_addr;
u32 v;

div_addr = omap2_get_clksel(clk, &field_mask);
if (!div_addr)
if (!clk->clksel_mask)
return 0;

field_val = __raw_readl(div_addr) & field_mask;
field_val >>= __ffs(field_mask);
v = __raw_readl(clk->clksel_reg) & clk->clksel_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)
{
u32 field_mask, field_val, reg_val, validrate, new_div = 0;
void __iomem *div_addr;
u32 v, field_val, validrate, new_div = 0;

validrate = omap2_clksel_round_rate_div(clk, rate, &new_div);
if (validrate != rate)
if (!clk->clksel_mask)
return -EINVAL;

div_addr = omap2_get_clksel(clk, &field_mask);
if (!div_addr)
validrate = omap2_clksel_round_rate_div(clk, rate, &new_div);
if (validrate != rate)
return -EINVAL;

field_val = omap2_divisor_to_clksel(clk, new_div);
if (field_val == ~0)
return -EINVAL;

reg_val = __raw_readl(div_addr);
reg_val &= ~field_mask;
reg_val |= (field_val << __ffs(field_mask));
__raw_writel(reg_val, div_addr);
v = __raw_readl(clk->clksel_reg);
v &= ~clk->clksel_mask;
v |= field_val << __ffs(clk->clksel_mask);
__raw_writel(v, clk->clksel_reg);
wmb();

clk->rate = clk->parent->rate / new_div;
Expand Down Expand Up @@ -737,18 +716,14 @@ int omap2_clk_set_rate(struct clk *clk, unsigned long rate)

/*
* 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,
struct clk *src_clk, u32 *field_mask,
struct clk *clk, u32 *parent_div)
static u32 _omap2_clksel_get_src_field(struct clk *src_clk, struct clk *clk,
u32 *field_val)
{
const struct clksel *clks;
const struct clksel_rate *clkr;

*parent_div = 0;
*src_addr = NULL;

clks = omap2_get_clksel_by_parent(clk, src_clk);
if (!clks)
return 0;
Expand All @@ -768,36 +743,33 @@ static u32 omap2_clksel_get_src_field(void __iomem **src_addr,
/* Should never happen. Add a clksel mask to the struct clk. */
WARN_ON(clk->clksel_mask == 0);

*field_mask = clk->clksel_mask;
*src_addr = clk->clksel_reg;
*parent_div = clkr->div;
*field_val = clkr->val;

return clkr->val;
return clkr->div;
}

int omap2_clk_set_parent(struct clk *clk, struct clk *new_parent)
{
void __iomem *src_addr;
u32 field_val, field_mask, reg_val, parent_div;
u32 field_val, v, parent_div;

if (clk->flags & CONFIG_PARTICIPANT)
return -EINVAL;

if (!clk->clksel)
return -EINVAL;

field_val = omap2_clksel_get_src_field(&src_addr, new_parent,
&field_mask, clk, &parent_div);
if (!src_addr)
parent_div = _omap2_clksel_get_src_field(new_parent, clk, &field_val);
if (!parent_div)
return -EINVAL;

if (clk->usecount > 0)
_omap2_clk_disable(clk);

/* Set new source value (previous dividers if any in effect) */
reg_val = __raw_readl(src_addr) & ~field_mask;
reg_val |= (field_val << __ffs(field_mask));
__raw_writel(reg_val, src_addr);
v = __raw_readl(clk->clksel_reg);
v &= ~clk->clksel_mask;
v |= field_val << __ffs(clk->clksel_mask);
__raw_writel(v, clk->clksel_reg);
wmb();

if (clk->flags & DELAYED_APP && cpu_is_omap24xx()) {
Expand Down

0 comments on commit 2d2ccc1

Please sign in to comment.