summaryrefslogtreecommitdiffstats
path: root/drivers/fpga
diff options
context:
space:
mode:
authorMoritz Fischer <moritz.fischer@ettus.com>2015-10-22 14:56:09 -0400
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2015-10-23 19:49:44 -0400
commit28f98a12f7bac9c3e5ba85d245d32ec0910cf8e5 (patch)
tree41a8bc8c3da5142751b61b5a35e442704032be03 /drivers/fpga
parent92d94a7ec552fafaa036fdb04d0894d6c444cafb (diff)
fpga: zynq-fpga: Fix issue with drvdata being overwritten.
Upon registering a FPGA Manager low level driver, FPGA Manager core overwrites the platform drvdata pointer. Prior to this commit zynq-fpga falsely relied on this pointer to still be valid at remove() time. Reported-by: Alan Tull <atull@opensource.altera.com> Signed-off-by: Moritz Fischer <moritz.fischer@ettus.com> Acked-by: Alan Tull <atull@opensource.altera.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
Diffstat (limited to 'drivers/fpga')
-rw-r--r--drivers/fpga/zynq-fpga.c7
1 files changed, 4 insertions, 3 deletions
diff --git a/drivers/fpga/zynq-fpga.c b/drivers/fpga/zynq-fpga.c
index 31db5509f3d4..c2fb4120bd62 100644
--- a/drivers/fpga/zynq-fpga.c
+++ b/drivers/fpga/zynq-fpga.c
@@ -416,7 +416,6 @@ static int zynq_fpga_probe(struct platform_device *pdev)
416 if (!priv) 416 if (!priv)
417 return -ENOMEM; 417 return -ENOMEM;
418 418
419 platform_set_drvdata(pdev, priv);
420 priv->dev = dev; 419 priv->dev = dev;
421 420
422 res = platform_get_resource(pdev, IORESOURCE_MEM, 0); 421 res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
@@ -477,10 +476,12 @@ static int zynq_fpga_probe(struct platform_device *pdev)
477static int zynq_fpga_remove(struct platform_device *pdev) 476static int zynq_fpga_remove(struct platform_device *pdev)
478{ 477{
479 struct zynq_fpga_priv *priv; 478 struct zynq_fpga_priv *priv;
479 struct fpga_manager *mgr;
480 480
481 fpga_mgr_unregister(&pdev->dev); 481 mgr = platform_get_drvdata(pdev);
482 priv = mgr->priv;
482 483
483 priv = platform_get_drvdata(pdev); 484 fpga_mgr_unregister(&pdev->dev);
484 485
485 clk_unprepare(priv->clk); 486 clk_unprepare(priv->clk);
486 487