diff options
Diffstat (limited to 'include/linux')
-rw-r--r-- | include/linux/acpi.h | 2 | ||||
-rw-r--r-- | include/linux/backlight.h | 4 | ||||
-rw-r--r-- | include/linux/bitops.h | 3 | ||||
-rw-r--r-- | include/linux/cpu.h | 13 | ||||
-rw-r--r-- | include/linux/cpufreq.h | 75 | ||||
-rw-r--r-- | include/linux/cpuidle.h | 8 | ||||
-rw-r--r-- | include/linux/devfreq.h | 6 | ||||
-rw-r--r-- | include/linux/opp.h | 134 | ||||
-rw-r--r-- | include/linux/pm_opp.h | 139 | ||||
-rw-r--r-- | include/linux/powercap.h | 325 |
10 files changed, 536 insertions, 173 deletions
diff --git a/include/linux/acpi.h b/include/linux/acpi.h index c30bac8503bc..74c5a8e467e8 100644 --- a/include/linux/acpi.h +++ b/include/linux/acpi.h | |||
@@ -116,7 +116,7 @@ void acpi_numa_arch_fixup(void); | |||
116 | 116 | ||
117 | #ifdef CONFIG_ACPI_HOTPLUG_CPU | 117 | #ifdef CONFIG_ACPI_HOTPLUG_CPU |
118 | /* Arch dependent functions for cpu hotplug support */ | 118 | /* Arch dependent functions for cpu hotplug support */ |
119 | int acpi_map_lsapic(acpi_handle handle, int *pcpu); | 119 | int acpi_map_lsapic(acpi_handle handle, int physid, int *pcpu); |
120 | int acpi_unmap_lsapic(int cpu); | 120 | int acpi_unmap_lsapic(int cpu); |
121 | #endif /* CONFIG_ACPI_HOTPLUG_CPU */ | 121 | #endif /* CONFIG_ACPI_HOTPLUG_CPU */ |
122 | 122 | ||
diff --git a/include/linux/backlight.h b/include/linux/backlight.h index 53b77949c79d..5f9cd963213d 100644 --- a/include/linux/backlight.h +++ b/include/linux/backlight.h | |||
@@ -100,6 +100,9 @@ struct backlight_device { | |||
100 | /* The framebuffer notifier block */ | 100 | /* The framebuffer notifier block */ |
101 | struct notifier_block fb_notif; | 101 | struct notifier_block fb_notif; |
102 | 102 | ||
103 | /* list entry of all registered backlight devices */ | ||
104 | struct list_head entry; | ||
105 | |||
103 | struct device dev; | 106 | struct device dev; |
104 | }; | 107 | }; |
105 | 108 | ||
@@ -123,6 +126,7 @@ extern void devm_backlight_device_unregister(struct device *dev, | |||
123 | struct backlight_device *bd); | 126 | struct backlight_device *bd); |
124 | extern void backlight_force_update(struct backlight_device *bd, | 127 | extern void backlight_force_update(struct backlight_device *bd, |
125 | enum backlight_update_reason reason); | 128 | enum backlight_update_reason reason); |
129 | extern bool backlight_device_registered(enum backlight_type type); | ||
126 | 130 | ||
127 | #define to_backlight_device(obj) container_of(obj, struct backlight_device, dev) | 131 | #define to_backlight_device(obj) container_of(obj, struct backlight_device, dev) |
128 | 132 | ||
diff --git a/include/linux/bitops.h b/include/linux/bitops.h index bd0c4598d03b..abc9ca778456 100644 --- a/include/linux/bitops.h +++ b/include/linux/bitops.h | |||
@@ -4,8 +4,11 @@ | |||
4 | 4 | ||
5 | #ifdef __KERNEL__ | 5 | #ifdef __KERNEL__ |
6 | #define BIT(nr) (1UL << (nr)) | 6 | #define BIT(nr) (1UL << (nr)) |
7 | #define BIT_ULL(nr) (1ULL << (nr)) | ||
7 | #define BIT_MASK(nr) (1UL << ((nr) % BITS_PER_LONG)) | 8 | #define BIT_MASK(nr) (1UL << ((nr) % BITS_PER_LONG)) |
8 | #define BIT_WORD(nr) ((nr) / BITS_PER_LONG) | 9 | #define BIT_WORD(nr) ((nr) / BITS_PER_LONG) |
10 | #define BIT_ULL_MASK(nr) (1ULL << ((nr) % BITS_PER_LONG_LONG)) | ||
11 | #define BIT_ULL_WORD(nr) ((nr) / BITS_PER_LONG_LONG) | ||
9 | #define BITS_PER_BYTE 8 | 12 | #define BITS_PER_BYTE 8 |
10 | #define BITS_TO_LONGS(nr) DIV_ROUND_UP(nr, BITS_PER_BYTE * sizeof(long)) | 13 | #define BITS_TO_LONGS(nr) DIV_ROUND_UP(nr, BITS_PER_BYTE * sizeof(long)) |
11 | #endif | 14 | #endif |
diff --git a/include/linux/cpu.h b/include/linux/cpu.h index fbd25c3c2923..03e235ad1bba 100644 --- a/include/linux/cpu.h +++ b/include/linux/cpu.h | |||
@@ -188,19 +188,6 @@ extern void cpu_hotplug_enable(void); | |||
188 | void clear_tasks_mm_cpumask(int cpu); | 188 | void clear_tasks_mm_cpumask(int cpu); |
189 | int cpu_down(unsigned int cpu); | 189 | int cpu_down(unsigned int cpu); |
190 | 190 | ||
191 | #ifdef CONFIG_ARCH_CPU_PROBE_RELEASE | ||
192 | extern void cpu_hotplug_driver_lock(void); | ||
193 | extern void cpu_hotplug_driver_unlock(void); | ||
194 | #else | ||
195 | static inline void cpu_hotplug_driver_lock(void) | ||
196 | { | ||
197 | } | ||
198 | |||
199 | static inline void cpu_hotplug_driver_unlock(void) | ||
200 | { | ||
201 | } | ||
202 | #endif | ||
203 | |||
204 | #else /* CONFIG_HOTPLUG_CPU */ | 191 | #else /* CONFIG_HOTPLUG_CPU */ |
205 | 192 | ||
206 | static inline void cpu_hotplug_begin(void) {} | 193 | static inline void cpu_hotplug_begin(void) {} |
diff --git a/include/linux/cpufreq.h b/include/linux/cpufreq.h index fcabc42d66ab..5bd6ab9b0c27 100644 --- a/include/linux/cpufreq.h +++ b/include/linux/cpufreq.h | |||
@@ -85,6 +85,20 @@ struct cpufreq_policy { | |||
85 | struct list_head policy_list; | 85 | struct list_head policy_list; |
86 | struct kobject kobj; | 86 | struct kobject kobj; |
87 | struct completion kobj_unregister; | 87 | struct completion kobj_unregister; |
88 | |||
89 | /* | ||
90 | * The rules for this semaphore: | ||
91 | * - Any routine that wants to read from the policy structure will | ||
92 | * do a down_read on this semaphore. | ||
93 | * - Any routine that will write to the policy structure and/or may take away | ||
94 | * the policy altogether (eg. CPU hotplug), will hold this lock in write | ||
95 | * mode before doing so. | ||
96 | * | ||
97 | * Additional rules: | ||
98 | * - Lock should not be held across | ||
99 | * __cpufreq_governor(data, CPUFREQ_GOV_POLICY_EXIT); | ||
100 | */ | ||
101 | struct rw_semaphore rwsem; | ||
88 | }; | 102 | }; |
89 | 103 | ||
90 | /* Only for ACPI */ | 104 | /* Only for ACPI */ |
@@ -180,13 +194,6 @@ __ATTR(_name, 0644, show_##_name, store_##_name) | |||
180 | struct cpufreq_driver { | 194 | struct cpufreq_driver { |
181 | char name[CPUFREQ_NAME_LEN]; | 195 | char name[CPUFREQ_NAME_LEN]; |
182 | u8 flags; | 196 | u8 flags; |
183 | /* | ||
184 | * This should be set by platforms having multiple clock-domains, i.e. | ||
185 | * supporting multiple policies. With this sysfs directories of governor | ||
186 | * would be created in cpu/cpu<num>/cpufreq/ directory and so they can | ||
187 | * use the same governor with different tunables for different clusters. | ||
188 | */ | ||
189 | bool have_governor_per_policy; | ||
190 | 197 | ||
191 | /* needed by all drivers */ | 198 | /* needed by all drivers */ |
192 | int (*init) (struct cpufreq_policy *policy); | 199 | int (*init) (struct cpufreq_policy *policy); |
@@ -194,9 +201,11 @@ struct cpufreq_driver { | |||
194 | 201 | ||
195 | /* define one out of two */ | 202 | /* define one out of two */ |
196 | int (*setpolicy) (struct cpufreq_policy *policy); | 203 | int (*setpolicy) (struct cpufreq_policy *policy); |
197 | int (*target) (struct cpufreq_policy *policy, | 204 | int (*target) (struct cpufreq_policy *policy, /* Deprecated */ |
198 | unsigned int target_freq, | 205 | unsigned int target_freq, |
199 | unsigned int relation); | 206 | unsigned int relation); |
207 | int (*target_index) (struct cpufreq_policy *policy, | ||
208 | unsigned int index); | ||
200 | 209 | ||
201 | /* should be defined, if possible */ | 210 | /* should be defined, if possible */ |
202 | unsigned int (*get) (unsigned int cpu); | 211 | unsigned int (*get) (unsigned int cpu); |
@@ -211,13 +220,29 @@ struct cpufreq_driver { | |||
211 | }; | 220 | }; |
212 | 221 | ||
213 | /* flags */ | 222 | /* flags */ |
214 | #define CPUFREQ_STICKY 0x01 /* the driver isn't removed even if | 223 | #define CPUFREQ_STICKY (1 << 0) /* driver isn't removed even if |
215 | * all ->init() calls failed */ | 224 | all ->init() calls failed */ |
216 | #define CPUFREQ_CONST_LOOPS 0x02 /* loops_per_jiffy or other kernel | 225 | #define CPUFREQ_CONST_LOOPS (1 << 1) /* loops_per_jiffy or other |
217 | * "constants" aren't affected by | 226 | kernel "constants" aren't |
218 | * frequency transitions */ | 227 | affected by frequency |
219 | #define CPUFREQ_PM_NO_WARN 0x04 /* don't warn on suspend/resume speed | 228 | transitions */ |
220 | * mismatches */ | 229 | #define CPUFREQ_PM_NO_WARN (1 << 2) /* don't warn on suspend/resume |
230 | speed mismatches */ | ||
231 | |||
232 | /* | ||
233 | * This should be set by platforms having multiple clock-domains, i.e. | ||
234 | * supporting multiple policies. With this sysfs directories of governor would | ||
235 | * be created in cpu/cpu<num>/cpufreq/ directory and so they can use the same | ||
236 | * governor with different tunables for different clusters. | ||
237 | */ | ||
238 | #define CPUFREQ_HAVE_GOVERNOR_PER_POLICY (1 << 3) | ||
239 | |||
240 | /* | ||
241 | * Driver will do POSTCHANGE notifications from outside of their ->target() | ||
242 | * routine and so must set cpufreq_driver->flags with this flag, so that core | ||
243 | * can handle them specially. | ||
244 | */ | ||
245 | #define CPUFREQ_ASYNC_NOTIFICATION (1 << 4) | ||
221 | 246 | ||
222 | int cpufreq_register_driver(struct cpufreq_driver *driver_data); | 247 | int cpufreq_register_driver(struct cpufreq_driver *driver_data); |
223 | int cpufreq_unregister_driver(struct cpufreq_driver *driver_data); | 248 | int cpufreq_unregister_driver(struct cpufreq_driver *driver_data); |
@@ -240,6 +265,13 @@ static inline void cpufreq_verify_within_limits(struct cpufreq_policy *policy, | |||
240 | return; | 265 | return; |
241 | } | 266 | } |
242 | 267 | ||
268 | static inline void | ||
269 | cpufreq_verify_within_cpu_limits(struct cpufreq_policy *policy) | ||
270 | { | ||
271 | cpufreq_verify_within_limits(policy, policy->cpuinfo.min_freq, | ||
272 | policy->cpuinfo.max_freq); | ||
273 | } | ||
274 | |||
243 | /********************************************************************* | 275 | /********************************************************************* |
244 | * CPUFREQ NOTIFIER INTERFACE * | 276 | * CPUFREQ NOTIFIER INTERFACE * |
245 | *********************************************************************/ | 277 | *********************************************************************/ |
@@ -392,6 +424,7 @@ int cpufreq_frequency_table_cpuinfo(struct cpufreq_policy *policy, | |||
392 | 424 | ||
393 | int cpufreq_frequency_table_verify(struct cpufreq_policy *policy, | 425 | int cpufreq_frequency_table_verify(struct cpufreq_policy *policy, |
394 | struct cpufreq_frequency_table *table); | 426 | struct cpufreq_frequency_table *table); |
427 | int cpufreq_generic_frequency_table_verify(struct cpufreq_policy *policy); | ||
395 | 428 | ||
396 | int cpufreq_frequency_table_target(struct cpufreq_policy *policy, | 429 | int cpufreq_frequency_table_target(struct cpufreq_policy *policy, |
397 | struct cpufreq_frequency_table *table, | 430 | struct cpufreq_frequency_table *table, |
@@ -407,8 +440,20 @@ struct cpufreq_frequency_table *cpufreq_frequency_get_table(unsigned int cpu); | |||
407 | 440 | ||
408 | /* the following are really really optional */ | 441 | /* the following are really really optional */ |
409 | extern struct freq_attr cpufreq_freq_attr_scaling_available_freqs; | 442 | extern struct freq_attr cpufreq_freq_attr_scaling_available_freqs; |
443 | extern struct freq_attr *cpufreq_generic_attr[]; | ||
410 | void cpufreq_frequency_table_get_attr(struct cpufreq_frequency_table *table, | 444 | void cpufreq_frequency_table_get_attr(struct cpufreq_frequency_table *table, |
411 | unsigned int cpu); | 445 | unsigned int cpu); |
412 | void cpufreq_frequency_table_put_attr(unsigned int cpu); | 446 | void cpufreq_frequency_table_put_attr(unsigned int cpu); |
447 | int cpufreq_table_validate_and_show(struct cpufreq_policy *policy, | ||
448 | struct cpufreq_frequency_table *table); | ||
449 | |||
450 | int cpufreq_generic_init(struct cpufreq_policy *policy, | ||
451 | struct cpufreq_frequency_table *table, | ||
452 | unsigned int transition_latency); | ||
453 | static inline int cpufreq_generic_exit(struct cpufreq_policy *policy) | ||
454 | { | ||
455 | cpufreq_frequency_table_put_attr(policy->cpu); | ||
456 | return 0; | ||
457 | } | ||
413 | 458 | ||
414 | #endif /* _LINUX_CPUFREQ_H */ | 459 | #endif /* _LINUX_CPUFREQ_H */ |
diff --git a/include/linux/cpuidle.h b/include/linux/cpuidle.h index 781addc66f03..50fcbb0ac4e7 100644 --- a/include/linux/cpuidle.h +++ b/include/linux/cpuidle.h | |||
@@ -114,7 +114,7 @@ struct cpuidle_driver { | |||
114 | int safe_state_index; | 114 | int safe_state_index; |
115 | 115 | ||
116 | /* the driver handles the cpus in cpumask */ | 116 | /* the driver handles the cpus in cpumask */ |
117 | struct cpumask *cpumask; | 117 | struct cpumask *cpumask; |
118 | }; | 118 | }; |
119 | 119 | ||
120 | #ifdef CONFIG_CPU_IDLE | 120 | #ifdef CONFIG_CPU_IDLE |
@@ -195,16 +195,10 @@ struct cpuidle_governor { | |||
195 | }; | 195 | }; |
196 | 196 | ||
197 | #ifdef CONFIG_CPU_IDLE | 197 | #ifdef CONFIG_CPU_IDLE |
198 | |||
199 | extern int cpuidle_register_governor(struct cpuidle_governor *gov); | 198 | extern int cpuidle_register_governor(struct cpuidle_governor *gov); |
200 | extern void cpuidle_unregister_governor(struct cpuidle_governor *gov); | ||
201 | |||
202 | #else | 199 | #else |
203 | |||
204 | static inline int cpuidle_register_governor(struct cpuidle_governor *gov) | 200 | static inline int cpuidle_register_governor(struct cpuidle_governor *gov) |
205 | {return 0;} | 201 | {return 0;} |
206 | static inline void cpuidle_unregister_governor(struct cpuidle_governor *gov) { } | ||
207 | |||
208 | #endif | 202 | #endif |
209 | 203 | ||
210 | #ifdef CONFIG_ARCH_HAS_CPU_RELAX | 204 | #ifdef CONFIG_ARCH_HAS_CPU_RELAX |
diff --git a/include/linux/devfreq.h b/include/linux/devfreq.h index 5f1ab92107e6..7a7cc74d7f27 100644 --- a/include/linux/devfreq.h +++ b/include/linux/devfreq.h | |||
@@ -15,7 +15,7 @@ | |||
15 | 15 | ||
16 | #include <linux/device.h> | 16 | #include <linux/device.h> |
17 | #include <linux/notifier.h> | 17 | #include <linux/notifier.h> |
18 | #include <linux/opp.h> | 18 | #include <linux/pm_opp.h> |
19 | 19 | ||
20 | #define DEVFREQ_NAME_LEN 16 | 20 | #define DEVFREQ_NAME_LEN 16 |
21 | 21 | ||
@@ -187,7 +187,7 @@ extern int devfreq_suspend_device(struct devfreq *devfreq); | |||
187 | extern int devfreq_resume_device(struct devfreq *devfreq); | 187 | extern int devfreq_resume_device(struct devfreq *devfreq); |
188 | 188 | ||
189 | /* Helper functions for devfreq user device driver with OPP. */ | 189 | /* Helper functions for devfreq user device driver with OPP. */ |
190 | extern struct opp *devfreq_recommended_opp(struct device *dev, | 190 | extern struct dev_pm_opp *devfreq_recommended_opp(struct device *dev, |
191 | unsigned long *freq, u32 flags); | 191 | unsigned long *freq, u32 flags); |
192 | extern int devfreq_register_opp_notifier(struct device *dev, | 192 | extern int devfreq_register_opp_notifier(struct device *dev, |
193 | struct devfreq *devfreq); | 193 | struct devfreq *devfreq); |
@@ -238,7 +238,7 @@ static inline int devfreq_resume_device(struct devfreq *devfreq) | |||
238 | return 0; | 238 | return 0; |
239 | } | 239 | } |
240 | 240 | ||
241 | static inline struct opp *devfreq_recommended_opp(struct device *dev, | 241 | static inline struct dev_pm_opp *devfreq_recommended_opp(struct device *dev, |
242 | unsigned long *freq, u32 flags) | 242 | unsigned long *freq, u32 flags) |
243 | { | 243 | { |
244 | return ERR_PTR(-EINVAL); | 244 | return ERR_PTR(-EINVAL); |
diff --git a/include/linux/opp.h b/include/linux/opp.h deleted file mode 100644 index 3aca2b8def33..000000000000 --- a/include/linux/opp.h +++ /dev/null | |||
@@ -1,134 +0,0 @@ | |||
1 | /* | ||
2 | * Generic OPP Interface | ||
3 | * | ||
4 | * Copyright (C) 2009-2010 Texas Instruments Incorporated. | ||
5 | * Nishanth Menon | ||
6 | * Romit Dasgupta | ||
7 | * Kevin Hilman | ||
8 | * | ||
9 | * This program is free software; you can redistribute it and/or modify | ||
10 | * it under the terms of the GNU General Public License version 2 as | ||
11 | * published by the Free Software Foundation. | ||
12 | */ | ||
13 | |||
14 | #ifndef __LINUX_OPP_H__ | ||
15 | #define __LINUX_OPP_H__ | ||
16 | |||
17 | #include <linux/err.h> | ||
18 | #include <linux/cpufreq.h> | ||
19 | #include <linux/notifier.h> | ||
20 | |||
21 | struct opp; | ||
22 | struct device; | ||
23 | |||
24 | enum opp_event { | ||
25 | OPP_EVENT_ADD, OPP_EVENT_ENABLE, OPP_EVENT_DISABLE, | ||
26 | }; | ||
27 | |||
28 | #if defined(CONFIG_PM_OPP) | ||
29 | |||
30 | unsigned long opp_get_voltage(struct opp *opp); | ||
31 | |||
32 | unsigned long opp_get_freq(struct opp *opp); | ||
33 | |||
34 | int opp_get_opp_count(struct device *dev); | ||
35 | |||
36 | struct opp *opp_find_freq_exact(struct device *dev, unsigned long freq, | ||
37 | bool available); | ||
38 | |||
39 | struct opp *opp_find_freq_floor(struct device *dev, unsigned long *freq); | ||
40 | |||
41 | struct opp *opp_find_freq_ceil(struct device *dev, unsigned long *freq); | ||
42 | |||
43 | int opp_add(struct device *dev, unsigned long freq, unsigned long u_volt); | ||
44 | |||
45 | int opp_enable(struct device *dev, unsigned long freq); | ||
46 | |||
47 | int opp_disable(struct device *dev, unsigned long freq); | ||
48 | |||
49 | struct srcu_notifier_head *opp_get_notifier(struct device *dev); | ||
50 | #else | ||
51 | static inline unsigned long opp_get_voltage(struct opp *opp) | ||
52 | { | ||
53 | return 0; | ||
54 | } | ||
55 | |||
56 | static inline unsigned long opp_get_freq(struct opp *opp) | ||
57 | { | ||
58 | return 0; | ||
59 | } | ||
60 | |||
61 | static inline int opp_get_opp_count(struct device *dev) | ||
62 | { | ||
63 | return 0; | ||
64 | } | ||
65 | |||
66 | static inline struct opp *opp_find_freq_exact(struct device *dev, | ||
67 | unsigned long freq, bool available) | ||
68 | { | ||
69 | return ERR_PTR(-EINVAL); | ||
70 | } | ||
71 | |||
72 | static inline struct opp *opp_find_freq_floor(struct device *dev, | ||
73 | unsigned long *freq) | ||
74 | { | ||
75 | return ERR_PTR(-EINVAL); | ||
76 | } | ||
77 | |||
78 | static inline struct opp *opp_find_freq_ceil(struct device *dev, | ||
79 | unsigned long *freq) | ||
80 | { | ||
81 | return ERR_PTR(-EINVAL); | ||
82 | } | ||
83 | |||
84 | static inline int opp_add(struct device *dev, unsigned long freq, | ||
85 | unsigned long u_volt) | ||
86 | { | ||
87 | return -EINVAL; | ||
88 | } | ||
89 | |||
90 | static inline int opp_enable(struct device *dev, unsigned long freq) | ||
91 | { | ||
92 | return 0; | ||
93 | } | ||
94 | |||
95 | static inline int opp_disable(struct device *dev, unsigned long freq) | ||
96 | { | ||
97 | return 0; | ||
98 | } | ||
99 | |||
100 | static inline struct srcu_notifier_head *opp_get_notifier(struct device *dev) | ||
101 | { | ||
102 | return ERR_PTR(-EINVAL); | ||
103 | } | ||
104 | #endif /* CONFIG_PM_OPP */ | ||
105 | |||
106 | #if defined(CONFIG_PM_OPP) && defined(CONFIG_OF) | ||
107 | int of_init_opp_table(struct device *dev); | ||
108 | #else | ||
109 | static inline int of_init_opp_table(struct device *dev) | ||
110 | { | ||
111 | return -EINVAL; | ||
112 | } | ||
113 | #endif | ||
114 | |||
115 | #if defined(CONFIG_CPU_FREQ) && defined(CONFIG_PM_OPP) | ||
116 | int opp_init_cpufreq_table(struct device *dev, | ||
117 | struct cpufreq_frequency_table **table); | ||
118 | void opp_free_cpufreq_table(struct device *dev, | ||
119 | struct cpufreq_frequency_table **table); | ||
120 | #else | ||
121 | static inline int opp_init_cpufreq_table(struct device *dev, | ||
122 | struct cpufreq_frequency_table **table) | ||
123 | { | ||
124 | return -EINVAL; | ||
125 | } | ||
126 | |||
127 | static inline | ||
128 | void opp_free_cpufreq_table(struct device *dev, | ||
129 | struct cpufreq_frequency_table **table) | ||
130 | { | ||
131 | } | ||
132 | #endif /* CONFIG_CPU_FREQ */ | ||
133 | |||
134 | #endif /* __LINUX_OPP_H__ */ | ||
diff --git a/include/linux/pm_opp.h b/include/linux/pm_opp.h new file mode 100644 index 000000000000..5151b0059585 --- /dev/null +++ b/include/linux/pm_opp.h | |||
@@ -0,0 +1,139 @@ | |||
1 | /* | ||
2 | * Generic OPP Interface | ||
3 | * | ||
4 | * Copyright (C) 2009-2010 Texas Instruments Incorporated. | ||
5 | * Nishanth Menon | ||
6 | * Romit Dasgupta | ||
7 | * Kevin Hilman | ||
8 | * | ||
9 | * This program is free software; you can redistribute it and/or modify | ||
10 | * it under the terms of the GNU General Public License version 2 as | ||
11 | * published by the Free Software Foundation. | ||
12 | */ | ||
13 | |||
14 | #ifndef __LINUX_OPP_H__ | ||
15 | #define __LINUX_OPP_H__ | ||
16 | |||
17 | #include <linux/err.h> | ||
18 | #include <linux/cpufreq.h> | ||
19 | #include <linux/notifier.h> | ||
20 | |||
21 | struct dev_pm_opp; | ||
22 | struct device; | ||
23 | |||
24 | enum dev_pm_opp_event { | ||
25 | OPP_EVENT_ADD, OPP_EVENT_ENABLE, OPP_EVENT_DISABLE, | ||
26 | }; | ||
27 | |||
28 | #if defined(CONFIG_PM_OPP) | ||
29 | |||
30 | unsigned long dev_pm_opp_get_voltage(struct dev_pm_opp *opp); | ||
31 | |||
32 | unsigned long dev_pm_opp_get_freq(struct dev_pm_opp *opp); | ||
33 | |||
34 | int dev_pm_opp_get_opp_count(struct device *dev); | ||
35 | |||
36 | struct dev_pm_opp *dev_pm_opp_find_freq_exact(struct device *dev, | ||
37 | unsigned long freq, | ||
38 | bool available); | ||
39 | |||
40 | struct dev_pm_opp *dev_pm_opp_find_freq_floor(struct device *dev, | ||
41 | unsigned long *freq); | ||
42 | |||
43 | struct dev_pm_opp *dev_pm_opp_find_freq_ceil(struct device *dev, | ||
44 | unsigned long *freq); | ||
45 | |||
46 | int dev_pm_opp_add(struct device *dev, unsigned long freq, | ||
47 | unsigned long u_volt); | ||
48 | |||
49 | int dev_pm_opp_enable(struct device *dev, unsigned long freq); | ||
50 | |||
51 | int dev_pm_opp_disable(struct device *dev, unsigned long freq); | ||
52 | |||
53 | struct srcu_notifier_head *dev_pm_opp_get_notifier(struct device *dev); | ||
54 | #else | ||
55 | static inline unsigned long dev_pm_opp_get_voltage(struct dev_pm_opp *opp) | ||
56 | { | ||
57 | return 0; | ||
58 | } | ||
59 | |||
60 | static inline unsigned long dev_pm_opp_get_freq(struct dev_pm_opp *opp) | ||
61 | { | ||
62 | return 0; | ||
63 | } | ||
64 | |||
65 | static inline int dev_pm_opp_get_opp_count(struct device *dev) | ||
66 | { | ||
67 | return 0; | ||
68 | } | ||
69 | |||
70 | static inline struct dev_pm_opp *dev_pm_opp_find_freq_exact(struct device *dev, | ||
71 | unsigned long freq, bool available) | ||
72 | { | ||
73 | return ERR_PTR(-EINVAL); | ||
74 | } | ||
75 | |||
76 | static inline struct dev_pm_opp *dev_pm_opp_find_freq_floor(struct device *dev, | ||
77 | unsigned long *freq) | ||
78 | { | ||
79 | return ERR_PTR(-EINVAL); | ||
80 | } | ||
81 | |||
82 | static inline struct dev_pm_opp *dev_pm_opp_find_freq_ceil(struct device *dev, | ||
83 | unsigned long *freq) | ||
84 | { | ||
85 | return ERR_PTR(-EINVAL); | ||
86 | } | ||
87 | |||
88 | static inline int dev_pm_opp_add(struct device *dev, unsigned long freq, | ||
89 | unsigned long u_volt) | ||
90 | { | ||
91 | return -EINVAL; | ||
92 | } | ||
93 | |||
94 | static inline int dev_pm_opp_enable(struct device *dev, unsigned long freq) | ||
95 | { | ||
96 | return 0; | ||
97 | } | ||
98 | |||
99 | static inline int dev_pm_opp_disable(struct device *dev, unsigned long freq) | ||
100 | { | ||
101 | return 0; | ||
102 | } | ||
103 | |||
104 | static inline struct srcu_notifier_head *dev_pm_opp_get_notifier( | ||
105 | struct device *dev) | ||
106 | { | ||
107 | return ERR_PTR(-EINVAL); | ||
108 | } | ||
109 | #endif /* CONFIG_PM_OPP */ | ||
110 | |||
111 | #if defined(CONFIG_PM_OPP) && defined(CONFIG_OF) | ||
112 | int of_init_opp_table(struct device *dev); | ||
113 | #else | ||
114 | static inline int of_init_opp_table(struct device *dev) | ||
115 | { | ||
116 | return -EINVAL; | ||
117 | } | ||
118 | #endif | ||
119 | |||
120 | #if defined(CONFIG_CPU_FREQ) && defined(CONFIG_PM_OPP) | ||
121 | int dev_pm_opp_init_cpufreq_table(struct device *dev, | ||
122 | struct cpufreq_frequency_table **table); | ||
123 | void dev_pm_opp_free_cpufreq_table(struct device *dev, | ||
124 | struct cpufreq_frequency_table **table); | ||
125 | #else | ||
126 | static inline int dev_pm_opp_init_cpufreq_table(struct device *dev, | ||
127 | struct cpufreq_frequency_table **table) | ||
128 | { | ||
129 | return -EINVAL; | ||
130 | } | ||
131 | |||
132 | static inline | ||
133 | void dev_pm_opp_free_cpufreq_table(struct device *dev, | ||
134 | struct cpufreq_frequency_table **table) | ||
135 | { | ||
136 | } | ||
137 | #endif /* CONFIG_CPU_FREQ */ | ||
138 | |||
139 | #endif /* __LINUX_OPP_H__ */ | ||
diff --git a/include/linux/powercap.h b/include/linux/powercap.h new file mode 100644 index 000000000000..4e250417ee30 --- /dev/null +++ b/include/linux/powercap.h | |||
@@ -0,0 +1,325 @@ | |||
1 | /* | ||
2 | * powercap.h: Data types and headers for sysfs power capping interface | ||
3 | * Copyright (c) 2013, Intel Corporation. | ||
4 | * | ||
5 | * This program is free software; you can redistribute it and/or modify it | ||
6 | * under the terms and conditions of the GNU General Public License, | ||
7 | * version 2, as published by the Free Software Foundation. | ||
8 | * | ||
9 | * This program is distributed in the hope it will be useful, but WITHOUT | ||
10 | * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | ||
11 | * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for | ||
12 | * more details. | ||
13 | * | ||
14 | * You should have received a copy of the GNU General Public License along with | ||
15 | * this program; if not, write to the Free Software Foundation, Inc. | ||
16 | * | ||
17 | */ | ||
18 | |||
19 | #ifndef __POWERCAP_H__ | ||
20 | #define __POWERCAP_H__ | ||
21 | |||
22 | #include <linux/device.h> | ||
23 | #include <linux/idr.h> | ||
24 | |||
25 | /* | ||
26 | * A power cap class device can contain multiple powercap control_types. | ||
27 | * Each control_type can have multiple power zones, which can be independently | ||
28 | * controlled. Each power zone can have one or more constraints. | ||
29 | */ | ||
30 | |||
31 | struct powercap_control_type; | ||
32 | struct powercap_zone; | ||
33 | struct powercap_zone_constraint; | ||
34 | |||
35 | /** | ||
36 | * struct powercap_control_type_ops - Define control type callbacks | ||
37 | * @set_enable: Enable/Disable whole control type. | ||
38 | * Default is enabled. But this callback allows all zones | ||
39 | * to be in disable state and remove any applied power | ||
40 | * limits. If disabled power zone can only be monitored | ||
41 | * not controlled. | ||
42 | * @get_enable: get Enable/Disable status. | ||
43 | * @release: Callback to inform that last reference to this | ||
44 | * control type is closed. So it is safe to free data | ||
45 | * structure associated with this control type. | ||
46 | * This callback is mandatory if the client own memory | ||
47 | * for the control type. | ||
48 | * | ||
49 | * This structure defines control type callbacks to be implemented by client | ||
50 | * drivers | ||
51 | */ | ||
52 | struct powercap_control_type_ops { | ||
53 | int (*set_enable) (struct powercap_control_type *, bool mode); | ||
54 | int (*get_enable) (struct powercap_control_type *, bool *mode); | ||
55 | int (*release) (struct powercap_control_type *); | ||
56 | }; | ||
57 | |||
58 | /** | ||
59 | * struct powercap_control_type- Defines a powercap control_type | ||
60 | * @name: name of control_type | ||
61 | * @dev: device for this control_type | ||
62 | * @idr: idr to have unique id for its child | ||
63 | * @root_node: Root holding power zones for this control_type | ||
64 | * @ops: Pointer to callback struct | ||
65 | * @node_lock: mutex for control type | ||
66 | * @allocated: This is possible that client owns the memory | ||
67 | * used by this structure. In this case | ||
68 | * this flag is set to false by framework to | ||
69 | * prevent deallocation during release process. | ||
70 | * Otherwise this flag is set to true. | ||
71 | * @ctrl_inst: link to the control_type list | ||
72 | * | ||
73 | * Defines powercap control_type. This acts as a container for power | ||
74 | * zones, which use same method to control power. E.g. RAPL, RAPL-PCI etc. | ||
75 | * All fields are private and should not be used by client drivers. | ||
76 | */ | ||
77 | struct powercap_control_type { | ||
78 | struct device dev; | ||
79 | struct idr idr; | ||
80 | int nr_zones; | ||
81 | const struct powercap_control_type_ops *ops; | ||
82 | struct mutex lock; | ||
83 | bool allocated; | ||
84 | struct list_head node; | ||
85 | }; | ||
86 | |||
87 | /** | ||
88 | * struct powercap_zone_ops - Define power zone callbacks | ||
89 | * @get_max_energy_range_uj: Get maximum range of energy counter in | ||
90 | * micro-joules. | ||
91 | * @get_energy_uj: Get current energy counter in micro-joules. | ||
92 | * @reset_energy_uj: Reset micro-joules energy counter. | ||
93 | * @get_max_power_range_uw: Get maximum range of power counter in | ||
94 | * micro-watts. | ||
95 | * @get_power_uw: Get current power counter in micro-watts. | ||
96 | * @set_enable: Enable/Disable power zone controls. | ||
97 | * Default is enabled. | ||
98 | * @get_enable: get Enable/Disable status. | ||
99 | * @release: Callback to inform that last reference to this | ||
100 | * control type is closed. So it is safe to free | ||
101 | * data structure associated with this | ||
102 | * control type. Mandatory, if client driver owns | ||
103 | * the power_zone memory. | ||
104 | * | ||
105 | * This structure defines zone callbacks to be implemented by client drivers. | ||
106 | * Client drives can define both energy and power related callbacks. But at | ||
107 | * the least one type (either power or energy) is mandatory. Client drivers | ||
108 | * should handle mutual exclusion, if required in callbacks. | ||
109 | */ | ||
110 | struct powercap_zone_ops { | ||
111 | int (*get_max_energy_range_uj) (struct powercap_zone *, u64 *); | ||
112 | int (*get_energy_uj) (struct powercap_zone *, u64 *); | ||
113 | int (*reset_energy_uj) (struct powercap_zone *); | ||
114 | int (*get_max_power_range_uw) (struct powercap_zone *, u64 *); | ||
115 | int (*get_power_uw) (struct powercap_zone *, u64 *); | ||
116 | int (*set_enable) (struct powercap_zone *, bool mode); | ||
117 | int (*get_enable) (struct powercap_zone *, bool *mode); | ||
118 | int (*release) (struct powercap_zone *); | ||
119 | }; | ||
120 | |||
121 | #define POWERCAP_ZONE_MAX_ATTRS 6 | ||
122 | #define POWERCAP_CONSTRAINTS_ATTRS 8 | ||
123 | #define MAX_CONSTRAINTS_PER_ZONE 10 | ||
124 | /** | ||
125 | * struct powercap_zone- Defines instance of a power cap zone | ||
126 | * @id: Unique id | ||
127 | * @name: Power zone name. | ||
128 | * @control_type_inst: Control type instance for this zone. | ||
129 | * @ops: Pointer to the zone operation structure. | ||
130 | * @dev: Instance of a device. | ||
131 | * @const_id_cnt: Number of constraint defined. | ||
132 | * @idr: Instance to an idr entry for children zones. | ||
133 | * @parent_idr: To remove reference from the parent idr. | ||
134 | * @private_data: Private data pointer if any for this zone. | ||
135 | * @zone_dev_attrs: Attributes associated with this device. | ||
136 | * @zone_attr_count: Attribute count. | ||
137 | * @dev_zone_attr_group: Attribute group for attributes. | ||
138 | * @dev_attr_groups: Attribute group store to register with device. | ||
139 | * @allocated: This is possible that client owns the memory | ||
140 | * used by this structure. In this case | ||
141 | * this flag is set to false by framework to | ||
142 | * prevent deallocation during release process. | ||
143 | * Otherwise this flag is set to true. | ||
144 | * @constraint_ptr: List of constraints for this zone. | ||
145 | * | ||
146 | * This defines a power zone instance. The fields of this structure are | ||
147 | * private, and should not be used by client drivers. | ||
148 | */ | ||
149 | struct powercap_zone { | ||
150 | int id; | ||
151 | char *name; | ||
152 | void *control_type_inst; | ||
153 | const struct powercap_zone_ops *ops; | ||
154 | struct device dev; | ||
155 | int const_id_cnt; | ||
156 | struct idr idr; | ||
157 | struct idr *parent_idr; | ||
158 | void *private_data; | ||
159 | struct attribute **zone_dev_attrs; | ||
160 | int zone_attr_count; | ||
161 | struct attribute_group dev_zone_attr_group; | ||
162 | const struct attribute_group *dev_attr_groups[2]; /* 1 group + NULL */ | ||
163 | bool allocated; | ||
164 | struct powercap_zone_constraint *constraints; | ||
165 | }; | ||
166 | |||
167 | /** | ||
168 | * struct powercap_zone_constraint_ops - Define constraint callbacks | ||
169 | * @set_power_limit_uw: Set power limit in micro-watts. | ||
170 | * @get_power_limit_uw: Get power limit in micro-watts. | ||
171 | * @set_time_window_us: Set time window in micro-seconds. | ||
172 | * @get_time_window_us: Get time window in micro-seconds. | ||
173 | * @get_max_power_uw: Get max power allowed in micro-watts. | ||
174 | * @get_min_power_uw: Get min power allowed in micro-watts. | ||
175 | * @get_max_time_window_us: Get max time window allowed in micro-seconds. | ||
176 | * @get_min_time_window_us: Get min time window allowed in micro-seconds. | ||
177 | * @get_name: Get the name of constraint | ||
178 | * | ||
179 | * This structure is used to define the constraint callbacks for the client | ||
180 | * drivers. The following callbacks are mandatory and can't be NULL: | ||
181 | * set_power_limit_uw | ||
182 | * get_power_limit_uw | ||
183 | * set_time_window_us | ||
184 | * get_time_window_us | ||
185 | * get_name | ||
186 | * Client drivers should handle mutual exclusion, if required in callbacks. | ||
187 | */ | ||
188 | struct powercap_zone_constraint_ops { | ||
189 | int (*set_power_limit_uw) (struct powercap_zone *, int, u64); | ||
190 | int (*get_power_limit_uw) (struct powercap_zone *, int, u64 *); | ||
191 | int (*set_time_window_us) (struct powercap_zone *, int, u64); | ||
192 | int (*get_time_window_us) (struct powercap_zone *, int, u64 *); | ||
193 | int (*get_max_power_uw) (struct powercap_zone *, int, u64 *); | ||
194 | int (*get_min_power_uw) (struct powercap_zone *, int, u64 *); | ||
195 | int (*get_max_time_window_us) (struct powercap_zone *, int, u64 *); | ||
196 | int (*get_min_time_window_us) (struct powercap_zone *, int, u64 *); | ||
197 | const char *(*get_name) (struct powercap_zone *, int); | ||
198 | }; | ||
199 | |||
200 | /** | ||
201 | * struct powercap_zone_constraint- Defines instance of a constraint | ||
202 | * @id: Instance Id of this constraint. | ||
203 | * @power_zone: Pointer to the power zone for this constraint. | ||
204 | * @ops: Pointer to the constraint callbacks. | ||
205 | * | ||
206 | * This defines a constraint instance. | ||
207 | */ | ||
208 | struct powercap_zone_constraint { | ||
209 | int id; | ||
210 | struct powercap_zone *power_zone; | ||
211 | struct powercap_zone_constraint_ops *ops; | ||
212 | }; | ||
213 | |||
214 | |||
215 | /* For clients to get their device pointer, may be used for dev_dbgs */ | ||
216 | #define POWERCAP_GET_DEV(power_zone) (&power_zone->dev) | ||
217 | |||
218 | /** | ||
219 | * powercap_set_zone_data() - Set private data for a zone | ||
220 | * @power_zone: A pointer to the valid zone instance. | ||
221 | * @pdata: A pointer to the user private data. | ||
222 | * | ||
223 | * Allows client drivers to associate some private data to zone instance. | ||
224 | */ | ||
225 | static inline void powercap_set_zone_data(struct powercap_zone *power_zone, | ||
226 | void *pdata) | ||
227 | { | ||
228 | if (power_zone) | ||
229 | power_zone->private_data = pdata; | ||
230 | } | ||
231 | |||
232 | /** | ||
233 | * powercap_get_zone_data() - Get private data for a zone | ||
234 | * @power_zone: A pointer to the valid zone instance. | ||
235 | * | ||
236 | * Allows client drivers to get private data associate with a zone, | ||
237 | * using call to powercap_set_zone_data. | ||
238 | */ | ||
239 | static inline void *powercap_get_zone_data(struct powercap_zone *power_zone) | ||
240 | { | ||
241 | if (power_zone) | ||
242 | return power_zone->private_data; | ||
243 | return NULL; | ||
244 | } | ||
245 | |||
246 | /** | ||
247 | * powercap_register_control_type() - Register a control_type with framework | ||
248 | * @control_type: Pointer to client allocated memory for the control type | ||
249 | * structure storage. If this is NULL, powercap framework | ||
250 | * will allocate memory and own it. | ||
251 | * Advantage of this parameter is that client can embed | ||
252 | * this data in its data structures and allocate in a | ||
253 | * single call, preventing multiple allocations. | ||
254 | * @control_type_name: The Name of this control_type, which will be shown | ||
255 | * in the sysfs Interface. | ||
256 | * @ops: Callbacks for control type. This parameter is optional. | ||
257 | * | ||
258 | * Used to create a control_type with the power capping class. Here control_type | ||
259 | * can represent a type of technology, which can control a range of power zones. | ||
260 | * For example a control_type can be RAPL (Running Average Power Limit) | ||
261 | * IntelĀ® 64 and IA-32 Processor Architectures. The name can be any string | ||
262 | * which must be unique, otherwise this function returns NULL. | ||
263 | * A pointer to the control_type instance is returned on success. | ||
264 | */ | ||
265 | struct powercap_control_type *powercap_register_control_type( | ||
266 | struct powercap_control_type *control_type, | ||
267 | const char *name, | ||
268 | const struct powercap_control_type_ops *ops); | ||
269 | |||
270 | /** | ||
271 | * powercap_unregister_control_type() - Unregister a control_type from framework | ||
272 | * @instance: A pointer to the valid control_type instance. | ||
273 | * | ||
274 | * Used to unregister a control_type with the power capping class. | ||
275 | * All power zones registered under this control type have to be unregistered | ||
276 | * before calling this function, or it will fail with an error code. | ||
277 | */ | ||
278 | int powercap_unregister_control_type(struct powercap_control_type *instance); | ||
279 | |||
280 | /* Zone register/unregister API */ | ||
281 | |||
282 | /** | ||
283 | * powercap_register_zone() - Register a power zone | ||
284 | * @power_zone: Pointer to client allocated memory for the power zone structure | ||
285 | * storage. If this is NULL, powercap framework will allocate | ||
286 | * memory and own it. Advantage of this parameter is that client | ||
287 | * can embed this data in its data structures and allocate in a | ||
288 | * single call, preventing multiple allocations. | ||
289 | * @control_type: A control_type instance under which this zone operates. | ||
290 | * @name: A name for this zone. | ||
291 | * @parent: A pointer to the parent power zone instance if any or NULL | ||
292 | * @ops: Pointer to zone operation callback structure. | ||
293 | * @no_constraints: Number of constraints for this zone | ||
294 | * @const_ops: Pointer to constraint callback structure | ||
295 | * | ||
296 | * Register a power zone under a given control type. A power zone must register | ||
297 | * a pointer to a structure representing zone callbacks. | ||
298 | * A power zone can be located under a parent power zone, in which case @parent | ||
299 | * should point to it. Otherwise, if @parent is NULL, the new power zone will | ||
300 | * be located directly under the given control type | ||
301 | * For each power zone there may be a number of constraints that appear in the | ||
302 | * sysfs under that zone as attributes with unique numeric IDs. | ||
303 | * Returns pointer to the power_zone on success. | ||
304 | */ | ||
305 | struct powercap_zone *powercap_register_zone( | ||
306 | struct powercap_zone *power_zone, | ||
307 | struct powercap_control_type *control_type, | ||
308 | const char *name, | ||
309 | struct powercap_zone *parent, | ||
310 | const struct powercap_zone_ops *ops, | ||
311 | int nr_constraints, | ||
312 | struct powercap_zone_constraint_ops *const_ops); | ||
313 | |||
314 | /** | ||
315 | * powercap_unregister_zone() - Unregister a zone device | ||
316 | * @control_type: A pointer to the valid instance of a control_type. | ||
317 | * @power_zone: A pointer to the valid zone instance for a control_type | ||
318 | * | ||
319 | * Used to unregister a zone device for a control_type. Caller should | ||
320 | * make sure that children for this zone are unregistered first. | ||
321 | */ | ||
322 | int powercap_unregister_zone(struct powercap_control_type *control_type, | ||
323 | struct powercap_zone *power_zone); | ||
324 | |||
325 | #endif | ||