thermal: Fix binding problem when there is thermal zone params
The thermal zone params can be used to set governor to specific thermal governor for thermal zone device. But if the thermal zone params has only governor name without thermal bind params, then the thermal zone device will not be binding to cooling device. Because tz->ops->bind operator is not invoked in bind_tz() and bind_cdev() when there is thermal zone params. Signed-off-by: Wei Ni <wni@nvidia.com> Signed-off-by: Jinyoung Park <jinyoungp@nvidia.com> Signed-off-by: Zhang Rui <rui.zhang@intel.com>
This commit is contained in:
parent
73b9bcd76d
commit
a9f2d19ba7
1 changed files with 4 additions and 3 deletions
|
@ -247,10 +247,11 @@ static void bind_cdev(struct thermal_cooling_device *cdev)
|
|||
if (!pos->tzp && !pos->ops->bind)
|
||||
continue;
|
||||
|
||||
if (!pos->tzp && pos->ops->bind) {
|
||||
if (pos->ops->bind) {
|
||||
ret = pos->ops->bind(pos, cdev);
|
||||
if (ret)
|
||||
print_bind_err_msg(pos, cdev, ret);
|
||||
continue;
|
||||
}
|
||||
|
||||
tzp = pos->tzp;
|
||||
|
@ -282,8 +283,8 @@ static void bind_tz(struct thermal_zone_device *tz)
|
|||
|
||||
mutex_lock(&thermal_list_lock);
|
||||
|
||||
/* If there is no platform data, try to use ops->bind */
|
||||
if (!tzp && tz->ops->bind) {
|
||||
/* If there is ops->bind, try to use ops->bind */
|
||||
if (tz->ops->bind) {
|
||||
list_for_each_entry(pos, &thermal_cdev_list, node) {
|
||||
ret = tz->ops->bind(tz, pos);
|
||||
if (ret)
|
||||
|
|
Loading…
Reference in a new issue