瀏覽代碼

spi: qup: Fix order of spi_register_master

This patch moves the devm_spi_register_master below the initialization of the
runtime_pm.  If done in the wrong order, the spi_register_master fails if any
probed slave devices issue SPI transactions.

Signed-off-by: Andy Gross <agross@codeaurora.org>
Acked-by: Ivan T. Ivanov <iivanov@mm-sol.com>
Signed-off-by: Mark Brown <broonie@linaro.org>
Andy Gross 11 年之前
父節點
當前提交
045c243a51
共有 1 個文件被更改,包括 7 次插入4 次删除
  1. 7 4
      drivers/spi/spi-qup.c

+ 7 - 4
drivers/spi/spi-qup.c

@@ -640,16 +640,19 @@ static int spi_qup_probe(struct platform_device *pdev)
 	if (ret)
 	if (ret)
 		goto error;
 		goto error;
 
 
-	ret = devm_spi_register_master(dev, master);
-	if (ret)
-		goto error;
-
 	pm_runtime_set_autosuspend_delay(dev, MSEC_PER_SEC);
 	pm_runtime_set_autosuspend_delay(dev, MSEC_PER_SEC);
 	pm_runtime_use_autosuspend(dev);
 	pm_runtime_use_autosuspend(dev);
 	pm_runtime_set_active(dev);
 	pm_runtime_set_active(dev);
 	pm_runtime_enable(dev);
 	pm_runtime_enable(dev);
+
+	ret = devm_spi_register_master(dev, master);
+	if (ret)
+		goto disable_pm;
+
 	return 0;
 	return 0;
 
 
+disable_pm:
+	pm_runtime_disable(&pdev->dev);
 error:
 error:
 	clk_disable_unprepare(cclk);
 	clk_disable_unprepare(cclk);
 	clk_disable_unprepare(iclk);
 	clk_disable_unprepare(iclk);