Commit 184a4bf6 authored by Lukasz Majewski's avatar Lukasz Majewski Committed by Eduardo Valentin

thermal: of: Extend current of-thermal.c code to allow setting emulated temp

Before this change it was only possible to set get_temp() and get_trend()
methods to be used in the common code handling passing parameters via
device tree to "cpu-thermal" CPU thermal zone device.

Now it is possible to also set emulated value of temperature for debug
purposes.
Signed-off-by: default avatarLukasz Majewski <l.majewski@samsung.com>
Acked-by: default avatarEduardo Valentin <edubezval@gmail.com>
Signed-off-by: default avatarEduardo Valentin <edubezval@gmail.com>
parent ce8be778
...@@ -161,6 +161,28 @@ of_thermal_get_trip_points(struct thermal_zone_device *tz) ...@@ -161,6 +161,28 @@ of_thermal_get_trip_points(struct thermal_zone_device *tz)
} }
EXPORT_SYMBOL_GPL(of_thermal_get_trip_points); EXPORT_SYMBOL_GPL(of_thermal_get_trip_points);
/**
* of_thermal_set_emul_temp - function to set emulated temperature
*
* @tz: pointer to a thermal zone
* @temp: temperature to set
*
* This function gives the ability to set emulated value of temperature,
* which is handy for debugging
*
* Return: zero on success, error code otherwise
*/
static int of_thermal_set_emul_temp(struct thermal_zone_device *tz,
unsigned long temp)
{
struct __thermal_zone *data = tz->devdata;
if (!data->ops || !data->ops->set_emul_temp)
return -EINVAL;
return data->ops->set_emul_temp(data->sensor_data, temp);
}
static int of_thermal_get_trend(struct thermal_zone_device *tz, int trip, static int of_thermal_get_trend(struct thermal_zone_device *tz, int trip,
enum thermal_trend *trend) enum thermal_trend *trend)
{ {
...@@ -392,6 +414,7 @@ thermal_zone_of_add_sensor(struct device_node *zone, ...@@ -392,6 +414,7 @@ thermal_zone_of_add_sensor(struct device_node *zone,
tzd->ops->get_temp = of_thermal_get_temp; tzd->ops->get_temp = of_thermal_get_temp;
tzd->ops->get_trend = of_thermal_get_trend; tzd->ops->get_trend = of_thermal_get_trend;
tzd->ops->set_emul_temp = of_thermal_set_emul_temp;
mutex_unlock(&tzd->lock); mutex_unlock(&tzd->lock);
return tzd; return tzd;
...@@ -520,6 +543,7 @@ void thermal_zone_of_sensor_unregister(struct device *dev, ...@@ -520,6 +543,7 @@ void thermal_zone_of_sensor_unregister(struct device *dev,
mutex_lock(&tzd->lock); mutex_lock(&tzd->lock);
tzd->ops->get_temp = NULL; tzd->ops->get_temp = NULL;
tzd->ops->get_trend = NULL; tzd->ops->get_trend = NULL;
tzd->ops->set_emul_temp = NULL;
tz->ops = NULL; tz->ops = NULL;
tz->sensor_data = NULL; tz->sensor_data = NULL;
......
...@@ -297,10 +297,13 @@ struct thermal_genl_event { ...@@ -297,10 +297,13 @@ struct thermal_genl_event {
* *
* Optional: * Optional:
* @get_trend: a pointer to a function that reads the sensor temperature trend. * @get_trend: a pointer to a function that reads the sensor temperature trend.
* @set_emul_temp: a pointer to a function that sets sensor emulated
* temperature.
*/ */
struct thermal_zone_of_device_ops { struct thermal_zone_of_device_ops {
int (*get_temp)(void *, long *); int (*get_temp)(void *, long *);
int (*get_trend)(void *, long *); int (*get_trend)(void *, long *);
int (*set_emul_temp)(void *, unsigned long);
}; };
/** /**
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment