x86 PCI: call dmi_check_pciprobe()
authorYinghai Lu <yhlu.kernel@gmail.com>
Mon, 14 Apr 2008 22:40:37 +0000 (15:40 -0700)
committerJesse Barnes <jbarnes@virtuousgeek.org>
Mon, 5 May 2008 16:24:00 +0000 (09:24 -0700)
this change:

| commit 08f1c192c3c32797068bfe97738babb3295bbf42
| Author: Muli Ben-Yehuda <muli@il.ibm.com>
| Date:   Sun Jul 22 00:23:39 2007 +0300
|
|    x86-64: introduce struct pci_sysdata to facilitate sharing of ->sysdata
|
|    This patch introduces struct pci_sysdata to x86 and x86-64, and
|    converts the existing two users (NUMA, Calgary) to use it.
|
|    This lays the groundwork for having other users of sysdata, such as
|    the PCI domains work.
|
|    The Calgary bits are tested, the NUMA bits just look ok.

replaces pcibios_scan_root with pci_scan_bus_parented...

but in pcibios_scan_root we have a DMI check:

    dmi_check_system(pciprobe_dmi_table);

when when have several peer root buses this could be called multiple
times (which is bad), so move that call to pci_access_init().

Signed-off-by: Yinghai Lu <yhlu.kernel@gmail.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: Jesse Barnes <jbarnes@virtuousgeek.org>
arch/x86/pci/common.c
arch/x86/pci/init.c
arch/x86/pci/pci.h

index a6d27797ef4702b18b090eb179b852a3511ad493..bfa72a9475b33470e406f8019ec4b8e0ce340b40 100644 (file)
@@ -362,13 +362,16 @@ static struct dmi_system_id __devinitdata pciprobe_dmi_table[] = {
        {}
 };
 
+void __init dmi_check_pciprobe(void)
+{
+       dmi_check_system(pciprobe_dmi_table);
+}
+
 struct pci_bus * __devinit pcibios_scan_root(int busnum)
 {
        struct pci_bus *bus = NULL;
        struct pci_sysdata *sd;
 
-       dmi_check_system(pciprobe_dmi_table);
-
        while ((bus = pci_find_next_bus(bus)) != NULL) {
                if (bus->number == busnum) {
                        /* Already scanned */
index b394b2a4b9129d80f6b1d3eff10b9ac346393b03..e70b9c57b88e1f7e7d012a0fd5950170c163f5e5 100644 (file)
@@ -33,6 +33,8 @@ static __init int pci_access_init(void)
                printk(KERN_ERR
                "PCI: Fatal: No config space access function found\n");
 
+       dmi_check_pciprobe();
+
        dmi_check_skip_isa_align();
 
        return 0;
index 10198202788137f845d7fb8ff202e93a07d3da80..f3972b12c60a0066528e641028f3c9813e56786f 100644 (file)
@@ -38,6 +38,7 @@ enum pci_bf_sort_state {
        pci_dmi_bf,
 };
 
+extern void __init dmi_check_pciprobe(void);
 extern void __init dmi_check_skip_isa_align(void);
 
 /* pci-i386.c */