fpga: socfpga-a10: disable clk on error in socfpga_a10_fpga_probe()
authorAlexey Khoroshilov <khoroshilov@ispras.ru>
Fri, 8 Dec 2017 17:37:00 +0000 (11:37 -0600)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Mon, 18 Dec 2017 14:59:16 +0000 (15:59 +0100)
If fpga_mgr_register() fails, a clock is left undisabled.

Found by Linux Driver Verification project (linuxtesting.org).

Signed-off-by: Alexey Khoroshilov <khoroshilov@ispras.ru>
Reviewed-by: Moritz Fischer <mdf@kernel.org>
Signed-off-by: Alan Tull <atull@kernel.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/fpga/socfpga-a10.c

index f8770af0f6b51975be92060292f8d5e1d7591d8d..a46e343a5b723cd828c54d52815c3ece8afa6ad7 100644 (file)
@@ -519,8 +519,14 @@ static int socfpga_a10_fpga_probe(struct platform_device *pdev)
                return -EBUSY;
        }
 
-       return fpga_mgr_register(dev, "SoCFPGA Arria10 FPGA Manager",
+       ret = fpga_mgr_register(dev, "SoCFPGA Arria10 FPGA Manager",
                                 &socfpga_a10_fpga_mgr_ops, priv);
+       if (ret) {
+               clk_disable_unprepare(priv->clk);
+               return ret;
+       }
+
+       return 0;
 }
 
 static int socfpga_a10_fpga_remove(struct platform_device *pdev)