summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
Diffstat (limited to 'sys')
-rw-r--r--sys/dev/acpi/acpi.c274
1 files changed, 137 insertions, 137 deletions
diff --git a/sys/dev/acpi/acpi.c b/sys/dev/acpi/acpi.c
index aa2f2c6f677..9bedb436b2b 100644
--- a/sys/dev/acpi/acpi.c
+++ b/sys/dev/acpi/acpi.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: acpi.c,v 1.94 2007/11/05 17:32:20 canacar Exp $ */
+/* $OpenBSD: acpi.c,v 1.95 2007/11/06 01:05:28 deraadt Exp $ */
/*
* Copyright (c) 2005 Thorsten Lockert <tholo@sigmasoft.com>
* Copyright (c) 2005 Jordan Hargrave <jordan@openbsd.org>
@@ -973,6 +973,142 @@ acpikqfilter(dev_t dev, struct knote *kn)
return (0);
}
+/* Read from power management register */
+int
+acpi_read_pmreg(struct acpi_softc *sc, int reg, int offset)
+{
+ bus_space_handle_t ioh;
+ bus_size_t size, __size;
+ int regval;
+
+ __size = 0;
+ /* Special cases: 1A/1B blocks can be OR'ed together */
+ switch (reg) {
+ case ACPIREG_PM1_EN:
+ return (acpi_read_pmreg(sc, ACPIREG_PM1A_EN, offset) |
+ acpi_read_pmreg(sc, ACPIREG_PM1B_EN, offset));
+ case ACPIREG_PM1_STS:
+ return (acpi_read_pmreg(sc, ACPIREG_PM1A_STS, offset) |
+ acpi_read_pmreg(sc, ACPIREG_PM1B_STS, offset));
+ case ACPIREG_PM1_CNT:
+ return (acpi_read_pmreg(sc, ACPIREG_PM1A_CNT, offset) |
+ acpi_read_pmreg(sc, ACPIREG_PM1B_CNT, offset));
+ case ACPIREG_GPE_STS:
+ __size = 1;
+ dnprintf(50, "read GPE_STS offset: %.2x %.2x %.2x\n", offset,
+ sc->sc_fadt->gpe0_blk_len>>1, sc->sc_fadt->gpe1_blk_len>>1);
+ if (offset < (sc->sc_fadt->gpe0_blk_len >> 1)) {
+ reg = ACPIREG_GPE0_STS;
+ }
+ break;
+ case ACPIREG_GPE_EN:
+ __size = 1;
+ dnprintf(50, "read GPE_EN offset: %.2x %.2x %.2x\n",
+ offset, sc->sc_fadt->gpe0_blk_len>>1,
+ sc->sc_fadt->gpe1_blk_len>>1);
+ if (offset < (sc->sc_fadt->gpe0_blk_len >> 1)) {
+ reg = ACPIREG_GPE0_EN;
+ }
+ break;
+ }
+
+ if (reg >= ACPIREG_MAXREG || sc->sc_pmregs[reg].size == 0)
+ return (0);
+
+ regval = 0;
+ ioh = sc->sc_pmregs[reg].ioh;
+ size = sc->sc_pmregs[reg].size;
+ if (__size)
+ size = __size;
+ if (size > 4)
+ size = 4;
+
+ switch (size) {
+ case 1:
+ regval = bus_space_read_1(sc->sc_iot, ioh, offset);
+ break;
+ case 2:
+ regval = bus_space_read_2(sc->sc_iot, ioh, offset);
+ break;
+ case 4:
+ regval = bus_space_read_4(sc->sc_iot, ioh, offset);
+ break;
+ }
+
+ dnprintf(30, "acpi_readpm: %s = %.4x:%.4x %x\n",
+ sc->sc_pmregs[reg].name,
+ sc->sc_pmregs[reg].addr, offset, regval);
+ return (regval);
+}
+
+/* Write to power management register */
+void
+acpi_write_pmreg(struct acpi_softc *sc, int reg, int offset, int regval)
+{
+ bus_space_handle_t ioh;
+ bus_size_t size, __size;
+
+ __size = 0;
+ /* Special cases: 1A/1B blocks can be written with same value */
+ switch (reg) {
+ case ACPIREG_PM1_EN:
+ acpi_write_pmreg(sc, ACPIREG_PM1A_EN, offset, regval);
+ acpi_write_pmreg(sc, ACPIREG_PM1B_EN, offset, regval);
+ break;
+ case ACPIREG_PM1_STS:
+ acpi_write_pmreg(sc, ACPIREG_PM1A_STS, offset, regval);
+ acpi_write_pmreg(sc, ACPIREG_PM1B_STS, offset, regval);
+ break;
+ case ACPIREG_PM1_CNT:
+ acpi_write_pmreg(sc, ACPIREG_PM1A_CNT, offset, regval);
+ acpi_write_pmreg(sc, ACPIREG_PM1B_CNT, offset, regval);
+ break;
+ case ACPIREG_GPE_STS:
+ __size = 1;
+ dnprintf(50, "write GPE_STS offset: %.2x %.2x %.2x %.2x\n",
+ offset, sc->sc_fadt->gpe0_blk_len>>1,
+ sc->sc_fadt->gpe1_blk_len>>1, regval);
+ if (offset < (sc->sc_fadt->gpe0_blk_len >> 1)) {
+ reg = ACPIREG_GPE0_STS;
+ }
+ break;
+ case ACPIREG_GPE_EN:
+ __size = 1;
+ dnprintf(50, "write GPE_EN offset: %.2x %.2x %.2x %.2x\n",
+ offset, sc->sc_fadt->gpe0_blk_len>>1,
+ sc->sc_fadt->gpe1_blk_len>>1, regval);
+ if (offset < (sc->sc_fadt->gpe0_blk_len >> 1)) {
+ reg = ACPIREG_GPE0_EN;
+ }
+ break;
+ }
+
+ /* All special case return here */
+ if (reg >= ACPIREG_MAXREG)
+ return;
+
+ ioh = sc->sc_pmregs[reg].ioh;
+ size = sc->sc_pmregs[reg].size;
+ if (__size)
+ size = __size;
+ if (size > 4)
+ size = 4;
+ switch (size) {
+ case 1:
+ bus_space_write_1(sc->sc_iot, ioh, offset, regval);
+ break;
+ case 2:
+ bus_space_write_2(sc->sc_iot, ioh, offset, regval);
+ break;
+ case 4:
+ bus_space_write_4(sc->sc_iot, ioh, offset, regval);
+ break;
+ }
+
+ dnprintf(30, "acpi_writepm: %s = %.4x:%.4x %x\n",
+ sc->sc_pmregs[reg].name, sc->sc_pmregs[reg].addr, offset, regval);
+}
+
/* move all stuff that doesn't go on the boot media in here */
#ifndef SMALL_KERNEL
int
@@ -1575,142 +1711,6 @@ acpi_map_pmregs(struct acpi_softc *sc)
}
}
-/* Read from power management register */
-int
-acpi_read_pmreg(struct acpi_softc *sc, int reg, int offset)
-{
- bus_space_handle_t ioh;
- bus_size_t size, __size;
- int regval;
-
- __size = 0;
- /* Special cases: 1A/1B blocks can be OR'ed together */
- switch (reg) {
- case ACPIREG_PM1_EN:
- return (acpi_read_pmreg(sc, ACPIREG_PM1A_EN, offset) |
- acpi_read_pmreg(sc, ACPIREG_PM1B_EN, offset));
- case ACPIREG_PM1_STS:
- return (acpi_read_pmreg(sc, ACPIREG_PM1A_STS, offset) |
- acpi_read_pmreg(sc, ACPIREG_PM1B_STS, offset));
- case ACPIREG_PM1_CNT:
- return (acpi_read_pmreg(sc, ACPIREG_PM1A_CNT, offset) |
- acpi_read_pmreg(sc, ACPIREG_PM1B_CNT, offset));
- case ACPIREG_GPE_STS:
- __size = 1;
- dnprintf(50, "read GPE_STS offset: %.2x %.2x %.2x\n", offset,
- sc->sc_fadt->gpe0_blk_len>>1, sc->sc_fadt->gpe1_blk_len>>1);
- if (offset < (sc->sc_fadt->gpe0_blk_len >> 1)) {
- reg = ACPIREG_GPE0_STS;
- }
- break;
- case ACPIREG_GPE_EN:
- __size = 1;
- dnprintf(50, "read GPE_EN offset: %.2x %.2x %.2x\n",
- offset, sc->sc_fadt->gpe0_blk_len>>1,
- sc->sc_fadt->gpe1_blk_len>>1);
- if (offset < (sc->sc_fadt->gpe0_blk_len >> 1)) {
- reg = ACPIREG_GPE0_EN;
- }
- break;
- }
-
- if (reg >= ACPIREG_MAXREG || sc->sc_pmregs[reg].size == 0)
- return (0);
-
- regval = 0;
- ioh = sc->sc_pmregs[reg].ioh;
- size = sc->sc_pmregs[reg].size;
- if (__size)
- size = __size;
- if (size > 4)
- size = 4;
-
- switch (size) {
- case 1:
- regval = bus_space_read_1(sc->sc_iot, ioh, offset);
- break;
- case 2:
- regval = bus_space_read_2(sc->sc_iot, ioh, offset);
- break;
- case 4:
- regval = bus_space_read_4(sc->sc_iot, ioh, offset);
- break;
- }
-
- dnprintf(30, "acpi_readpm: %s = %.4x:%.4x %x\n",
- sc->sc_pmregs[reg].name,
- sc->sc_pmregs[reg].addr, offset, regval);
- return (regval);
-}
-
-/* Write to power management register */
-void
-acpi_write_pmreg(struct acpi_softc *sc, int reg, int offset, int regval)
-{
- bus_space_handle_t ioh;
- bus_size_t size, __size;
-
- __size = 0;
- /* Special cases: 1A/1B blocks can be written with same value */
- switch (reg) {
- case ACPIREG_PM1_EN:
- acpi_write_pmreg(sc, ACPIREG_PM1A_EN, offset, regval);
- acpi_write_pmreg(sc, ACPIREG_PM1B_EN, offset, regval);
- break;
- case ACPIREG_PM1_STS:
- acpi_write_pmreg(sc, ACPIREG_PM1A_STS, offset, regval);
- acpi_write_pmreg(sc, ACPIREG_PM1B_STS, offset, regval);
- break;
- case ACPIREG_PM1_CNT:
- acpi_write_pmreg(sc, ACPIREG_PM1A_CNT, offset, regval);
- acpi_write_pmreg(sc, ACPIREG_PM1B_CNT, offset, regval);
- break;
- case ACPIREG_GPE_STS:
- __size = 1;
- dnprintf(50, "write GPE_STS offset: %.2x %.2x %.2x %.2x\n",
- offset, sc->sc_fadt->gpe0_blk_len>>1,
- sc->sc_fadt->gpe1_blk_len>>1, regval);
- if (offset < (sc->sc_fadt->gpe0_blk_len >> 1)) {
- reg = ACPIREG_GPE0_STS;
- }
- break;
- case ACPIREG_GPE_EN:
- __size = 1;
- dnprintf(50, "write GPE_EN offset: %.2x %.2x %.2x %.2x\n",
- offset, sc->sc_fadt->gpe0_blk_len>>1,
- sc->sc_fadt->gpe1_blk_len>>1, regval);
- if (offset < (sc->sc_fadt->gpe0_blk_len >> 1)) {
- reg = ACPIREG_GPE0_EN;
- }
- break;
- }
-
- /* All special case return here */
- if (reg >= ACPIREG_MAXREG)
- return;
-
- ioh = sc->sc_pmregs[reg].ioh;
- size = sc->sc_pmregs[reg].size;
- if (__size)
- size = __size;
- if (size > 4)
- size = 4;
- switch (size) {
- case 1:
- bus_space_write_1(sc->sc_iot, ioh, offset, regval);
- break;
- case 2:
- bus_space_write_2(sc->sc_iot, ioh, offset, regval);
- break;
- case 4:
- bus_space_write_4(sc->sc_iot, ioh, offset, regval);
- break;
- }
-
- dnprintf(30, "acpi_writepm: %s = %.4x:%.4x %x\n",
- sc->sc_pmregs[reg].name, sc->sc_pmregs[reg].addr, offset, regval);
-}
-
int
acpi_foundec(struct aml_node *node, void *arg)
{