diff options
author | Marco Peereboom <marco@cvs.openbsd.org> | 2006-02-19 04:50:48 +0000 |
---|---|---|
committer | Marco Peereboom <marco@cvs.openbsd.org> | 2006-02-19 04:50:48 +0000 |
commit | 145770fa9bc425bb5ca9cbf0fad51f7c2a42a256 (patch) | |
tree | 2646a521dbd9d32c1a59804d363c8b8d0ed976f6 | |
parent | 5f50945fa963bcbb2a85a9a31a6cd5434c8fa835 (diff) |
jordan:
Enable interrupts.
Added peripheral code to make this work.
marco:
Replace softintr and other types of interrupts with a handler with context.
Fixed interrupt magic for GPEs.
Some KNF
This is work done by jordan and I but has to be a single commit.
-rw-r--r-- | sys/dev/acpi/acpi.c | 251 | ||||
-rw-r--r-- | sys/dev/acpi/acpivar.h | 48 | ||||
-rw-r--r-- | sys/dev/acpi/dsdt.c | 64 | ||||
-rw-r--r-- | sys/dev/acpi/dsdt.h | 4 |
4 files changed, 239 insertions, 128 deletions
diff --git a/sys/dev/acpi/acpi.c b/sys/dev/acpi/acpi.c index 2b127c583c7..aa8be64ed10 100644 --- a/sys/dev/acpi/acpi.c +++ b/sys/dev/acpi/acpi.c @@ -1,4 +1,4 @@ -/* $OpenBSD: acpi.c,v 1.33 2006/02/17 17:42:52 marco Exp $ */ +/* $OpenBSD: acpi.c,v 1.34 2006/02/19 04:50:46 marco Exp $ */ /* * Copyright (c) 2005 Thorsten Lockert <tholo@sigmasoft.com> * Copyright (c) 2005 Jordan Hargrave <jordan@openbsd.org> @@ -25,6 +25,7 @@ #include <sys/event.h> #include <sys/signalvar.h> #include <sys/proc.h> +#include <sys/kthread.h> #include <machine/conf.h> #include <machine/bus.h> @@ -33,6 +34,7 @@ #include <dev/acpi/acpireg.h> #include <dev/acpi/acpivar.h> #include <dev/acpi/amltypes.h> +#include <dev/acpi/acpidev.h> #include <dev/acpi/dsdt.h> #ifdef ACPI_DEBUG @@ -41,6 +43,9 @@ int acpi_debug = 11; #define ACPIEN_RETRIES 15 +void acpi_isr_thread(void *); +void acpi_create_thread(void *); + int acpi_match(struct device *, void *, void *); void acpi_attach(struct device *, struct device *, void *); int acpi_submatch(struct device *, void *, void *); @@ -53,14 +58,14 @@ void acpi_write_pmreg(struct acpi_softc *, int, int); void acpi_gpe(struct aml_node *, void *); void acpi_foundhid(struct aml_node *, void *); -void acpi_inidev(struct aml_node *, void *); +void acpi_inidev(struct aml_node *, void *); int acpi_loadtables(struct acpi_softc *, struct acpi_rsdp *); void acpi_load_table(paddr_t, size_t, acpi_qhead_t *); void acpi_load_dsdt(paddr_t, struct acpi_q **); -void acpi_softintr(void *); void acpi_init_states(struct acpi_softc *); +void acpi_init_gpes(struct acpi_softc *); void acpi_filtdetach(struct knote *); int acpi_filtread(struct knote *, long); @@ -309,6 +314,9 @@ acpi_map_pmregs(struct acpi_softc *sc) name = "gpe0_sts"; size = sc->sc_fadt->gpe0_blk_len >> 1; addr = sc->sc_fadt->gpe0_blk; + + dnprintf(10, "gpe0 block len : %x\n", sc->sc_fadt->gpe0_blk_len >> 1); + dnprintf(10, "gpe0 block addr: %x\n", sc->sc_fadt->gpe0_blk); if (reg == ACPIREG_GPE0_EN && addr) { addr += size; name = "gpe0_en"; @@ -319,6 +327,9 @@ acpi_map_pmregs(struct acpi_softc *sc) name = "gpe1_sts"; size = sc->sc_fadt->gpe1_blk_len >> 1; addr = sc->sc_fadt->gpe1_blk; + + dnprintf(10, "gpe1 block len : %x\n", sc->sc_fadt->gpe1_blk_len >> 1); + dnprintf(10, "gpe1 block addr: %x\n", sc->sc_fadt->gpe1_blk); if (reg == ACPIREG_GPE1_EN && addr) { addr += size; name = "gpe1_en"; @@ -327,7 +338,7 @@ acpi_map_pmregs(struct acpi_softc *sc) } if (size && addr) { dnprintf(50, "mapping: %.4x %.4x %s\n", - addr, size, name); + addr, size, name); /* Size and address exist; map register space */ bus_space_map(sc->sc_iot, addr, size, 0, @@ -397,8 +408,8 @@ acpi_read_pmreg(struct acpi_softc *sc, int reg) } dnprintf(30, "acpi_readpm: %s = %.4x %x\n", - sc->sc_pmregs[reg].name, - sc->sc_pmregs[reg].addr, regval); + sc->sc_pmregs[reg].name, + sc->sc_pmregs[reg].addr, regval); return (regval); } @@ -489,13 +500,13 @@ acpi_foundhid(struct aml_node *node, void *arg) dev = aml_strval(&res); break; case AML_OBJTYPE_INTEGER: - dev = aml_eisaid(res.v_integer); + dev = aml_eisaid(aml_val2int(NULL, &res)); break; default: dev = "unknown"; break; } - dnprintf(20, " device: %s\n", dev); + dnprintf(20, " device: %s\n", dev); if (!strcmp(dev, ACPI_DEV_AC)) { struct acpi_attach_args aaa; @@ -620,6 +631,9 @@ acpi_attach(struct device *parent, struct device *self, void *aux) /* Find available sleeping states */ acpi_init_states(sc); + /* Initialize GPE handlers */ + acpi_init_gpes(sc); + /* * Set up a pointer to the firmware control structure */ @@ -658,43 +672,8 @@ acpi_attach(struct device *parent, struct device *self, void *aux) } while (!(acpi_read_pmreg(sc, ACPIREG_PM1_CNT) & ACPI_PM1_SCI_EN)); #endif -#ifdef __HAVE_GENERIC_SOFT_INTERRUPTS - sc->sc_softih = softintr_establish(IPL_TTY, acpi_softintr, sc); -#else - timeout_set(&sc->sc_timeout, acpi_softintr, sc); -#endif acpi_attach_machdep(sc); - /* - * If we have an interrupt handler, we can get notification - * when certain status bits changes in the ACPI registers, - * so let us enable some events we can forward to userland - */ - if (sc->sc_interrupt) { - int16_t flag; - - dnprintf(1,"slpbtn:%c pwrbtn:%c\n", - sc->sc_fadt->flags & FADT_SLP_BUTTON ? 'n' : 'y', - sc->sc_fadt->flags & FADT_PWR_BUTTON ? 'n' : 'y'); - - /* Enable Sleep/Power buttons if they exist */ - flag = acpi_read_pmreg(sc, ACPIREG_PM1_EN); - if (!(sc->sc_fadt->flags & FADT_PWR_BUTTON)) { - flag |= ACPI_PM1_PWRBTN_EN; - } - if (!(sc->sc_fadt->flags & FADT_SLP_BUTTON)) { - flag |= ACPI_PM1_SLPBTN_EN; - } - acpi_write_pmreg(sc, ACPIREG_PM1_EN, flag); - -#if 0 - flag = acpi_read_pmreg(sc, ACPIREG_GPE0_STS); - acpi_write_pmreg(sc, ACPIREG_GPE0_STS, flag); - acpi_write_pmreg(sc, ACPIREG_GPE0_EN, 0); - acpi_write_pmreg(sc, ACPIREG_GPE0_EN, (1L << 0x1D)); -#endif - } - printf("\n"); /* @@ -734,13 +713,18 @@ acpi_attach(struct device *parent, struct device *self, void *aux) acpi_softc = sc; -#if 1 /* attach devices found in dsdt */ aml_find_node(aml_root.child, "_INI", acpi_inidev, sc); -#endif /* attach devices found in dsdt */ aml_find_node(aml_root.child, "_HID", acpi_foundhid, sc); + + /* Setup threads */ + sc->sc_thread = malloc(sizeof(struct acpi_thread), M_DEVBUF, M_WAITOK); + sc->sc_thread->sc = sc; + sc->sc_thread->running = 1; + + kthread_create_deferred(acpi_create_thread, sc); } int @@ -807,11 +791,11 @@ acpi_loadtables(struct acpi_softc *sc, struct acpi_rsdp *rsdp) xsdt = (struct acpi_xsdt *)hrsdt.va; ntables = (len - sizeof(struct acpi_table_header)) / - sizeof(xsdt->table_offsets[0]); + sizeof(xsdt->table_offsets[0]); for (i = 0; i < ntables; i++) { acpi_map(xsdt->table_offsets[i], sizeof(*hdr), - &handle); + &handle); hdr = (struct acpi_table_header *)handle.va; acpi_load_table(xsdt->table_offsets[i], hdr->length, &sc->sc_tables); @@ -835,11 +819,11 @@ acpi_loadtables(struct acpi_softc *sc, struct acpi_rsdp *rsdp) rsdt = (struct acpi_rsdt *)hrsdt.va; ntables = (len - sizeof(struct acpi_table_header)) / - sizeof(rsdt->table_offsets[0]); + sizeof(rsdt->table_offsets[0]); for (i = 0; i < ntables; i++) { acpi_map(rsdt->table_offsets[i], sizeof(*hdr), - &handle); + &handle); hdr = (struct acpi_table_header *)handle.va; acpi_load_table(rsdt->table_offsets[i], hdr->length, &sc->sc_tables); @@ -910,15 +894,13 @@ acpi_interrupt(void *arg) en = acpi_read_pmreg(sc, ACPIREG_GPE0_EN); if (sts & en) { dnprintf(10, "GPE interrupt: %.8x %.8x %.8x\n", - sts, en, sts & en); + sts, en, sts & en); + /* disable interrupts until handled */ acpi_write_pmreg(sc, ACPIREG_GPE0_EN, en & ~sts); - acpi_write_pmreg(sc, ACPIREG_GPE0_STS,en); - acpi_write_pmreg(sc, ACPIREG_GPE0_EN, en); + + sc->sc_gpe_sts = sts; + sc->sc_gpe_en = en; processed = 1; - for (en = 0; en < icount; en++) { - icount = (icount << 1) | 1; - } - icount++; } sts = acpi_read_pmreg(sc, ACPIREG_PM1_STS); @@ -935,40 +917,42 @@ acpi_interrupt(void *arg) processed = 1; } if (processed) { -#ifdef __HAVE_GENERIC_SOFT_INTERRUPTS - softintr_schedule(sc->sc_softih); -#else - if (!timeout_pending(&sc->sc_timeout)) - timeout_add(&sc->sc_timeout, 0); -#endif + sc->sc_wakeup = 0; + wakeup(sc); } return (processed); } void -acpi_softintr(void *arg) +acpi_init_gpes(struct acpi_softc *sc) { - struct acpi_softc *sc = arg; - - if (sc->sc_powerbtn) { - sc->sc_powerbtn = 0; - acpi_evindex++; - dnprintf(1,"power button pressed\n"); - KNOTE(sc->sc_note, ACPI_EVENT_COMPOSE(ACPI_EV_PWRBTN, - acpi_evindex)); - - /* power down */ - acpi_s5 = 1; - psignal(initproc, SIGUSR1); - } - if (sc->sc_sleepbtn) { - sc->sc_sleepbtn = 0; - acpi_evindex++; - dnprintf(1,"sleep button pressed\n"); - KNOTE(sc->sc_note, ACPI_EVENT_COMPOSE(ACPI_EV_SLPBTN, - acpi_evindex)); + struct aml_node *gpe; + char name[12]; + int idx, ngpe; + + ngpe = 0; + memset(sc->sc_gpes, 0, sizeof(sc->sc_gpes)); + for (idx=0; idx<256; idx++) { + + /* Search Level-sensitive GPES */ + sc->sc_gpes[ngpe].gpe_type = GPE_LEVEL; + snprintf(name, sizeof(name), "\\_GPE._L%.2X", idx); + gpe = aml_searchname(&aml_root, name); + if (gpe == NULL) { + /* Search Edge-sensitive GPES */ + sc->sc_gpes[ngpe].gpe_type = GPE_EDGE; + snprintf(name, sizeof(name), "\\_GPE._E%.2X", idx); + gpe = aml_searchname(&aml_root, name); + } + if (gpe != NULL) { + sc->sc_gpes[ngpe].gpe_number = idx; + sc->sc_gpes[ngpe].gpe_handler = gpe; + dnprintf(10, "%s exists\n", name); + ngpe++; + } } + sc->sc_maxgpe = ngpe; } void @@ -1150,3 +1134,106 @@ acpikqfilter(dev_t dev, struct knote *kn) return (0); } + +void +acpi_isr_thread(void *arg) +{ + struct acpi_thread *thread = arg; + struct acpi_softc *sc = thread->sc; + u_int32_t gpemask, gpe; + struct aml_value res; + u_int32_t sts, en; + + /* + * If we have an interrupt handler, we can get notification + * when certain status bits changes in the ACPI registers, + * so let us enable some events we can forward to userland + */ + if (sc->sc_interrupt) { + int16_t flag; + + dnprintf(1,"slpbtn:%c pwrbtn:%c\n", + sc->sc_fadt->flags & FADT_SLP_BUTTON ? 'n' : 'y', + sc->sc_fadt->flags & FADT_PWR_BUTTON ? 'n' : 'y'); + dnprintf(10, "Enabling acpi interrupts...\n"); + sc->sc_wakeup = 1; + + /* Enable Sleep/Power buttons if they exist */ + flag = acpi_read_pmreg(sc, ACPIREG_PM1_EN); + if (!(sc->sc_fadt->flags & FADT_PWR_BUTTON)) { + flag |= ACPI_PM1_PWRBTN_EN; + } + if (!(sc->sc_fadt->flags & FADT_SLP_BUTTON)) { + flag |= ACPI_PM1_SLPBTN_EN; + } + acpi_write_pmreg(sc, ACPIREG_PM1_EN, flag); + + /* Clear GPE interrupts */ + acpi_write_pmreg(sc, ACPIREG_GPE0_EN, 0); + acpi_write_pmreg(sc, ACPIREG_GPE0_STS, -1); + + /* XXX: Enable GPEs _L1D */ + acpi_write_pmreg(sc, ACPIREG_GPE0_EN, (1L << 0x1D)); + } + + while (thread->running) { + dnprintf(10, "sleep...\n"); + while (sc->sc_wakeup) + tsleep(sc, PWAIT, "acpi_idle", 0); + sc->sc_wakeup = 1; + dnprintf(10, "wakeup..\n"); + + sts = sc->sc_gpe_sts; + en = sc->sc_gpe_en; + if (en & sts) { + sc->sc_gpe_en = 0; + sc->sc_gpe_sts = 0; + + gpemask = en & sts; + dnprintf(10, "softgpe: %x\n", en & sts); + for (gpe=0; gpe<sc->sc_maxgpe; gpe++) { + if (gpemask & (1L << sc->sc_gpes[gpe].gpe_number)) { + dnprintf(10, "Got GPE: %x %x\n", gpe, sc->sc_gpes[gpe].gpe_number); + aml_eval_object(sc, sc->sc_gpes[gpe].gpe_handler, &res, 0, NULL); + } + } + acpi_write_pmreg(sc, ACPIREG_GPE0_STS, en & sts); + acpi_write_pmreg(sc, ACPIREG_GPE0_EN, en); + } + + if (sc->sc_powerbtn) { + sc->sc_powerbtn = 0; + acpi_evindex++; + dnprintf(1,"power button pressed\n"); + KNOTE(sc->sc_note, ACPI_EVENT_COMPOSE(ACPI_EV_PWRBTN, + acpi_evindex)); + + /* power down */ + acpi_s5 = 1; + psignal(initproc, SIGUSR1); + } + if (sc->sc_sleepbtn) { + sc->sc_sleepbtn = 0; + acpi_evindex++; + dnprintf(1,"sleep button pressed\n"); + KNOTE(sc->sc_note, ACPI_EVENT_COMPOSE(ACPI_EV_SLPBTN, + acpi_evindex)); + } + } + free(thread, M_DEVBUF); + + kthread_exit(0); +} + +void +acpi_create_thread(void *arg) +{ + struct acpi_softc *sc = arg; + + if (kthread_create(acpi_isr_thread, sc->sc_thread, NULL, + DEVNAME(sc)) != 0) { + printf("%s: unable to create isr thread, GPEs disabled\n", + DEVNAME(sc)); + return; + } +} diff --git a/sys/dev/acpi/acpivar.h b/sys/dev/acpi/acpivar.h index dc0bb680413..5dbd010417b 100644 --- a/sys/dev/acpi/acpivar.h +++ b/sys/dev/acpi/acpivar.h @@ -1,4 +1,4 @@ -/* $OpenBSD: acpivar.h,v 1.15 2006/02/17 17:35:59 marco Exp $ */ +/* $OpenBSD: acpivar.h,v 1.16 2006/02/19 04:50:46 marco Exp $ */ /* * Copyright (c) 2005 Thorsten Lockert <tholo@sigmasoft.com> * @@ -90,21 +90,26 @@ struct acpi_reg_map { const char *name; }; +struct acpi_thread { + struct acpi_softc *sc; + volatile int running; +}; + struct acpi_softc { - struct device sc_dev; + struct device sc_dev; - bus_space_tag_t sc_iot; - bus_space_tag_t sc_memt; + bus_space_tag_t sc_iot; + bus_space_tag_t sc_memt; #if 0 - bus_space_tag_t sc_pcit; - bus_space_tag_t sc_smbust; + bus_space_tag_t sc_pcit; + bus_space_tag_t sc_smbust; #endif /* * First-level ACPI tables */ struct acpi_fadt *sc_fadt; - acpi_qhead_t sc_tables; + acpi_qhead_t sc_tables; /* * Second-level information from FADT @@ -112,25 +117,42 @@ struct acpi_softc { struct acpi_facs *sc_facs; /* Shared with firmware! */ struct klist *sc_note; - struct acpi_reg_map sc_pmregs[ACPIREG_MAXREG]; - bus_space_handle_t sc_ioh_pm1a_evt; + struct acpi_reg_map sc_pmregs[ACPIREG_MAXREG]; + bus_space_handle_t sc_ioh_pm1a_evt; void *sc_interrupt; #ifdef __HAVE_GENERIC_SOFT_INTERRUPTS void *sc_softih; #else - struct timeout sc_timeout; + struct timeout sc_timeout; #endif - int sc_powerbtn; - int sc_sleepbtn; + int sc_powerbtn; + int sc_sleepbtn; + u_int32_t sc_gpemask; struct { int slp_typa; int slp_typb; - } sc_sleeptype[5]; + } sc_sleeptype[5]; + + struct { + int gpe_type; + int gpe_number; + struct aml_node *gpe_handler; + } sc_gpes[256]; + int sc_maxgpe; + + int sc_wakeup; + u_int32_t sc_gpe_sts; + u_int32_t sc_gpe_en; + struct acpi_thread *sc_thread; }; +#define GPE_NONE 0x00 +#define GPE_LEVEL 0x01 +#define GPE_EDGE 0x02 + struct acpi_table { int offset; size_t size; diff --git a/sys/dev/acpi/dsdt.c b/sys/dev/acpi/dsdt.c index 73d9320c97c..cd8508a5e2a 100644 --- a/sys/dev/acpi/dsdt.c +++ b/sys/dev/acpi/dsdt.c @@ -1,4 +1,4 @@ -/* $OpenBSD: dsdt.c,v 1.23 2006/02/17 17:35:59 marco Exp $ */ +/* $OpenBSD: dsdt.c,v 1.24 2006/02/19 04:50:47 marco Exp $ */ /* * Copyright (c) 2005 Jordan Hargrave <jordan@openbsd.org> * @@ -233,8 +233,9 @@ aml_setbit(u_int8_t *pb, int bit, int val) } } -void aml_addchildnode(struct aml_node *parent, - struct aml_node *child) +void +aml_addchildnode(struct aml_node *parent, + struct aml_node *child) { struct aml_node **tmp; @@ -246,8 +247,9 @@ void aml_addchildnode(struct aml_node *parent, *tmp = child; } -struct aml_node *aml_create_node(struct aml_node *parent, int opcode, - const char *mnem, u_int8_t *start) +struct aml_node * +aml_create_node(struct aml_node *parent, int opcode, + const char *mnem, u_int8_t *start) { struct aml_node *node; @@ -299,6 +301,8 @@ aml_allocvalue(int type, int64_t ival, void *bval) break; case AML_OBJTYPE_STRING: /* Allocate string: if pointer valid, copy data */ + if (ival < 0) + ival = strlen((const char *)bval); rv->length = ival; if (ival) { rv->v_string = acpi_os_allocmem(ival+1); @@ -357,7 +361,7 @@ aml_allocint(u_int64_t ival) struct aml_value * aml_allocstr(const char *str) { - return aml_allocvalue(AML_OBJTYPE_STRING, strlen(str), (void *)str); + return aml_allocvalue(AML_OBJTYPE_STRING, -1, (void *)str); } int @@ -518,6 +522,7 @@ aml_comparevalue(struct acpi_context *ctx, int opcode, struct aml_value *lhs, if (rhs->type == AML_OBJTYPE_INTEGER) { return aml_logicalcmp(opcode, aml_val2int(ctx, lhs), rhs->v_integer); } + /* XXX: fix this.. non integer comparisons */ dnprintf(40,"comparevalue: %.2x %.2x\n", lhs->type, rhs->type); return 0; } @@ -736,12 +741,10 @@ aml_isnamedop(u_int16_t opcode) case AMLOP_MULTINAMEPREFIX: case AMLOP_DUALNAMEPREFIX: case AMLOP_NAMECHAR: + case 'A' ... 'Z': return (1); } - if (opcode >= 'A' && opcode <= 'Z') - return (1); - return (0); } @@ -816,8 +819,10 @@ aml_evalmath(u_int16_t opcode, int64_t lhs, int64_t rhs) { dnprintf(50, "evalmath: %s %lld %lld\n", aml_opname(opcode), lhs, rhs); switch (opcode) { + case AMLOP_INCREMENT: case AMLOP_ADD: return (lhs + rhs); + case AMLOP_DECREMENT: case AMLOP_SUBTRACT: return (lhs - rhs); case AMLOP_MULTIPLY: @@ -840,10 +845,6 @@ aml_evalmath(u_int16_t opcode, int64_t lhs, int64_t rhs) return ~(lhs | rhs); case AMLOP_XOR: return (lhs ^ rhs); - case AMLOP_INCREMENT: - return (lhs + 1); - case AMLOP_DECREMENT: - return (lhs - 1); case AMLOP_FINDSETLEFTBIT: return aml_msb(lhs); case AMLOP_FINDSETRIGHTBIT: @@ -1050,9 +1051,8 @@ struct aml_opcode *aml_getopcode(struct acpi_context *ctx) u_int16_t twocode, opcode; /* Check if this is a name object */ - if (aml_isnamedop(*ctx->pos)) { + if (aml_isnamedop(*ctx->pos)) opcode = AMLOP_NAMECHAR; - } else { opcode = aml_parse_int(ctx, AML_BYTE); twocode = (opcode << 8L) + *ctx->pos; @@ -1170,13 +1170,11 @@ aml_bufcpy(u_int8_t *pDst, int dstPos, const u_int8_t *pSrc, int srcPos, if (aml_bytealigned(dstPos|srcPos|len)) { /* Aligned transfer: use memcpy */ memcpy(pDst+aml_bytepos(dstPos), pSrc+aml_bytepos(srcPos), aml_bytelen(len)); + return; } - else { - /* Misaligned transfer: perform bitwise copy */ - for (idx=0; idx<len; idx++) { - aml_setbit(pDst, idx+dstPos, aml_tstbit(pSrc, idx+srcPos)); - } - } + /* Misaligned transfer: perform bitwise copy */ + for (idx = 0; idx < len; idx++) + aml_setbit(pDst, idx + dstPos, aml_tstbit(pSrc, idx + srcPos)); } /* Search list of objects for a name match @@ -1713,6 +1711,8 @@ struct aml_value * aml_esetnodevalue(struct acpi_context *ctx, struct aml_value *lhs, struct aml_value *rhs, int64_t rval) { + struct aml_value *tmp; + if (rhs == NULL) { rhs = aml_allocint(rval); } @@ -1723,28 +1723,28 @@ aml_esetnodevalue(struct acpi_context *ctx, struct aml_value *lhs, dnprintf(50, "current: "); aml_showvalue(lhs); - while (lhs->type == AML_OBJTYPE_OBJREF) { - lhs = aml_ederef(ctx, lhs); - } - - switch (lhs->type) { + tmp = aml_ederef(ctx, lhs); + switch (tmp->type) { case AML_OBJTYPE_UNINITIALIZED: /* Object is not initialized */ - *lhs = *rhs; + *tmp = *rhs; break; case AML_OBJTYPE_FIELDUNIT: case AML_OBJTYPE_BUFFERFIELD: - aml_efield(ctx, lhs, rhs); + aml_efield(ctx, tmp, rhs); break; case AML_OBJTYPE_STATICINT: /* Read-only */ break; default: /* Object is already initialized, free old value */ - _aml_freevalue(lhs); - *lhs = *rhs; + _aml_freevalue(tmp); + *tmp = *rhs; + } + aml_showvalue(tmp); + if (tmp != lhs) { + aml_freevalue(&tmp); } - aml_showvalue(lhs); dnprintf(50, "--------- post set ----------\n"); return rhs; } @@ -2360,7 +2360,7 @@ aml_eparseval(struct acpi_context *ctx, int deref) case AMLOP_NOTIFY: lhs = aml_eparseval(ctx, 1); i1 = aml_eparseint(ctx, AML_ANYINT); - dnprintf(40, "NOTIFY: %llx %s\n", i1, lhs->name); + dnprintf(10, "NOTIFY: %llx %s\n", i1, lhs->name); break; case AMLOP_LOAD: case AMLOP_STORE: diff --git a/sys/dev/acpi/dsdt.h b/sys/dev/acpi/dsdt.h index 47dfbfae6a7..1316c724cde 100644 --- a/sys/dev/acpi/dsdt.h +++ b/sys/dev/acpi/dsdt.h @@ -1,4 +1,4 @@ -/* $OpenBSD: dsdt.h,v 1.6 2006/02/16 21:11:13 jordan Exp $ */ +/* $OpenBSD: dsdt.h,v 1.7 2006/02/19 04:50:47 marco Exp $ */ /* * Copyright (c) 2005 Marco Peereboom <marco@openbsd.org> * @@ -43,4 +43,6 @@ int aml_comparevalue(struct acpi_context *, int, struct aml_value *, struct am int64_t aml_val2int(struct acpi_context *, struct aml_value *); +struct aml_node *aml_searchname(struct aml_node *, const char *); + #endif /* __DEV_ACPI_DSDT_H__ */ |