Re: [PATCH 06/15] PCI/acpiphp: Convert "acpiphp" sub-driver'sfunctionality to built-in only

From: Myron Stowe
Date: Fri Dec 07 2012 - 14:10:58 EST


On Thu, 2012-12-06 at 22:48 -0800, Yinghai Lu wrote:
> On Thu, Dec 6, 2012 at 10:25 PM, Myron Stowe <myron.stowe@xxxxxxxxxx> wrote:
> > The "ACPI Hot Plug PCI Controller ("acpiphp")" sub-driver may be compiled
> > as a module. Kernel modules are instantiated somewhat randomly - the
> > order in which they are linked as the kernel as built - thus if there are
> > any dependencies on the ordering of attaching sub-drivers, they can not be
> > effectively dealt with.
> >
> > This patch series resolves any potential sequencing inter-dependencies by
> > converting "acpiphp" sub-driver's functionality to being only supported as
> > statically built-in to the kernel. Inter-dependencies can then be
> > effectively handled by explicitly sequencing the addition of such
> > functionality.
>
> some slots may support both acpiphp and pciehp.
>
> if make acpiphp to be built-in, user do not have choice anymore.

What area are you worried about and how do we exercise that choice
today?

Here is my current understanding to set a little context -

I see the following call chains with respect to pciehp and acpiphp:

pcied_init # pciehp module_init
pciehp_firmware_init
pciehp_acpi_slot_detection_init
parse_detect_mode #pcie, acpi, auto (default)
pcie_port_service_register


acpiphp_init # module_init
init_acpi
acpiphp_glue_init
acpi_pci_register_driver(&acpi_pci_hp_driver)
list_for_each_entry(root, &acpi_pci_roots, node)
driver->add # for \_SB_.PCI0
add_bridge
add_host_bridge
bridge = kzalloc(struct acpiphp_bridge)
bridge->handle = handle # \_SB_.PCI0
bridge->pci_bus = root_bus #pci_bus 0000:00
init_bridge_misc
acpi_walk_namespace(..., register_slot, ...)
register_slot
if (device_is_managed_by_native_pciehp(pdev))
return AE_OK

Does pciehp influence device_is_managed_by_native_pciehp()? If not, it
seems that the acpiphp driver will never attach.

Looking at ./drivers/pci/hotplug/Makefile, CONFIG_HOTPLUG_PCI_PCIE comes
before CONFIG_HOTPLUG_PCI_ACPI so if pciehp and acpiphp are both
configured as modules then the load order would seem to be:
acpiphp, pciehp: acpiphp ignores, pciehp claims
pciehp, acpiphp: pciehp claims, acpiphp ignores

To complete the matrix taking built-in vs. module into account -
pciehp=y, acpiphp=y
pciehp, acpiphp: pciehp claims, acpiphp ignores

pciehp=y, acpiphp=m
pciehp, acpiphp: pciehp claims, acpiphp ignores

pciehp=m, acpiphp=y
acpiphp, pciehp: acpiphp ignores, pciehp claims

The above combinations all seem to end up with pciehp claiming the slot
which raises the question: How do we get acpiphp to claim a slot today?

Thanks,
Myron
>
> Thanks
>
> Yinghai


--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/