diff options
author | Matwey V. Kornilov <matwey@sai.msu.ru> | 2015-02-19 20:41:48 +0300 |
---|---|---|
committer | Bjorn Helgaas <bhelgaas@google.com> | 2015-03-06 11:47:28 -0600 |
commit | a43f32d647273023edddb0dc8f91c4c6378b252b (patch) | |
tree | 82eb305a0ba4dd653c864c7b35e26796a7cd343b /drivers/pci/host/pcie-designware.c | |
parent | 085a68d0010ffa57603b93c2b09fdf98bf74218c (diff) | |
download | op-kernel-dev-a43f32d647273023edddb0dc8f91c4c6378b252b.zip op-kernel-dev-a43f32d647273023edddb0dc8f91c4c6378b252b.tar.gz |
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 1f4ea6f..2e9f84f 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); |