blob: 11d4e1063dbb9b91e43b7a07cb97e166b13aa63c [file] [log] [blame]
#define pr_fmt(fmt) KBUILD_MODNAME ": " fmt
#include <linux/module.h>
#include <linux/thermal.h>
#include "thermal_core.h"
/**
* backward_compatible_throttle
* @tz - thermal_zone_device
*
* This function update the cooler state by monitoring the current temperature and trip points
*/
static int backward_compatible_throttle(struct thermal_zone_device *tz, int trip)
{
long trip_temp;
struct thermal_instance *instance;
if (trip == THERMAL_TRIPS_NONE) {
trip_temp = tz->forced_passive;
} else {
tz->ops->get_trip_temp(tz, trip, &trip_temp);
}
/* mutex_lock(&tz->lock); */
list_for_each_entry(instance, &tz->thermal_instances, tz_node) {
if (instance->trip != trip)
continue;
if (tz->temperature >= trip_temp)
instance->target = 1;
else
instance->target = 0;
instance->cdev->updated = false;
thermal_cdev_update(instance->cdev);
}
/* mutex_unlock(&tz->lock); */
return 0;
}
static struct thermal_governor thermal_gov_backward_compatible = {
.name = "backward_compatible",
.throttle = backward_compatible_throttle,
/* .owner = THIS_MODULE, */
};
static int __init thermal_gov_backward_compatible_init(void)
{
return thermal_register_governor(&thermal_gov_backward_compatible);
}
static void __exit thermal_gov_backward_compatible_exit(void)
{
thermal_unregister_governor(&thermal_gov_backward_compatible);
}
/* This should load after thermal framework */
fs_initcall(thermal_gov_backward_compatible_init);
module_exit(thermal_gov_backward_compatible_exit);
MODULE_AUTHOR("Weiyi Lu");
MODULE_DESCRIPTION("A backward compatible Thermal governor");
MODULE_LICENSE("GPL");