diff options
author | Dan Williams <dan.j.williams@intel.com> | 2009-01-11 00:20:39 -0800 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2009-01-11 00:20:39 -0800 |
commit | 649274d993212e7c23c0cb734572c2311c200872 (patch) | |
tree | 84ff8e44e5b44bbe3c388eded5c3e28bf0bd2375 /include/linux | |
parent | 47fd23fe8efeea3af4593a8424419df48724eb25 (diff) | |
download | kernel-crypto-649274d993212e7c23c0cb734572c2311c200872.tar.gz kernel-crypto-649274d993212e7c23c0cb734572c2311c200872.tar.xz kernel-crypto-649274d993212e7c23c0cb734572c2311c200872.zip |
net_dma: acquire/release dma channels on ifup/ifdown
The recent dmaengine rework removed the capability to remove dma device
driver modules while net_dma is active. Rather than notify
dmaengine-clients that channels are trying to be removed, we now rely on
clients to notify dmaengine when they no longer have a need for
channels. Teach net_dma to release channels by taking dmaengine
references at netdevice open and dropping references at netdevice close.
Acked-by: Maciej Sosnowski <maciej.sosnowski@intel.com>
Signed-off-by: Dan Williams <dan.j.williams@intel.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'include/linux')
-rw-r--r-- | include/linux/dmaengine.h | 10 |
1 files changed, 10 insertions, 0 deletions
diff --git a/include/linux/dmaengine.h b/include/linux/dmaengine.h index 64dea2ab326..c73f1e2b59b 100644 --- a/include/linux/dmaengine.h +++ b/include/linux/dmaengine.h @@ -270,8 +270,18 @@ struct dma_device { /* --- public DMA engine API --- */ +#ifdef CONFIG_DMA_ENGINE void dmaengine_get(void); void dmaengine_put(void); +#else +static inline void dmaengine_get(void) +{ +} +static inline void dmaengine_put(void) +{ +} +#endif + dma_cookie_t dma_async_memcpy_buf_to_buf(struct dma_chan *chan, void *dest, void *src, size_t len); dma_cookie_t dma_async_memcpy_buf_to_pg(struct dma_chan *chan, |