Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/acpi Add a function to report whether the operating ...
details: https://anonhg.NetBSD.org/src/rev/5bd7e4e4a403
branches: trunk
changeset: 994130:5bd7e4e4a403
user: jmcneill <jmcneill%NetBSD.org@localhost>
date: Sun Oct 21 11:04:26 2018 +0000
description:
Add a function to report whether the operating system may ignore the boot
configuration of PCI resources for a given bus.
diffstat:
sys/dev/acpi/acpi_pci.c | 63 +++++++++++++++++++++++++++++++++++++++++++++++-
sys/dev/acpi/acpi_pci.h | 3 +-
2 files changed, 63 insertions(+), 3 deletions(-)
diffs (104 lines):
diff -r 02d597f8d059 -r 5bd7e4e4a403 sys/dev/acpi/acpi_pci.c
--- a/sys/dev/acpi/acpi_pci.c Sun Oct 21 07:08:40 2018 +0000
+++ b/sys/dev/acpi/acpi_pci.c Sun Oct 21 11:04:26 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: acpi_pci.c,v 1.23 2018/10/15 10:00:30 jmcneill Exp $ */
+/* $NetBSD: acpi_pci.c,v 1.24 2018/10/21 11:04:26 jmcneill Exp $ */
/*
* Copyright (c) 2009, 2010 The NetBSD Foundation, Inc.
@@ -29,7 +29,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: acpi_pci.c,v 1.23 2018/10/15 10:00:30 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: acpi_pci.c,v 1.24 2018/10/21 11:04:26 jmcneill Exp $");
#include <sys/param.h>
#include <sys/device.h>
@@ -58,6 +58,14 @@
void *);
/*
+ * UUID for _DSM control method, from PCI Firmware Specification.
+ */
+static UINT8 acpi_pci_dsm_uuid[ACPI_UUID_LENGTH] = {
+ 0xd0, 0x37, 0xc9, 0xe5, 0x53, 0x35, 0x7a, 0x4d,
+ 0x91, 0x17, 0xea, 0x4d, 0x19, 0xc3, 0x43, 0x4d
+};
+
+/*
* Regarding PCI Segment Groups (ACPI 4.0, p. 277):
*
* "The optional _SEG object is located under a PCI host bridge and
@@ -459,3 +467,54 @@
return dv;
}
+
+/*
+ * acpi_pci_ignore_boot_config:
+ *
+ * Returns 1 if the operating system may ignore the boot configuration
+ * of PCI resources.
+ */
+ACPI_INTEGER
+acpi_pci_ignore_boot_config(ACPI_HANDLE handle)
+{
+ ACPI_OBJECT_LIST objs;
+ ACPI_OBJECT obj[4], *pobj;
+ ACPI_BUFFER buf;
+ ACPI_INTEGER ret;
+
+ objs.Count = 4;
+ objs.Pointer = obj;
+ obj[0].Type = ACPI_TYPE_BUFFER;
+ obj[0].Buffer.Length = ACPI_UUID_LENGTH;
+ obj[0].Buffer.Pointer = acpi_pci_dsm_uuid;
+ obj[1].Type = ACPI_TYPE_INTEGER;
+ obj[1].Integer.Value = 1;
+ obj[2].Type = ACPI_TYPE_INTEGER;
+ obj[2].Integer.Value = 5;
+ obj[3].Type = ACPI_TYPE_PACKAGE;
+ obj[3].Package.Count = 0;
+ obj[3].Package.Elements = NULL;
+
+ buf.Pointer = NULL;
+ buf.Length = ACPI_ALLOCATE_LOCAL_BUFFER;
+
+ if (ACPI_FAILURE(AcpiEvaluateObject(handle, "_DSM", &objs, &buf)) || buf.Pointer == NULL)
+ return 0;
+
+ ret = 0;
+
+ pobj = buf.Pointer;
+ switch (pobj->Type) {
+ case ACPI_TYPE_INTEGER:
+ ret = pobj->Integer.Value;
+ break;
+ case ACPI_TYPE_PACKAGE:
+ if (pobj->Package.Count == 1 && pobj->Package.Elements[0].Type == ACPI_TYPE_INTEGER)
+ ret = pobj->Package.Elements[0].Integer.Value;
+ break;
+ }
+
+ ACPI_FREE(buf.Pointer);
+
+ return ret;
+}
diff -r 02d597f8d059 -r 5bd7e4e4a403 sys/dev/acpi/acpi_pci.h
--- a/sys/dev/acpi/acpi_pci.h Sun Oct 21 07:08:40 2018 +0000
+++ b/sys/dev/acpi/acpi_pci.h Sun Oct 21 11:04:26 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: acpi_pci.h,v 1.9 2018/10/15 10:00:30 jmcneill Exp $ */
+/* $NetBSD: acpi_pci.h,v 1.10 2018/10/21 11:04:26 jmcneill Exp $ */
/*
* Copyright (c) 2009 The NetBSD Foundation, Inc.
@@ -38,5 +38,6 @@
uint16_t, uint16_t);
device_t acpi_pcidev_find_dev(struct acpi_devnode *);
struct acpi_devnode *acpi_pciroot_find(uint16_t, uint16_t);
+ACPI_INTEGER acpi_pci_ignore_boot_config(ACPI_HANDLE);
#endif /* !_SYS_DEV_ACPI_ACPI_PCI_H */
Home |
Main Index |
Thread Index |
Old Index