Commit cf6f3bf7 authored by David Woodhouse's avatar David Woodhouse

Run pci_apply_final_quirks() sooner.

Having this as a device_initcall() means that some real device drivers
can actually initialise _before_ the quirks are run, which is wrong.

We want it to run _before_ device_initcall(), but _after_ fs_initcall(),
since some arch-specific PCI initialisation like pcibios_assign_resources()
is done at fs_initcall().

We could use rootfs_initcall() but I actually want to use that for the
IOMMU initialisation, which has to come after the quirks, but still
before the real devices. So use fs_initcall_sync() instead -- since this
is entirely synchronous, it doesn't hurt that it'll escape the
synchronisation.
Signed-off-by: default avatarDavid Woodhouse <David.Woodhouse@intel.com>
parent 00010268
...@@ -2584,7 +2584,7 @@ static int __init pci_apply_final_quirks(void) ...@@ -2584,7 +2584,7 @@ static int __init pci_apply_final_quirks(void)
return 0; return 0;
} }
device_initcall(pci_apply_final_quirks); fs_initcall_sync(pci_apply_final_quirks);
#else #else
void pci_fixup_device(enum pci_fixup_pass pass, struct pci_dev *dev) {} void pci_fixup_device(enum pci_fixup_pass pass, struct pci_dev *dev) {}
#endif #endif
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment