diff options
author | Sinan Kaya <okaya@codeaurora.org> | 2017-03-25 19:04:02 -0400 |
---|---|---|
committer | Vinod Koul <vinod.koul@intel.com> | 2017-03-27 01:13:38 -0400 |
commit | c3a4528788cf09d709217f21be4b0fc38ada17d0 (patch) | |
tree | 0ba61ccd3d43873fd5cf266d8915cfc2a0673fe4 | |
parent | c1ae3cfa0e89fa1a7ecc4c99031f5e9ae99d9201 (diff) |
dmaengine: qcom_hidma: disable/enable IRQs on pause/resume
Once the channels are stopped, disable interrupts to make sure no new
HW interaction can happen.
Similarly, re-enable the interrupts only if we know that channel is
operational again.
Signed-off-by: Sinan Kaya <okaya@codeaurora.org>
Signed-off-by: Vinod Koul <vinod.koul@intel.com>
-rw-r--r-- | drivers/dma/qcom/hidma_ll.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/drivers/dma/qcom/hidma_ll.c b/drivers/dma/qcom/hidma_ll.c index 6645bdf0d151..1530a661518d 100644 --- a/drivers/dma/qcom/hidma_ll.c +++ b/drivers/dma/qcom/hidma_ll.c | |||
@@ -499,6 +499,9 @@ int hidma_ll_enable(struct hidma_lldev *lldev) | |||
499 | lldev->trch_state = HIDMA_CH_ENABLED; | 499 | lldev->trch_state = HIDMA_CH_ENABLED; |
500 | lldev->evch_state = HIDMA_CH_ENABLED; | 500 | lldev->evch_state = HIDMA_CH_ENABLED; |
501 | 501 | ||
502 | /* enable irqs */ | ||
503 | writel(ENABLE_IRQS, lldev->evca + HIDMA_EVCA_IRQ_EN_REG); | ||
504 | |||
502 | return 0; | 505 | return 0; |
503 | } | 506 | } |
504 | 507 | ||
@@ -596,6 +599,9 @@ int hidma_ll_disable(struct hidma_lldev *lldev) | |||
596 | 599 | ||
597 | lldev->trch_state = HIDMA_CH_SUSPENDED; | 600 | lldev->trch_state = HIDMA_CH_SUSPENDED; |
598 | lldev->evch_state = HIDMA_CH_SUSPENDED; | 601 | lldev->evch_state = HIDMA_CH_SUSPENDED; |
602 | |||
603 | /* disable interrupts */ | ||
604 | writel(0, lldev->evca + HIDMA_EVCA_IRQ_EN_REG); | ||
599 | return 0; | 605 | return 0; |
600 | } | 606 | } |
601 | 607 | ||