Commit 84248e35 authored by Rafael J. Wysocki's avatar Rafael J. Wysocki
Browse files

thermal: gov_bang_bang: Split bang_bang_control()



Move the setting of the thermal instance target state from
bang_bang_control() into a separate function that will be also called
in a different place going forward.

No intentional functional impact.

Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
Acked-by: default avatarPeter Kästle <peter@piie.net>
Reviewed-by: default avatarZhang Rui <rui.zhang@intel.com>
Cc: 6.10+ <stable@vger.kernel.org> # 6.10+
Link: https://patch.msgid.link/3313587.aeNJFYEL58@rjwysocki.net
parent b9b6ee6f
Loading
Loading
Loading
Loading
+23 −19
Original line number Diff line number Diff line
@@ -13,6 +13,27 @@

#include "thermal_core.h"

static void bang_bang_set_instance_target(struct thermal_instance *instance,
					  unsigned int target)
{
	if (instance->target != 0 && instance->target != 1 &&
	    instance->target != THERMAL_NO_TARGET)
		pr_debug("Unexpected state %ld of thermal instance %s in bang-bang\n",
			 instance->target, instance->name);

	/*
	 * Enable the fan when the trip is crossed on the way up and disable it
	 * when the trip is crossed on the way down.
	 */
	instance->target = target;

	dev_dbg(&instance->cdev->device, "target=%ld\n", instance->target);

	mutex_lock(&instance->cdev->lock);
	__thermal_cdev_update(instance->cdev);
	mutex_unlock(&instance->cdev->lock);
}

/**
 * bang_bang_control - controls devices associated with the given zone
 * @tz: thermal_zone_device
@@ -54,25 +75,8 @@ static void bang_bang_control(struct thermal_zone_device *tz,
		tz->temperature, trip->hysteresis);

	list_for_each_entry(instance, &tz->thermal_instances, tz_node) {
		if (instance->trip != trip)
			continue;

		if (instance->target != 0 && instance->target != 1 &&
		    instance->target != THERMAL_NO_TARGET)
			pr_debug("Unexpected state %ld of thermal instance %s in bang-bang\n",
				 instance->target, instance->name);

		/*
		 * Enable the fan when the trip is crossed on the way up and
		 * disable it when the trip is crossed on the way down.
		 */
		instance->target = crossed_up;

		dev_dbg(&instance->cdev->device, "target=%ld\n", instance->target);

		mutex_lock(&instance->cdev->lock);
		__thermal_cdev_update(instance->cdev);
		mutex_unlock(&instance->cdev->lock);
		if (instance->trip == trip)
			bang_bang_set_instance_target(instance, crossed_up);
	}
}