I would love to clean those functions up.
> Currently, pci_read_config_byte_nodev() will construct a fake struct
> pci_dev, and then use the normal pci_read_config_byte(). I think it
> makes more sense to actually do things the other way around.
>
> For reading/writing config space, we need to know (dev, fn), and need the
> access method (struct pci_ops), which is a property of the bridge plus
> possibly some private data (the arch's sysdata). So the member
>
> struct pci_ops *ops;
>
> of struct pci_dev is actually not necessary, it will always be
> pdev->ops == pdev->bus->ops AFAICS.
>
> So we could instead have
>
> pci_bus_read_config_byte(struct pci_bus *bus, u8 dev, u8 fn, ...)
>
> and for common use
>
> static inline pci_read_config_byte(struct pci_dev, *pdev, ...)
> {
> return pci_bus_read_config_byte(pdev->bus,
> PCI_SLOT(pdev->devfn),
> PCI_FUNC(pdev->devfn));
> }
>
> The PCI hotplug controllers / ACPI could then use the pci_bus_* variants,
> when they don't have a struct pci_dev available. They would need at least
> the root bridge's struct pci_bus, though.
Thats a good idea. The hotplug controllers do have acess to the pci_bus
structure. Andy, does ACPI have access to this when you are needing to
do these kinds of calls?
If there are no complaints, I think I'll go implement this, and move the
functions into the main pci code so that other parts of the kernel (like
ACPI) can use them.
Thanks for the idea!
greg k-h
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
ous message: Patrick Mochel: "Re: driverfs: [PATCH] remove bus and improve driver management"