diff options
author | Anson Huang <Anson.Huang@nxp.com> | 2018-07-30 18:56:49 +0200 |
---|---|---|
committer | Eduardo Valentin <edubezval@gmail.com> | 2018-08-20 21:00:40 +0200 |
commit | 152395fd03d4ce1e535a75cdbf58105e50587611 (patch) | |
tree | 3cd4e9f026c7072504e8cf867721c24a953b92da | |
parent | thermal: rcar_gen3_thermal: convert to SPDX identifiers (diff) | |
download | linux-152395fd03d4ce1e535a75cdbf58105e50587611.tar.xz linux-152395fd03d4ce1e535a75cdbf58105e50587611.zip |
thermal: of-thermal: disable passive polling when thermal zone is disabled
When thermal zone is in passive mode, disabling its mode from
sysfs is NOT taking effect at all, it is still polling the
temperature of the disabled thermal zone and handling all thermal
trips, it makes user confused. The disabling operation should
disable the thermal zone behavior completely, for both active and
passive mode, this patch clears the passive_delay when thermal
zone is disabled and restores it when it is enabled.
Signed-off-by: Anson Huang <Anson.Huang@nxp.com>
Signed-off-by: Eduardo Valentin <edubezval@gmail.com>
-rw-r--r-- | drivers/thermal/of-thermal.c | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/drivers/thermal/of-thermal.c b/drivers/thermal/of-thermal.c index 977a8307fbb1..4f2816559205 100644 --- a/drivers/thermal/of-thermal.c +++ b/drivers/thermal/of-thermal.c @@ -260,10 +260,13 @@ static int of_thermal_set_mode(struct thermal_zone_device *tz, mutex_lock(&tz->lock); - if (mode == THERMAL_DEVICE_ENABLED) + if (mode == THERMAL_DEVICE_ENABLED) { tz->polling_delay = data->polling_delay; - else + tz->passive_delay = data->passive_delay; + } else { tz->polling_delay = 0; + tz->passive_delay = 0; + } mutex_unlock(&tz->lock); |