Я выделил память, выровненную 4KB в пространстве пользователя, используя posix_memalign , а затем передал адрес драйверу через ioctl . В драйвере я использовал get_user_pages для прикрепления памяти, затем получил DMA_ADDR с использованием DMA_MAP_PAGE и выполнил передачу DMA. После завершения передачи я назвал функцию синхронизации dma_sync_single_for_cpu (dma_from_device) в обработчике прерываний, а затем уведомил пространство пользователя. DATA. Так почему же этот кэш не согласуется? < /P>
[/b]
При проверке памяти из пространства ядра с использованием виртуального адреса ядра, полученного через KMAP после закрепления страницы, данные всегда верны.
Подробнее здесь:
https://stackoverflow.com/questions/796 ... c-single-f