thermal: of: fix cooling device weights in device tree

Currently you can specify the weight of the cooling device in the device
tree but that information is not populated to the
thermal_bind_params where the fair share governor expects it to
be.  The of thermal zone device doesn't have a thermal_bind_params
structure and arguably it's better to pass the weight inside the
thermal_instance as it is specific to the bind of a cooling device to a
thermal zone parameter.

Core thermal code is fixed to populate the weight in the instance from
the thermal_bind_params, so platform code that was passing the weight
inside the thermal_bind_params continue to work seamlessly.

While we are at it, create a default value for the weight parameter for
those thermal zones that currently don't define it and remove the
hardcoded default in of-thermal.

Cc: Zhang Rui <rui.zhang@intel.com>
Cc: "Rafael J. Wysocki" <rjw@rjwysocki.net>
Cc: Len Brown <lenb@kernel.org>
Cc: Peter Feuerer <peter@piie.net>
Cc: Darren Hart <dvhart@infradead.org>
Cc: Eduardo Valentin <edubezval@gmail.com>
Cc: Kukjin Kim <kgene@kernel.org>
Cc: Durgadoss R <durgadoss.r@intel.com>
Signed-off-by: Kapileshwar Singh <kapileshwar.singh@arm.com>
Signed-off-by: Eduardo Valentin <edubezval@gmail.com>
This commit is contained in:
Kapileshwar Singh 2015-02-18 16:04:21 +00:00 committed by Eduardo Valentin
parent 5ebe6afaf0
commit 6cd9e9f629
11 changed files with 42 additions and 18 deletions

View File

@ -95,7 +95,7 @@ temperature) and throttle appropriate devices.
1.3 interface for binding a thermal zone device with a thermal cooling device 1.3 interface for binding a thermal zone device with a thermal cooling device
1.3.1 int thermal_zone_bind_cooling_device(struct thermal_zone_device *tz, 1.3.1 int thermal_zone_bind_cooling_device(struct thermal_zone_device *tz,
int trip, struct thermal_cooling_device *cdev, int trip, struct thermal_cooling_device *cdev,
unsigned long upper, unsigned long lower); unsigned long upper, unsigned long lower, unsigned int weight);
This interface function bind a thermal cooling device to the certain trip This interface function bind a thermal cooling device to the certain trip
point of a thermal zone device. point of a thermal zone device.
@ -110,6 +110,8 @@ temperature) and throttle appropriate devices.
lower:the Minimum cooling state can be used for this trip point. lower:the Minimum cooling state can be used for this trip point.
THERMAL_NO_LIMIT means no lower limit, THERMAL_NO_LIMIT means no lower limit,
and the cooling device can be in cooling state 0. and the cooling device can be in cooling state 0.
weight: the influence of this cooling device in this thermal
zone. See 1.4.1 below for more information.
1.3.2 int thermal_zone_unbind_cooling_device(struct thermal_zone_device *tz, 1.3.2 int thermal_zone_unbind_cooling_device(struct thermal_zone_device *tz,
int trip, struct thermal_cooling_device *cdev); int trip, struct thermal_cooling_device *cdev);

View File

@ -800,7 +800,8 @@ static int acpi_thermal_cooling_device_cb(struct thermal_zone_device *thermal,
result = result =
thermal_zone_bind_cooling_device thermal_zone_bind_cooling_device
(thermal, trip, cdev, (thermal, trip, cdev,
THERMAL_NO_LIMIT, THERMAL_NO_LIMIT); THERMAL_NO_LIMIT, THERMAL_NO_LIMIT,
THERMAL_WEIGHT_DEFAULT);
else else
result = result =
thermal_zone_unbind_cooling_device thermal_zone_unbind_cooling_device
@ -824,7 +825,8 @@ static int acpi_thermal_cooling_device_cb(struct thermal_zone_device *thermal,
if (bind) if (bind)
result = thermal_zone_bind_cooling_device result = thermal_zone_bind_cooling_device
(thermal, trip, cdev, (thermal, trip, cdev,
THERMAL_NO_LIMIT, THERMAL_NO_LIMIT); THERMAL_NO_LIMIT, THERMAL_NO_LIMIT,
THERMAL_WEIGHT_DEFAULT);
else else
result = thermal_zone_unbind_cooling_device result = thermal_zone_unbind_cooling_device
(thermal, trip, cdev); (thermal, trip, cdev);
@ -841,7 +843,8 @@ static int acpi_thermal_cooling_device_cb(struct thermal_zone_device *thermal,
result = thermal_zone_bind_cooling_device result = thermal_zone_bind_cooling_device
(thermal, THERMAL_TRIPS_NONE, (thermal, THERMAL_TRIPS_NONE,
cdev, THERMAL_NO_LIMIT, cdev, THERMAL_NO_LIMIT,
THERMAL_NO_LIMIT); THERMAL_NO_LIMIT,
THERMAL_WEIGHT_DEFAULT);
else else
result = thermal_zone_unbind_cooling_device result = thermal_zone_unbind_cooling_device
(thermal, THERMAL_TRIPS_NONE, (thermal, THERMAL_TRIPS_NONE,

View File

@ -372,7 +372,8 @@ static int acerhdf_bind(struct thermal_zone_device *thermal,
return 0; return 0;
if (thermal_zone_bind_cooling_device(thermal, 0, cdev, if (thermal_zone_bind_cooling_device(thermal, 0, cdev,
THERMAL_NO_LIMIT, THERMAL_NO_LIMIT)) { THERMAL_NO_LIMIT, THERMAL_NO_LIMIT,
THERMAL_WEIGHT_DEFAULT)) {
pr_err("error binding cooling dev\n"); pr_err("error binding cooling dev\n");
return -EINVAL; return -EINVAL;
} }

View File

@ -76,7 +76,7 @@ static int db8500_cdev_bind(struct thermal_zone_device *thermal,
upper = lower = i > max_state ? max_state : i; upper = lower = i > max_state ? max_state : i;
ret = thermal_zone_bind_cooling_device(thermal, i, cdev, ret = thermal_zone_bind_cooling_device(thermal, i, cdev,
upper, lower); upper, lower, THERMAL_WEIGHT_DEFAULT);
dev_info(&cdev->device, "%s bind to %d: %d-%s\n", cdev->type, dev_info(&cdev->device, "%s bind to %d: %d-%s\n", cdev->type,
i, ret, ret ? "fail" : "succeed"); i, ret, ret ? "fail" : "succeed");

View File

@ -109,7 +109,7 @@ static int fair_share_throttle(struct thermal_zone_device *tz, int trip)
continue; continue;
instance->target = get_target_state(tz, cdev, instance->target = get_target_state(tz, cdev,
tzp->tbp[i].weight, cur_trip_level); instance->weight, cur_trip_level);
instance->cdev->updated = false; instance->cdev->updated = false;
thermal_cdev_update(cdev); thermal_cdev_update(cdev);

View File

@ -306,7 +306,8 @@ static int imx_bind(struct thermal_zone_device *tz,
ret = thermal_zone_bind_cooling_device(tz, IMX_TRIP_PASSIVE, cdev, ret = thermal_zone_bind_cooling_device(tz, IMX_TRIP_PASSIVE, cdev,
THERMAL_NO_LIMIT, THERMAL_NO_LIMIT,
THERMAL_NO_LIMIT); THERMAL_NO_LIMIT,
THERMAL_WEIGHT_DEFAULT);
if (ret) { if (ret) {
dev_err(&tz->device, dev_err(&tz->device,
"binding zone %s with cdev %s failed:%d\n", "binding zone %s with cdev %s failed:%d\n",

View File

@ -227,7 +227,8 @@ static int of_thermal_bind(struct thermal_zone_device *thermal,
ret = thermal_zone_bind_cooling_device(thermal, ret = thermal_zone_bind_cooling_device(thermal,
tbp->trip_id, cdev, tbp->trip_id, cdev,
tbp->max, tbp->max,
tbp->min); tbp->min,
tbp->usage);
if (ret) if (ret)
return ret; return ret;
} }
@ -581,7 +582,7 @@ static int thermal_of_populate_bind_params(struct device_node *np,
u32 prop; u32 prop;
/* Default weight. Usage is optional */ /* Default weight. Usage is optional */
__tbp->usage = 0; __tbp->usage = THERMAL_WEIGHT_DEFAULT;
ret = of_property_read_u32(np, "contribution", &prop); ret = of_property_read_u32(np, "contribution", &prop);
if (ret == 0) if (ret == 0)
__tbp->usage = prop; __tbp->usage = prop;

View File

@ -218,7 +218,8 @@ static void print_bind_err_msg(struct thermal_zone_device *tz,
static void __bind(struct thermal_zone_device *tz, int mask, static void __bind(struct thermal_zone_device *tz, int mask,
struct thermal_cooling_device *cdev, struct thermal_cooling_device *cdev,
unsigned long *limits) unsigned long *limits,
unsigned int weight)
{ {
int i, ret; int i, ret;
@ -233,7 +234,8 @@ static void __bind(struct thermal_zone_device *tz, int mask,
upper = limits[i * 2 + 1]; upper = limits[i * 2 + 1];
} }
ret = thermal_zone_bind_cooling_device(tz, i, cdev, ret = thermal_zone_bind_cooling_device(tz, i, cdev,
upper, lower); upper, lower,
weight);
if (ret) if (ret)
print_bind_err_msg(tz, cdev, ret); print_bind_err_msg(tz, cdev, ret);
} }
@ -280,7 +282,8 @@ static void bind_cdev(struct thermal_cooling_device *cdev)
continue; continue;
tzp->tbp[i].cdev = cdev; tzp->tbp[i].cdev = cdev;
__bind(pos, tzp->tbp[i].trip_mask, cdev, __bind(pos, tzp->tbp[i].trip_mask, cdev,
tzp->tbp[i].binding_limits); tzp->tbp[i].binding_limits,
tzp->tbp[i].weight);
} }
} }
@ -319,7 +322,8 @@ static void bind_tz(struct thermal_zone_device *tz)
continue; continue;
tzp->tbp[i].cdev = pos; tzp->tbp[i].cdev = pos;
__bind(tz, tzp->tbp[i].trip_mask, pos, __bind(tz, tzp->tbp[i].trip_mask, pos,
tzp->tbp[i].binding_limits); tzp->tbp[i].binding_limits,
tzp->tbp[i].weight);
} }
} }
exit: exit:
@ -713,7 +717,8 @@ passive_store(struct device *dev, struct device_attribute *attr,
thermal_zone_bind_cooling_device(tz, thermal_zone_bind_cooling_device(tz,
THERMAL_TRIPS_NONE, cdev, THERMAL_TRIPS_NONE, cdev,
THERMAL_NO_LIMIT, THERMAL_NO_LIMIT,
THERMAL_NO_LIMIT); THERMAL_NO_LIMIT,
THERMAL_WEIGHT_DEFAULT);
} }
mutex_unlock(&thermal_list_lock); mutex_unlock(&thermal_list_lock);
if (!tz->passive_delay) if (!tz->passive_delay)
@ -931,6 +936,9 @@ static const struct attribute_group *cooling_device_attr_groups[] = {
* @lower: the Minimum cooling state can be used for this trip point. * @lower: the Minimum cooling state can be used for this trip point.
* THERMAL_NO_LIMIT means no lower limit, * THERMAL_NO_LIMIT means no lower limit,
* and the cooling device can be in cooling state 0. * and the cooling device can be in cooling state 0.
* @weight: The weight of the cooling device to be bound to the
* thermal zone. Use THERMAL_WEIGHT_DEFAULT for the
* default value
* *
* This interface function bind a thermal cooling device to the certain trip * This interface function bind a thermal cooling device to the certain trip
* point of a thermal zone device. * point of a thermal zone device.
@ -941,7 +949,8 @@ static const struct attribute_group *cooling_device_attr_groups[] = {
int thermal_zone_bind_cooling_device(struct thermal_zone_device *tz, int thermal_zone_bind_cooling_device(struct thermal_zone_device *tz,
int trip, int trip,
struct thermal_cooling_device *cdev, struct thermal_cooling_device *cdev,
unsigned long upper, unsigned long lower) unsigned long upper, unsigned long lower,
unsigned int weight)
{ {
struct thermal_instance *dev; struct thermal_instance *dev;
struct thermal_instance *pos; struct thermal_instance *pos;
@ -986,6 +995,7 @@ int thermal_zone_bind_cooling_device(struct thermal_zone_device *tz,
dev->upper = upper; dev->upper = upper;
dev->lower = lower; dev->lower = lower;
dev->target = THERMAL_NO_TARGET; dev->target = THERMAL_NO_TARGET;
dev->weight = weight;
result = get_idr(&tz->idr, &tz->lock, &dev->id); result = get_idr(&tz->idr, &tz->lock, &dev->id);
if (result) if (result)

View File

@ -48,6 +48,7 @@ struct thermal_instance {
struct device_attribute attr; struct device_attribute attr;
struct list_head tz_node; /* node in tz->thermal_instances */ struct list_head tz_node; /* node in tz->thermal_instances */
struct list_head cdev_node; /* node in cdev->thermal_instances */ struct list_head cdev_node; /* node in cdev->thermal_instances */
unsigned int weight; /* The weight of the cooling device */
}; };
int thermal_register_governor(struct thermal_governor *); int thermal_register_governor(struct thermal_governor *);

View File

@ -146,7 +146,8 @@ static int ti_thermal_bind(struct thermal_zone_device *thermal,
return thermal_zone_bind_cooling_device(thermal, 0, cdev, return thermal_zone_bind_cooling_device(thermal, 0, cdev,
/* bind with min and max states defined by cpu_cooling */ /* bind with min and max states defined by cpu_cooling */
THERMAL_NO_LIMIT, THERMAL_NO_LIMIT,
THERMAL_NO_LIMIT); THERMAL_NO_LIMIT,
THERMAL_WEIGHT_DEFAULT);
} }
/* Unbind callback functions for thermal zone */ /* Unbind callback functions for thermal zone */

View File

@ -40,6 +40,9 @@
/* No upper/lower limit requirement */ /* No upper/lower limit requirement */
#define THERMAL_NO_LIMIT ((u32)~0) #define THERMAL_NO_LIMIT ((u32)~0)
/* Default weight of a bound cooling device */
#define THERMAL_WEIGHT_DEFAULT 0
/* Unit conversion macros */ /* Unit conversion macros */
#define KELVIN_TO_CELSIUS(t) (long)(((long)t-2732 >= 0) ? \ #define KELVIN_TO_CELSIUS(t) (long)(((long)t-2732 >= 0) ? \
((long)t-2732+5)/10 : ((long)t-2732-5)/10) ((long)t-2732+5)/10 : ((long)t-2732-5)/10)
@ -323,7 +326,8 @@ void thermal_zone_device_unregister(struct thermal_zone_device *);
int thermal_zone_bind_cooling_device(struct thermal_zone_device *, int, int thermal_zone_bind_cooling_device(struct thermal_zone_device *, int,
struct thermal_cooling_device *, struct thermal_cooling_device *,
unsigned long, unsigned long); unsigned long, unsigned long,
unsigned int);
int thermal_zone_unbind_cooling_device(struct thermal_zone_device *, int, int thermal_zone_unbind_cooling_device(struct thermal_zone_device *, int,
struct thermal_cooling_device *); struct thermal_cooling_device *);
void thermal_zone_device_update(struct thermal_zone_device *); void thermal_zone_device_update(struct thermal_zone_device *);