blob: c14061b2b9f1abb7517d0e7bc587ce4053c8fcf1 [file] [log] [blame]
Paul Walmsleyd8a94452009-12-08 16:21:29 -07001/*
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
11unsigned long omap2_table_mpu_recalc(struct clk *clk);
12int omap2_select_table_rate(struct clk *clk, unsigned long rate);
13long omap2_round_to_table_rate(struct clk *clk, unsigned long rate);
Paul Walmsley44da0a52010-01-26 20:13:08 -070014unsigned long omap2xxx_sys_clk_recalc(struct clk *clk);
Paul Walmsleyd8a94452009-12-08 16:21:29 -070015unsigned long omap2_osc_clk_recalc(struct clk *clk);
Paul Walmsleyd8a94452009-12-08 16:21:29 -070016unsigned long omap2_dpllcore_recalc(struct clk *clk);
17int omap2_reprogram_dpllcore(struct clk *clk, unsigned long rate);
18unsigned long omap2xxx_clk_get_core_rate(struct clk *clk);
Paul Walmsley49214642010-01-26 20:13:06 -070019u32 omap2xxx_get_apll_clkin(void);
Paul Walmsley87a1b262010-01-26 20:13:07 -070020u32 omap2xxx_get_sysclkdiv(void);
Paul Walmsleyd8a94452009-12-08 16:21:29 -070021
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
33extern void __iomem *prcm_clksrc_ctrl;
34
35extern struct clk *dclk;
36
37extern const struct clkops clkops_omap2430_i2chs_wait;
38extern const struct clkops clkops_oscck;
39extern const struct clkops clkops_apll96;
40extern const struct clkops clkops_apll54;
41
42#endif