Commit da781936 authored by Nikita Travkin's avatar Nikita Travkin Committed by Rafael J. Wysocki

thermal: gov_power_allocator: Allow binding without trip points

IPA probe function was recently refactored to perform extra error checks
and make sure the thermal zone has trip points necessary for the IPA
operation. With this change, if a thermal zone is probed such that it
has no trip points that IPA can use, IPA will fail and the TZ won't be
created. This is the case if a platform defines a TZ without cooling
devices and only with "hot"/"critical" trip points, often found on some
Qualcomm devices [1].

Documentation across IPA code (notably get_governor_trips() kerneldoc)
suggests that IPA is supposed to handle such TZ even if it won't
actually do anything.

This commit partially reverts the previous change to allow IPA to bind
to such "empty" thermal zones.

Fixes: e83747c2 ("thermal: gov_power_allocator: Set up trip points earlier")
Link: arch/arm64/boot/dts/qcom/sc7180.dtsi#n4776 # [1]
Signed-off-by: default avatarNikita Travkin <nikita@trvn.ru>
Reviewed-by: default avatarLukasz Luba <lukasz.luba@arm.com>
Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
parent 1057c4c3
...@@ -679,11 +679,6 @@ static int power_allocator_bind(struct thermal_zone_device *tz) ...@@ -679,11 +679,6 @@ static int power_allocator_bind(struct thermal_zone_device *tz)
return -ENOMEM; return -ENOMEM;
get_governor_trips(tz, params); get_governor_trips(tz, params);
if (!params->trip_max) {
dev_warn(&tz->device, "power_allocator: missing trip_max\n");
kfree(params);
return -EINVAL;
}
ret = check_power_actors(tz, params); ret = check_power_actors(tz, params);
if (ret < 0) { if (ret < 0) {
...@@ -714,9 +709,10 @@ static int power_allocator_bind(struct thermal_zone_device *tz) ...@@ -714,9 +709,10 @@ static int power_allocator_bind(struct thermal_zone_device *tz)
else else
params->sustainable_power = tz->tzp->sustainable_power; params->sustainable_power = tz->tzp->sustainable_power;
estimate_pid_constants(tz, tz->tzp->sustainable_power, if (params->trip_max)
params->trip_switch_on, estimate_pid_constants(tz, tz->tzp->sustainable_power,
params->trip_max->temperature); params->trip_switch_on,
params->trip_max->temperature);
reset_pid_controller(params); reset_pid_controller(params);
......
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