]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
thermal: core: Clean up trip bind/unbind functions
authorRafael J. Wysocki <rafael.j.wysocki@intel.com>
Wed, 21 Aug 2024 15:26:28 +0000 (17:26 +0200)
committerRafael J. Wysocki <rafael.j.wysocki@intel.com>
Fri, 23 Aug 2024 13:42:58 +0000 (15:42 +0200)
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: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Reviewed-by: Zhang Rui <rui.zhang@intel.com>
Acked-by: Huisong Li <lihuisong@huawei.com>
Reviewed-by: Daniel 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: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
drivers/thermal/thermal_core.c

index 9ca9d741fa0f47238a627101f92b1e5fa616716f..534766cecc1526b72827231d1cf4946d77890d12 100644 (file)
@@ -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,12 +886,10 @@ free_mem:
  * 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,
-                                        const struct thermal_trip *trip,
-                                        struct thermal_cooling_device *cdev)
+static void thermal_unbind_cdev_from_trip(struct thermal_zone_device *tz,
+                                         const struct thermal_trip *trip,
+                                         struct thermal_cooling_device *cdev)
 {
        struct thermal_instance *pos, *next;
 
@@ -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 @@ unbind:
        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,13 +968,14 @@ 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)) {
-                       ret = thermal_bind_cdev_to_trip(tz, trip, cdev, c.upper,
-                                                       c.lower, c.weight);
-                       if (ret)
-                               print_bind_err_msg(tz, trip, cdev, ret);
-               }
+               if (!tz->ops.should_bind(tz, trip, cdev, &c))
+                       continue;
+
+               ret = thermal_bind_cdev_to_trip(tz, trip, cdev, &c);
+               if (ret)
+                       print_bind_err_msg(tz, trip, cdev, ret);
        }
 
        mutex_unlock(&tz->lock);