On Sun, 29 Apr 2007 20:14:37 -0600 Robert Hancock wrote: > diff -up linux-2.6.21.1/arch/i386/pci/mmconfig-shared.c > linux-2.6.21.1edit/arch/i386/pci/mmconfig-shared.c > --- linux-2.6.21.1/arch/i386/pci/mmconfig-shared.c 2007-04-27 > 15:49:26.000000000 -0600 > +++ linux-2.6.21.1edit/arch/i386/pci/mmconfig-shared.c 2007-04-29 > 19:47:57.000000000 -0600 > @@ -191,9 +191,77 @@ static void __init pci_mmcfg_insert_reso > } > } > > + > +static int __init is_acpi_reserved(unsigned long start, unsigned long end) > +{ > + struct resource mcfg_res; > + > + mcfg_res.start = start; > + mcfg_res.end = end; > + mcfg_res.flags = 0; > + > + acpi_get_devices("PNP0C01", find_mboard_resource, &mcfg_res, NULL); > + > + if( !mcfg_res.flags )
if (!mcfg_res.flags) > + acpi_get_devices("PNP0C02", find_mboard_resource, &mcfg_res, > NULL); > + > + return mcfg_res.flags; > +} > + > +static void __init pci_mmcfg_reject_broken(void) > { > typeof(pci_mmcfg_config[0]) *cfg; > + int i; > > if ((pci_mmcfg_config_num == 0) || > (pci_mmcfg_config == NULL) || > @@ -213,18 +281,36 @@ static void __init pci_mmcfg_reject_brok > "Rejected as broken MCFG.\n"); > goto reject; > } > - > - /* > - * Only do this check when type 1 works. If it doesn't work > - * assume we run on a Mac and always use MCFG > - */ > - if (type == 1 && !e820_all_mapped(cfg->address, > - cfg->address + MMCONFIG_APER_MIN, > - E820_RESERVED)) { > - printk(KERN_ERR "PCI: BIOS Bug: MCFG area at %Lx is not" > - " E820-reserved\n", cfg->address); > - goto reject; > + > + for(i=0; i < pci_mmcfg_config_num; i++) { for (i = 0; i < pci_mmcfg_config_num; i++) { > + u32 size = (cfg->end_bus_number + 1) << 20; > + cfg = &pci_mmcfg_config[i]; > + printk(KERN_NOTICE "PCI: MCFG configuration %d: base %p segment > %hu buses %u - %u\n", line too long. > + i, (void*)cfg->address, cfg->pci_segment, > + (unsigned int)cfg->start_bus_number, > + (unsigned int)cfg->end_bus_number); > + if(is_acpi_reserved(cfg->address, if ( > + cfg->address + size - 1)) > + printk(KERN_NOTICE "PCI: MCFG area at %Lx reserved " > + "in ACPI motherboard resources\n", > + cfg->address); > + else { > + printk(KERN_ERR "PCI: BIOS Bug: MCFG area at %Lx is not > " > + "reserved in ACPI motherboard resources\n", > + cfg->address); > + /* Don't try to do this check unless configuration type > 1 is > + available. */ > + if((pci_probe & PCI_PROBE_CONF1) && if (( and that line ends with a space :( > + e820_all_mapped(cfg->address, > + cfg->address + size - 1, > + E820_RESERVED)) > + printk(KERN_NOTICE "PCI: MCFG area at %Lx > reserved in E820\n", > + cfg->address); > + else > + goto reject; > + } > } > + > return; > > reject: > @@ -234,20 +320,46 @@ reject: > pci_mmcfg_config_num = 0; > } > > -void __init pci_mmcfg_init(int type) > +void __init pci_mmcfg_early_init(int type) > +{ > + if ((pci_probe & PCI_PROBE_MMCONF) == 0) > + return; > + > + /* If type 1 access is available, no need to enable MMCONFIG yet, we can > + defer until later when the ACPI interpreter is available to better > + validate things. */ > + if( type == 1 ) if (type == 1) > + return; > + > + acpi_table_parse(ACPI_SIG_MCFG, acpi_parse_mcfg); > + > + if ((pci_mmcfg_config_num == 0) || > + (pci_mmcfg_config == NULL) || > + (pci_mmcfg_config[0].address == 0)) > + return; > + > + if (pci_mmcfg_arch_init()) > + pci_probe = (pci_probe & ~PCI_PROBE_MASK) | PCI_PROBE_MMCONF; > +} > diff -ruw linux-2.6.21.1/drivers/acpi/bus.c > linux-2.6.21.1edit/drivers/acpi/bus.c > --- linux-2.6.21.1/drivers/acpi/bus.c 2007-04-27 15:49:26.000000000 -0600 > +++ linux-2.6.21.1edit/drivers/acpi/bus.c 2007-04-29 19:22:07.000000000 > -0600 > @@ -42,6 +42,7 @@ > ACPI_MODULE_NAME("bus"); > #ifdef CONFIG_X86 > extern void __init acpi_pic_sci_set_trigger(unsigned int irq, u16 trigger); > +extern void __init pci_mmcfg_late_init(void); externs should go in header files. (not that you started this here) > #endif > > struct acpi_device *acpi_root; > @@ -753,6 +754,9 @@ > result = acpi_bus_init(); > > if (!result) { > +#ifdef CONFIG_X86 > + pci_mmcfg_late_init(); > +#endif > #ifdef CONFIG_PM_LEGACY > if (!PM_IS_ACTIVE()) > pm_active = 1; > - --- ~Randy *** Remember to use Documentation/SubmitChecklist when testing your code *** - To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to [EMAIL PROTECTED] More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/