summaryrefslogtreecommitdiff
path: root/sys/dev/acpi
diff options
context:
space:
mode:
authorJoshua Stein <jcs@cvs.openbsd.org>2019-07-31 15:58:01 +0000
committerJoshua Stein <jcs@cvs.openbsd.org>2019-07-31 15:58:01 +0000
commit0b2304cb4b818ffb94266a1890643c11508d0029 (patch)
tree9056da837975680167bfb13956273e3ce9e41c56 /sys/dev/acpi
parent968519120280ef3cee580fabc789a5f13f6afa7a (diff)
aml_find_node: perform callback on matched direct-child nodes before
recursing into child devices looking for matches. This ensures that when walking nodes with acpi_inidev, a method like \_SB_.PCI0._INI will be executed before \_SB_.PCI0.I2C1.TPL1._INI. This matches how ACPICA walks nodes and a commonly-used DSDT template assumes that \OSYS has been initialized in \_SB_.PCI0._INI before being used by other device _INI methods. This should also help to execute \_INI and \_SB_._INI first, if present, which ACPICA does explicitly. Tested in snaps, ok deraadt
Diffstat (limited to 'sys/dev/acpi')
-rw-r--r--sys/dev/acpi/dsdt.c11
1 files changed, 7 insertions, 4 deletions
diff --git a/sys/dev/acpi/dsdt.c b/sys/dev/acpi/dsdt.c
index cbd38c9be6f..68651c0bffd 100644
--- a/sys/dev/acpi/dsdt.c
+++ b/sys/dev/acpi/dsdt.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: dsdt.c,v 1.245 2019/07/31 15:47:49 jcs Exp $ */
+/* $OpenBSD: dsdt.c,v 1.246 2019/07/31 15:58:00 jcs Exp $ */
/*
* Copyright (c) 2005 Jordan Hargrave <jordan@openbsd.org>
*
@@ -1263,6 +1263,7 @@ aml_find_node(struct aml_node *node, const char *name,
struct aml_node *child;
const char *nn;
+ /* match child of this node first before recursing */
SIMPLEQ_FOREACH(child, &node->son, sib) {
nn = child->name;
if (nn != NULL) {
@@ -1270,12 +1271,14 @@ aml_find_node(struct aml_node *node, const char *name,
while (*nn == AMLOP_PARENTPREFIX) nn++;
if (strcmp(name, nn) == 0) {
/* Only recurse if cbproc() wants us to */
- if (cbproc(child, arg) == 0)
- continue;
+ if (cbproc(child, arg) != 0)
+ return;
}
}
- aml_find_node(child, name, cbproc, arg);
}
+
+ SIMPLEQ_FOREACH(child, &node->son, sib)
+ aml_find_node(child, name, cbproc, arg);
}
/*