Skip to content

Commit

Permalink
Merge tag 'thermal-6.11-rc1-2' of git://git.kernel.org/pub/scm/linux/…
Browse files Browse the repository at this point in the history
…kernel/git/rafael/linux-pm

Pull thermal control fix from Rafael Wysocki:
 "Fix a flood of kernel messages coming from the thermal core on systems
  where iwlwifi is loaded, but the network interfaces controlled by it
  are down (Rafael Wysocki)"

* tag 'thermal-6.11-rc1-2' of git://git.kernel.org/pub/scm/linux/kernel/git/rafael/linux-pm:
  thermal: core: Allow thermal zones to tell the core to ignore them
  • Loading branch information
Linus Torvalds committed Jul 22, 2024
2 parents 9deed1d + e528be3 commit 539fbb9
Show file tree
Hide file tree
Showing 4 changed files with 37 additions and 29 deletions.
10 changes: 8 additions & 2 deletions drivers/net/wireless/intel/iwlwifi/mvm/tt.c
Original file line number Diff line number Diff line change
Expand Up @@ -621,8 +621,14 @@ static int iwl_mvm_tzone_get_temp(struct thermal_zone_device *device,
guard(mvm)(mvm);

if (!iwl_mvm_firmware_running(mvm) ||
mvm->fwrt.cur_fw_img != IWL_UCODE_REGULAR)
return -ENODATA;
mvm->fwrt.cur_fw_img != IWL_UCODE_REGULAR) {
/*
* Tell the core that there is no valid temperature value to
* return, but it need not worry about this.
*/
*temperature = THERMAL_TEMP_INVALID;
return 0;
}

ret = iwl_mvm_get_temp(mvm, &temp);
if (ret)
Expand Down
51 changes: 24 additions & 27 deletions drivers/thermal/thermal_core.c
Original file line number Diff line number Diff line change
Expand Up @@ -300,8 +300,6 @@ static void monitor_thermal_zone(struct thermal_zone_device *tz)
thermal_zone_device_set_polling(tz, tz->passive_delay_jiffies);
else if (tz->polling_delay_jiffies)
thermal_zone_device_set_polling(tz, tz->polling_delay_jiffies);
else if (tz->temperature == THERMAL_TEMP_INVALID)
thermal_zone_device_set_polling(tz, msecs_to_jiffies(THERMAL_RECHECK_DELAY_MS));
}

static struct thermal_governor *thermal_get_tz_governor(struct thermal_zone_device *tz)
Expand Down Expand Up @@ -382,7 +380,7 @@ static void handle_thermal_trip(struct thermal_zone_device *tz,
td->threshold = trip->temperature;

if (tz->last_temperature >= old_threshold &&
tz->last_temperature != THERMAL_TEMP_INVALID) {
tz->last_temperature != THERMAL_TEMP_INIT) {
/*
* Mitigation is under way, so it needs to stop if the zone
* temperature falls below the low temperature of the trip.
Expand Down Expand Up @@ -417,27 +415,6 @@ static void handle_thermal_trip(struct thermal_zone_device *tz,
}
}

static void update_temperature(struct thermal_zone_device *tz)
{
int temp, ret;

ret = __thermal_zone_get_temp(tz, &temp);
if (ret) {
if (ret != -EAGAIN)
dev_warn(&tz->device,
"failed to read out thermal zone (%d)\n",
ret);
return;
}

tz->last_temperature = tz->temperature;
tz->temperature = temp;

trace_thermal_temperature(tz);

thermal_genl_sampling_temp(tz->id, temp);
}

static void thermal_zone_device_check(struct work_struct *work)
{
struct thermal_zone_device *tz = container_of(work, struct
Expand All @@ -452,7 +429,7 @@ static void thermal_zone_device_init(struct thermal_zone_device *tz)

INIT_DELAYED_WORK(&tz->poll_queue, thermal_zone_device_check);

tz->temperature = THERMAL_TEMP_INVALID;
tz->temperature = THERMAL_TEMP_INIT;
tz->passive = 0;
tz->prev_low_trip = -INT_MAX;
tz->prev_high_trip = INT_MAX;
Expand Down Expand Up @@ -504,17 +481,37 @@ void __thermal_zone_device_update(struct thermal_zone_device *tz,
struct thermal_trip_desc *td;
LIST_HEAD(way_down_list);
LIST_HEAD(way_up_list);
int temp, ret;

if (tz->suspended)
return;

if (!thermal_zone_device_is_enabled(tz))
return;

update_temperature(tz);
ret = __thermal_zone_get_temp(tz, &temp);
if (ret) {
if (ret != -EAGAIN)
dev_info(&tz->device, "Temperature check failed (%d)\n", ret);

if (tz->temperature == THERMAL_TEMP_INVALID)
thermal_zone_device_set_polling(tz, msecs_to_jiffies(THERMAL_RECHECK_DELAY_MS));
return;
} else if (temp <= THERMAL_TEMP_INVALID) {
/*
* Special case: No valid temperature value is available, but
* the zone owner does not want the core to do anything about
* it. Continue regular zone polling if needed, so that this
* function can be called again, but skip everything else.
*/
goto monitor;
}

tz->last_temperature = tz->temperature;
tz->temperature = temp;

trace_thermal_temperature(tz);

thermal_genl_sampling_temp(tz->id, temp);

tz->notify_event = event;

Expand Down
3 changes: 3 additions & 0 deletions drivers/thermal/thermal_core.h
Original file line number Diff line number Diff line change
Expand Up @@ -133,6 +133,9 @@ struct thermal_zone_device {
struct thermal_trip_desc trips[] __counted_by(num_trips);
};

/* Initial thermal zone temperature. */
#define THERMAL_TEMP_INIT INT_MIN

/*
* Default delay after a failing thermal zone temperature check before
* attempting to check it again.
Expand Down
2 changes: 2 additions & 0 deletions drivers/thermal/thermal_helpers.c
Original file line number Diff line number Diff line change
Expand Up @@ -163,6 +163,8 @@ int thermal_zone_get_temp(struct thermal_zone_device *tz, int *temp)
}

ret = __thermal_zone_get_temp(tz, temp);
if (!ret && *temp <= THERMAL_TEMP_INVALID)
ret = -ENODATA;

unlock:
mutex_unlock(&tz->lock);
Expand Down

0 comments on commit 539fbb9

Please sign in to comment.