dmaengine: qcom_hidma: prevent disable in error
authorSinan Kaya <okaya@codeaurora.org>
Thu, 6 Oct 2016 19:33:14 +0000 (15:33 -0400)
committerVinod Koul <vinod.koul@intel.com>
Tue, 18 Oct 2016 15:03:33 +0000 (20:33 +0530)
When an error is observed, we try to disable the channel and prevent
further accesses from the client.

Depending on the type of error, transitioning into disabled state might
not be possible. Adding a check to make sure that HW is in enabled/running
state before the disable transition happens.

Signed-off-by: Sinan Kaya <okaya@codeaurora.org>
Signed-off-by: Vinod Koul <vinod.koul@intel.com>
drivers/dma/qcom/hidma_ll.c

index 3224f24c577bb35ed808e391379e1e2619710f6b..c3a66c9b0ab7b8ed9a37ae4378732087a1013db2 100644 (file)
@@ -564,19 +564,8 @@ int hidma_ll_disable(struct hidma_lldev *lldev)
        u32 val;
        int ret;
 
-       val = readl(lldev->evca + HIDMA_EVCA_CTRLSTS_REG);
-       lldev->evch_state = HIDMA_CH_STATE(val);
-       val = readl(lldev->trca + HIDMA_TRCA_CTRLSTS_REG);
-       lldev->trch_state = HIDMA_CH_STATE(val);
-
-       /* already suspended by this OS */
-       if ((lldev->trch_state == HIDMA_CH_SUSPENDED) ||
-           (lldev->evch_state == HIDMA_CH_SUSPENDED))
-               return 0;
-
-       /* already stopped by the manager */
-       if ((lldev->trch_state == HIDMA_CH_STOPPED) ||
-           (lldev->evch_state == HIDMA_CH_STOPPED))
+       /* The channel needs to be in working state */
+       if (!hidma_ll_isenabled(lldev))
                return 0;
 
        val = readl(lldev->trca + HIDMA_TRCA_CTRLSTS_REG);