]> bbs.cooldavid.org Git - net-next-2.6.git/blame - arch/arm/mach-nomadik/clock.c
Merge branch 'perf-fixes-for-linus' of git://git.kernel.org/pub/scm/linux/kernel...
[net-next-2.6.git] / arch / arm / mach-nomadik / clock.c
CommitLineData
28ad94ec
AR
1/*
2 * linux/arch/arm/mach-nomadik/clock.c
3 *
4 * Copyright (C) 2009 Alessandro Rubini
5 */
6#include <linux/kernel.h>
7#include <linux/module.h>
8#include <linux/errno.h>
9#include <linux/clk.h>
10#include <asm/clkdev.h>
11#include "clock.h"
12
13/*
14 * The nomadik board uses generic clocks, but the serial pl011 file
15 * calls clk_enable(), clk_disable(), clk_get_rate(), so we provide them
16 */
17unsigned long clk_get_rate(struct clk *clk)
18{
19 return clk->rate;
20}
21EXPORT_SYMBOL(clk_get_rate);
22
23/* enable and disable do nothing */
24int clk_enable(struct clk *clk)
25{
26 return 0;
27}
28EXPORT_SYMBOL(clk_enable);
29
30void clk_disable(struct clk *clk)
31{
32}
33EXPORT_SYMBOL(clk_disable);
34
ba327b1e
LW
35static struct clk clk_24 = {
36 .rate = 2400000,
37};
38
dc6048c7
RV
39static struct clk clk_48 = {
40 .rate = 48 * 1000 * 1000,
41};
42
af7dc228
RV
43/*
44 * Catch-all default clock to satisfy drivers using the clk API. We don't
45 * model the actual hardware clocks yet.
46 */
47static struct clk clk_default;
48
dc6048c7
RV
49#define CLK(_clk, dev) \
50 { \
51 .clk = _clk, \
52 .dev_id = dev, \
53 }
54
55static struct clk_lookup lookups[] = {
ba327b1e
LW
56 CLK(&clk_24, "mtu0"),
57 CLK(&clk_24, "mtu1"),
dc6048c7
RV
58 CLK(&clk_48, "uart0"),
59 CLK(&clk_48, "uart1"),
af7dc228
RV
60 CLK(&clk_default, "gpio.0"),
61 CLK(&clk_default, "gpio.1"),
62 CLK(&clk_default, "gpio.2"),
63 CLK(&clk_default, "gpio.3"),
1944cc89 64 CLK(&clk_default, "rng"),
dc6048c7 65};
28ad94ec 66
ba327b1e 67int __init clk_init(void)
dc6048c7
RV
68{
69 clkdev_add_table(lookups, ARRAY_SIZE(lookups));
28ad94ec
AR
70 return 0;
71}