[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <20190409153801.6941-1-dinguyen@kernel.org>
Date: Tue, 9 Apr 2019 10:38:01 -0500
From: Dinh Nguyen <dinguyen@...nel.org>
To: linux-mtd@...ts.infradead.org
Cc: dinguyen@...nel.org, marex@...x.de, tudor.ambarus@...rochip.com,
dwmw2@...radead.org, computersforpeace@...il.com,
bbrezillon@...nel.org, vigneshr@...com,
linux-kernel@...r.kernel.org,
Tien-Fong Chee <tien.fong.chee@...el.com>
Subject: [PATCHv2] mtd: spi-nor: cadence-quadspi: add reset control
Get the reset control for the QSPI controller and bring it out of reset.
Suggested-by: Tien-Fong Chee <tien.fong.chee@...el.com>
Signed-off-by: Dinh Nguyen <dinguyen@...nel.org>
---
v2: use devm_reset_control_get_optional_exclusive
print an error message
return -EPROBE_DEFER
---
drivers/mtd/spi-nor/cadence-quadspi.c | 14 ++++++++++++++
1 file changed, 14 insertions(+)
diff --git a/drivers/mtd/spi-nor/cadence-quadspi.c b/drivers/mtd/spi-nor/cadence-quadspi.c
index 792628750eec..c548567adcf0 100644
--- a/drivers/mtd/spi-nor/cadence-quadspi.c
+++ b/drivers/mtd/spi-nor/cadence-quadspi.c
@@ -34,6 +34,7 @@
#include <linux/of.h>
#include <linux/platform_device.h>
#include <linux/pm_runtime.h>
+#include <linux/reset.h>
#include <linux/sched.h>
#include <linux/spi/spi.h>
#include <linux/timer.h>
@@ -1336,6 +1337,7 @@ static int cqspi_probe(struct platform_device *pdev)
struct cqspi_st *cqspi;
struct resource *res;
struct resource *res_ahb;
+ struct reset_control *rstc;
const struct cqspi_driver_platdata *ddata;
int ret;
int irq;
@@ -1362,6 +1364,18 @@ static int cqspi_probe(struct platform_device *pdev)
return PTR_ERR(cqspi->clk);
}
+ /* Obtain QSPI reset control */
+ rstc = devm_reset_control_get_optional_exclusive(dev, NULL);
+ if (IS_ERR(rstc)) {
+ dev_err(dev, "Cannot get QSPI reset.\n");
+ if (PTR_ERR(rstc) == -EPROBE_DEFER)
+ return -EPROBE_DEFER;
+ } else {
+ reset_control_assert(rstc);
+ udelay(1);
+ reset_control_deassert(rstc);
+ }
+
/* Obtain and remap controller address. */
res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
cqspi->iobase = devm_ioremap_resource(dev, res);
--
2.20.0
Powered by blists - more mailing lists