1. 02 Sep, 2013 6 commits
  2. 28 Aug, 2013 2 commits
    • Lars-Peter Clausen's avatar
      dma: pl330: Fix handling of TERMINATE_ALL while processing completed descriptors · 39ff8613
      Lars-Peter Clausen authored
      The pl330 DMA driver is broken in regard to handling a terminate all request
      while it is processing the list of completed descriptors. This is most visible
      when calling dmaengine_terminate_all() from within the descriptors callback for
      cyclic transfers. In this case the TERMINATE_ALL transfer will clear the
      work_list and stop the transfer. But after all callbacks for all completed
      descriptors have been handled the descriptors will be re-enqueued into the (now
      empty) work_list. So the next time dma_async_issue_pending() is called for the
      channel these descriptors will be transferred again which will cause data
      corruption. Similar issues can occur if dmaengine_terminate_all() is not called
      from within the descriptor callback but runs on a different CPU at the same time
      as the completed descriptor list is processed.
      
      This patch introduces a new per channel list which will hold the completed
      descriptors. While processing the list the channel's lock will be held to avoid
      racing against dmaengine_terminate_all(). The lock will be released when calling
      the descriptors callback though. Since the list of completed descriptors might
      be modified (e.g. by calling dmaengine_terminate_all() from the callback) we can
      not use the normal list iterator macros. Instead we'll need to check for each
      loop iteration again if there are still items in the list. The drivers
      TERMINATE_ALL implementation is updated to move descriptors from both the
      work_list as well the new completed_list back to the descriptor pool. This makes
      sure that none of the descripts finds its way back into the work list and also
      that we do not call any futher complete callbacks after
      dmaengine_terminate_all() has been called.
      Signed-off-by: default avatarLars-Peter Clausen <lars@metafoo.de>
      Signed-off-by: default avatarVinod Koul <vinod.koul@intel.com>
      39ff8613
    • Zhangfei Gao's avatar
      dmaengine: Add hisilicon k3 DMA engine driver · 8e6152bc
      Zhangfei Gao authored
      Add dmaengine driver for hisilicon k3 platform based on virt_dma
      Signed-off-by: default avatarZhangfei Gao <zhangfei.gao@linaro.org>
      Tested-by: default avatarKai Yang <jean.yangkai@huawei.com>
      Acked-by: default avatarArnd Bergmann <arnd@arndb.de>
      Signed-off-by: default avatarVinod Koul <vinod.koul@intel.com>
      8e6152bc
  3. 26 Aug, 2013 3 commits
  4. 25 Aug, 2013 9 commits
  5. 19 Aug, 2013 2 commits
  6. 14 Aug, 2013 10 commits
  7. 13 Aug, 2013 7 commits
  8. 05 Aug, 2013 1 commit
    • Xiang Wang's avatar
      dma: mmp_pdma: clear DRCMR when free a phy channel · 26a2dfde
      Xiang Wang authored
      In mmp pdma, phy channels are allocated/freed dynamically.
      The mapping from DMA request to DMA channel number in DRCMR
      should be cleared when a phy channel is freed. Otherwise
      conflicts will happen when:
      1. A is using channel 2 and free it after finished, but A
      still maps to channel 2 in DRCMR of A.
      2. Now another one B gets channel 2. So B maps to channel 2
      too in DRCMR of B.
      In the datasheet, it is described that "Do not map two active
      requests to the same channel since it produces unpredictable
      results" and we can observe that during test.
      Signed-off-by: default avatarXiang Wang <wangx@marvell.com>
      Signed-off-by: default avatarVinod Koul <vinod.koul@intel.com>
      26a2dfde