blob: a2df8f6fcc2509c7a13cc06fc53180aa1f28c764 [file] [log] [blame]
Nishanth Menone1f60b22010-10-13 00:13:10 +02001/*
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>
MyungJoo Ham03ca3702011-09-30 22:35:12 +020018#include <linux/notifier.h>
Nishanth Menone1f60b22010-10-13 00:13:10 +020019
Nishanth Menon47d43ba2013-09-19 16:03:51 -050020struct dev_pm_opp;
Paul Gortmaker313162d2012-01-30 11:46:54 -050021struct device;
Nishanth Menone1f60b22010-10-13 00:13:10 +020022
Nishanth Menon47d43ba2013-09-19 16:03:51 -050023enum dev_pm_opp_event {
Viresh Kumar129eec52014-11-27 08:54:06 +053024 OPP_EVENT_ADD, OPP_EVENT_REMOVE, OPP_EVENT_ENABLE, OPP_EVENT_DISABLE,
MyungJoo Ham03ca3702011-09-30 22:35:12 +020025};
26
Nishanth Menone1f60b22010-10-13 00:13:10 +020027#if defined(CONFIG_PM_OPP)
28
Nishanth Menon47d43ba2013-09-19 16:03:51 -050029unsigned long dev_pm_opp_get_voltage(struct dev_pm_opp *opp);
Nishanth Menone1f60b22010-10-13 00:13:10 +020030
Nishanth Menon47d43ba2013-09-19 16:03:51 -050031unsigned long dev_pm_opp_get_freq(struct dev_pm_opp *opp);
Nishanth Menone1f60b22010-10-13 00:13:10 +020032
Bartlomiej Zolnierkiewicz19445b22015-07-09 17:43:35 +020033bool dev_pm_opp_is_turbo(struct dev_pm_opp *opp);
34
Nishanth Menon5d4879c2013-09-19 16:03:50 -050035int dev_pm_opp_get_opp_count(struct device *dev);
Viresh Kumar3ca9bb32015-07-29 16:23:03 +053036unsigned long dev_pm_opp_get_max_clock_latency(struct device *dev);
Viresh Kumar655c9df2016-02-09 10:30:35 +053037unsigned long dev_pm_opp_get_max_volt_latency(struct device *dev);
Viresh Kumar21743442016-02-09 10:30:36 +053038unsigned long dev_pm_opp_get_max_transition_latency(struct device *dev);
Bartlomiej Zolnierkiewicz4eafbd12015-09-08 18:41:01 +020039struct dev_pm_opp *dev_pm_opp_get_suspend_opp(struct device *dev);
Nishanth Menone1f60b22010-10-13 00:13:10 +020040
Nishanth Menon47d43ba2013-09-19 16:03:51 -050041struct dev_pm_opp *dev_pm_opp_find_freq_exact(struct device *dev,
42 unsigned long freq,
43 bool available);
Nishanth Menone1f60b22010-10-13 00:13:10 +020044
Nishanth Menon47d43ba2013-09-19 16:03:51 -050045struct dev_pm_opp *dev_pm_opp_find_freq_floor(struct device *dev,
46 unsigned long *freq);
Nishanth Menone1f60b22010-10-13 00:13:10 +020047
Nishanth Menon47d43ba2013-09-19 16:03:51 -050048struct dev_pm_opp *dev_pm_opp_find_freq_ceil(struct device *dev,
49 unsigned long *freq);
Nishanth Menone1f60b22010-10-13 00:13:10 +020050
Nishanth Menon5d4879c2013-09-19 16:03:50 -050051int dev_pm_opp_add(struct device *dev, unsigned long freq,
52 unsigned long u_volt);
Viresh Kumar129eec52014-11-27 08:54:06 +053053void dev_pm_opp_remove(struct device *dev, unsigned long freq);
Nishanth Menone1f60b22010-10-13 00:13:10 +020054
Nishanth Menon5d4879c2013-09-19 16:03:50 -050055int dev_pm_opp_enable(struct device *dev, unsigned long freq);
Nishanth Menone1f60b22010-10-13 00:13:10 +020056
Nishanth Menon5d4879c2013-09-19 16:03:50 -050057int dev_pm_opp_disable(struct device *dev, unsigned long freq);
Nishanth Menone1f60b22010-10-13 00:13:10 +020058
Nishanth Menon5d4879c2013-09-19 16:03:50 -050059struct srcu_notifier_head *dev_pm_opp_get_notifier(struct device *dev);
Viresh Kumar7de36b02015-12-09 08:01:46 +053060int dev_pm_opp_set_supported_hw(struct device *dev, const u32 *versions,
61 unsigned int count);
62void dev_pm_opp_put_supported_hw(struct device *dev);
Viresh Kumar01fb4d32015-12-09 08:01:47 +053063int dev_pm_opp_set_prop_name(struct device *dev, const char *name);
64void dev_pm_opp_put_prop_name(struct device *dev);
Viresh Kumar9f8ea962016-02-09 10:30:33 +053065int dev_pm_opp_set_regulator(struct device *dev, const char *name);
66void dev_pm_opp_put_regulator(struct device *dev);
Viresh Kumar6a0712f2016-02-09 10:30:39 +053067int dev_pm_opp_set_rate(struct device *dev, unsigned long target_freq);
Viresh Kumar642aa8c2016-04-21 14:28:55 +053068int dev_pm_opp_set_sharing_cpus(struct device *cpu_dev, cpumask_var_t cpumask);
Nishanth Menone1f60b22010-10-13 00:13:10 +020069#else
Nishanth Menon47d43ba2013-09-19 16:03:51 -050070static inline unsigned long dev_pm_opp_get_voltage(struct dev_pm_opp *opp)
Nishanth Menone1f60b22010-10-13 00:13:10 +020071{
72 return 0;
73}
74
Nishanth Menon47d43ba2013-09-19 16:03:51 -050075static inline unsigned long dev_pm_opp_get_freq(struct dev_pm_opp *opp)
Nishanth Menone1f60b22010-10-13 00:13:10 +020076{
77 return 0;
78}
79
Bartlomiej Zolnierkiewicz19445b22015-07-09 17:43:35 +020080static inline bool dev_pm_opp_is_turbo(struct dev_pm_opp *opp)
81{
82 return false;
83}
84
Nishanth Menon5d4879c2013-09-19 16:03:50 -050085static inline int dev_pm_opp_get_opp_count(struct device *dev)
Nishanth Menone1f60b22010-10-13 00:13:10 +020086{
87 return 0;
88}
89
Viresh Kumar3ca9bb32015-07-29 16:23:03 +053090static inline unsigned long dev_pm_opp_get_max_clock_latency(struct device *dev)
91{
92 return 0;
93}
94
Viresh Kumar655c9df2016-02-09 10:30:35 +053095static inline unsigned long dev_pm_opp_get_max_volt_latency(struct device *dev)
96{
97 return 0;
98}
99
Viresh Kumar21743442016-02-09 10:30:36 +0530100static inline unsigned long dev_pm_opp_get_max_transition_latency(struct device *dev)
101{
102 return 0;
103}
104
Bartlomiej Zolnierkiewicz4eafbd12015-09-08 18:41:01 +0200105static inline struct dev_pm_opp *dev_pm_opp_get_suspend_opp(struct device *dev)
106{
107 return NULL;
108}
109
Nishanth Menon47d43ba2013-09-19 16:03:51 -0500110static inline struct dev_pm_opp *dev_pm_opp_find_freq_exact(struct device *dev,
Nishanth Menone1f60b22010-10-13 00:13:10 +0200111 unsigned long freq, bool available)
112{
Viresh Kumard708b382016-04-27 08:52:21 +0530113 return ERR_PTR(-ENOTSUPP);
Nishanth Menone1f60b22010-10-13 00:13:10 +0200114}
115
Nishanth Menon47d43ba2013-09-19 16:03:51 -0500116static inline struct dev_pm_opp *dev_pm_opp_find_freq_floor(struct device *dev,
Nishanth Menone1f60b22010-10-13 00:13:10 +0200117 unsigned long *freq)
118{
Viresh Kumard708b382016-04-27 08:52:21 +0530119 return ERR_PTR(-ENOTSUPP);
Nishanth Menone1f60b22010-10-13 00:13:10 +0200120}
121
Nishanth Menon47d43ba2013-09-19 16:03:51 -0500122static inline struct dev_pm_opp *dev_pm_opp_find_freq_ceil(struct device *dev,
Nishanth Menone1f60b22010-10-13 00:13:10 +0200123 unsigned long *freq)
124{
Viresh Kumard708b382016-04-27 08:52:21 +0530125 return ERR_PTR(-ENOTSUPP);
Nishanth Menone1f60b22010-10-13 00:13:10 +0200126}
127
Nishanth Menon5d4879c2013-09-19 16:03:50 -0500128static inline int dev_pm_opp_add(struct device *dev, unsigned long freq,
Nishanth Menone1f60b22010-10-13 00:13:10 +0200129 unsigned long u_volt)
130{
Viresh Kumard708b382016-04-27 08:52:21 +0530131 return -ENOTSUPP;
Nishanth Menone1f60b22010-10-13 00:13:10 +0200132}
133
Viresh Kumar129eec52014-11-27 08:54:06 +0530134static inline void dev_pm_opp_remove(struct device *dev, unsigned long freq)
135{
136}
137
Nishanth Menon5d4879c2013-09-19 16:03:50 -0500138static inline int dev_pm_opp_enable(struct device *dev, unsigned long freq)
Nishanth Menone1f60b22010-10-13 00:13:10 +0200139{
140 return 0;
141}
142
Nishanth Menon5d4879c2013-09-19 16:03:50 -0500143static inline int dev_pm_opp_disable(struct device *dev, unsigned long freq)
Nishanth Menone1f60b22010-10-13 00:13:10 +0200144{
145 return 0;
146}
MyungJoo Ham03ca3702011-09-30 22:35:12 +0200147
Nishanth Menon5d4879c2013-09-19 16:03:50 -0500148static inline struct srcu_notifier_head *dev_pm_opp_get_notifier(
149 struct device *dev)
MyungJoo Ham03ca3702011-09-30 22:35:12 +0200150{
Viresh Kumard708b382016-04-27 08:52:21 +0530151 return ERR_PTR(-ENOTSUPP);
MyungJoo Ham03ca3702011-09-30 22:35:12 +0200152}
Viresh Kumar7de36b02015-12-09 08:01:46 +0530153
154static inline int dev_pm_opp_set_supported_hw(struct device *dev,
155 const u32 *versions,
156 unsigned int count)
157{
Viresh Kumard708b382016-04-27 08:52:21 +0530158 return -ENOTSUPP;
Viresh Kumar7de36b02015-12-09 08:01:46 +0530159}
160
161static inline void dev_pm_opp_put_supported_hw(struct device *dev) {}
162
Viresh Kumar01fb4d32015-12-09 08:01:47 +0530163static inline int dev_pm_opp_set_prop_name(struct device *dev, const char *name)
164{
Viresh Kumard708b382016-04-27 08:52:21 +0530165 return -ENOTSUPP;
Viresh Kumar01fb4d32015-12-09 08:01:47 +0530166}
167
168static inline void dev_pm_opp_put_prop_name(struct device *dev) {}
169
Viresh Kumar9f8ea962016-02-09 10:30:33 +0530170static inline int dev_pm_opp_set_regulator(struct device *dev, const char *name)
171{
Viresh Kumard708b382016-04-27 08:52:21 +0530172 return -ENOTSUPP;
Viresh Kumar9f8ea962016-02-09 10:30:33 +0530173}
174
175static inline void dev_pm_opp_put_regulator(struct device *dev) {}
176
Viresh Kumar6a0712f2016-02-09 10:30:39 +0530177static inline int dev_pm_opp_set_rate(struct device *dev, unsigned long target_freq)
178{
Viresh Kumard708b382016-04-27 08:52:21 +0530179 return -ENOTSUPP;
Viresh Kumar6a0712f2016-02-09 10:30:39 +0530180}
181
Viresh Kumar642aa8c2016-04-21 14:28:55 +0530182static inline int dev_pm_opp_set_sharing_cpus(struct device *cpu_dev, cpumask_var_t cpumask)
183{
Viresh Kumard708b382016-04-27 08:52:21 +0530184 return -ENOTSUPP;
Viresh Kumar642aa8c2016-04-21 14:28:55 +0530185}
186
Tony Lindgrena96d69d2011-11-03 10:12:27 +0100187#endif /* CONFIG_PM_OPP */
Nishanth Menone1f60b22010-10-13 00:13:10 +0200188
Shawn Guod6561bb2013-02-21 11:04:45 +0000189#if defined(CONFIG_PM_OPP) && defined(CONFIG_OF)
Viresh Kumar8f8d37b2015-09-04 13:47:24 +0530190int dev_pm_opp_of_add_table(struct device *dev);
191void dev_pm_opp_of_remove_table(struct device *dev);
192int dev_pm_opp_of_cpumask_add_table(cpumask_var_t cpumask);
193void dev_pm_opp_of_cpumask_remove_table(cpumask_var_t cpumask);
194int dev_pm_opp_of_get_sharing_cpus(struct device *cpu_dev, cpumask_var_t cpumask);
Shawn Guod6561bb2013-02-21 11:04:45 +0000195#else
Viresh Kumar8f8d37b2015-09-04 13:47:24 +0530196static inline int dev_pm_opp_of_add_table(struct device *dev)
Shawn Guod6561bb2013-02-21 11:04:45 +0000197{
Viresh Kumard708b382016-04-27 08:52:21 +0530198 return -ENOTSUPP;
Shawn Guod6561bb2013-02-21 11:04:45 +0000199}
Viresh Kumar129eec52014-11-27 08:54:06 +0530200
Viresh Kumar8f8d37b2015-09-04 13:47:24 +0530201static inline void dev_pm_opp_of_remove_table(struct device *dev)
Viresh Kumar129eec52014-11-27 08:54:06 +0530202{
203}
Viresh Kumar8d4d4e92015-06-12 17:10:38 +0530204
Viresh Kumar8f8d37b2015-09-04 13:47:24 +0530205static inline int dev_pm_opp_of_cpumask_add_table(cpumask_var_t cpumask)
Viresh Kumar8d4d4e92015-06-12 17:10:38 +0530206{
Viresh Kumard708b382016-04-27 08:52:21 +0530207 return -ENOTSUPP;
Viresh Kumar8d4d4e92015-06-12 17:10:38 +0530208}
209
Viresh Kumar8f8d37b2015-09-04 13:47:24 +0530210static inline void dev_pm_opp_of_cpumask_remove_table(cpumask_var_t cpumask)
Viresh Kumar8d4d4e92015-06-12 17:10:38 +0530211{
212}
213
Viresh Kumar8f8d37b2015-09-04 13:47:24 +0530214static inline int dev_pm_opp_of_get_sharing_cpus(struct device *cpu_dev, cpumask_var_t cpumask)
Viresh Kumar8d4d4e92015-06-12 17:10:38 +0530215{
Viresh Kumard708b382016-04-27 08:52:21 +0530216 return -ENOTSUPP;
Viresh Kumar8d4d4e92015-06-12 17:10:38 +0530217}
Shawn Guod6561bb2013-02-21 11:04:45 +0000218#endif
219
Nishanth Menone1f60b22010-10-13 00:13:10 +0200220#endif /* __LINUX_OPP_H__ */