Hi Gary, * Gary Hade <garyhade@xxxxxxxxxx>: > On Tue, Nov 13, 2007 at 01:11:02PM -0700, Matthew Wilcox wrote: > > On Tue, Nov 13, 2007 at 10:51:22AM -0800, Greg KH wrote: > > > Ok, again, I want to see the IBM people sign off on this, after testing > > > on all of their machines, before I'll consider this, as I know the IBM > > > acpi tables are "odd". > > > > That seems a little higher standard than patches are normally held to. > > How about the patches get sent to the appropriate people at IBM (who are > > they?) > > I be one of them. :) I have been involved in many (but not all) > of IBM's x86 based (IBM System x) servers with hotplug capable > PCI slots. I have mostly worked on 'acpiphp' associated issues. Thanks for testing the series. It's much appreciated. > Have you possibly considered a kernel option as a kinder and > gentler way of introducing the changes? That is a good idea. I will work on that. > ==== > IBM x3850 > Slots 1-2: PCI-X under PCI root bridges > Slots 3-6: PCIe under transparent P2P bridges > Slot 1: PCI-X - populated > Slot 2: PCI-X - !populated > Slot 3: PCIe - populated > Slot 4: PCIe - !populated > Slot 5: PCIe - !populated > Slot 6: PCIe - populated > > result is with 2.6.24-rc2 plus all 4 proposed patches Silly question, but I have to ask. :) I sent out 5 patches -- is this simply a typo on your part, or did you only apply 4/5 patches? > problem: acpiphp failed to register empty PCIe slots 4 and 5 Ok, so acpiphp wasn't going to register those slots anyway, since they are empty. It would have bailed out after not seeing _ADR or _EJ0 on those slots. The acpi-pci-slot driver created those slots anyway, which is one of the points of the patch -- to create sysfs entries even for empty slots. > acpiphp_glue: found PCI-to-PCI bridge at PCI 0000:0f:00.0 This is the real address of slot 4. > acpiphp_glue: found ACPI PCI Hotplug slot 4 at PCI 0000:10:00 > acpiphp: pci_hp_register failed with error -17 > acpiphp_glue: acpiphp_register_hotplug_slot failed(err code = 0xffffffef) [repeated 7x] We saw this message 8x, once for each SxFy object under your p2p bridge. I actually somewhat did expect to see this error message (hence the RFC part of my patch ;) I currently don't have a good way to determine if we've already seen an empty slot under a p2p bridge, so we try to register every SxFy object. Of course, a /sys/bus/pci/slots/4/ entry already exists, so that's why we're getting -17 (-EEXIST). > acpiphp_glue: found PCI-to-PCI bridge at PCI 0000:14:00.0 > acpiphp_glue: found ACPI PCI Hotplug slot 5 at PCI 0000:15:00 > acpiphp: pci_hp_register failed with error -17 > acpiphp_glue: acpiphp_register_hotplug_slot failed(err code = 0xffffffef) Same explanation as above. > # find /sys/bus/pci/slots > /sys/bus/pci/slots [snip] > /sys/bus/pci/slots/4 > /sys/bus/pci/slots/4/address > /sys/bus/pci/slots/5 > /sys/bus/pci/slots/5/address Arguably, the right thing happened here. We got entries for empty slots, and we know their addresses. If anyone can clue me in on a better way to implement patch 4/5 in my series so that we're not seeing those multiple attempts to register slots under p2p bridges, I'd love to hear your ideas. Thanks again for testing. /ac - To unsubscribe from this list: send the line "unsubscribe linux-acpi" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html