| /* |
| * linux/include/linux/cpu_cooling.h |
| * |
| * Copyright (C) 2012 Samsung Electronics Co., Ltd(http://www.samsung.com) |
| * Copyright (C) 2012 Amit Daniel <amit.kachhap@linaro.org> |
| * |
| * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |
| * This program is free software; you can redistribute it and/or modify |
| * it under the terms of the GNU General Public License as published by |
| * the Free Software Foundation; version 2 of the License. |
| * |
| * This program is distributed in the hope that it will be useful, but |
| * WITHOUT ANY WARRANTY; without even the implied warranty of |
| * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
| * General Public License for more details. |
| * |
| * You should have received a copy of the GNU General Public License along |
| * with this program; if not, write to the Free Software Foundation, Inc., |
| * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. |
| * |
| * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ |
| */ |
| |
| #ifndef __CPU_COOLING_H__ |
| #define __CPU_COOLING_H__ |
| |
| #include <linux/of.h> |
| #include <linux/thermal.h> |
| #include <linux/cpumask.h> |
| |
| typedef int (*get_static_t)(cpumask_t *cpumask, int interval, |
| unsigned long voltage, u32 *power); |
| |
| /** |
| * struct cpufreq_cooling_device - data for cooling device with cpufreq |
| * @id: unique integer value corresponding to each cpufreq_cooling_device |
| * registered. |
| * @cool_dev: thermal_cooling_device pointer to keep track of the |
| * registered cooling device. |
| * @cpufreq_state: integer value representing the current state of cpufreq |
| * cooling devices. |
| * @clipped_freq: integer value representing the absolute value of the clipped |
| * frequency. |
| * @max_level: maximum cooling level. One less than total number of valid |
| * cpufreq frequencies. |
| * @allowed_cpus: all the cpus involved for this cpufreq_cooling_device. |
| * @node: list_head to link all cpufreq_cooling_device together. |
| * @last_load: load measured by the latest call to cpufreq_get_actual_power() |
| * @time_in_idle: previous reading of the absolute time that this cpu was idle |
| * @time_in_idle_timestamp: wall time of the last invocation of |
| * get_cpu_idle_time_us() |
| * @dyn_power_table: array of struct power_table for frequency to power |
| * conversion, sorted in ascending order. |
| * @dyn_power_table_entries: number of entries in the @dyn_power_table array |
| * @cpu_dev: the first cpu_device from @allowed_cpus that has OPPs registered |
| * @plat_get_static_power: callback to calculate the static power |
| * |
| * This structure is required for keeping information of each registered |
| * cpufreq_cooling_device. |
| */ |
| struct cpufreq_cooling_device { |
| int id; |
| struct thermal_cooling_device *cool_dev; |
| unsigned int cpufreq_state; |
| unsigned int clipped_freq; |
| unsigned int max_level; |
| unsigned int *freq_table; /* In descending order */ |
| struct cpumask allowed_cpus; |
| struct cpumask target_cpus; |
| struct list_head node; |
| u32 last_load; |
| u64 *time_in_idle; |
| u64 *time_in_idle_timestamp; |
| struct power_table *dyn_power_table; |
| int dyn_power_table_entries; |
| struct device *cpu_dev; |
| get_static_t plat_get_static_power; |
| int *var_table; |
| int *var_coeff; |
| int *asv_coeff; |
| unsigned int var_volt_size; |
| unsigned int var_temp_size; |
| }; |
| |
| #ifdef CONFIG_CPU_THERMAL |
| /** |
| * cpufreq_cooling_register - function to create cpufreq cooling device. |
| * @clip_cpus: cpumask of cpus where the frequency constraints will happen |
| */ |
| struct thermal_cooling_device * |
| cpufreq_cooling_register(const struct cpumask *clip_cpus); |
| |
| struct thermal_cooling_device * |
| cpufreq_power_cooling_register(const struct cpumask *clip_cpus, |
| u32 capacitance, get_static_t plat_static_func); |
| |
| /** |
| * of_cpufreq_cooling_register - create cpufreq cooling device based on DT. |
| * @np: a valid struct device_node to the cooling device device tree node. |
| * @clip_cpus: cpumask of cpus where the frequency constraints will happen |
| */ |
| #ifdef CONFIG_THERMAL_OF |
| struct thermal_cooling_device * |
| of_cpufreq_cooling_register(struct device_node *np, |
| const struct cpumask *clip_cpus); |
| |
| struct thermal_cooling_device * |
| of_cpufreq_power_cooling_register(struct device_node *np, |
| const struct cpumask *clip_cpus, |
| u32 capacitance, |
| get_static_t plat_static_func); |
| #else |
| static inline struct thermal_cooling_device * |
| of_cpufreq_cooling_register(struct device_node *np, |
| const struct cpumask *clip_cpus) |
| { |
| return ERR_PTR(-ENOSYS); |
| } |
| |
| static inline struct thermal_cooling_device * |
| of_cpufreq_power_cooling_register(struct device_node *np, |
| const struct cpumask *clip_cpus, |
| u32 capacitance, |
| get_static_t plat_static_func) |
| { |
| return NULL; |
| } |
| #endif |
| |
| /** |
| * cpufreq_cooling_unregister - function to remove cpufreq cooling device. |
| * @cdev: thermal cooling device pointer. |
| */ |
| void cpufreq_cooling_unregister(struct thermal_cooling_device *cdev); |
| |
| unsigned long cpufreq_cooling_get_level(unsigned int cpu, unsigned int freq); |
| #else /* !CONFIG_CPU_THERMAL */ |
| static inline struct thermal_cooling_device * |
| cpufreq_cooling_register(const struct cpumask *clip_cpus) |
| { |
| return ERR_PTR(-ENOSYS); |
| } |
| static inline struct thermal_cooling_device * |
| cpufreq_power_cooling_register(const struct cpumask *clip_cpus, |
| u32 capacitance, get_static_t plat_static_func) |
| { |
| return NULL; |
| } |
| |
| static inline struct thermal_cooling_device * |
| of_cpufreq_cooling_register(struct device_node *np, |
| const struct cpumask *clip_cpus) |
| { |
| return ERR_PTR(-ENOSYS); |
| } |
| |
| static inline struct thermal_cooling_device * |
| of_cpufreq_power_cooling_register(struct device_node *np, |
| const struct cpumask *clip_cpus, |
| u32 capacitance, |
| get_static_t plat_static_func) |
| { |
| return NULL; |
| } |
| |
| static inline |
| void cpufreq_cooling_unregister(struct thermal_cooling_device *cdev) |
| { |
| return; |
| } |
| static inline |
| unsigned long cpufreq_cooling_get_level(unsigned int cpu, unsigned int freq) |
| { |
| return THERMAL_CSTATE_INVALID; |
| } |
| #endif /* CONFIG_CPU_THERMAL */ |
| |
| #endif /* __CPU_COOLING_H__ */ |