Commit 287fcdaa authored by Stephan Gerhold's avatar Stephan Gerhold Committed by Mark Brown

spi: qup: Parse OPP table for DVFS support

Parse the OPP table from the device tree and use dev_pm_opp_set_rate()
instead of clk_set_rate() to allow making performance state for power
domains specified in the OPP table.

This is needed to guarantee correct behavior of the clock, especially
with the higher clock/SPI bus frequencies.
Acked-by: default avatarKonrad Dybcio <konrad.dybcio@linaro.org>
Signed-off-by: default avatarStephan Gerhold <stephan.gerhold@kernkonzept.com>
Link: https://lore.kernel.org/r/20230919-spi-qup-dvfs-v2-2-1bac2e9ab8db@kernkonzept.comSigned-off-by: default avatarMark Brown <broonie@kernel.org>
parent e6419c35
...@@ -12,6 +12,7 @@ ...@@ -12,6 +12,7 @@
#include <linux/module.h> #include <linux/module.h>
#include <linux/of.h> #include <linux/of.h>
#include <linux/platform_device.h> #include <linux/platform_device.h>
#include <linux/pm_opp.h>
#include <linux/pm_runtime.h> #include <linux/pm_runtime.h>
#include <linux/spi/spi.h> #include <linux/spi/spi.h>
#include <linux/dmaengine.h> #include <linux/dmaengine.h>
...@@ -667,7 +668,7 @@ static int spi_qup_io_prep(struct spi_device *spi, struct spi_transfer *xfer) ...@@ -667,7 +668,7 @@ static int spi_qup_io_prep(struct spi_device *spi, struct spi_transfer *xfer)
return -EIO; return -EIO;
} }
ret = clk_set_rate(controller->cclk, xfer->speed_hz); ret = dev_pm_opp_set_rate(controller->dev, xfer->speed_hz);
if (ret) { if (ret) {
dev_err(controller->dev, "fail to set frequency %d", dev_err(controller->dev, "fail to set frequency %d",
xfer->speed_hz); xfer->speed_hz);
...@@ -1027,6 +1028,15 @@ static int spi_qup_probe(struct platform_device *pdev) ...@@ -1027,6 +1028,15 @@ static int spi_qup_probe(struct platform_device *pdev)
return -ENXIO; return -ENXIO;
} }
ret = devm_pm_opp_set_clkname(dev, "core");
if (ret)
return ret;
/* OPP table is optional */
ret = devm_pm_opp_of_add_table(dev);
if (ret && ret != -ENODEV)
return dev_err_probe(dev, ret, "invalid OPP table\n");
host = spi_alloc_host(dev, sizeof(struct spi_qup)); host = spi_alloc_host(dev, sizeof(struct spi_qup));
if (!host) { if (!host) {
dev_err(dev, "cannot allocate host\n"); dev_err(dev, "cannot allocate host\n");
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment