diff options
author | Matwey V. Kornilov | 2015-02-19 18:41:48 +0100 |
---|---|---|
committer | Bjorn Helgaas | 2015-03-06 18:47:28 +0100 |
commit | a43f32d647273023edddb0dc8f91c4c6378b252b (patch) | |
tree | 82eb305a0ba4dd653c864c7b35e26796a7cd343b /drivers/pci/host/pcie-designware.c | |
parent | PCI: xgene: Add register offset to config space base address (diff) | |
download | kernel-qcow2-linux-a43f32d647273023edddb0dc8f91c4c6378b252b.tar.gz kernel-qcow2-linux-a43f32d647273023edddb0dc8f91c4c6378b252b.tar.xz kernel-qcow2-linux-a43f32d647273023edddb0dc8f91c4c6378b252b.zip |
PCI: spear: Drop __initdata from spear13xx_pcie_driver
Struct spear13xx_pcie_driver was in initdata, but we passed a pointer to it
to platform_driver_register(), which can use the pointer at arbitrary times
in the future, even after the initdata is freed. That leads to crashes.
Move spear13xx_pcie_driver and things referenced by it
(spear13xx_pcie_probe() and dw_pcie_host_init()) out of initdata.
[bhelgaas: changelog]
Fixes: 6675ef212dac ("PCI: spear: Fix Section mismatch compilation warning for probe()")
Signed-off-by: Matwey V. Kornilov <matwey@sai.msu.ru>
Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
Acked-by: Viresh Kumar <viresh.kumar@linaro.org>
CC: stable@vger.kernel.org # v3.17+
Diffstat (limited to 'drivers/pci/host/pcie-designware.c')
-rw-r--r-- | drivers/pci/host/pcie-designware.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/pci/host/pcie-designware.c b/drivers/pci/host/pcie-designware.c index 1f4ea6f2d910..2e9f84fdd9ce 100644 --- a/drivers/pci/host/pcie-designware.c +++ b/drivers/pci/host/pcie-designware.c @@ -342,7 +342,7 @@ static const struct irq_domain_ops msi_domain_ops = { .map = dw_pcie_msi_map, }; -int __init dw_pcie_host_init(struct pcie_port *pp) +int dw_pcie_host_init(struct pcie_port *pp) { struct device_node *np = pp->dev->of_node; struct platform_device *pdev = to_platform_device(pp->dev); |