blob: 15f554443b599cc3d8d6c36a18ceb92dafee2070 [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 Kumardde370b2016-04-27 08:52:22 +053068int dev_pm_opp_set_sharing_cpus(struct device *cpu_dev, const cpumask_var_t cpumask);
Viresh Kumar6f707da2016-04-27 08:52:23 +053069int dev_pm_opp_get_sharing_cpus(struct device *cpu_dev, cpumask_var_t cpumask);
Nishanth Menone1f60b22010-10-13 00:13:10 +020070#else
Nishanth Menon47d43ba2013-09-19 16:03:51 -050071static inline unsigned long dev_pm_opp_get_voltage(struct dev_pm_opp *opp)
Nishanth Menone1f60b22010-10-13 00:13:10 +020072{
73 return 0;
74}
75
Nishanth Menon47d43ba2013-09-19 16:03:51 -050076static inline unsigned long dev_pm_opp_get_freq(struct dev_pm_opp *opp)
Nishanth Menone1f60b22010-10-13 00:13:10 +020077{
78 return 0;
79}
80
Bartlomiej Zolnierkiewicz19445b22015-07-09 17:43:35 +020081static inline bool dev_pm_opp_is_turbo(struct dev_pm_opp *opp)
82{
83 return false;
84}
85
Nishanth Menon5d4879c2013-09-19 16:03:50 -050086static inline int dev_pm_opp_get_opp_count(struct device *dev)
Nishanth Menone1f60b22010-10-13 00:13:10 +020087{
88 return 0;
89}
90
Viresh Kumar3ca9bb32015-07-29 16:23:03 +053091static inline unsigned long dev_pm_opp_get_max_clock_latency(struct device *dev)
92{
93 return 0;
94}
95
Viresh Kumar655c9df2016-02-09 10:30:35 +053096static inline unsigned long dev_pm_opp_get_max_volt_latency(struct device *dev)
97{
98 return 0;
99}
100
Viresh Kumar21743442016-02-09 10:30:36 +0530101static inline unsigned long dev_pm_opp_get_max_transition_latency(struct device *dev)
102{
103 return 0;
104}
105
Bartlomiej Zolnierkiewicz4eafbd12015-09-08 18:41:01 +0200106static inline struct dev_pm_opp *dev_pm_opp_get_suspend_opp(struct device *dev)
107{
108 return NULL;
109}
110
Nishanth Menon47d43ba2013-09-19 16:03:51 -0500111static inline struct dev_pm_opp *dev_pm_opp_find_freq_exact(struct device *dev,
Nishanth Menone1f60b22010-10-13 00:13:10 +0200112 unsigned long freq, bool available)
113{
Viresh Kumard708b382016-04-27 08:52:21 +0530114 return ERR_PTR(-ENOTSUPP);
Nishanth Menone1f60b22010-10-13 00:13:10 +0200115}
116
Nishanth Menon47d43ba2013-09-19 16:03:51 -0500117static inline struct dev_pm_opp *dev_pm_opp_find_freq_floor(struct device *dev,
Nishanth Menone1f60b22010-10-13 00:13:10 +0200118 unsigned long *freq)
119{
Viresh Kumard708b382016-04-27 08:52:21 +0530120 return ERR_PTR(-ENOTSUPP);
Nishanth Menone1f60b22010-10-13 00:13:10 +0200121}
122
Nishanth Menon47d43ba2013-09-19 16:03:51 -0500123static inline struct dev_pm_opp *dev_pm_opp_find_freq_ceil(struct device *dev,
Nishanth Menone1f60b22010-10-13 00:13:10 +0200124 unsigned long *freq)
125{
Viresh Kumard708b382016-04-27 08:52:21 +0530126 return ERR_PTR(-ENOTSUPP);
Nishanth Menone1f60b22010-10-13 00:13:10 +0200127}
128
Nishanth Menon5d4879c2013-09-19 16:03:50 -0500129static inline int dev_pm_opp_add(struct device *dev, unsigned long freq,
Nishanth Menone1f60b22010-10-13 00:13:10 +0200130 unsigned long u_volt)
131{
Viresh Kumard708b382016-04-27 08:52:21 +0530132 return -ENOTSUPP;
Nishanth Menone1f60b22010-10-13 00:13:10 +0200133}
134
Viresh Kumar129eec52014-11-27 08:54:06 +0530135static inline void dev_pm_opp_remove(struct device *dev, unsigned long freq)
136{
137}
138
Nishanth Menon5d4879c2013-09-19 16:03:50 -0500139static inline int dev_pm_opp_enable(struct device *dev, unsigned long freq)
Nishanth Menone1f60b22010-10-13 00:13:10 +0200140{
141 return 0;
142}
143
Nishanth Menon5d4879c2013-09-19 16:03:50 -0500144static inline int dev_pm_opp_disable(struct device *dev, unsigned long freq)
Nishanth Menone1f60b22010-10-13 00:13:10 +0200145{
146 return 0;
147}
MyungJoo Ham03ca3702011-09-30 22:35:12 +0200148
Nishanth Menon5d4879c2013-09-19 16:03:50 -0500149static inline struct srcu_notifier_head *dev_pm_opp_get_notifier(
150 struct device *dev)
MyungJoo Ham03ca3702011-09-30 22:35:12 +0200151{
Viresh Kumard708b382016-04-27 08:52:21 +0530152 return ERR_PTR(-ENOTSUPP);
MyungJoo Ham03ca3702011-09-30 22:35:12 +0200153}
Viresh Kumar7de36b02015-12-09 08:01:46 +0530154
155static inline int dev_pm_opp_set_supported_hw(struct device *dev,
156 const u32 *versions,
157 unsigned int count)
158{
Viresh Kumard708b382016-04-27 08:52:21 +0530159 return -ENOTSUPP;
Viresh Kumar7de36b02015-12-09 08:01:46 +0530160}
161
162static inline void dev_pm_opp_put_supported_hw(struct device *dev) {}
163
Viresh Kumar01fb4d32015-12-09 08:01:47 +0530164static inline int dev_pm_opp_set_prop_name(struct device *dev, const char *name)
165{
Viresh Kumard708b382016-04-27 08:52:21 +0530166 return -ENOTSUPP;
Viresh Kumar01fb4d32015-12-09 08:01:47 +0530167}
168
169static inline void dev_pm_opp_put_prop_name(struct device *dev) {}
170
Viresh Kumar9f8ea962016-02-09 10:30:33 +0530171static inline int dev_pm_opp_set_regulator(struct device *dev, const char *name)
172{
Viresh Kumard708b382016-04-27 08:52:21 +0530173 return -ENOTSUPP;
Viresh Kumar9f8ea962016-02-09 10:30:33 +0530174}
175
176static inline void dev_pm_opp_put_regulator(struct device *dev) {}
177
Viresh Kumar6a0712f2016-02-09 10:30:39 +0530178static inline int dev_pm_opp_set_rate(struct device *dev, unsigned long target_freq)
179{
Viresh Kumard708b382016-04-27 08:52:21 +0530180 return -ENOTSUPP;
Viresh Kumar6a0712f2016-02-09 10:30:39 +0530181}
182
Viresh Kumardde370b2016-04-27 08:52:22 +0530183static inline int dev_pm_opp_set_sharing_cpus(struct device *cpu_dev, const cpumask_var_t cpumask)
Viresh Kumar642aa8c2016-04-21 14:28:55 +0530184{
Viresh Kumard708b382016-04-27 08:52:21 +0530185 return -ENOTSUPP;
Viresh Kumar642aa8c2016-04-21 14:28:55 +0530186}
187
Viresh Kumar6f707da2016-04-27 08:52:23 +0530188static inline int dev_pm_opp_get_sharing_cpus(struct device *cpu_dev, cpumask_var_t cpumask)
189{
190 return -EINVAL;
191}
192
Tony Lindgrena96d69d2011-11-03 10:12:27 +0100193#endif /* CONFIG_PM_OPP */
Nishanth Menone1f60b22010-10-13 00:13:10 +0200194
Shawn Guod6561bb2013-02-21 11:04:45 +0000195#if defined(CONFIG_PM_OPP) && defined(CONFIG_OF)
Viresh Kumar8f8d37b2015-09-04 13:47:24 +0530196int dev_pm_opp_of_add_table(struct device *dev);
197void dev_pm_opp_of_remove_table(struct device *dev);
198int dev_pm_opp_of_cpumask_add_table(cpumask_var_t cpumask);
199void dev_pm_opp_of_cpumask_remove_table(cpumask_var_t cpumask);
200int dev_pm_opp_of_get_sharing_cpus(struct device *cpu_dev, cpumask_var_t cpumask);
Shawn Guod6561bb2013-02-21 11:04:45 +0000201#else
Viresh Kumar8f8d37b2015-09-04 13:47:24 +0530202static inline int dev_pm_opp_of_add_table(struct device *dev)
Shawn Guod6561bb2013-02-21 11:04:45 +0000203{
Viresh Kumard708b382016-04-27 08:52:21 +0530204 return -ENOTSUPP;
Shawn Guod6561bb2013-02-21 11:04:45 +0000205}
Viresh Kumar129eec52014-11-27 08:54:06 +0530206
Viresh Kumar8f8d37b2015-09-04 13:47:24 +0530207static inline void dev_pm_opp_of_remove_table(struct device *dev)
Viresh Kumar129eec52014-11-27 08:54:06 +0530208{
209}
Viresh Kumar8d4d4e92015-06-12 17:10:38 +0530210
Viresh Kumar8f8d37b2015-09-04 13:47:24 +0530211static inline int dev_pm_opp_of_cpumask_add_table(cpumask_var_t cpumask)
Viresh Kumar8d4d4e92015-06-12 17:10:38 +0530212{
Viresh Kumard708b382016-04-27 08:52:21 +0530213 return -ENOTSUPP;
Viresh Kumar8d4d4e92015-06-12 17:10:38 +0530214}
215
Viresh Kumar8f8d37b2015-09-04 13:47:24 +0530216static inline void dev_pm_opp_of_cpumask_remove_table(cpumask_var_t cpumask)
Viresh Kumar8d4d4e92015-06-12 17:10:38 +0530217{
218}
219
Viresh Kumar8f8d37b2015-09-04 13:47:24 +0530220static inline int dev_pm_opp_of_get_sharing_cpus(struct device *cpu_dev, cpumask_var_t cpumask)
Viresh Kumar8d4d4e92015-06-12 17:10:38 +0530221{
Viresh Kumard708b382016-04-27 08:52:21 +0530222 return -ENOTSUPP;
Viresh Kumar8d4d4e92015-06-12 17:10:38 +0530223}
Shawn Guod6561bb2013-02-21 11:04:45 +0000224#endif
225
Nishanth Menone1f60b22010-10-13 00:13:10 +0200226#endif /* __LINUX_OPP_H__ */