Hi Arnd, On Thursday, April 12, 2012 1:18 PM Arnd Bergmann wrote: > On Thursday 12 April 2012, Marek Szyprowski wrote: > > Scatter lists were initially designed for the disk based block io operations, > > hence the presence of the in-page offsets and lengths for each chunk. For > > multimedia use cases providing an array of struct pages and asking dma-mapping > > to map them into contiguous memory is probably all we need. I wonder if > > introducing such new calls is a good idea. Anrd, what do think? It will > > definitely simplify the drivers and improve the code understanding. On the > > other hand it requires a significant amount of work in the dma-mapping > > framework for all architectures, but that's not a big issue for me. > > My feeling is that it's too much like the existing _sg version, so I wouldn't > add yet another variant. While having a simple page array is definitely > simpler and potentially faster, I think the API is already too complex > and we need to be very careful with new additions. You are right, the API is already complex. The idea of adding page array came after explaining once again how the _sg functions work and how to use them for this specific use case. There is one more point for page array. Scatter-lists are also very inefficient in terms of the used memory. In the worst case we create a single scatterlist entry for every single page of the large buffer. For each entry we really use only a page pointer, leaving offset at zero and size set to 4KiB, dma_address and dma_length entries are usually used only for the first element in the list. On the other hand scatter lists are the only way to describe a complex block IO requests which is spread across multiple io buffers, which are smaller than a single page. Having a specialized set of functions in the API is not bad in general. Maybe the obscurity of the current _sg functions was the reason that almost every developer involved in gfx/multimedia and memory management tried to provide his own solution instead of using the dma-mapping api. We already have dma_map_page() and dma_map_single() which are very similar. Maybe adding dma_map_pages() won't be such a bad idea? If not maybe we should provide some kind of helper functions which converts page array to scatterlist and then maps them. Best regards -- Marek Szyprowski Samsung Poland R&D Center -- To unsubscribe from this list: send the line "unsubscribe linux-tegra" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html