|
@@ -335,9 +335,6 @@ passive_store(struct device *dev, struct device_attribute *attr,
|
|
|
tz->passive_delay = 0;
|
|
|
}
|
|
|
|
|
|
- tz->tc1 = 1;
|
|
|
- tz->tc2 = 1;
|
|
|
-
|
|
|
tz->forced_passive = state;
|
|
|
|
|
|
thermal_zone_device_update(tz);
|
|
@@ -718,13 +715,12 @@ static void thermal_zone_device_set_polling(struct thermal_zone_device *tz,
|
|
|
static void thermal_zone_device_passive(struct thermal_zone_device *tz,
|
|
|
int temp, int trip_temp, int trip)
|
|
|
{
|
|
|
- int trend = 0;
|
|
|
+ enum thermal_trend trend;
|
|
|
struct thermal_cooling_device_instance *instance;
|
|
|
struct thermal_cooling_device *cdev;
|
|
|
long state, max_state;
|
|
|
|
|
|
- if (!tz->ops->get_trend ||
|
|
|
- tz->ops->get_trend(tz, trip, (enum thermal_trend *)&trend)) {
|
|
|
+ if (!tz->ops->get_trend || tz->ops->get_trend(tz, trip, &trend)) {
|
|
|
/*
|
|
|
* compare the current temperature and previous temperature
|
|
|
* to get the thermal trend, if no special requirement
|
|
@@ -747,11 +743,8 @@ static void thermal_zone_device_passive(struct thermal_zone_device *tz,
|
|
|
if (temp >= trip_temp) {
|
|
|
tz->passive = true;
|
|
|
|
|
|
- trend = (tz->tc1 * (temp - tz->last_temperature)) +
|
|
|
- (tz->tc2 * (temp - trip_temp));
|
|
|
-
|
|
|
/* Heating up? */
|
|
|
- if (trend > 0) {
|
|
|
+ if (trend == THERMAL_TREND_RAISING) {
|
|
|
list_for_each_entry(instance, &tz->cooling_devices,
|
|
|
node) {
|
|
|
if (instance->trip != trip)
|
|
@@ -762,7 +755,7 @@ static void thermal_zone_device_passive(struct thermal_zone_device *tz,
|
|
|
if (state++ < max_state)
|
|
|
cdev->ops->set_cur_state(cdev, state);
|
|
|
}
|
|
|
- } else if (trend < 0) { /* Cooling off? */
|
|
|
+ } else if (trend == THERMAL_TREND_DROPPING) { /* Cooling off? */
|
|
|
list_for_each_entry(instance, &tz->cooling_devices,
|
|
|
node) {
|
|
|
if (instance->trip != trip)
|
|
@@ -1288,8 +1281,6 @@ static void remove_trip_attrs(struct thermal_zone_device *tz)
|
|
|
* @mask: a bit string indicating the writeablility of trip points
|
|
|
* @devdata: private device data
|
|
|
* @ops: standard thermal zone device callbacks
|
|
|
- * @tc1: thermal coefficient 1 for passive calculations
|
|
|
- * @tc2: thermal coefficient 2 for passive calculations
|
|
|
* @passive_delay: number of milliseconds to wait between polls when
|
|
|
* performing passive cooling
|
|
|
* @polling_delay: number of milliseconds to wait between polls when checking
|
|
@@ -1297,13 +1288,12 @@ static void remove_trip_attrs(struct thermal_zone_device *tz)
|
|
|
* driven systems)
|
|
|
*
|
|
|
* thermal_zone_device_unregister() must be called when the device is no
|
|
|
- * longer needed. The passive cooling formula uses tc1 and tc2 as described in
|
|
|
- * section 11.1.5.1 of the ACPI specification 3.0.
|
|
|
+ * longer needed. The passive cooling depends on the .get_trend() return value.
|
|
|
*/
|
|
|
struct thermal_zone_device *thermal_zone_device_register(const char *type,
|
|
|
int trips, int mask, void *devdata,
|
|
|
const struct thermal_zone_device_ops *ops,
|
|
|
- int tc1, int tc2, int passive_delay, int polling_delay)
|
|
|
+ int passive_delay, int polling_delay)
|
|
|
{
|
|
|
struct thermal_zone_device *tz;
|
|
|
struct thermal_cooling_device *pos;
|
|
@@ -1339,8 +1329,6 @@ struct thermal_zone_device *thermal_zone_device_register(const char *type,
|
|
|
tz->device.class = &thermal_class;
|
|
|
tz->devdata = devdata;
|
|
|
tz->trips = trips;
|
|
|
- tz->tc1 = tc1;
|
|
|
- tz->tc2 = tc2;
|
|
|
tz->passive_delay = passive_delay;
|
|
|
tz->polling_delay = polling_delay;
|
|
|
|