ARM: tegra: clock: Add common EMC interface header
[linux-3.10.git] / arch / arm / mach-tegra / tegra_emc.h
1 /*
2  * arch/arm/mach-tegra/tegra_emc.h
3  *
4  * Copyright (C) 2013 NVIDIA Corporation
5  *
6  * This program is free software; you can redistribute it and/or modify
7  * it under the terms of the GNU General Public License as published by
8  * the Free Software Foundation; version 2 of the License.
9  *
10  * This program is distributed in the hope that it will be useful, but WITHOUT
11  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
12  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
13  * more details.
14  *
15  * You should have received a copy of the GNU General Public License along
16  * with this program; if not, write to the Free Software Foundation, Inc.,
17  * 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
18  *
19  */
20
21 #ifndef _MACH_TEGRA_TEGRA_EMC_H
22 #define _MACH_TEGRA_TEGRA_EMC_H
23
24 extern u8 tegra_emc_bw_efficiency;
25
26 enum {
27         DRAM_OVER_TEMP_NONE = 0,
28         DRAM_OVER_TEMP_REFRESH,
29 };
30
31 struct clk;
32
33 void tegra_emc_dram_type_init(struct clk *c);
34 int tegra_emc_get_dram_type(void);
35 int tegra_emc_get_dram_temperature(void);
36 int tegra_emc_set_over_temp_state(unsigned long state);
37
38 int tegra_emc_set_rate(unsigned long rate);
39 long tegra_emc_round_rate(unsigned long rate);
40 struct clk *tegra_emc_predict_parent(unsigned long rate, u32 *div_value);
41 bool tegra_emc_is_parent_ready(unsigned long rate, struct clk **parent,
42                 unsigned long *parent_rate, unsigned long *backup_rate);
43 void tegra_emc_timing_invalidate(void);
44
45 #ifdef CONFIG_ARCH_TEGRA_3x_SOC
46 int tegra_emc_backup(unsigned long rate);
47 void tegra_init_dram_bit_map(const u32 *bit_map, int map_size);
48 #endif
49
50 #ifdef CONFIG_PM_SLEEP
51 void tegra_mc_timing_restore(void);
52 #else
53 static inline void tegra_mc_timing_restore(void)
54 { }
55 #endif
56
57 #endif