diff options
Diffstat (limited to 'sys/dev/acpi')
-rw-r--r-- | sys/dev/acpi/acpi.c | 21 | ||||
-rw-r--r-- | sys/dev/acpi/acpivar.h | 5 | ||||
-rw-r--r-- | sys/dev/acpi/dsdt.c | 56 | ||||
-rw-r--r-- | sys/dev/acpi/dsdt.h | 7 |
4 files changed, 85 insertions, 4 deletions
diff --git a/sys/dev/acpi/acpi.c b/sys/dev/acpi/acpi.c index b5d102a54ee..06111abcad1 100644 --- a/sys/dev/acpi/acpi.c +++ b/sys/dev/acpi/acpi.c @@ -1,4 +1,4 @@ -/* $OpenBSD: acpi.c,v 1.35 2006/02/19 19:03:49 grange Exp $ */ +/* $OpenBSD: acpi.c,v 1.36 2006/02/19 21:32:30 jordan Exp $ */ /* * Copyright (c) 2005 Thorsten Lockert <tholo@sigmasoft.com> * Copyright (c) 2005 Jordan Hargrave <jordan@openbsd.org> @@ -527,6 +527,19 @@ acpi_foundhid(struct aml_node *node, void *arg) aaa.aaa_memt = sc->sc_memt; aaa.aaa_node = node->parent; config_found(self, &aaa, acpi_print); + } else if (!strcmp(dev, ACPI_DEV_LD) || + !strcmp(dev, ACPI_DEV_PBD) || + !strcmp(dev, ACPI_DEV_SBD)) { +#if 0 + struct acpi_attach_args aaa; + + memset(&aaa, 0, sizeof(aaa)); + aaa.aaa_name = "acpibtn"; + aaa.aaa_iot = sc->sc_iot; + aaa.aaa_memt = sc->sc_memt; + aaa.aaa_node = node->parent; + config_found(self, &aaa, acpi_print); +#endif } } @@ -1242,6 +1255,9 @@ acpi_isr_thread(void *arg) if (sc->sc_powerbtn) { sc->sc_powerbtn = 0; + + if (sc->sc_pbtndev) + aml_notify(sc->sc_pbtndev, 0x80); acpi_evindex++; dnprintf(1,"power button pressed\n"); KNOTE(sc->sc_note, ACPI_EVENT_COMPOSE(ACPI_EV_PWRBTN, @@ -1253,6 +1269,9 @@ acpi_isr_thread(void *arg) } if (sc->sc_sleepbtn) { sc->sc_sleepbtn = 0; + + if (sc->sc_sbtndev) + aml_notify(sc->sc_sbtndev, 0x80); acpi_evindex++; dnprintf(1,"sleep button pressed\n"); KNOTE(sc->sc_note, ACPI_EVENT_COMPOSE(ACPI_EV_SLPBTN, diff --git a/sys/dev/acpi/acpivar.h b/sys/dev/acpi/acpivar.h index 5dbd010417b..1e1c37789b9 100644 --- a/sys/dev/acpi/acpivar.h +++ b/sys/dev/acpi/acpivar.h @@ -1,4 +1,4 @@ -/* $OpenBSD: acpivar.h,v 1.16 2006/02/19 04:50:46 marco Exp $ */ +/* $OpenBSD: acpivar.h,v 1.17 2006/02/19 21:32:30 jordan Exp $ */ /* * Copyright (c) 2005 Thorsten Lockert <tholo@sigmasoft.com> * @@ -147,6 +147,9 @@ struct acpi_softc { u_int32_t sc_gpe_sts; u_int32_t sc_gpe_en; struct acpi_thread *sc_thread; + + struct aml_node *sc_pbtndev; + struct aml_node *sc_sbtndev; }; #define GPE_NONE 0x00 diff --git a/sys/dev/acpi/dsdt.c b/sys/dev/acpi/dsdt.c index cd8508a5e2a..5fb1713ef8d 100644 --- a/sys/dev/acpi/dsdt.c +++ b/sys/dev/acpi/dsdt.c @@ -1,4 +1,4 @@ -/* $OpenBSD: dsdt.c,v 1.24 2006/02/19 04:50:47 marco Exp $ */ +/* $OpenBSD: dsdt.c,v 1.25 2006/02/19 21:32:30 jordan Exp $ */ /* * Copyright (c) 2005 Jordan Hargrave <jordan@openbsd.org> * @@ -233,6 +233,56 @@ aml_setbit(u_int8_t *pb, int bit, int val) } } +/*===================================== + * This code handles AML notifications + *=====================================*/ +struct aml_notify_data +{ + struct aml_node *node; + void *cbarg; + int (*cbproc)(struct aml_node *, int, void *); + + SLIST_ENTRY(aml_notify_data) link; +}; + +SLIST_HEAD(aml_notify_head, aml_notify_data); +struct aml_notify_head aml_notify_list = + SLIST_HEAD_INITIALIZER(&aml_notify_list); + +void aml_register_notify(struct aml_node *node, + int (*proc)(struct aml_node *, int, void *), + void *arg) +{ + struct aml_notify_data *pdata; + + dnprintf(10, "aml_register_notify: %s %x\n", + node->name, cbproc); + pdata = acpi_os_allocmem(sizeof(struct aml_notify_data)); + pdata->node = node; + pdata->cbarg = arg; + pdata->cbproc = proc; + + SLIST_INSERT_HEAD(&aml_notify_list, pdata, link); +} + +void aml_notify(struct aml_node *node, int notify_value) +{ + struct aml_notify_data *pdata = NULL; + + SLIST_FOREACH(pdata, &aml_notify_list, link) + if (pdata->node == node) { + pdata->cbproc(node, notify_value, pdata->cbarg); + } +} + +void _aml_notify(struct aml_node *, void *); + +void +_aml_notify(struct aml_node *node, void *arg) +{ + aml_notify(node, *(int64_t *)arg); +} + void aml_addchildnode(struct aml_node *parent, struct aml_node *child) @@ -2361,12 +2411,16 @@ aml_eparseval(struct acpi_context *ctx, int deref) lhs = aml_eparseval(ctx, 1); i1 = aml_eparseint(ctx, AML_ANYINT); dnprintf(10, "NOTIFY: %llx %s\n", i1, lhs->name); + aml_find_node(aml_root.child, lhs->name, + _aml_notify, + &i1); break; case AMLOP_LOAD: case AMLOP_STORE: rhs = aml_eparseval(ctx, 1); lhs = aml_eparseval(ctx, 0); rv = aml_esetnodevalue(ctx, lhs, rhs, 0); + break; case AMLOP_COPYOBJECT: rhs = aml_eparseval(ctx, 1); diff --git a/sys/dev/acpi/dsdt.h b/sys/dev/acpi/dsdt.h index 1316c724cde..3ed580943f9 100644 --- a/sys/dev/acpi/dsdt.h +++ b/sys/dev/acpi/dsdt.h @@ -1,4 +1,4 @@ -/* $OpenBSD: dsdt.h,v 1.7 2006/02/19 04:50:47 marco Exp $ */ +/* $OpenBSD: dsdt.h,v 1.8 2006/02/19 21:32:30 jordan Exp $ */ /* * Copyright (c) 2005 Marco Peereboom <marco@openbsd.org> * @@ -45,4 +45,9 @@ int64_t aml_val2int(struct acpi_context *, struct aml_value *); struct aml_node *aml_searchname(struct aml_node *, const char *); +void aml_register_notify(struct aml_node *, + int (*)(struct aml_node *, int, void *), + void *); +void aml_notify(struct aml_node *, int); + #endif /* __DEV_ACPI_DSDT_H__ */ |