"Adam J. Richter" wrote:
>
> David Brownell wrote:
>
> >struct dma_pool *dma_pool_create(char *, struct device *, size_t)
> >void dma_pool_destroy (struct dma_pool *pool)
> >void *dma_pool_alloc(struct dma_pool *, int mem_flags, dma_addr_t *)
> >void dma_pool_free(struct dma_pool *, void *, dma_addr_t)
>
> I would like to be able to have failure-free, deadlock-free
> blocking memory allocation, such as we have with the non-DMA mempool
> library so that we can guarantee that drivers that have been
> successfully initialized will continue to work regardless of memory
> pressure, and reduce error branches that drivers have to deal with.
>
> Such a facility could be layered on top of your interface
> perhaps by extending the mempool code to pass an extra parameter
> around. If so, then you should think about arranging your interface
> so that it could be driven with as little glue as possible by mempool.
>
What is that parameter? The size, I assume. To do that you'd
need to create different pools for different allocation sizes.
Bear in mind that mempool only makes sense with memory objects
which have the special characteristic that "if you wait long enough,
someone will free one". ie: BIOs, nfs requests, etc. Probably,
DMA buffers fit into that picture as well.
If anything comes out of this discussion, please let it be the
removal of the hard-wired GFP_ATOMIC in dma_alloc_coherent. That's
quite broken - the interface should (always) be designed so that the
caller can pass in the gfp flags (__GFP_WAIT,__GFP_IO,__GFP_FS, at least)
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@vger.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
This archive was generated by hypermail 2b29 : Tue Dec 31 2002 - 22:00:20 EST