Module Name: src
Committed By: jruoho
Date: Sun Apr 25 10:05:23 UTC 2010
Modified Files:
src/sys/dev/acpi: acpi.c
Log Message:
Evaluate _TTS on sleep state transitions. This is mainly to pro-actively
support some weird BIOS, which may require the evaluation. Ok jmcne...@.
To generate a diff of this commit:
cvs rdiff -u -r1.188 -r1.189 src/sys/dev/acpi/acpi.c
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Modified files:
Index: src/sys/dev/acpi/acpi.c
diff -u src/sys/dev/acpi/acpi.c:1.188 src/sys/dev/acpi/acpi.c:1.189
--- src/sys/dev/acpi/acpi.c:1.188 Sun Apr 25 09:12:38 2010
+++ src/sys/dev/acpi/acpi.c Sun Apr 25 10:05:22 2010
@@ -1,4 +1,4 @@
-/* $NetBSD: acpi.c,v 1.188 2010/04/25 09:12:38 jruoho Exp $ */
+/* $NetBSD: acpi.c,v 1.189 2010/04/25 10:05:22 jruoho Exp $ */
/*-
* Copyright (c) 2003, 2007 The NetBSD Foundation, Inc.
@@ -65,7 +65,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: acpi.c,v 1.188 2010/04/25 09:12:38 jruoho Exp $");
+__KERNEL_RCSID(0, "$NetBSD: acpi.c,v 1.189 2010/04/25 10:05:22 jruoho Exp $");
#include "opt_acpi.h"
#include "opt_pcifixup.h"
@@ -1463,6 +1463,19 @@
}
/*
+ * Evaluate the _TTS method, which should be called
+ * before _PTS. We should also re-evaluate this once
+ * we return to S0 (see ACPI 3.0, section 7.3.6).
+ * In reality, _TTS is seldom seen in the field.
+ */
+ rv = acpi_eval_set_integer(NULL, "\\_TTS", state);
+
+ if (ACPI_SUCCESS(rv))
+ aprint_debug_dev(sc->sc_dev, "evaluated _TTS\n");
+
+ rv = AE_OK;
+
+ /*
* This will evaluate the _PTS and _SST methods,
* but unlike the documentation claims, not _GTS,
* which is evaluated in AcpiEnterSleepState().
@@ -1504,8 +1517,11 @@
}
break;
+
case ACPI_STATE_S5:
+ (void)acpi_eval_set_integer(NULL, "\\_TTS", state);
+
rv = AcpiEnterSleepStatePrep(ACPI_STATE_S5);
if (ACPI_FAILURE(rv)) {
@@ -1522,11 +1538,14 @@
(void)AcpiEnterSleepState(ACPI_STATE_S5);
aprint_error_dev(sc->sc_dev, "WARNING: powerdown failed!\n");
+
break;
}
sc->sc_sleepstate = ACPI_STATE_S0;
+ (void)acpi_eval_set_integer(NULL, "\\_TTS", ACPI_STATE_S0);
+
return rv;
}