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

thermal: core: Clean up trip bind/unbind functions



Make thermal_bind_cdev_to_trip() take a struct cooling_spec pointer
to reduce the number of its arguments, change the return type of
thermal_unbind_cdev_from_trip() to void and rearrange the code in
thermal_zone_cdev_binding() to reduce the indentation level.

No intentional functional impact.

Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
Reviewed-by: default avatarZhang Rui <rui.zhang@intel.com>
Acked-by: default avatarHuisong Li <lihuisong@huawei.com>
Reviewed-by: default avatarDaniel Lezcano <daniel.lezcano@linaro.org>
Link: https://patch.msgid.link/1831773.TLkxdtWsSY@rjwysocki.net


[ rjw: Changed the name of a new function argument ]
Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
parent c579286a
Loading
Loading
Loading
Loading
+21 −33
Original line number Diff line number Diff line
@@ -765,15 +765,7 @@ struct thermal_zone_device *thermal_zone_get_by_id(int id)
 * @tz:		pointer to struct thermal_zone_device
 * @trip:	trip point the cooling devices is associated with in this zone.
 * @cdev:	pointer to struct thermal_cooling_device
 * @upper:	the Maximum cooling state for this trip point.
 *		THERMAL_NO_LIMIT means no upper limit,
 *		and the cooling device can be in max_state.
 * @lower:	the Minimum cooling state can be used for this trip point.
 *		THERMAL_NO_LIMIT means no lower limit,
 *		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
 * @cool_spec:	cooling specification for @trip and @cdev
 *
 * This interface function bind a thermal cooling device to the certain trip
 * point of a thermal zone device.
@@ -784,8 +776,7 @@ struct thermal_zone_device *thermal_zone_get_by_id(int id)
static int thermal_bind_cdev_to_trip(struct thermal_zone_device *tz,
				     const struct thermal_trip *trip,
				     struct thermal_cooling_device *cdev,
				     unsigned long upper, unsigned long lower,
				     unsigned int weight)
				     struct cooling_spec *cool_spec)
{
	struct thermal_instance *dev;
	struct thermal_instance *pos;
@@ -799,17 +790,17 @@ static int thermal_bind_cdev_to_trip(struct thermal_zone_device *tz,
		return -EINVAL;

	/* lower default 0, upper default max_state */
	if (lower == THERMAL_NO_LIMIT)
		lower = 0;
	if (cool_spec->lower == THERMAL_NO_LIMIT)
		cool_spec->lower = 0;

	if (upper == THERMAL_NO_LIMIT) {
		upper = cdev->max_state;
	if (cool_spec->upper == THERMAL_NO_LIMIT) {
		cool_spec->upper = cdev->max_state;
		upper_no_limit = true;
	} else {
		upper_no_limit = false;
	}

	if (lower > upper || upper > cdev->max_state)
	if (cool_spec->lower > cool_spec->upper || cool_spec->upper > cdev->max_state)
		return -EINVAL;

	dev = kzalloc(sizeof(*dev), GFP_KERNEL);
@@ -818,11 +809,11 @@ static int thermal_bind_cdev_to_trip(struct thermal_zone_device *tz,
	dev->tz = tz;
	dev->cdev = cdev;
	dev->trip = trip;
	dev->upper = upper;
	dev->upper = cool_spec->upper;
	dev->upper_no_limit = upper_no_limit;
	dev->lower = lower;
	dev->lower = cool_spec->lower;
	dev->target = THERMAL_NO_TARGET;
	dev->weight = weight;
	dev->weight = cool_spec->weight;

	result = ida_alloc(&tz->ida, GFP_KERNEL);
	if (result < 0)
@@ -895,10 +886,8 @@ static int thermal_bind_cdev_to_trip(struct thermal_zone_device *tz,
 * This interface function unbind a thermal cooling device from the certain
 * trip point of a thermal zone device.
 * This function is usually called in the thermal zone device .unbind callback.
 *
 * Return: 0 on success, the proper error value otherwise.
 */
static int thermal_unbind_cdev_from_trip(struct thermal_zone_device *tz,
static void thermal_unbind_cdev_from_trip(struct thermal_zone_device *tz,
					  const struct thermal_trip *trip,
					  struct thermal_cooling_device *cdev)
{
@@ -920,7 +909,7 @@ static int thermal_unbind_cdev_from_trip(struct thermal_zone_device *tz,
	}
	mutex_unlock(&cdev->lock);

	return -ENODEV;
	return;

unbind:
	device_remove_file(&tz->device, &pos->weight_attr);
@@ -928,7 +917,6 @@ static int thermal_unbind_cdev_from_trip(struct thermal_zone_device *tz,
	sysfs_remove_link(&tz->device.kobj, pos->name);
	ida_free(&tz->ida, pos->id);
	kfree(pos);
	return 0;
}

static void thermal_release(struct device *dev)
@@ -967,7 +955,6 @@ static void thermal_zone_cdev_binding(struct thermal_zone_device *tz,
				      struct thermal_cooling_device *cdev)
{
	struct thermal_trip_desc *td;
	int ret;

	if (!tz->ops.should_bind)
		return;
@@ -981,14 +968,15 @@ static void thermal_zone_cdev_binding(struct thermal_zone_device *tz,
			.lower = THERMAL_NO_LIMIT,
			.weight = THERMAL_WEIGHT_DEFAULT
		};
		int ret;

		if (!tz->ops.should_bind(tz, trip, cdev, &c))
			continue;

		if (tz->ops.should_bind(tz, trip, cdev, &c)) {
			ret = thermal_bind_cdev_to_trip(tz, trip, cdev, c.upper,
							c.lower, c.weight);
		ret = thermal_bind_cdev_to_trip(tz, trip, cdev, &c);
		if (ret)
			print_bind_err_msg(tz, trip, cdev, ret);
	}
	}

	mutex_unlock(&tz->lock);
}