All configuration left in d40_phy_cfg() is runtime configurable and
there is already a call into it from d40_runtime_config(), so let's
rely on that.

Acked-by: Vinod Koul <vnod.k...@intel.com>
Acked-by: Arnd Bergmann <a...@arndb.de>
Signed-off-by: Lee Jones <lee.jo...@linaro.org>
---
 drivers/dma/ste_dma40.c    |   14 +++---
 drivers/dma/ste_dma40_ll.c |  101 +++++++++++++++++++++-----------------------
 drivers/dma/ste_dma40_ll.h |    3 +-
 3 files changed, 58 insertions(+), 60 deletions(-)

diff --git a/drivers/dma/ste_dma40.c b/drivers/dma/ste_dma40.c
index 759293e..b7fe46b 100644
--- a/drivers/dma/ste_dma40.c
+++ b/drivers/dma/ste_dma40.c
@@ -2043,6 +2043,14 @@ static int d40_config_memcpy(struct d40_chan *d40c)
        } else if (dma_has_cap(DMA_MEMCPY, cap) &&
                   dma_has_cap(DMA_SLAVE, cap)) {
                d40c->dma_cfg = dma40_memcpy_conf_phy;
+
+               /* Generate interrrupt at end of transfer or relink. */
+               d40c->dst_def_cfg |= BIT(D40_SREG_CFG_TIM_POS);
+
+               /* Generate interrupt on error. */
+               d40c->src_def_cfg |= BIT(D40_SREG_CFG_EIM_POS);
+               d40c->dst_def_cfg |= BIT(D40_SREG_CFG_EIM_POS);
+
        } else {
                chan_err(d40c, "No memcpy\n");
                return -EINVAL;
@@ -2496,9 +2504,6 @@ static int d40_alloc_chan_resources(struct dma_chan *chan)
        }
 
        pm_runtime_get_sync(d40c->base->dev);
-       /* Fill in basic CFG register values */
-       d40_phy_cfg(&d40c->dma_cfg, &d40c->src_def_cfg,
-                   &d40c->dst_def_cfg, chan_is_logical(d40c));
 
        d40_set_prio_realtime(d40c);
 
@@ -2862,8 +2867,7 @@ static int d40_set_runtime_config(struct dma_chan *chan,
        if (chan_is_logical(d40c))
                d40_log_cfg(cfg, &d40c->log_def.lcsp1, &d40c->log_def.lcsp3);
        else
-               d40_phy_cfg(cfg, &d40c->src_def_cfg,
-                           &d40c->dst_def_cfg, false);
+               d40_phy_cfg(cfg, &d40c->src_def_cfg, &d40c->dst_def_cfg);
 
        /* These settings will take precedence later */
        d40c->runtime_addr = config_addr;
diff --git a/drivers/dma/ste_dma40_ll.c b/drivers/dma/ste_dma40_ll.c
index 435a223..ab5a2a7 100644
--- a/drivers/dma/ste_dma40_ll.c
+++ b/drivers/dma/ste_dma40_ll.c
@@ -50,63 +50,58 @@ void d40_log_cfg(struct stedma40_chan_cfg *cfg,
 
 }
 
-/* Sets up SRC and DST CFG register for both logical and physical channels */
-void d40_phy_cfg(struct stedma40_chan_cfg *cfg,
-                u32 *src_cfg, u32 *dst_cfg, bool is_log)
+void d40_phy_cfg(struct stedma40_chan_cfg *cfg, u32 *src_cfg, u32 *dst_cfg)
 {
        u32 src = 0;
        u32 dst = 0;
 
-       if (!is_log) {
-               /* Physical channel */
-               if ((cfg->dir ==  STEDMA40_PERIPH_TO_MEM) ||
-                   (cfg->dir == STEDMA40_PERIPH_TO_PERIPH)) {
-                       /* Set master port to 1 */
-                       src |= 1 << D40_SREG_CFG_MST_POS;
-                       src |= D40_TYPE_TO_EVENT(cfg->dev_type);
-
-                       if (cfg->src_info.flow_ctrl == STEDMA40_NO_FLOW_CTRL)
-                               src |= 1 << D40_SREG_CFG_PHY_TM_POS;
-                       else
-                               src |= 3 << D40_SREG_CFG_PHY_TM_POS;
-               }
-               if ((cfg->dir ==  STEDMA40_MEM_TO_PERIPH) ||
-                   (cfg->dir == STEDMA40_PERIPH_TO_PERIPH)) {
-                       /* Set master port to 1 */
-                       dst |= 1 << D40_SREG_CFG_MST_POS;
-                       dst |= D40_TYPE_TO_EVENT(cfg->dev_type);
-
-                       if (cfg->dst_info.flow_ctrl == STEDMA40_NO_FLOW_CTRL)
-                               dst |= 1 << D40_SREG_CFG_PHY_TM_POS;
-                       else
-                               dst |= 3 << D40_SREG_CFG_PHY_TM_POS;
-               }
-               /* Interrupt on end of transfer for destination */
-               dst |= 1 << D40_SREG_CFG_TIM_POS;
-
-               /* Generate interrupt on error */
-               src |= 1 << D40_SREG_CFG_EIM_POS;
-               dst |= 1 << D40_SREG_CFG_EIM_POS;
-
-               /* PSIZE */
-               if (cfg->src_info.psize != STEDMA40_PSIZE_PHY_1) {
-                       src |= 1 << D40_SREG_CFG_PHY_PEN_POS;
-                       src |= cfg->src_info.psize << D40_SREG_CFG_PSIZE_POS;
-               }
-               if (cfg->dst_info.psize != STEDMA40_PSIZE_PHY_1) {
-                       dst |= 1 << D40_SREG_CFG_PHY_PEN_POS;
-                       dst |= cfg->dst_info.psize << D40_SREG_CFG_PSIZE_POS;
-               }
-
-               /* Element size */
-               src |= cfg->src_info.data_width << D40_SREG_CFG_ESIZE_POS;
-               dst |= cfg->dst_info.data_width << D40_SREG_CFG_ESIZE_POS;
-
-               /* Set the priority bit to high for the physical channel */
-               if (cfg->high_priority) {
-                       src |= 1 << D40_SREG_CFG_PRI_POS;
-                       dst |= 1 << D40_SREG_CFG_PRI_POS;
-               }
+       if ((cfg->dir ==  STEDMA40_PERIPH_TO_MEM) ||
+           (cfg->dir == STEDMA40_PERIPH_TO_PERIPH)) {
+               /* Set master port to 1 */
+               src |= 1 << D40_SREG_CFG_MST_POS;
+               src |= D40_TYPE_TO_EVENT(cfg->dev_type);
+
+               if (cfg->src_info.flow_ctrl == STEDMA40_NO_FLOW_CTRL)
+                       src |= 1 << D40_SREG_CFG_PHY_TM_POS;
+               else
+                       src |= 3 << D40_SREG_CFG_PHY_TM_POS;
+       }
+       if ((cfg->dir ==  STEDMA40_MEM_TO_PERIPH) ||
+           (cfg->dir == STEDMA40_PERIPH_TO_PERIPH)) {
+               /* Set master port to 1 */
+               dst |= 1 << D40_SREG_CFG_MST_POS;
+               dst |= D40_TYPE_TO_EVENT(cfg->dev_type);
+
+               if (cfg->dst_info.flow_ctrl == STEDMA40_NO_FLOW_CTRL)
+                       dst |= 1 << D40_SREG_CFG_PHY_TM_POS;
+               else
+                       dst |= 3 << D40_SREG_CFG_PHY_TM_POS;
+       }
+       /* Interrupt on end of transfer for destination */
+       dst |= 1 << D40_SREG_CFG_TIM_POS;
+
+       /* Generate interrupt on error */
+       src |= 1 << D40_SREG_CFG_EIM_POS;
+       dst |= 1 << D40_SREG_CFG_EIM_POS;
+
+       /* PSIZE */
+       if (cfg->src_info.psize != STEDMA40_PSIZE_PHY_1) {
+               src |= 1 << D40_SREG_CFG_PHY_PEN_POS;
+               src |= cfg->src_info.psize << D40_SREG_CFG_PSIZE_POS;
+       }
+       if (cfg->dst_info.psize != STEDMA40_PSIZE_PHY_1) {
+               dst |= 1 << D40_SREG_CFG_PHY_PEN_POS;
+               dst |= cfg->dst_info.psize << D40_SREG_CFG_PSIZE_POS;
+       }
+
+       /* Element size */
+       src |= cfg->src_info.data_width << D40_SREG_CFG_ESIZE_POS;
+       dst |= cfg->dst_info.data_width << D40_SREG_CFG_ESIZE_POS;
+
+       /* Set the priority bit to high for the physical channel */
+       if (cfg->high_priority) {
+               src |= 1 << D40_SREG_CFG_PRI_POS;
+               dst |= 1 << D40_SREG_CFG_PRI_POS;
        }
 
        if (cfg->src_info.big_endian)
diff --git a/drivers/dma/ste_dma40_ll.h b/drivers/dma/ste_dma40_ll.h
index fdde8ef..1b47312 100644
--- a/drivers/dma/ste_dma40_ll.h
+++ b/drivers/dma/ste_dma40_ll.h
@@ -432,8 +432,7 @@ enum d40_lli_flags {
 
 void d40_phy_cfg(struct stedma40_chan_cfg *cfg,
                 u32 *src_cfg,
-                u32 *dst_cfg,
-                bool is_log);
+                u32 *dst_cfg);
 
 void d40_log_cfg(struct stedma40_chan_cfg *cfg,
                 u32 *lcsp1,
-- 
1.7.10.4

--
To unsubscribe from this list: send the line "unsubscribe linux-usb" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to