summaryrefslogtreecommitdiffstats
path: root/drivers/dma/virt-dma.h
diff options
context:
space:
mode:
authorVinod Koul2016-01-06 10:47:47 +0100
committerVinod Koul2016-01-06 10:47:47 +0100
commitd3f1e93ce8e00be19711c35f0c67c54a58aea559 (patch)
tree58010cdfa4fc473fc0693410b4a444755c4438c9 /drivers/dma/virt-dma.h
parentMerge branch 'topic/univ_api' into for-linus (diff)
parentdmaengine: Add might_sleep() to dmaengine_synchronize() (diff)
downloadkernel-qcow2-linux-d3f1e93ce8e00be19711c35f0c67c54a58aea559.tar.gz
kernel-qcow2-linux-d3f1e93ce8e00be19711c35f0c67c54a58aea559.tar.xz
kernel-qcow2-linux-d3f1e93ce8e00be19711c35f0c67c54a58aea559.zip
Merge branch 'topic/async' into for-linus
Diffstat (limited to 'drivers/dma/virt-dma.h')
-rw-r--r--drivers/dma/virt-dma.h13
1 files changed, 13 insertions, 0 deletions
diff --git a/drivers/dma/virt-dma.h b/drivers/dma/virt-dma.h
index bff8c39dd716..d9731ca5e262 100644
--- a/drivers/dma/virt-dma.h
+++ b/drivers/dma/virt-dma.h
@@ -163,4 +163,17 @@ static inline void vchan_free_chan_resources(struct virt_dma_chan *vc)
vchan_dma_desc_free_list(vc, &head);
}
+/**
+ * vchan_synchronize() - synchronize callback execution to the current context
+ * @vc: virtual channel to synchronize
+ *
+ * Makes sure that all scheduled or active callbacks have finished running. For
+ * proper operation the caller has to ensure that no new callbacks are scheduled
+ * after the invocation of this function started.
+ */
+static inline void vchan_synchronize(struct virt_dma_chan *vc)
+{
+ tasklet_kill(&vc->task);
+}
+
#endif