提交 5f33bd76 编写于 作者: H Heiko Stuebner 提交者: Kukjin Kim

ARM: S3C2443: Add get_rate operation for clk_armdiv

Signed-off-by: NHeiko Stuebner <heiko@sntech.de>
Signed-off-by: NKukjin Kim <kgene.kim@samsung.com>
上级 efb1fb48
...@@ -189,6 +189,19 @@ static unsigned long s3c2443_armclk_roundrate(struct clk *clk, ...@@ -189,6 +189,19 @@ static unsigned long s3c2443_armclk_roundrate(struct clk *clk,
return parent / best; return parent / best;
} }
static unsigned long s3c2443_armclk_getrate(struct clk *clk)
{
unsigned long rate = clk_get_rate(clk->parent);
unsigned long clkcon0;
int val;
clkcon0 = __raw_readl(S3C2443_CLKDIV0);
clkcon0 &= armdivmask;
val = clkcon0 >> S3C2443_CLKDIV0_ARMDIV_SHIFT;
return rate / armdiv[val];
}
static int s3c2443_armclk_setrate(struct clk *clk, unsigned long rate) static int s3c2443_armclk_setrate(struct clk *clk, unsigned long rate)
{ {
unsigned long parent = clk_get_rate(clk->parent); unsigned long parent = clk_get_rate(clk->parent);
...@@ -224,6 +237,7 @@ static struct clk clk_armdiv = { ...@@ -224,6 +237,7 @@ static struct clk clk_armdiv = {
.parent = &clk_msysclk.clk, .parent = &clk_msysclk.clk,
.ops = &(struct clk_ops) { .ops = &(struct clk_ops) {
.round_rate = s3c2443_armclk_roundrate, .round_rate = s3c2443_armclk_roundrate,
.get_rate = s3c2443_armclk_getrate,
.set_rate = s3c2443_armclk_setrate, .set_rate = s3c2443_armclk_setrate,
}, },
}; };
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册