diff options
author | Moritz Fischer <moritz.fischer@ettus.com> | 2015-10-22 14:56:09 -0400 |
---|---|---|
committer | Greg Kroah-Hartman <gregkh@linuxfoundation.org> | 2015-10-23 19:49:44 -0400 |
commit | 28f98a12f7bac9c3e5ba85d245d32ec0910cf8e5 (patch) | |
tree | 41a8bc8c3da5142751b61b5a35e442704032be03 /drivers/fpga | |
parent | 92d94a7ec552fafaa036fdb04d0894d6c444cafb (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.c | 7 |
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) | |||
477 | static int zynq_fpga_remove(struct platform_device *pdev) | 476 | static 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 | ||