[PATCH 06/15] thermal: sysfs: lock tz while on passive properties

From: Eduardo Valentin
Date: Tue May 31 2016 - 02:35:39 EST


Serialized calls to tz.ops in user facing
sysfs handler passive_store() and
passive_show().

Cc: Zhang Rui <rui.zhang@xxxxxxxxx>
Cc: linux-pm@xxxxxxxxxxxxxxx
Cc: linux-kernel@xxxxxxxxxxxxxxx
Signed-off-by: Eduardo Valentin <edubezval@xxxxxxxxx>
---
drivers/thermal/thermal_sysfs.c | 15 ++++++++++++++-
1 file changed, 14 insertions(+), 1 deletion(-)

diff --git a/drivers/thermal/thermal_sysfs.c b/drivers/thermal/thermal_sysfs.c
index afb42a2..dcaeb17 100644
--- a/drivers/thermal/thermal_sysfs.c
+++ b/drivers/thermal/thermal_sysfs.c
@@ -252,18 +252,24 @@ passive_store(struct device *dev, struct device_attribute *attr,
if (state && state < 1000)
return -EINVAL;

+ mutex_lock(&tz->lock);
if (state && !tz->forced_passive) {
if (!tz->passive_delay)
tz->passive_delay = 1000;
+ mutex_unlock(&tz->lock);
thermal_zone_device_rebind_exception(tz, "Processor",
sizeof("Processor"));
+ mutex_lock(&tz->lock);
} else if (!state && tz->forced_passive) {
tz->passive_delay = 0;
+ mutex_unlock(&tz->lock);
thermal_zone_device_unbind_exception(tz, "Processor",
sizeof("Processor"));
+ mutex_lock(&tz->lock);
}

tz->forced_passive = state;
+ mutex_unlock(&tz->lock);

thermal_zone_device_update(tz);

@@ -275,8 +281,13 @@ passive_show(struct device *dev, struct device_attribute *attr,
char *buf)
{
struct thermal_zone_device *tz = to_thermal_zone(dev);
+ unsigned int passive;

- return sprintf(buf, "%d\n", tz->forced_passive);
+ mutex_lock(&tz->lock);
+ passive = tz->forced_passive;
+ mutex_unlock(&tz->lock);
+
+ return sprintf(buf, "%u\n", passive);
}

static ssize_t
@@ -494,7 +505,9 @@ static umode_t thermal_zone_passive_is_visible(struct kobject *kobj,
tz = container_of(dev, struct thermal_zone_device, device);

for (count = 0; count < tz->trips; count++) {
+ mutex_lock(&tz->lock);
tz->ops->get_trip_type(tz, count, &trip_type);
+ mutex_unlock(&tz->lock);

if (trip_type == THERMAL_TRIP_PASSIVE)
return attr->mode;
--
2.1.4