将Linux IOMMU API与用户空间地址

时间:2016-06-28 22:40:35

标签: c linux linux-device-driver dma iommu

我有一个pci设备驱动程序,当前使用dma_map_page将用户空间地址映射到dma地址。这工作正常,但我正在尝试将此端口移植到iommu api以获得使用组和域提供的一些好处。

当前代码:此工作正常

ret = get_user_pages_fast(user_addr, one_page, flags, page);
dma_addr = dma_map_page(dev, off, size, *page, DMA_BIDIRECTIONAL);

IOMMU代码:这不起作用

ret = get_user_pages_fast(...);
pfn = page_to_pfn(*page);
group = iommu_group_get(dev);
domain = iommu_domain_alloc(dev->bus);
iommu_attach_device(domain, dev);
iommu_attach_group(domain, group);
iommu_map(domain, iova, pfn << PAGE_SHIFT, size, IOMMU_READ|IOMMU_WRITE);

所有功能都成功返回,但是当我将iova传递给设备时,设备无法使用它。有没有人曾经使用过iommu,知道我的问题在哪里或者我可以看到哪里?我无法在任何地方找到Linux的iommu实现。

修改: 在dmesg中有一些我第一次错过的条目:

DEBUG: phys addr 0x7738de000
DEBUG: iova 0xdeadb000
DMAR: DRHD: handling fault status reg 2
DMAR: DMAR:[DMA Read] Request device [50:00.0] fault addr 1fdaee4000 
DMAR:[fault reason 06] PTE Read access is not set

1 个答案:

答案 0 :(得分:0)

此类操作具有特权,因为它正在访问页表,或者可能是在任务结构内维护的数据结构。

请检查虚拟机管理程序如何执行此操作或虚拟机处理此类调用。可能有一些驱动程序接口通过管理程序将IOMMU分页单元设置为来宾操作系统。

Hypervisor也以特权模式执行。