Blame view
arch/arm/mach-pxa/clock.c
1.5 KB
97d654f8e [ARM] Convert SA1... |
1 2 3 4 5 |
/* * linux/arch/arm/mach-sa1100/clock.c */ #include <linux/module.h> #include <linux/kernel.h> |
97d654f8e [ARM] Convert SA1... |
6 7 |
#include <linux/clk.h> #include <linux/spinlock.h> |
a6dba20c5 [ARM] pxa: introd... |
8 |
#include <linux/delay.h> |
6d803ba73 ARM: 6483/1: arm ... |
9 |
#include <linux/clkdev.h> |
97d654f8e [ARM] Convert SA1... |
10 |
|
a6dba20c5 [ARM] pxa: introd... |
11 |
#include "clock.h" |
97d654f8e [ARM] Convert SA1... |
12 |
|
97d654f8e [ARM] Convert SA1... |
13 |
static DEFINE_SPINLOCK(clocks_lock); |
97d654f8e [ARM] Convert SA1... |
14 15 16 17 18 19 |
int clk_enable(struct clk *clk) { unsigned long flags; spin_lock_irqsave(&clocks_lock, flags); if (clk->enabled++ == 0) |
a6dba20c5 [ARM] pxa: introd... |
20 |
clk->ops->enable(clk); |
97d654f8e [ARM] Convert SA1... |
21 |
spin_unlock_irqrestore(&clocks_lock, flags); |
a6dba20c5 [ARM] pxa: introd... |
22 23 24 |
if (clk->delay) udelay(clk->delay); |
97d654f8e [ARM] Convert SA1... |
25 26 27 28 29 30 31 32 33 34 35 36 |
return 0; } EXPORT_SYMBOL(clk_enable); void clk_disable(struct clk *clk) { unsigned long flags; WARN_ON(clk->enabled == 0); spin_lock_irqsave(&clocks_lock, flags); if (--clk->enabled == 0) |
a6dba20c5 [ARM] pxa: introd... |
37 |
clk->ops->disable(clk); |
97d654f8e [ARM] Convert SA1... |
38 39 40 41 42 43 |
spin_unlock_irqrestore(&clocks_lock, flags); } EXPORT_SYMBOL(clk_disable); unsigned long clk_get_rate(struct clk *clk) { |
a6dba20c5 [ARM] pxa: introd... |
44 45 46 47 48 49 50 |
unsigned long rate; rate = clk->rate; if (clk->ops->getrate) rate = clk->ops->getrate(clk); return rate; |
97d654f8e [ARM] Convert SA1... |
51 52 |
} EXPORT_SYMBOL(clk_get_rate); |
52585ccd9 ARM: pxa: add clk... |
53 54 55 56 57 58 59 60 61 62 63 64 65 66 |
int clk_set_rate(struct clk *clk, unsigned long rate) { unsigned long flags; int ret = -EINVAL; if (clk->ops->setrate) { spin_lock_irqsave(&clocks_lock, flags); ret = clk->ops->setrate(clk, rate); spin_unlock_irqrestore(&clocks_lock, flags); } return ret; } EXPORT_SYMBOL(clk_set_rate); |
4029813c8 ARM: pxa: separat... |
67 |
void clk_dummy_enable(struct clk *clk) |
97d654f8e [ARM] Convert SA1... |
68 |
{ |
97d654f8e [ARM] Convert SA1... |
69 |
} |
97d654f8e [ARM] Convert SA1... |
70 |
|
4029813c8 ARM: pxa: separat... |
71 |
void clk_dummy_disable(struct clk *clk) |
97d654f8e [ARM] Convert SA1... |
72 |
{ |
a6dba20c5 [ARM] pxa: introd... |
73 |
} |
4029813c8 ARM: pxa: separat... |
74 75 76 77 78 79 80 |
const struct clkops clk_dummy_ops = { .enable = clk_dummy_enable, .disable = clk_dummy_disable, }; struct clk clk_dummy = { .ops = &clk_dummy_ops, |
a6dba20c5 [ARM] pxa: introd... |
81 |
}; |