summaryrefslogtreecommitdiff
path: root/sys/dev
diff options
context:
space:
mode:
authorMark Kettenis <kettenis@cvs.openbsd.org>2020-04-14 20:42:27 +0000
committerMark Kettenis <kettenis@cvs.openbsd.org>2020-04-14 20:42:27 +0000
commit8dbc81a23ecbf7e9754f044233b8a06b8ac0bd42 (patch)
tree07e703babc48c5eee7d7a7700612aca29eab2796 /sys/dev
parent4458ad7aaa1f8b15232d74929d404c8817ff0590 (diff)
Implement acpi_getprop(), the ACPI equivalent of OF_getprop().
ok patrick@
Diffstat (limited to 'sys/dev')
-rw-r--r--sys/dev/acpi/acpi.c55
-rw-r--r--sys/dev/acpi/acpivar.h3
2 files changed, 55 insertions, 3 deletions
diff --git a/sys/dev/acpi/acpi.c b/sys/dev/acpi/acpi.c
index ab5a2f09f1b..c3871e007a3 100644
--- a/sys/dev/acpi/acpi.c
+++ b/sys/dev/acpi/acpi.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: acpi.c,v 1.381 2020/04/12 09:21:19 kettenis Exp $ */
+/* $OpenBSD: acpi.c,v 1.382 2020/04/14 20:42:26 kettenis Exp $ */
/*
* Copyright (c) 2005 Thorsten Lockert <tholo@sigmasoft.com>
* Copyright (c) 2005 Jordan Hargrave <jordan@openbsd.org>
@@ -2961,6 +2961,57 @@ acpi_foundsony(struct aml_node *node, void *arg)
/* Support for _DSD Device Properties. */
+int
+acpi_getprop(struct aml_node *node, const char *prop, void *buf, int buflen)
+{
+ struct aml_value dsd;
+ int i;
+
+ /* daffd814-6eba-4d8c-8a91-bc9bbf4aa301 */
+ static uint8_t prop_guid[] = {
+ 0x14, 0xd8, 0xff, 0xda, 0xba, 0x6e, 0x8c, 0x4d,
+ 0x8a, 0x91, 0xbc, 0x9b, 0xbf, 0x4a, 0xa3, 0x01,
+ };
+
+ if (aml_evalname(acpi_softc, node, "_DSD", 0, NULL, &dsd))
+ return -1;
+
+ if (dsd.type != AML_OBJTYPE_PACKAGE || dsd.length != 2 ||
+ dsd.v_package[0]->type != AML_OBJTYPE_BUFFER ||
+ dsd.v_package[1]->type != AML_OBJTYPE_PACKAGE)
+ return -1;
+
+ /* Check UUID. */
+ if (dsd.v_package[0]->length != sizeof(prop_guid) ||
+ memcmp(dsd.v_package[0]->v_buffer, prop_guid,
+ sizeof(prop_guid)) != 0)
+ return -1;
+
+ /* Check properties. */
+ for (i = 0; i < dsd.v_package[1]->length; i++) {
+ struct aml_value *res = dsd.v_package[1]->v_package[i];
+ int len;
+
+ if (res->type != AML_OBJTYPE_PACKAGE || res->length != 2 ||
+ res->v_package[0]->type != AML_OBJTYPE_STRING)
+ continue;
+
+ len = res->v_package[1]->length;
+ switch (res->v_package[1]->type) {
+ case AML_OBJTYPE_BUFFER:
+ memcpy(buf, res->v_package[1]->v_buffer,
+ min(len, buflen));
+ return len;
+ case AML_OBJTYPE_STRING:
+ memcpy(buf, res->v_package[1]->v_string,
+ min(len, buflen));
+ return len;
+ }
+ }
+
+ return -1;
+}
+
uint32_t
acpi_getpropint(struct aml_node *node, const char *prop, uint32_t defval)
{
@@ -2999,7 +3050,7 @@ acpi_getpropint(struct aml_node *node, const char *prop, uint32_t defval)
if (strcmp(res->v_package[0]->v_string, prop) == 0)
return res->v_package[1]->v_integer;
}
-
+
return defval;
}
diff --git a/sys/dev/acpi/acpivar.h b/sys/dev/acpi/acpivar.h
index cfdc825bd23..b80105a50f5 100644
--- a/sys/dev/acpi/acpivar.h
+++ b/sys/dev/acpi/acpivar.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: acpivar.h,v 1.106 2020/04/12 09:21:19 kettenis Exp $ */
+/* $OpenBSD: acpivar.h,v 1.107 2020/04/14 20:42:26 kettenis Exp $ */
/*
* Copyright (c) 2005 Thorsten Lockert <tholo@sigmasoft.com>
*
@@ -372,6 +372,7 @@ int acpi_matchhids(struct acpi_attach_args *, const char *[], const char *);
int acpi_parsehid(struct aml_node *, void *, char *, char *, size_t);
int64_t acpi_getsta(struct acpi_softc *sc, struct aml_node *);
+int acpi_getprop(struct aml_node *, const char *, void *, int);
uint32_t acpi_getpropint(struct aml_node *, const char *, uint32_t);
int acpi_record_event(struct acpi_softc *, u_int);