summaryrefslogtreecommitdiffstats
path: root/sys/dev/acpica/acpi_thermal.c
diff options
context:
space:
mode:
authorume <ume@FreeBSD.org>2005-08-25 11:31:30 +0000
committerume <ume@FreeBSD.org>2005-08-25 11:31:30 +0000
commit6dd061bc1cbebd33498cd9f21e6af6b55f35b13b (patch)
tree3a6fac476e691e16cbc2c01ad4ad53e1e4721282 /sys/dev/acpica/acpi_thermal.c
parentc34aa62640ea511eed36401f8fbd3d744931a81f (diff)
downloadFreeBSD-src-6dd061bc1cbebd33498cd9f21e6af6b55f35b13b.zip
FreeBSD-src-6dd061bc1cbebd33498cd9f21e6af6b55f35b13b.tar.gz
get current temperature from _TMP during passive cooling is active.
it makes CPU freq transition smooth.
Diffstat (limited to 'sys/dev/acpica/acpi_thermal.c')
-rw-r--r--sys/dev/acpica/acpi_thermal.c48
1 files changed, 33 insertions, 15 deletions
diff --git a/sys/dev/acpica/acpi_thermal.c b/sys/dev/acpica/acpi_thermal.c
index e78a24d..d49fdad 100644
--- a/sys/dev/acpica/acpi_thermal.c
+++ b/sys/dev/acpica/acpi_thermal.c
@@ -415,6 +415,28 @@ acpi_tz_aclevel_string(int active)
}
/*
+ * Get the current temperature.
+ */
+static int
+acpi_tz_get_temperature(struct acpi_tz_softc *sc)
+{
+ int temp;
+ ACPI_STATUS status;
+
+ status = acpi_GetInteger(sc->tz_handle, "_TMP", &temp);
+ if (ACPI_FAILURE(status)) {
+ ACPI_VPRINT(sc->tz_dev, acpi_device_get_parent_softc(sc->tz_dev),
+ "error fetching current temperature -- %s\n",
+ AcpiFormatException(status));
+ return (FALSE);
+ }
+
+ ACPI_DEBUG_PRINT((ACPI_DB_VALUES, "got %d.%dC\n", TZ_KELVTOC(temp)));
+ sc->tz_temperature = temp;
+ return (TRUE);
+}
+
+/*
* Evaluate the condition of a thermal zone, take appropriate actions.
*/
static void
@@ -425,24 +447,17 @@ acpi_tz_monitor(void *Context)
int temp;
int i;
int newactive, newflags;
- ACPI_STATUS status;
ACPI_FUNCTION_TRACE((char *)(uintptr_t)__func__);
sc = (struct acpi_tz_softc *)Context;
/* Get the current temperature. */
- status = acpi_GetInteger(sc->tz_handle, "_TMP", &temp);
- if (ACPI_FAILURE(status)) {
- ACPI_VPRINT(sc->tz_dev, acpi_device_get_parent_softc(sc->tz_dev),
- "error fetching current temperature -- %s\n",
- AcpiFormatException(status));
+ if (!acpi_tz_get_temperature(sc)) {
/* XXX disable zone? go to max cooling? */
return_VOID;
}
-
- ACPI_DEBUG_PRINT((ACPI_DB_VALUES, "got %d.%dC\n", TZ_KELVTOC(temp)));
- sc->tz_temperature = temp;
+ temp = sc->tz_temperature;
/*
* Work out what we ought to be doing right now.
@@ -979,19 +994,22 @@ static void
acpi_tz_cooling_thread(void *arg)
{
struct acpi_tz_softc *sc;
- int error, perf, temperature;
+ int error, perf, curr_temp, prev_temp;
ACPI_FUNCTION_TRACE((char *)(uintptr_t)__func__);
sc = (struct acpi_tz_softc *)arg;
- temperature = sc->tz_temperature;
+ prev_temp = sc->tz_temperature;
while (sc->tz_cooling_enabled) {
- if (sc->tz_temperature >= sc->tz_zone.psv)
+ if (sc->tz_cooling_active)
+ (void)acpi_tz_get_temperature(sc);
+ curr_temp = sc->tz_temperature;
+ if (curr_temp >= sc->tz_zone.psv)
sc->tz_cooling_active = TRUE;
if (sc->tz_cooling_active) {
- perf = sc->tz_zone.tc1 * (sc->tz_temperature - temperature) +
- sc->tz_zone.tc2 * (sc->tz_temperature - sc->tz_zone.psv);
+ perf = sc->tz_zone.tc1 * (curr_temp - prev_temp) +
+ sc->tz_zone.tc2 * (curr_temp - sc->tz_zone.psv);
perf /= 10;
if (perf != 0) {
@@ -1008,7 +1026,7 @@ acpi_tz_cooling_thread(void *arg)
}
}
}
- temperature = sc->tz_temperature;
+ prev_temp = curr_temp;
tsleep(&sc->tz_cooling_proc, PZERO, "cooling",
hz * sc->tz_zone.tsp / 10);
}
OpenPOWER on IntegriCloud