Files
kernel-tenderloin-3.0/include/linux
Dan Williams 59b5ec2144 dmaengine: introduce dma_request_channel and private channels
This interface is primarily for device-to-memory clients which need to
search for dma channels with platform-specific characteristics.  The
prototype is:

struct dma_chan *dma_request_channel(dma_cap_mask_t mask,
                                     dma_filter_fn filter_fn,
                                     void *filter_param);

When the optional 'filter_fn' parameter is set to NULL
dma_request_channel simply returns the first channel that satisfies the
capability mask.  Otherwise, when the mask parameter is insufficient for
specifying the necessary channel, the filter_fn routine can be used to
disposition the available channels in the system. The filter_fn routine
is called once for each free channel in the system.  Upon seeing a
suitable channel filter_fn returns DMA_ACK which flags that channel to
be the return value from dma_request_channel.  A channel allocated via
this interface is exclusive to the caller, until dma_release_channel()
is called.

To ensure that all channels are not consumed by the general-purpose
allocator the DMA_PRIVATE capability is provided to exclude a dma_device
from general-purpose (memory-to-memory) consideration.

Reviewed-by: Andrew Morton <akpm@linux-foundation.org>
Acked-by: Maciej Sosnowski <maciej.sosnowski@intel.com>
Signed-off-by: Dan Williams <dan.j.williams@intel.com>
2009-01-06 11:38:15 -07:00
..
2008-10-22 01:19:37 +02:00
2008-10-13 21:51:51 +01:00
2009-01-04 13:33:20 -08:00
2008-12-30 16:51:43 -05:00
2008-11-11 21:15:50 -05:00
2008-10-20 11:01:52 -07:00
2008-12-29 08:29:50 +01:00
2008-12-03 22:12:38 -08:00
2008-12-03 22:12:38 -08:00
2008-10-20 08:52:42 -07:00
2009-01-01 10:12:19 +10:30
2008-12-29 08:29:50 +01:00
2008-11-26 12:13:34 +01:00
2009-01-04 13:33:20 -08:00
2008-11-12 17:17:18 -08:00
2008-11-14 10:39:23 +11:00
2008-10-30 11:38:45 -07:00
2008-10-16 11:21:32 -07:00
2008-11-30 11:00:15 -08:00
2009-01-02 12:19:34 -08:00
2008-12-29 17:47:23 +10:00
2008-12-25 11:01:43 +11:00
2008-11-24 18:57:41 -05:00
2008-12-31 18:07:38 -05:00
2009-01-03 14:02:18 +01:00
2008-12-29 07:39:34 -05:00
2008-10-16 16:53:13 +02:00
2008-12-15 23:44:31 -08:00
2009-01-04 13:33:20 -08:00
2009-01-04 13:33:20 -08:00
2008-12-29 11:27:46 +02:00
2008-12-31 18:07:42 -05:00
2008-10-16 16:08:57 +02:00
2008-10-16 11:21:40 -07:00
2008-12-08 01:14:16 -08:00
2008-10-14 23:51:02 +02:00
2008-10-22 20:21:33 +02:00
2008-10-16 11:21:38 -07:00
2008-12-31 18:07:42 -05:00
2008-10-29 22:02:09 +01:00
2008-11-03 18:21:45 +01:00
2008-10-15 14:24:08 +02:00
2008-12-31 15:11:46 +01:00
2009-01-03 14:11:07 +01:00
2008-10-20 22:34:12 +01:00
2008-12-28 22:43:21 -05:00
2008-10-13 09:47:43 +11:00
2008-10-20 08:52:31 -07:00
2008-10-22 10:00:23 +11:00
2008-11-06 15:41:21 -08:00
2008-12-08 14:31:59 +01:00
2008-11-19 18:49:57 -08:00
2008-12-23 15:21:45 -05:00
2008-12-19 15:22:54 -05:00
2008-12-21 14:21:14 +11:00
2008-11-30 10:03:35 -08:00
2008-10-20 08:50:26 -07:00
2008-10-16 11:21:49 -07:00
2008-10-22 16:42:43 -07:00
2008-11-28 16:24:56 -08:00
2008-12-04 09:09:37 +01:00
2008-11-07 22:56:00 -08:00
2008-11-20 04:10:00 -08:00
2008-10-23 00:11:07 -04:00
2008-10-23 18:54:05 +04:00
2008-12-20 09:15:46 +01:00
2008-10-16 11:21:46 -07:00
2008-10-16 11:21:46 -07:00
2008-11-12 17:17:17 -08:00
2008-11-16 19:39:21 -08:00
2008-10-20 08:52:40 -07:00
2009-01-04 13:33:20 -08:00
2008-12-15 23:42:33 -08:00
2008-12-30 09:05:16 +10:30
2008-11-24 21:27:22 -08:00
2008-11-02 10:15:07 -08:00
2008-10-20 08:52:31 -07:00
2008-11-19 18:49:57 -08:00
2008-10-16 11:21:47 -07:00
2008-10-13 09:51:40 -07:00
2009-01-01 10:12:25 +10:30
2008-12-12 17:01:38 +01:00
2009-01-02 10:19:36 -08:00
2008-12-29 08:29:51 +01:00
2008-10-16 11:21:31 -07:00