Update copyrights
[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  * Copyright (C) 2010-2011 NVIDIA Corporation
10  *
11  * This software is licensed under the terms of the GNU General Public
12  * License version 2, as published by the Free Software Foundation, and
13  * may be copied, distributed, and modified under those terms.
14  *
15  * This program is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
18  * GNU General Public License for more details.
19  *
20  */
21
22 #ifndef __MACH_CLK_H
23 #define __MACH_CLK_H
24
25 struct clk;
26 struct dvfs;
27
28 enum tegra_clk_ex_param {
29         TEGRA_CLK_VI_INP_SEL,
30         TEGRA_CLK_DTV_INVERT,
31         TEGRA_CLK_NAND_PAD_DIV2_ENB,
32         TEGRA_CLK_PLLD_CSI_OUT_ENB,
33         TEGRA_CLK_PLLD_DSI_OUT_ENB,
34         TEGRA_CLK_PLLD_MIPI_MUX_SEL,
35 };
36
37 void tegra_periph_reset_deassert(struct clk *c);
38 void tegra_periph_reset_assert(struct clk *c);
39
40 int tegra_dvfs_set_rate(struct clk *c, unsigned long rate);
41 unsigned long clk_get_rate_all_locked(struct clk *c);
42 #ifdef CONFIG_ARCH_TEGRA_2x_SOC
43 void tegra_sdmmc_tap_delay(struct clk *c, int delay);
44 #else
45 static inline void tegra_sdmmc_tap_delay(struct clk *c, int delay)
46 {
47 }
48 #endif
49 int tegra_dvfs_rail_disable_by_name(const char *reg_id);
50 int tegra_clk_cfg_ex(struct clk *c, enum tegra_clk_ex_param p, u32 setting);
51
52 #endif