Use the new reset_reset_bulk() API to properly cycle reset signals
during probe instead of just deasserting them. This ensures the
controller is properly reset before initialization.

Signed-off-by: Michal Simek <[email protected]>
Reviewed-by: Simon Glass <[email protected]>
---

Changes in v2:
- Pass 10us via parameter

 drivers/spi/cadence_qspi.c | 16 ++++------------
 1 file changed, 4 insertions(+), 12 deletions(-)

diff --git a/drivers/spi/cadence_qspi.c b/drivers/spi/cadence_qspi.c
index 2a4a49c5f1cf..984d4a39ded4 100644
--- a/drivers/spi/cadence_qspi.c
+++ b/drivers/spi/cadence_qspi.c
@@ -31,6 +31,8 @@
 #define CQSPI_DISABLE_STIG_MODE                BIT(0)
 #define CQSPI_DMA_MODE                 BIT(1)
 
+#define CQSPI_RESET_DELAY_US           10
+
 __weak int cadence_qspi_apb_dma_read(struct cadence_spi_priv *priv,
                                     const struct spi_mem_op *op)
 {
@@ -256,19 +258,9 @@ static int cadence_spi_probe(struct udevice *bus)
 
        priv->resets = devm_reset_bulk_get_optional(bus);
        if (priv->resets) {
-               /* Assert all OSPI reset lines */
-               ret = reset_assert_bulk(priv->resets);
-               if (ret) {
-                       dev_err(bus, "Failed to assert OSPI reset: %d\n", ret);
-                       return ret;
-               }
-
-               udelay(10);
-
-               /* Deassert all OSPI reset lines */
-               ret = reset_deassert_bulk(priv->resets);
+               ret = reset_reset_bulk(priv->resets, CQSPI_RESET_DELAY_US);
                if (ret) {
-                       dev_err(bus, "Failed to deassert OSPI reset: %d\n", 
ret);
+                       dev_err(bus, "Failed to reset OSPI: %d\n", ret);
                        return ret;
                }
        }
-- 
2.43.0

Reply via email to