크기가 약 40MB 인 대형 DMA 버퍼를 할당하려고합니다. 내가 dma_alloc_coherent()
를 사용하는 경우, 그것은 실패하고 내가 보는 것은 : 내가 다른 값을 시도하고 dma_alloc_coherent()
이상 2^25 바이트 (32메가바이트)를 할당 할 수없는 것 같습니다큰 DMA 버퍼 할당
------------[ cut here ]------------
WARNING: at mm/page_alloc.c:2106 __alloc_pages_nodemask+0x1dc/0x788()
Modules linked in:
[<8004799c>] (unwind_backtrace+0x0/0xf8) from [<80078ae4>] (warn_slowpath_common+0x4c/0x64)
[<80078ae4>] (warn_slowpath_common+0x4c/0x64) from [<80078b18>] (warn_slowpath_null+0x1c/0x24)
[<80078b18>] (warn_slowpath_null+0x1c/0x24) from [<800dfbd0>] (__alloc_pages_nodemask+0x1dc/0x788)
[<800dfbd0>] (__alloc_pages_nodemask+0x1dc/0x788) from [<8004a880>] (__dma_alloc+0xa4/0x2fc)
[<8004a880>] (__dma_alloc+0xa4/0x2fc) from [<8004b0b4>] (dma_alloc_coherent+0x54/0x60)
[<8004b0b4>] (dma_alloc_coherent+0x54/0x60) from [<803ced70>] (mxc_ipu_ioctl+0x270/0x3ec)
[<803ced70>] (mxc_ipu_ioctl+0x270/0x3ec) from [<80123b78>] (do_vfs_ioctl+0x80/0x54c)
[<80123b78>] (do_vfs_ioctl+0x80/0x54c) from [<8012407c>] (sys_ioctl+0x38/0x5c)
[<8012407c>] (sys_ioctl+0x38/0x5c) from [<80041f80>] (ret_fast_syscall+0x0/0x30)
---[ end trace 4e0c10ffc7ffc0d8 ]---
.
어떻게 큰 DMA 버퍼를 할당 할 수 있습니까?
큰 DMA 버퍼가 비싸다. 메모리 블록은 인접한 물리적 메모리 (일부 SPARC 시스템에서와 같이 I/O 용 MMU가없는 경우) 및 잠겨 있습니다 (우선 순위가 높은 작업에 의해 페이지 폴트를위한 공간을 만들기 위해 페이징 할 수 없음). 일반적인 해결 방법은 둘 이상의 DMA 버퍼를 사용하고 DMA 체인 (일명 scatter/gather)을 이용하는 것입니다. 한 블록에 40MB를 전송하는 I/O 연산이 실제로 있습니까? 아니면 실제로 연산의 누적입니까? – sawdust
제가 작업하고있는 소프트웨어의 사용 사례는 특수한 하드웨어로 비디오 캡쳐 및 이미지 처리를 위해 대형 DMA 버퍼가 필요합니다. 여러 개의 작은 버퍼를 사용하여 수행 할 수 있지만 시간이 지남에 따라 조각화는 버퍼를 해제하고 버퍼를 문제가있는 것으로 다시 할당합니다. 필요한 크기와 양의 DMA 버퍼가 고정되어 있으므로 부팅 할 때 메모리를 한 번 할당하고 사용자 공간에서 메모리 요청을 관리하려고합니다. – miluz
@miluz,이 문제를 해결 했습니까? 어떻게? – ransh