diff options
| -rw-r--r-- | drivers/pci/bus.c | 4 | ||||
| -rw-r--r-- | drivers/pci/quirks.c | 18 | 
2 files changed, 22 insertions, 0 deletions
diff --git a/drivers/pci/bus.c b/drivers/pci/bus.c index 4ce5ef2f282..b511bd4e3f7 100644 --- a/drivers/pci/bus.c +++ b/drivers/pci/bus.c @@ -164,6 +164,10 @@ pci_bus_alloc_resource(struct pci_bus *bus, struct resource *res,  int pci_bus_add_device(struct pci_dev *dev)  {  	int retval; +	extern bool pci_fixup_final_inited; + +	if (pci_fixup_final_inited) +		pci_fixup_device(pci_fixup_final, dev);  	retval = device_add(&dev->dev);  	if (retval)  		return retval; diff --git a/drivers/pci/quirks.c b/drivers/pci/quirks.c index 4565f4ff8ae..d8e9a0edf93 100644 --- a/drivers/pci/quirks.c +++ b/drivers/pci/quirks.c @@ -3028,6 +3028,22 @@ void pci_fixup_device(enum pci_fixup_pass pass, struct pci_dev *dev)  }  EXPORT_SYMBOL(pci_fixup_device); + +/* + * The global variable 'pci_fixup_final_inited' is being used as a interim + * solution for calling the final quirks only during hot-plug events (not + * during boot processing). + * + * When the boot path's PCI device setup sequencing is addressed, we can + * remove the instance, and usages of, 'pci_fixup_final_inited' along with + * removing 'fs_initcall_sync(pci_apply_final_quirks);' and end up with a + * single, uniform, solution that satisfies both the boot path and the + * various hot-plug event paths. + * + * ToDo: Remove 'pci_fixup_final_inited' + */ +bool pci_fixup_final_inited; +  static int __init pci_apply_final_quirks(void)  {  	struct pci_dev *dev = NULL; @@ -3058,6 +3074,8 @@ static int __init pci_apply_final_quirks(void)  			pci_cache_line_size = pci_dfl_cache_line_size;  		}  	} +	pci_fixup_final_inited = 1; +  	if (!pci_cache_line_size) {  		printk(KERN_DEBUG "PCI: CLS %u bytes, default %u\n",  		       cls << 2, pci_dfl_cache_line_size << 2);  |