Source-Changes-HG archive

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

[src/trunk]: src/sys/arch/x86/x86 In mpacpi_pci_attach_hook(), set the device...



details:   https://anonhg.NetBSD.org/src/rev/7921fa881f24
branches:  trunk
changeset: 1021154:7921fa881f24
user:      thorpej <thorpej%NetBSD.org@localhost>
date:      Wed May 12 22:17:40 2021 +0000

description:
In mpacpi_pci_attach_hook(), set the device handle of the PCI bus instance
to the associated ACPI handle if a device handle is not already set.

XXX This is a mess. Sure would be nice if it looked / worked more like
XXX the ARM code.

diffstat:

 sys/arch/x86/x86/mpacpi.c |  36 +++++++++++++++++++++++++++++++-----
 1 files changed, 31 insertions(+), 5 deletions(-)

diffs (84 lines):

diff -r d67546f33c1e -r 7921fa881f24 sys/arch/x86/x86/mpacpi.c
--- a/sys/arch/x86/x86/mpacpi.c Wed May 12 21:56:13 2021 +0000
+++ b/sys/arch/x86/x86/mpacpi.c Wed May 12 22:17:40 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: mpacpi.c,v 1.105 2021/04/24 23:36:51 thorpej Exp $     */
+/*     $NetBSD: mpacpi.c,v 1.106 2021/05/12 22:17:40 thorpej Exp $     */
 
 /*
  * Copyright (c) 2003 Wasabi Systems, Inc.
@@ -36,7 +36,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: mpacpi.c,v 1.105 2021/04/24 23:36:51 thorpej Exp $");
+__KERNEL_RCSID(0, "$NetBSD: mpacpi.c,v 1.106 2021/05/12 22:17:40 thorpej Exp $");
 
 #include "acpica.h"
 #include "opt_acpi.h"
@@ -90,7 +90,7 @@
 #if NPCI > 0
 struct mpacpi_pcibus {
        TAILQ_ENTRY(mpacpi_pcibus) mpr_list;
-       ACPI_HANDLE mpr_handle;         /* Same thing really, but.. */
+       devhandle_t mpr_devhandle;
        ACPI_BUFFER mpr_buf;            /* preserve _PRT */
        int mpr_seg;                    /* PCI segment number */
        int mpr_bus;                    /* PCI bus number */
@@ -509,7 +509,7 @@
        }
 
        mpr = kmem_zalloc(sizeof(struct mpacpi_pcibus), KM_SLEEP);
-       mpr->mpr_handle = ad->ad_handle;
+       mpr->mpr_devhandle = devhandle_from_acpi(ad->ad_handle);
        mpr->mpr_buf = buf;
        mpr->mpr_seg = ad->ad_pciinfo->ap_segment;
        mpr->mpr_bus = ad->ad_pciinfo->ap_downbus;
@@ -953,6 +953,29 @@
 
 #if NPCI > 0
 
+static void
+mpacpi_set_devhandle(device_t self, struct pcibus_attach_args *pba)
+{
+       devhandle_t devhandle = device_handle(self);
+       struct mpacpi_pcibus *mpr;
+
+       /* If we already have a valid handle, eject now. */
+       if (devhandle_type(devhandle) != DEVHANDLE_TYPE_INVALID) {
+               return;
+       }
+
+       TAILQ_FOREACH(mpr, &mpacpi_pcibusses, mpr_list) {
+               /* XXX Assuming always segment 0 on x86. */
+               if (mpr->mpr_seg != 0) {
+                       continue;
+               }
+               if (mpr->mpr_bus == pba->pba_bus) {
+                       device_set_handle(self, mpr->mpr_devhandle);
+                       return;
+               }
+       }
+}
+
 int
 mpacpi_pci_attach_hook(device_t parent, device_t self,
                       struct pcibus_attach_args *pba)
@@ -984,13 +1007,16 @@
        if (mpb->mb_name != NULL) {
                if (strcmp(mpb->mb_name, "pci"))
                        return EINVAL;
-       } else
+       } else {
                /*
                 * As we cannot find all PCI-to-PCI bridge in
                 * mpacpi_find_pcibusses, some of the MP_busses may remain
                 * uninitialized.
                 */
                mpb->mb_name = "pci";
+       }
+
+       mpacpi_set_devhandle(self, pba);
 
        mpb->mb_dev = self;
        mpb->mb_pci_bridge_tag = pba->pba_bridgetag;



Home | Main Index | Thread Index | Old Index