thermal: trip: Drop lockdep assertion from thermal_zone_trip_id()
authorRafael J. Wysocki <rafael.j.wysocki@intel.com>
Wed, 11 Oct 2023 15:45:42 +0000 (17:45 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 1 Feb 2024 00:19:14 +0000 (16:19 -0800)
commit 108ffd12be24ba1d74b3314df8db32a0a6d55ba5 upstream.

The lockdep assertion in thermal_zone_trip_id() triggers when the
trip point sysfs attribute of a thermal instance is read, because
there is no thermal zone locking in that code path.

This is not verly useful, though, because there is no mechanism by which
the location of the trips[] table in a thermal zone or its size can
change after binding cooling devices to the trips in that thermal
zone and before those cooling devices are unbound from them.  Thus
it is not in fact necessary to hold the thermal zone lock when
thermal_zone_trip_id() is called from trip_point_show() and so the
lockdep asserion in the former is invalid.

Accordingly, drop that lockdep assertion.

Fixes: 2c7b4bfadef0 ("thermal: core: Store trip pointer in struct thermal_instance")
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/thermal/thermal_trip.c

index 6e5cebd1e63a108130a22ebe93f79bc7eee93d94..afc9499128c29ba7aa4ff0cc3fb9318403c9c2aa 100644 (file)
@@ -178,8 +178,6 @@ int thermal_zone_trip_id(struct thermal_zone_device *tz,
 {
        int i;
 
-       lockdep_assert_held(&tz->lock);
-
        for (i = 0; i < tz->num_trips; i++) {
                if (&tz->trips[i] == trip)
                        return i;