mirror of
https://github.com/edk2-porting/linux-next.git
synced 2025-01-01 00:54:15 +08:00
a4c428e523
The cpu idle cooling device offers a new method to cool down a CPU by injecting idle cycles at runtime. It has some similarities with the intel power clamp driver but it is actually designed to be more generic and relying on the idle injection powercap framework. The idle injection duration is fixed while the running duration is variable. That allows to have control on the device reactivity for the user experience. An idle state powering down the CPU or the cluster will allow to drop the static leakage, thus restoring the heat capacity of the SoC. It can be set with a trip point between the hot and the critical points, giving the opportunity to prevent a hard reset of the system when the cpufreq cooling fails to cool down the CPU. With more sophisticated boards having a per core sensor, the idle cooling device allows to cool down a single core without throttling the compute capacity of several cpus belonging to the same clock line, so it could be used in collaboration with the cpufreq cooling device. Signed-off-by: Daniel Lezcano <daniel.lezcano@linaro.org> Acked-by: Viresh Kumar <viresh.kumar@linaro.org> Link: https://lore.kernel.org/r/20191219225317.17158-2-daniel.lezcano@linaro.org
82 lines
2.1 KiB
C
82 lines
2.1 KiB
C
/* SPDX-License-Identifier: GPL-2.0-only */
|
|
/*
|
|
* 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>
|
|
*
|
|
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
*
|
|
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
*/
|
|
|
|
#ifndef __CPU_COOLING_H__
|
|
#define __CPU_COOLING_H__
|
|
|
|
#include <linux/of.h>
|
|
#include <linux/thermal.h>
|
|
#include <linux/cpumask.h>
|
|
|
|
struct cpufreq_policy;
|
|
|
|
#ifdef CONFIG_CPU_FREQ_THERMAL
|
|
/**
|
|
* cpufreq_cooling_register - function to create cpufreq cooling device.
|
|
* @policy: cpufreq policy.
|
|
*/
|
|
struct thermal_cooling_device *
|
|
cpufreq_cooling_register(struct cpufreq_policy *policy);
|
|
|
|
/**
|
|
* cpufreq_cooling_unregister - function to remove cpufreq cooling device.
|
|
* @cdev: thermal cooling device pointer.
|
|
*/
|
|
void cpufreq_cooling_unregister(struct thermal_cooling_device *cdev);
|
|
|
|
/**
|
|
* of_cpufreq_cooling_register - create cpufreq cooling device based on DT.
|
|
* @policy: cpufreq policy.
|
|
*/
|
|
struct thermal_cooling_device *
|
|
of_cpufreq_cooling_register(struct cpufreq_policy *policy);
|
|
|
|
#else /* !CONFIG_CPU_FREQ_THERMAL */
|
|
static inline struct thermal_cooling_device *
|
|
cpufreq_cooling_register(struct cpufreq_policy *policy)
|
|
{
|
|
return ERR_PTR(-ENOSYS);
|
|
}
|
|
|
|
static inline
|
|
void cpufreq_cooling_unregister(struct thermal_cooling_device *cdev)
|
|
{
|
|
return;
|
|
}
|
|
|
|
static inline struct thermal_cooling_device *
|
|
of_cpufreq_cooling_register(struct cpufreq_policy *policy)
|
|
{
|
|
return NULL;
|
|
}
|
|
#endif /* CONFIG_CPU_FREQ_THERMAL */
|
|
|
|
struct cpuidle_driver;
|
|
|
|
#ifdef CONFIG_CPU_IDLE_THERMAL
|
|
int cpuidle_cooling_register(struct cpuidle_driver *drv);
|
|
int cpuidle_of_cooling_register(struct device_node *np,
|
|
struct cpuidle_driver *drv);
|
|
#else /* CONFIG_CPU_IDLE_THERMAL */
|
|
static inline int cpuidle_cooling_register(struct cpuidle_driver *drv)
|
|
{
|
|
return 0;
|
|
}
|
|
static inline int cpuidle_of_cooling_register(struct device_node *np,
|
|
struct cpuidle_driver *drv)
|
|
{
|
|
return 0;
|
|
}
|
|
#endif /* CONFIG_CPU_IDLE_THERMAL */
|
|
|
|
#endif /* __CPU_COOLING_H__ */
|