DMA框架介绍(1)

本文探讨了内核DMA框架的工作原理,包括如何将内存物理地址映射为设备可访问的IOVA,以及IOMMU框架在DMA映射和 unmapping 过程中的作用。此外,还详细介绍了IOVA框架的RCACHE缓存机制和ARM SMMU驱动如何参与硬件交互,如设备识别和页表操作。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

        对SMMU驱动已经熟悉了一段时间,接下来计划对相关的内容进行分析。

       内核DMA框架用于将内存物理地址PA进行映射为设备可访问的IOVA,并对驱动提供API可用接口。它包括IOVA框架(包括IOVA的分配和释放)、IOMMU框架(DMA MAP/UNMAP过程)、页表操作、ARM SMMU驱动及提供给驱动的框架。

DMA API接口为驱动提供DMA分配/释放接口,包括一致性DMA和流式DMA;

IOMMU框架提供DMA MAP/UNMAP过程:根据DMA API接口提供的参数,分配/释放IOVA,并调用ARM驱动进行页表相关操作,建立/销毁页表项; 

IOVA框架提供IOVA的分配和释放,同时提供RCACHE缓存机制; 

ARM驱动负责与SMMU硬件的交互,包括SMMU识别、外设的识别等。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值