ARM: tegra: Clear PMU event overflow status
[linux-3.10.git] / arch / arm / mach-tegra / include / mach / edp.h
1 /*
2  * arch/arm/mach-tegra/include/mach/edp.h
3  *
4  * Copyright (c) 2011, 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; either version 2 of the License, or
9  * (at your option) any later version.
10  *
11  * This program is distributed in the hope that it will be useful, but WITHOUT
12  * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
13  * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
14  * more details.
15  *
16  * You should have received a copy of the GNU General Public License along
17  * with this program; if not, write to the Free Software Foundation, Inc.,
18  * 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
19  */
20
21 #ifndef __MACH_EDP_H
22 #define __MACH_EDP_H
23
24 #include <linux/debugfs.h>
25 #include <linux/edp.h>
26 #include <linux/thermal.h>
27
28 struct tegra_edp_vdd_cpu_entry {
29         char speedo_id;
30         char regulator_100mA;
31         char temperature;
32         char freq_limits[4];
33 };
34
35 struct tegra_edp_limits {
36         int temperature;
37         unsigned int freq_limits[4];
38 };
39
40 struct tegra_system_edp_entry {
41         char speedo_id;
42         char power_limit_100mW;
43         char freq_limits[4];
44 };
45
46 struct tegra_edp_cpu_leakage_params {
47         int cpu_speedo_id;
48         int dyn_consts_n[NR_CPUS];       /* pre-multiplied by 1,000,000 */
49         int leakage_consts_n[NR_CPUS];   /* pre-multiplied by 1,000,000 */
50         int leakage_consts_ijk[4][4][4]; /* pre-multiplied by 100,000 */
51 };
52
53 struct tegra_edp_freq_voltage_table {
54         unsigned int freq;
55         int voltage_mV;
56 };
57
58 enum tegra_core_edp_profiles {
59         CORE_EDP_PROFILE_BALANCED = 0,
60         CORE_EDP_PROFILE_FAVOR_GPU,
61         CORE_EDP_PROFILE_FAVOR_EMC,
62
63         CORE_EDP_PROFILES_NUM,
64 };
65
66 struct tegra_core_edp_limits {
67         int sku;
68         struct clk **cap_clocks;
69         int cap_clocks_num;
70         int *temperatures;
71         int temperature_ranges;
72         int core_modules_states;
73         unsigned long *cap_rates_scpu_on;
74         unsigned long *cap_rates_scpu_off;
75 };
76
77 #ifdef CONFIG_TEGRA_EDP_LIMITS
78 struct thermal_cooling_device *edp_cooling_device_create(void *v);
79 void tegra_init_cpu_edp_limits(unsigned int regulator_mA);
80 void tegra_recalculate_cpu_edp_limits(void);
81 void tegra_init_system_edp_limits(unsigned int power_limit_mW);
82 void tegra_get_cpu_edp_limits(const struct tegra_edp_limits **limits, int *size);
83 unsigned int tegra_get_edp_limit(int *get_edp_thermal_index);
84 void tegra_get_system_edp_limits(const unsigned int **limits);
85 int tegra_system_edp_alarm(bool alarm);
86
87 #else
88 static inline struct thermal_cooling_device *edp_cooling_device_create(
89         int index)
90 { return NULL; }
91 static inline void tegra_init_cpu_edp_limits(int regulator_mA)
92 {}
93 static inline void tegra_recalculate_cpu_edp_limits(void)
94 {}
95 static inline void tegra_init_system_edp_limits(int power_limit_mW)
96 {}
97 static inline void tegra_get_cpu_edp_limits(struct tegra_edp_limits **limits,
98                                             int *size)
99 {}
100 static inline unsigned int tegra_get_edp_limit(int *get_edp_thermal_index)
101 { return -1; }
102 static inline void tegra_get_system_edp_limits(unsigned int **limits)
103 {}
104 static inline int tegra_system_edp_alarm(bool alarm)
105 { return -1; }
106 #endif
107
108 #ifdef CONFIG_ARCH_TEGRA_2x_SOC
109 static inline void tegra_edp_throttle_cpu_now(u8 factor)
110 {}
111 #else
112 void tegra_edp_throttle_cpu_now(u8 factor);
113 #endif
114
115 #if defined(CONFIG_TEGRA_EDP_LIMITS) && defined(CONFIG_EDP_FRAMEWORK)
116 void __init tegra_battery_edp_init(unsigned int cap);
117 #else
118 static inline void tegra_battery_edp_init(unsigned int cap) {}
119 #endif
120
121 #ifdef CONFIG_TEGRA_CORE_EDP_LIMITS
122 void tegra_init_core_edp_limits(unsigned int regulator_mA);
123 int tegra_core_edp_debugfs_init(struct dentry *edp_dir);
124 int tegra_core_edp_cpu_state_update(bool scpu_state);
125 #else
126 static inline void tegra_init_core_edp_limits(unsigned int regulator_mA)
127 {}
128 static inline int tegra_core_edp_debugfs_init(struct dentry *edp_dir)
129 { return 0; }
130 static inline int tegra_core_edp_cpu_state_update(bool scpu_state)
131 { return 0; }
132 #endif
133
134 #ifdef CONFIG_ARCH_TEGRA_11x_SOC
135 int tegra11x_select_core_edp_table(unsigned int regulator_mA,
136                                    struct tegra_core_edp_limits *limits);
137 #else
138 static inline int tegra11x_select_core_edp_table(
139         unsigned int regulator_mA, struct tegra_core_edp_limits *limits)
140 { return -ENOSYS; }
141 #endif
142
143 #endif  /* __MACH_EDP_H */