DMA数据处理采用连续内存
2015-09-03 22:31
211 查看
DMA传输,是由PCI卡直接将数据送达虚拟内存地址(virtual address),不用CPU中转。
主要操作包括:
1 指定一片虚拟内存地址
2 将地址和大小告知PCI(例如通过将这两样存在PCI卡的寄存器中)
3 PCI卡收到数据后,读2中设置,将PCI卡中物理存储的数据(例如硬件队列中的数据)放入虚拟内存。
4 应用程序读取虚拟内存中数据后做处理。
在DMA中,需要注意步骤1中,虚拟内存的分配方式。
分配方式主要是两种:连续分配和断续分配。
连续分配:分配完整的一段内存。
断续分配:CPU分配一段,但不保证没人用时不会被别人占占用。
这断续分配在频繁读写DMA的场景下易于出问题。出问题的原因不在于DMA处理速度,即不在于步骤3.,而在于DMA已经完成步骤3,正在进行步骤4的时候。在步骤4时,就要警惕有人趁机插一腿使用内存,复写了(overwrite)了一部分虚拟内存。
建议频繁读写DMA时,使用连续内存(例如指定page几页专门用于DMA用)分配步骤1所需内存。。
主要操作包括:
1 指定一片虚拟内存地址
2 将地址和大小告知PCI(例如通过将这两样存在PCI卡的寄存器中)
3 PCI卡收到数据后,读2中设置,将PCI卡中物理存储的数据(例如硬件队列中的数据)放入虚拟内存。
4 应用程序读取虚拟内存中数据后做处理。
在DMA中,需要注意步骤1中,虚拟内存的分配方式。
分配方式主要是两种:连续分配和断续分配。
连续分配:分配完整的一段内存。
断续分配:CPU分配一段,但不保证没人用时不会被别人占占用。
这断续分配在频繁读写DMA的场景下易于出问题。出问题的原因不在于DMA处理速度,即不在于步骤3.,而在于DMA已经完成步骤3,正在进行步骤4的时候。在步骤4时,就要警惕有人趁机插一腿使用内存,复写了(overwrite)了一部分虚拟内存。
建议频繁读写DMA时,使用连续内存(例如指定page几页专门用于DMA用)分配步骤1所需内存。。
相关文章推荐
- (linux命令学习)找到相应性质的文件并删除
- GCD队列的注意事项
- 自制51单片机最小系统
- hdu 2871(区间合并)
- 逆向工程核心原理学习笔记2-基址重定位基本原理
- Java冒泡排序法
- 关于phpStudy测试php时遇到解析不了的解决办法
- newssoj1005监听还原 recover(kmp)
- UVA 11491
- Python 集合set
- Quartz.net Cron表达式
- 著名的黑客站点
- 在python3中使用urllib.request编写简单的网络爬虫
- random函数
- BZOJ 1059 矩阵游戏 (二分图最大匹配)
- CF 558 A. Lala Land and Apple Trees
- HDU 3065 AC自动机
- C语言中经常遇到的 segmentation fault 错误
- iOS开发之UI基础--三种简单的动画设置
- Reverse Words in a String