Alignment problems: arm_memblock_steal() + dma_declare_coherent_memory()
Russell King - ARM Linux
linux at arm.linux.org.uk
Fri Sep 14 05:23:40 EDT 2012
On Fri, Sep 14, 2012 at 10:49:27AM +0200, javier Martin wrote:
> Hello,
> we use arm_memblock_steal() + dma_declare_coherent_memory() in order
> to reserve son contiguous video memory in our platform:
> http://git.linuxtv.org/media_tree.git/blob/refs/heads/staging/for_v3.7:/arch/arm/mach-imx/mach-imx27_visstrim_m10.c
>
> We've noticed that some restrictive alignment constraints are being
> applied. For example, for coda driver, the following allocations are
> made:
>
> coda coda-imx27.0: dma_alloc_from_coherent: try to allocate 557056
> bytes, out of 8388608 (vaddr = 0xc6000000) PAGE_SHIFT = 0xc
> coda coda-imx27.0: dma_alloc_from_coherent: try to allocate 65536
> bytes, out of 8388608 (vaddr = 0xc6100000) PAGE_SHIFT = 0xc
> coda coda-imx27.0: dma_alloc_from_coherent: try to allocate 10240
> bytes, out of 8388608 (vaddr = 0xc6110000) PAGE_SHIFT = 0xc
> coda coda-imx27.0: dma_alloc_from_coherent: try to allocate 622080
> bytes, out of 8388608 (vaddr = 0xc6200000) PAGE_SHIFT = 0xc
> coda coda-imx27.0: dma_alloc_from_coherent: try to allocate 622080
> bytes, out of 8388608 (vaddr = 0xc6300000) PAGE_SHIFT = 0xc
> coda coda-imx27.0: dma_alloc_from_coherent: try to allocate 622080
> bytes, out of 8388608 (vaddr = 0xc6400000) PAGE_SHIFT = 0xc
> coda coda-imx27.0: dma_alloc_from_coherent: try to allocate 589824
> bytes, out of 8388608 (vaddr = 0xc6500000) PAGE_SHIFT = 0xc
> coda coda-imx27.0: dma_alloc_from_coherent: try to allocate 589824
> bytes, out of 8388608 (vaddr = 0xc6600000) PAGE_SHIFT = 0xc
> coda coda-imx27.0: dma_alloc_from_coherent: try to allocate 622080
> bytes, out of 8388608 (vaddr = 0xc6700000) PAGE_SHIFT = 0xc
>
> If we take a look at the size of each allocation and the different
> vaddr values we find that the alignment is 0x100000 = 1MB for values
> like 622080 byte size. Why is that?
Have you thought about get_order() on the allocation size, and what the
resulting order will be? I'm sure if you could come up with a better
allocation algorithm for this which doesn't lead to too much fragmentation
(or convert it to use the pool infrastructure)...
BTW, your question has nothing to do with arm_memblock_steal().
More information about the linux-arm-kernel
mailing list