spi/bcm63xx-hspi: Enable the clock before calling clk_get_rate().
authorStefan Potyra <Stefan.Potyra@elektrobit.com>
Thu, 26 Apr 2018 07:28:02 +0000 (09:28 +0200)
committerMark Brown <broonie@kernel.org>
Thu, 26 Apr 2018 11:41:22 +0000 (12:41 +0100)
Enable the clock prior to calling clk_get_rate(), because clk_get_rate()
should only be called if the clock is enabled.

Additionally, prepare/enable the pll_clk before calling clk_get_rate()
for the same reason.

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

Fixes: 142168eba9dc ("spi: bcm63xx-hsspi: add bcm63xx HSSPI driver")
Signed-off-by: Stefan Potyra <Stefan.Potyra@elektrobit.com>
Signed-off-by: Mark Brown <broonie@kernel.org>
drivers/spi/spi-bcm63xx-hsspi.c

index cbcba614b253375d024cf45f03408fa53337d8f5..c23849f7aa7bc673bd9cba50ca8755b77742ab34 100644 (file)
@@ -352,22 +352,31 @@ static int bcm63xx_hsspi_probe(struct platform_device *pdev)
        if (IS_ERR(clk))
                return PTR_ERR(clk);
 
+       ret = clk_prepare_enable(clk);
+       if (ret)
+               return ret;
+
        rate = clk_get_rate(clk);
        if (!rate) {
                struct clk *pll_clk = devm_clk_get(dev, "pll");
 
-               if (IS_ERR(pll_clk))
-                       return PTR_ERR(pll_clk);
+               if (IS_ERR(pll_clk)) {
+                       ret = PTR_ERR(pll_clk);
+                       goto out_disable_clk;
+               }
+
+               ret = clk_prepare_enable(pll_clk);
+               if (ret)
+                       goto out_disable_clk;
 
                rate = clk_get_rate(pll_clk);
-               if (!rate)
-                       return -EINVAL;
+               clk_disable_unprepare(pll_clk);
+               if (!rate) {
+                       ret = -EINVAL;
+                       goto out_disable_clk;
+               }
        }
 
-       ret = clk_prepare_enable(clk);
-       if (ret)
-               return ret;
-
        master = spi_alloc_master(&pdev->dev, sizeof(*bs));
        if (!master) {
                ret = -ENOMEM;