diff options
Diffstat (limited to 'sys/dev/acpi')
-rw-r--r-- | sys/dev/acpi/acpitz.c | 55 |
1 files changed, 15 insertions, 40 deletions
diff --git a/sys/dev/acpi/acpitz.c b/sys/dev/acpi/acpitz.c index 6cbdf53c004..789f6042283 100644 --- a/sys/dev/acpi/acpitz.c +++ b/sys/dev/acpi/acpitz.c @@ -1,4 +1,4 @@ -/* $OpenBSD: acpitz.c,v 1.5 2006/10/24 19:58:03 marco Exp $ */ +/* $OpenBSD: acpitz.c,v 1.6 2006/10/24 20:30:00 marco Exp $ */ /* * Copyright (c) 2006 Can Erkin Acar <canacar@openbsd.org> * Copyright (c) 2005 Marco Peereboom <marco@openbsd.org> @@ -48,9 +48,6 @@ struct acpitz_softc { int acpitz_match(struct device *, void *, void *); void acpitz_attach(struct device *, struct device *, void *); -void acpitz_refresh(void *); -int acpitz_gettmp(struct acpitz_softc *); -int acpitz_notify(struct aml_node *, int, void *); struct cfattach acpitz_ca = { sizeof(struct acpitz_softc), acpitz_match, acpitz_attach @@ -62,10 +59,8 @@ struct cfdriver acpitz_cd = { void acpitz_monitor(struct acpitz_softc *); void acpitz_refresh(void *); -int acpitz_getbif(struct acpitz_softc *); -int acpitz_getbst(struct acpitz_softc *); int acpitz_notify(struct aml_node *, int, void *); -int acpitz_getcrt(struct acpitz_softc *); +int acpitz_getreading(struct acpitz_softc *, char *); int acpitz_match(struct device *parent, void *match, void *aux) @@ -100,12 +95,15 @@ acpitz_attach(struct device *parent, struct device *self, void *aux) memset(&res, 0, sizeof(res)); memset(&env, 0, sizeof(env)); - if (acpitz_gettmp(sc)) { + sc->sc_tmp = -1; + sc->sc_crt = -1; + + if (-1 == (sc->sc_tmp = acpitz_getreading(sc, "_TMP"))) { printf(", failed to read _TMP"); return; } - if (acpitz_getcrt(sc)) { + if (-1 == (sc->sc_crt = acpitz_getreading(sc, "_CRT"))) { printf(", no critical temperature defined!"); sc->sc_crt = 0; } else @@ -138,13 +136,13 @@ acpitz_refresh(void *arg) dnprintf(30, "%s: %s: refresh\n", DEVNAME(sc), sc->sc_devnode->parent->name); - if (acpitz_gettmp(sc)) { + if (-1 == (sc->sc_tmp = acpitz_getreading(sc, "_TMP"))) { dnprintf(30, "%s: %s: failed to read temp!\n", DEVNAME(sc), sc->sc_devnode->parent->name); sc->sc_tmp = 0; /* XXX */ } - if (sc->sc_crt && sc->sc_crt <= sc->sc_tmp) { + if (sc->sc_tmp != -1 && sc->sc_crt != -1 && sc->sc_crt <= sc->sc_tmp) { /* Do critical shutdown */ printf("%s: Critical temperature, shutting down!\n", DEVNAME(sc)); @@ -161,20 +159,19 @@ acpitz_refresh(void *arg) } int -acpitz_gettmp(struct acpitz_softc *sc) +acpitz_getreading(struct acpitz_softc *sc, char *name) { struct aml_value res; - int rv = 1; + int rv = -1; rw_enter_write(&sc->sc_lock); - if (aml_evalname(sc->sc_acpi, sc->sc_devnode, "_TMP", 0, NULL, &res)) { - dnprintf(10, "%s: no _TMP\n", DEVNAME(sc)); + if (aml_evalname(sc->sc_acpi, sc->sc_devnode, name, 0, NULL, &res)) { + dnprintf(10, "%s: no %s\n", DEVNAME(sc), name); goto out; } - sc->sc_tmp = aml_val2int(&res); - rv = 0; + rv = aml_val2int(&res); out: aml_freevalue(&res); rw_exit_write(&sc->sc_lock); @@ -182,28 +179,6 @@ acpitz_gettmp(struct acpitz_softc *sc) } int -acpitz_getcrt(struct acpitz_softc *sc) -{ - struct aml_value res; - int rv = 1; - - rw_enter_write(&sc->sc_lock); - - if (aml_evalname(sc->sc_acpi, sc->sc_devnode, "_CRT", 0, NULL, &res)) { - dnprintf(10, "%s: no _CRT\n", DEVNAME(sc)); - goto out; - } - - sc->sc_crt = aml_val2int(&res); - rv = 0; - out: - aml_freevalue(&res); - rw_exit_write(&sc->sc_lock); - return (rv); -} - - -int acpitz_notify(struct aml_node *node, int notify_type, void *arg) { struct acpitz_softc *sc = arg; @@ -215,7 +190,7 @@ acpitz_notify(struct aml_node *node, int notify_type, void *arg) switch (notify_type) { case 0x81: /* Operating Points changed */ crt = sc->sc_crt; - acpitz_getcrt(sc); + sc->sc_crt = acpitz_getreading(sc, "_CRT"); if (crt != sc->sc_crt) printf("%s: critical temperature: %u degC", DEVNAME(sc), |