Commit dd3b3d16 authored by Rafael J. Wysocki's avatar Rafael J. Wysocki

thermal: ACPI: Make helpers retrieve temperature only

It is slightly better to make the ACPI thermal helper functions retrieve
the trip point temperature only instead of doing the full trip point
initialization, because they are also used for updating some already
registered trip points, in which case initializing a new trip just
in order to update the temperature of an existing one is somewhat
wasteful.

Modify the ACPI thermal helpers accordingly and update their users.

No intentional functional impact.
Signed-off-by: default avatarRafael J. Wysocki <rafael.j.wysocki@intel.com>
Acked-by: default avatarDaniel Lezcano <daniel.lezcano@linaro.org>
parent f4118dbe
...@@ -70,24 +70,35 @@ static int int340x_thermal_read_trips(struct acpi_device *zone_adev, ...@@ -70,24 +70,35 @@ static int int340x_thermal_read_trips(struct acpi_device *zone_adev,
{ {
int i, ret; int i, ret;
ret = thermal_acpi_trip_critical(zone_adev, &zone_trips[trip_cnt]); ret = thermal_acpi_critical_trip_temp(zone_adev,
if (!ret) &zone_trips[trip_cnt].temperature);
if (!ret) {
zone_trips[trip_cnt].type = THERMAL_TRIP_CRITICAL;
trip_cnt++; trip_cnt++;
}
ret = thermal_acpi_trip_hot(zone_adev, &zone_trips[trip_cnt]); ret = thermal_acpi_hot_trip_temp(zone_adev,
if (!ret) &zone_trips[trip_cnt].temperature);
if (!ret) {
zone_trips[trip_cnt].type = THERMAL_TRIP_HOT;
trip_cnt++; trip_cnt++;
}
ret = thermal_acpi_trip_passive(zone_adev, &zone_trips[trip_cnt]); ret = thermal_acpi_passive_trip_temp(zone_adev,
if (!ret) &zone_trips[trip_cnt].temperature);
if (!ret) {
zone_trips[trip_cnt].type = THERMAL_TRIP_PASSIVE;
trip_cnt++; trip_cnt++;
}
for (i = 0; i < INT340X_THERMAL_MAX_ACT_TRIP_COUNT; i++) { for (i = 0; i < INT340X_THERMAL_MAX_ACT_TRIP_COUNT; i++) {
ret = thermal_acpi_trip_active(zone_adev, i, &zone_trips[trip_cnt]); ret = thermal_acpi_active_trip_temp(zone_adev, i,
&zone_trips[trip_cnt].temperature);
if (ret) if (ret)
break; break;
zone_trips[trip_cnt].type = THERMAL_TRIP_ACTIVE;
trip_cnt++; trip_cnt++;
} }
...@@ -213,22 +224,21 @@ void int340x_thermal_update_trips(struct int34x_thermal_zone *int34x_zone) ...@@ -213,22 +224,21 @@ void int340x_thermal_update_trips(struct int34x_thermal_zone *int34x_zone)
mutex_lock(&int34x_zone->zone->lock); mutex_lock(&int34x_zone->zone->lock);
for (i = int34x_zone->aux_trip_nr; i < trip_cnt; i++) { for (i = int34x_zone->aux_trip_nr; i < trip_cnt; i++) {
struct thermal_trip trip; int temp, err;
int err;
switch (zone_trips[i].type) { switch (zone_trips[i].type) {
case THERMAL_TRIP_CRITICAL: case THERMAL_TRIP_CRITICAL:
err = thermal_acpi_trip_critical(zone_adev, &trip); err = thermal_acpi_critical_trip_temp(zone_adev, &temp);
break; break;
case THERMAL_TRIP_HOT: case THERMAL_TRIP_HOT:
err = thermal_acpi_trip_hot(zone_adev, &trip); err = thermal_acpi_hot_trip_temp(zone_adev, &temp);
break; break;
case THERMAL_TRIP_PASSIVE: case THERMAL_TRIP_PASSIVE:
err = thermal_acpi_trip_passive(zone_adev, &trip); err = thermal_acpi_passive_trip_temp(zone_adev, &temp);
break; break;
case THERMAL_TRIP_ACTIVE: case THERMAL_TRIP_ACTIVE:
err = thermal_acpi_trip_active(zone_adev, act_trip_nr++, err = thermal_acpi_active_trip_temp(zone_adev, act_trip_nr++,
&trip); &temp);
break; break;
default: default:
err = -ENODEV; err = -ENODEV;
...@@ -238,7 +248,7 @@ void int340x_thermal_update_trips(struct int34x_thermal_zone *int34x_zone) ...@@ -238,7 +248,7 @@ void int340x_thermal_update_trips(struct int34x_thermal_zone *int34x_zone)
continue; continue;
} }
zone_trips[i].temperature = trip.temperature; zone_trips[i].temperature = temp;
} }
mutex_unlock(&int34x_zone->zone->lock); mutex_unlock(&int34x_zone->zone->lock);
......
...@@ -100,16 +100,17 @@ static void pch_wpt_add_acpi_psv_trip(struct pch_thermal_device *ptd, ...@@ -100,16 +100,17 @@ static void pch_wpt_add_acpi_psv_trip(struct pch_thermal_device *ptd,
int *nr_trips) int *nr_trips)
{ {
struct acpi_device *adev; struct acpi_device *adev;
int ret; int temp;
adev = ACPI_COMPANION(&ptd->pdev->dev); adev = ACPI_COMPANION(&ptd->pdev->dev);
if (!adev) if (!adev)
return; return;
ret = thermal_acpi_trip_passive(adev, &ptd->trips[*nr_trips]); if (thermal_acpi_passive_trip_temp(adev, &temp) || temp <= 0)
if (ret || ptd->trips[*nr_trips].temperature <= 0)
return; return;
ptd->trips[*nr_trips].type = THERMAL_TRIP_PASSIVE;
ptd->trips[*nr_trips].temperature = temp;
++(*nr_trips); ++(*nr_trips);
} }
#else #else
......
...@@ -21,42 +21,11 @@ ...@@ -21,42 +21,11 @@
#define TEMP_MIN_DECIK 2180 #define TEMP_MIN_DECIK 2180
#define TEMP_MAX_DECIK 4480 #define TEMP_MAX_DECIK 4480
static int thermal_acpi_trip_init(struct acpi_device *adev, static int thermal_acpi_trip_temp(struct acpi_device *adev, char *obj_name,
enum thermal_trip_type type, int id, int *ret_temp)
struct thermal_trip *trip)
{ {
unsigned long long temp; unsigned long long temp;
acpi_status status; acpi_status status;
char obj_name[5];
switch (type) {
case THERMAL_TRIP_ACTIVE:
if (id < 0 || id > 9)
return -EINVAL;
obj_name[1] = 'A';
obj_name[2] = 'C';
obj_name[3] = '0' + id;
break;
case THERMAL_TRIP_PASSIVE:
obj_name[1] = 'P';
obj_name[2] = 'S';
obj_name[3] = 'V';
break;
case THERMAL_TRIP_HOT:
obj_name[1] = 'H';
obj_name[2] = 'O';
obj_name[3] = 'T';
break;
case THERMAL_TRIP_CRITICAL:
obj_name[1] = 'C';
obj_name[2] = 'R';
obj_name[3] = 'T';
break;
}
obj_name[0] = '_';
obj_name[4] = '\0';
status = acpi_evaluate_integer(adev->handle, obj_name, NULL, &temp); status = acpi_evaluate_integer(adev->handle, obj_name, NULL, &temp);
if (ACPI_FAILURE(status)) { if (ACPI_FAILURE(status)) {
...@@ -65,87 +34,84 @@ static int thermal_acpi_trip_init(struct acpi_device *adev, ...@@ -65,87 +34,84 @@ static int thermal_acpi_trip_init(struct acpi_device *adev,
} }
if (temp >= TEMP_MIN_DECIK && temp <= TEMP_MAX_DECIK) { if (temp >= TEMP_MIN_DECIK && temp <= TEMP_MAX_DECIK) {
trip->temperature = deci_kelvin_to_millicelsius(temp); *ret_temp = deci_kelvin_to_millicelsius(temp);
} else { } else {
acpi_handle_debug(adev->handle, "%s result %llu out of range\n", acpi_handle_debug(adev->handle, "%s result %llu out of range\n",
obj_name, temp); obj_name, temp);
trip->temperature = THERMAL_TEMP_INVALID; *ret_temp = THERMAL_TEMP_INVALID;
} }
trip->hysteresis = 0;
trip->type = type;
return 0; return 0;
} }
/** /**
* thermal_acpi_trip_active - Get the specified active trip point * thermal_acpi_active_trip_temp - Retrieve active trip point temperature
* @adev: Thermal zone ACPI device object to get the description from. * @adev: Target thermal zone ACPI device object.
* @id: Active cooling level (0 - 9). * @id: Active cooling level (0 - 9).
* @trip: Trip point structure to be populated on success. * @ret_temp: Address to store the retrieved temperature value on success.
* *
* Evaluate the _ACx object for the thermal zone represented by @adev to obtain * Evaluate the _ACx object for the thermal zone represented by @adev to obtain
* the temperature of the active cooling trip point corresponding to the active * the temperature of the active cooling trip point corresponding to the active
* cooling level given by @id and initialize @trip as an active trip point using * cooling level given by @id.
* that temperature value.
* *
* Return 0 on success or a negative error value on failure. * Return 0 on success or a negative error value on failure.
*/ */
int thermal_acpi_trip_active(struct acpi_device *adev, int id, int thermal_acpi_active_trip_temp(struct acpi_device *adev, int id, int *ret_temp)
struct thermal_trip *trip)
{ {
return thermal_acpi_trip_init(adev, THERMAL_TRIP_ACTIVE, id, trip); char obj_name[] = {'_', 'A', 'C', '0' + id, '\0'};
if (id < 0 || id > 9)
return -EINVAL;
return thermal_acpi_trip_temp(adev, obj_name, ret_temp);
} }
EXPORT_SYMBOL_GPL(thermal_acpi_trip_active); EXPORT_SYMBOL_GPL(thermal_acpi_active_trip_temp);
/** /**
* thermal_acpi_trip_passive - Get the passive trip point * thermal_acpi_passive_trip_temp - Retrieve passive trip point temperature
* @adev: Thermal zone ACPI device object to get the description from. * @adev: Target thermal zone ACPI device object.
* @trip: Trip point structure to be populated on success. * @ret_temp: Address to store the retrieved temperature value on success.
* *
* Evaluate the _PSV object for the thermal zone represented by @adev to obtain * Evaluate the _PSV object for the thermal zone represented by @adev to obtain
* the temperature of the passive cooling trip point and initialize @trip as a * the temperature of the passive cooling trip point.
* passive trip point using that temperature value.
* *
* Return 0 on success or -ENODATA on failure. * Return 0 on success or -ENODATA on failure.
*/ */
int thermal_acpi_trip_passive(struct acpi_device *adev, struct thermal_trip *trip) int thermal_acpi_passive_trip_temp(struct acpi_device *adev, int *ret_temp)
{ {
return thermal_acpi_trip_init(adev, THERMAL_TRIP_PASSIVE, INT_MAX, trip); return thermal_acpi_trip_temp(adev, "_PSV", ret_temp);
} }
EXPORT_SYMBOL_GPL(thermal_acpi_trip_passive); EXPORT_SYMBOL_GPL(thermal_acpi_passive_trip_temp);
/** /**
* thermal_acpi_trip_hot - Get the near critical trip point * thermal_acpi_hot_trip_temp - Retrieve hot trip point temperature
* @adev: the ACPI device to get the description from. * @adev: Target thermal zone ACPI device object.
* @trip: a &struct thermal_trip to be filled if the function succeed. * @ret_temp: Address to store the retrieved temperature value on success.
* *
* Evaluate the _HOT object for the thermal zone represented by @adev to obtain * Evaluate the _HOT object for the thermal zone represented by @adev to obtain
* the temperature of the trip point at which the system is expected to be put * the temperature of the trip point at which the system is expected to be put
* into the S4 sleep state and initialize @trip as a hot trip point using that * into the S4 sleep state.
* temperature value.
* *
* Return 0 on success or -ENODATA on failure. * Return 0 on success or -ENODATA on failure.
*/ */
int thermal_acpi_trip_hot(struct acpi_device *adev, struct thermal_trip *trip) int thermal_acpi_hot_trip_temp(struct acpi_device *adev, int *ret_temp)
{ {
return thermal_acpi_trip_init(adev, THERMAL_TRIP_HOT, INT_MAX, trip); return thermal_acpi_trip_temp(adev, "_HOT", ret_temp);
} }
EXPORT_SYMBOL_GPL(thermal_acpi_trip_hot); EXPORT_SYMBOL_GPL(thermal_acpi_hot_trip_temp);
/** /**
* thermal_acpi_trip_critical - Get the critical trip point * thermal_acpi_critical_trip_temp - Retrieve critical trip point temperature
* @adev: the ACPI device to get the description from. * @adev: Target thermal zone ACPI device object.
* @trip: a &struct thermal_trip to be filled if the function succeed. * @ret_temp: Address to store the retrieved temperature value on success.
* *
* Evaluate the _CRT object for the thermal zone represented by @adev to obtain * Evaluate the _CRT object for the thermal zone represented by @adev to obtain
* the temperature of the critical cooling trip point and initialize @trip as a * the temperature of the critical cooling trip point.
* critical trip point using that temperature value.
* *
* Return 0 on success or -ENODATA on failure. * Return 0 on success or -ENODATA on failure.
*/ */
int thermal_acpi_trip_critical(struct acpi_device *adev, struct thermal_trip *trip) int thermal_acpi_critical_trip_temp(struct acpi_device *adev, int *ret_temp)
{ {
return thermal_acpi_trip_init(adev, THERMAL_TRIP_CRITICAL, INT_MAX, trip); return thermal_acpi_trip_temp(adev, "_CRT", ret_temp);
} }
EXPORT_SYMBOL_GPL(thermal_acpi_trip_critical); EXPORT_SYMBOL_GPL(thermal_acpi_critical_trip_temp);
...@@ -347,11 +347,10 @@ int thermal_zone_get_num_trips(struct thermal_zone_device *tz); ...@@ -347,11 +347,10 @@ int thermal_zone_get_num_trips(struct thermal_zone_device *tz);
int thermal_zone_get_crit_temp(struct thermal_zone_device *tz, int *temp); int thermal_zone_get_crit_temp(struct thermal_zone_device *tz, int *temp);
#ifdef CONFIG_THERMAL_ACPI #ifdef CONFIG_THERMAL_ACPI
int thermal_acpi_trip_active(struct acpi_device *adev, int id, int thermal_acpi_active_trip_temp(struct acpi_device *adev, int id, int *ret_temp);
struct thermal_trip *trip); int thermal_acpi_passive_trip_temp(struct acpi_device *adev, int *ret_temp);
int thermal_acpi_trip_passive(struct acpi_device *adev, struct thermal_trip *trip); int thermal_acpi_hot_trip_temp(struct acpi_device *adev, int *ret_temp);
int thermal_acpi_trip_hot(struct acpi_device *adev, struct thermal_trip *trip); int thermal_acpi_critical_trip_temp(struct acpi_device *adev, int *ret_temp);
int thermal_acpi_trip_critical(struct acpi_device *adev, struct thermal_trip *trip);
#endif #endif
#ifdef CONFIG_THERMAL #ifdef CONFIG_THERMAL
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment