spi: sh-msiof: Extract sh_msiof_spi_{start,stop}() helpers
authorGeert Uytterhoeven <geert+renesas@glider.be>
Fri, 20 Jun 2014 10:16:17 +0000 (12:16 +0200)
committerMark Brown <broonie@linaro.org>
Sat, 21 Jun 2014 10:17:35 +0000 (11:17 +0100)
Based on an old patch by Guennadi Liakhovetski <g.liakhovetski@gmx.de>

Signed-off-by: Geert Uytterhoeven <geert+renesas@glider.be>
Signed-off-by: Mark Brown <broonie@linaro.org>
drivers/spi/spi-sh-msiof.c

index 38824a994131a29e512c63745d6bcd54fd19d226..2cd5fcb86f715ec54575392bfd75237f68a7f27d 100644 (file)
@@ -509,6 +509,40 @@ static int sh_msiof_prepare_message(struct spi_master *master,
        return 0;
 }
 
+static int sh_msiof_spi_start(struct sh_msiof_spi_priv *p, void *rx_buf)
+{
+       int ret;
+
+       /* setup clock and rx/tx signals */
+       ret = sh_msiof_modify_ctr_wait(p, 0, CTR_TSCKE);
+       if (rx_buf && !ret)
+               ret = sh_msiof_modify_ctr_wait(p, 0, CTR_RXE);
+       if (!ret)
+               ret = sh_msiof_modify_ctr_wait(p, 0, CTR_TXE);
+
+       /* start by setting frame bit */
+       if (!ret)
+               ret = sh_msiof_modify_ctr_wait(p, 0, CTR_TFSE);
+
+       return ret;
+}
+
+static int sh_msiof_spi_stop(struct sh_msiof_spi_priv *p, void *rx_buf)
+{
+       int ret;
+
+       /* shut down frame, rx/tx and clock signals */
+       ret = sh_msiof_modify_ctr_wait(p, CTR_TFSE, 0);
+       if (!ret)
+               ret = sh_msiof_modify_ctr_wait(p, CTR_TXE, 0);
+       if (rx_buf && !ret)
+               ret = sh_msiof_modify_ctr_wait(p, CTR_RXE, 0);
+       if (!ret)
+               ret = sh_msiof_modify_ctr_wait(p, CTR_TSCKE, 0);
+
+       return ret;
+}
+
 static int sh_msiof_spi_txrx_once(struct sh_msiof_spi_priv *p,
                                  void (*tx_fifo)(struct sh_msiof_spi_priv *,
                                                  const void *, int, int),
@@ -536,15 +570,9 @@ static int sh_msiof_spi_txrx_once(struct sh_msiof_spi_priv *p,
        if (tx_buf)
                tx_fifo(p, tx_buf, words, fifo_shift);
 
-       /* setup clock and rx/tx signals */
-       ret = sh_msiof_modify_ctr_wait(p, 0, CTR_TSCKE);
-       if (rx_buf)
-               ret = ret ? ret : sh_msiof_modify_ctr_wait(p, 0, CTR_RXE);
-       ret = ret ? ret : sh_msiof_modify_ctr_wait(p, 0, CTR_TXE);
-
-       /* start by setting frame bit */
        reinit_completion(&p->done);
-       ret = ret ? ret : sh_msiof_modify_ctr_wait(p, 0, CTR_TFSE);
+
+       ret = sh_msiof_spi_start(p, rx_buf);
        if (ret) {
                dev_err(&p->pdev->dev, "failed to start hardware\n");
                goto err;
@@ -560,12 +588,7 @@ static int sh_msiof_spi_txrx_once(struct sh_msiof_spi_priv *p,
        /* clear status bits */
        sh_msiof_reset_str(p);
 
-       /* shut down frame, rx/tx and clock signals */
-       ret = sh_msiof_modify_ctr_wait(p, CTR_TFSE, 0);
-       ret = ret ? ret : sh_msiof_modify_ctr_wait(p, CTR_TXE, 0);
-       if (rx_buf)
-               ret = ret ? ret : sh_msiof_modify_ctr_wait(p, CTR_RXE, 0);
-       ret = ret ? ret : sh_msiof_modify_ctr_wait(p, CTR_TSCKE, 0);
+       ret = sh_msiof_spi_stop(p, rx_buf);
        if (ret) {
                dev_err(&p->pdev->dev, "failed to shut down hardware\n");
                goto err;