3f1672e071c270945857b34f8c0ec683262b2960
[safe/jmp/linux-2.6] / arch / arm / mach-omap2 / clock2xxx.h
1 /*
2  * OMAP2 clock function prototypes and macros
3  *
4  * Copyright (C) 2005-2009 Texas Instruments, Inc.
5  * Copyright (C) 2004-2009 Nokia Corporation
6  */
7
8 #ifndef __ARCH_ARM_MACH_OMAP2_CLOCK_24XX_H
9 #define __ARCH_ARM_MACH_OMAP2_CLOCK_24XX_H
10
11 unsigned long omap2_table_mpu_recalc(struct clk *clk);
12 int omap2_select_table_rate(struct clk *clk, unsigned long rate);
13 long omap2_round_to_table_rate(struct clk *clk, unsigned long rate);
14 unsigned long omap2_sys_clk_recalc(struct clk *clk);
15 unsigned long omap2_osc_clk_recalc(struct clk *clk);
16 unsigned long omap2_sys_clk_recalc(struct clk *clk);
17 unsigned long omap2_dpllcore_recalc(struct clk *clk);
18 int omap2_reprogram_dpllcore(struct clk *clk, unsigned long rate);
19 unsigned long omap2xxx_clk_get_core_rate(struct clk *clk);
20 u32 omap2xxx_get_apll_clkin(void);
21
22 /* REVISIT: These should be set dynamically for CONFIG_MULTI_OMAP2 */
23 #ifdef CONFIG_ARCH_OMAP2420
24 #define OMAP_CM_REGADDR                 OMAP2420_CM_REGADDR
25 #define OMAP24XX_PRCM_CLKOUT_CTRL       OMAP2420_PRCM_CLKOUT_CTRL
26 #define OMAP24XX_PRCM_CLKEMUL_CTRL      OMAP2420_PRCM_CLKEMUL_CTRL
27 #else
28 #define OMAP_CM_REGADDR                 OMAP2430_CM_REGADDR
29 #define OMAP24XX_PRCM_CLKOUT_CTRL       OMAP2430_PRCM_CLKOUT_CTRL
30 #define OMAP24XX_PRCM_CLKEMUL_CTRL      OMAP2430_PRCM_CLKEMUL_CTRL
31 #endif
32
33 extern void __iomem *prcm_clksrc_ctrl;
34
35 extern struct clk *dclk;
36
37 extern const struct clkops clkops_omap2430_i2chs_wait;
38 extern const struct clkops clkops_oscck;
39 extern const struct clkops clkops_apll96;
40 extern const struct clkops clkops_apll54;
41
42 #endif