Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/dev/acpi Assign device handles to "at acpi" and "at pci"...



details:   https://anonhg.NetBSD.org/src/rev/0d1167c80b4b
branches:  trunk
changeset: 980452:0d1167c80b4b
user:      thorpej <thorpej%NetBSD.org@localhost>
date:      Fri Feb 05 17:13:40 2021 +0000

description:
Assign device handles to "at acpi" and "at pci" devices in
acpi_device_register().

diffstat:

 sys/dev/acpi/acpi.c |  41 +++++++++++++++++++++++++++++++++++++----
 1 files changed, 37 insertions(+), 4 deletions(-)

diffs (63 lines):

diff -r b4107235d16e -r 0d1167c80b4b sys/dev/acpi/acpi.c
--- a/sys/dev/acpi/acpi.c       Fri Feb 05 17:12:43 2021 +0000
+++ b/sys/dev/acpi/acpi.c       Fri Feb 05 17:13:40 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: acpi.c,v 1.289 2021/02/04 21:39:00 thorpej Exp $       */
+/*     $NetBSD: acpi.c,v 1.290 2021/02/05 17:13:40 thorpej Exp $       */
 
 /*-
  * Copyright (c) 2003, 2007 The NetBSD Foundation, Inc.
@@ -100,7 +100,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: acpi.c,v 1.289 2021/02/04 21:39:00 thorpej Exp $");
+__KERNEL_RCSID(0, "$NetBSD: acpi.c,v 1.290 2021/02/05 17:13:40 thorpej Exp $");
 
 #include "pci.h"
 #include "opt_acpi.h"
@@ -1130,9 +1130,42 @@
  *     attaching devices.
  */
 void
-acpi_device_register(device_t dev __unused, void *v __unused)
+acpi_device_register(device_t dev, void *v)
 {
-       /* Placeholder. */
+       /* All we do here is set the devhandle in the device_t. */
+       device_t parent = device_parent(dev);
+       ACPI_HANDLE hdl = NULL;
+
+       /*
+        * aa_node is only valid if we attached to the "acpinodebus"
+        * interface attribute.
+        */
+       if (device_attached_to_iattr(dev, "acpinodebus")) {
+               const struct acpi_attach_args *aa = v;
+               hdl = aa->aa_node->ad_handle;
+       } else if (device_is_a(parent, "pci")) {
+               const struct pci_attach_args *pa = v;
+               struct acpi_devnode *ad;
+               u_int segment;
+
+#ifdef __HAVE_PCI_GET_SEGMENT
+               segment = pci_get_segment(pa->pa_pc);
+#else
+               segment = 0;
+#endif /* __HAVE_PCI_GET_SEGMENT */
+
+               ad = acpi_pcidev_find(segment,
+                   pa->pa_bus, pa->pa_device, pa->pa_function);
+               if (ad == NULL || (hdl = ad->ad_handle) == NULL) {
+                       aprint_debug_dev(dev, "no matching ACPI node\n");
+                       return;
+               }
+       } else {
+               return;
+       }
+       KASSERT(hdl != NULL);
+
+       device_set_handle(dev, devhandle_from_acpi(hdl));
 }
 
 /*



Home | Main Index | Thread Index | Old Index