[PATCH v5 01/42] PCI: Add pcibios_setup_bridge()
Gavin Shan
gwshan at linux.vnet.ibm.com
Tue Jun 9 15:49:23 AEST 2015
On Fri, Jun 05, 2015 at 02:44:32PM -0500, Bjorn Helgaas wrote:
>On Thu, Jun 04, 2015 at 04:41:30PM +1000, Gavin Shan wrote:
>> Currently, PowerPC PowerNV platform utilizes ppc_md.pcibios_fixup(),
>> which is called for once after PCI probing and resource assignment
>> are completed, to allocate platform required resources for PCI devices:
>> PE#, IO and MMIO mapping, DMA address translation (TCE) table etc.
>> Obviously, it's not hotplug friendly.
>>
>> The patch adds weak function pcibios_setup_bridge(), which is called
>> by pci_setup_bridge(). PowerPC PowerNV platform will reuse the function
>> to assign above platform required resources to newly added PCI devices,
>> in order to support PCI hotplug in subsequent patches.
>>
>> Signed-off-by: Gavin Shan <gwshan at linux.vnet.ibm.com>
>
>Acked-by: Bjorn Helgaas <bhelgaas at google.com>
>
Thanks for your review, Bjorn.
Thanks,
Gavin
>> ---
>> v5:
>> * Corrected subject as Bjorn suggested
>> * pci_setup_bridge() calls pcibios_setup_bridge() and __pci_setup_bridge()
>> ---
>> drivers/pci/setup-bus.c | 5 +++++
>> include/linux/pci.h | 1 +
>> 2 files changed, 6 insertions(+)
>>
>> diff --git a/drivers/pci/setup-bus.c b/drivers/pci/setup-bus.c
>> index 4fd0cac..623dee3 100644
>> --- a/drivers/pci/setup-bus.c
>> +++ b/drivers/pci/setup-bus.c
>> @@ -693,11 +693,16 @@ static void __pci_setup_bridge(struct pci_bus *bus, unsigned long type)
>> pci_write_config_word(bridge, PCI_BRIDGE_CONTROL, bus->bridge_ctl);
>> }
>>
>> +void __weak pcibios_setup_bridge(struct pci_bus *bus, unsigned long type)
>> +{
>> +}
>> +
>> void pci_setup_bridge(struct pci_bus *bus)
>> {
>> unsigned long type = IORESOURCE_IO | IORESOURCE_MEM |
>> IORESOURCE_PREFETCH;
>>
>> + pcibios_setup_bridge(bus, type);
>> __pci_setup_bridge(bus, type);
>> }
>>
>> diff --git a/include/linux/pci.h b/include/linux/pci.h
>> index 94bacfa..5aacd0a 100644
>> --- a/include/linux/pci.h
>> +++ b/include/linux/pci.h
>> @@ -811,6 +811,7 @@ void pci_stop_and_remove_bus_device_locked(struct pci_dev *dev);
>> void pci_stop_root_bus(struct pci_bus *bus);
>> void pci_remove_root_bus(struct pci_bus *bus);
>> void pci_setup_cardbus(struct pci_bus *bus);
>> +void pcibios_setup_bridge(struct pci_bus *bus, unsigned long type);
>> void pci_sort_breadthfirst(void);
>> #define dev_is_pci(d) ((d)->bus == &pci_bus_type)
>> #define dev_is_pf(d) ((dev_is_pci(d) ? to_pci_dev(d)->is_physfn : false))
>> --
>> 2.1.0
>>
>
More information about the Linuxppc-dev
mailing list