02085f81ae390c84bd5ed88c966d4fee99e1d084
[linux-2.6.git] / arch / arm / mach-tegra / include / mach / clk.h
1 /*
2  * arch/arm/mach-tegra/include/mach/clk.h
3  *
4  * Copyright (C) 2010 Google, Inc.
5  *
6  * Author:
7  *      Erik Gilling <konkers@google.com>
8  *
9  * This software is licensed under the terms of the GNU General Public
10  * License version 2, as published by the Free Software Foundation, and
11  * may be copied, distributed, and modified under those terms.
12  *
13  * This program is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16  * GNU General Public License for more details.
17  *
18  */
19
20 #ifndef __MACH_CLK_H
21 #define __MACH_CLK_H
22
23 struct clk;
24 struct dvfs;
25
26 enum tegra_clk_ex_param {
27         TEGRA_CLK_VI_INP_SEL,
28         TEGRA_CLK_DTV_INVERT,
29         TEGRA_CLK_NAND_PAD_DIV2_ENB,
30         TEGRA_CLK_PLLD_CSI_OUT_ENB,
31         TEGRA_CLK_PLLD_DSI_OUT_ENB,
32         TEGRA_CLK_PLLD_MIPI_MUX_SEL,
33 };
34
35 void tegra_periph_reset_deassert(struct clk *c);
36 void tegra_periph_reset_assert(struct clk *c);
37
38 int tegra_dvfs_set_rate(struct clk *c, unsigned long rate);
39 unsigned long clk_get_rate_all_locked(struct clk *c);
40 #ifdef CONFIG_ARCH_TEGRA_2x_SOC
41 void tegra_sdmmc_tap_delay(struct clk *c, int delay);
42 #else
43 static inline void tegra_sdmmc_tap_delay(struct clk *c, int delay)
44 {
45 }
46 #endif
47 int tegra_dvfs_rail_disable_by_name(const char *reg_id);
48 int tegra_clk_cfg_ex(struct clk *c, enum tegra_clk_ex_param p, u32 setting);
49
50 #endif