aboutsummaryrefslogtreecommitdiff
path: root/arch/arm/mach-pxa/clock.c
diff options
context:
space:
mode:
Diffstat (limited to 'arch/arm/mach-pxa/clock.c')
-rw-r--r--arch/arm/mach-pxa/clock.c110
1 files changed, 36 insertions, 74 deletions
diff --git a/arch/arm/mach-pxa/clock.c b/arch/arm/mach-pxa/clock.c
index 8f7c90a0593..4d466102a02 100644
--- a/arch/arm/mach-pxa/clock.c
+++ b/arch/arm/mach-pxa/clock.c
@@ -3,62 +3,27 @@
*/
#include <linux/module.h>
#include <linux/kernel.h>
-#include <linux/list.h>
-#include <linux/errno.h>
-#include <linux/err.h>
-#include <linux/string.h>
#include <linux/clk.h>
#include <linux/spinlock.h>
+#include <linux/delay.h>
+#include <linux/clkdev.h>
-#include <asm/arch/pxa-regs.h>
-#include <asm/hardware.h>
-#include <asm/semaphore.h>
-
-struct clk {
- struct list_head node;
- unsigned long rate;
- struct module *owner;
- const char *name;
- unsigned int enabled;
- void (*enable)(void);
- void (*disable)(void);
-};
+#include "clock.h"
-static LIST_HEAD(clocks);
-static DECLARE_MUTEX(clocks_sem);
static DEFINE_SPINLOCK(clocks_lock);
-struct clk *clk_get(struct device *dev, const char *id)
-{
- struct clk *p, *clk = ERR_PTR(-ENOENT);
-
- down(&clocks_sem);
- list_for_each_entry(p, &clocks, node) {
- if (strcmp(id, p->name) == 0 && try_module_get(p->owner)) {
- clk = p;
- break;
- }
- }
- up(&clocks_sem);
-
- return clk;
-}
-EXPORT_SYMBOL(clk_get);
-
-void clk_put(struct clk *clk)
-{
- module_put(clk->owner);
-}
-EXPORT_SYMBOL(clk_put);
-
int clk_enable(struct clk *clk)
{
unsigned long flags;
spin_lock_irqsave(&clocks_lock, flags);
if (clk->enabled++ == 0)
- clk->enable();
+ clk->ops->enable(clk);
spin_unlock_irqrestore(&clocks_lock, flags);
+
+ if (clk->delay)
+ udelay(clk->delay);
+
return 0;
}
EXPORT_SYMBOL(clk_enable);
@@ -71,54 +36,51 @@ void clk_disable(struct clk *clk)
spin_lock_irqsave(&clocks_lock, flags);
if (--clk->enabled == 0)
- clk->disable();
+ clk->ops->disable(clk);
spin_unlock_irqrestore(&clocks_lock, flags);
}
EXPORT_SYMBOL(clk_disable);
unsigned long clk_get_rate(struct clk *clk)
{
- return clk->rate;
-}
-EXPORT_SYMBOL(clk_get_rate);
+ unsigned long rate;
+ rate = clk->rate;
+ if (clk->ops->getrate)
+ rate = clk->ops->getrate(clk);
-static void clk_gpio27_enable(void)
-{
- pxa_gpio_mode(GPIO11_3_6MHz_MD);
+ return rate;
}
+EXPORT_SYMBOL(clk_get_rate);
-static void clk_gpio27_disable(void)
+int clk_set_rate(struct clk *clk, unsigned long rate)
{
-}
+ unsigned long flags;
+ int ret = -EINVAL;
-static struct clk clk_gpio27 = {
- .name = "GPIO27_CLK",
- .rate = 3686400,
- .enable = clk_gpio27_enable,
- .disable = clk_gpio27_disable,
-};
+ if (clk->ops->setrate) {
+ spin_lock_irqsave(&clocks_lock, flags);
+ ret = clk->ops->setrate(clk, rate);
+ spin_unlock_irqrestore(&clocks_lock, flags);
+ }
-int clk_register(struct clk *clk)
-{
- down(&clocks_sem);
- list_add(&clk->node, &clocks);
- up(&clocks_sem);
- return 0;
+ return ret;
}
-EXPORT_SYMBOL(clk_register);
+EXPORT_SYMBOL(clk_set_rate);
-void clk_unregister(struct clk *clk)
+void clk_dummy_enable(struct clk *clk)
{
- down(&clocks_sem);
- list_del(&clk->node);
- up(&clocks_sem);
}
-EXPORT_SYMBOL(clk_unregister);
-static int __init clk_init(void)
+void clk_dummy_disable(struct clk *clk)
{
- clk_register(&clk_gpio27);
- return 0;
}
-arch_initcall(clk_init);
+
+const struct clkops clk_dummy_ops = {
+ .enable = clk_dummy_enable,
+ .disable = clk_dummy_disable,
+};
+
+struct clk clk_dummy = {
+ .ops = &clk_dummy_ops,
+};