免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
1234
最近访问板块 发新帖
楼主: duanius
打印 上一主题 下一主题

有关dma映射的问题 [复制链接]

论坛徽章:
0
31 [报告]
发表于 2008-08-05 22:51 |只看该作者
原帖由 spray_lx 于 2008-8-5 17:29 发表


兄弟能介绍下x86构架是怎么实现这种coherent的吗?

另外一个问题是基于ARM/MIPS构架的。记得在2.4.x的内核中,分配DMA空间就是获得连续的物理页框后,将映射物理页框的页面属性修改或ioremap为un-cachea ...

x86架构如何保证内存一致性在很多帖子中我已经和其它朋友讨论过了。兄弟可以百度一下,应该可以搜到chinanuix的帖子。
chinaunix的搜索功能不好用,我自己也翻不到。

你提到MIPS/ARM,我认为un-cacheable的内存都是一致的

论坛徽章:
0
32 [报告]
发表于 2009-05-06 03:13 |只看该作者
学习下

论坛徽章:
0
33 [报告]
发表于 2012-03-21 18:06 |只看该作者
好文,顶一把

论坛徽章:
1
拜羊年徽章
日期:2015-03-03 16:15:43
34 [报告]
发表于 2012-03-22 11:55 |只看该作者
回复 1# duanius
如果在DMA内存区,cache应该是在初始化页面时就disable了。不用担心。
如果cpu的dma engine支持scatter gather功能, 就不必大片连续的物理空间,可以用几个小片接力传递。

   

论坛徽章:
0
35 [报告]
发表于 2012-03-22 12:33 |只看该作者
”当一个缓冲区被流式映射 只有将其unmap掉后  驱动才能安全的访问里面的数据内容“,这个概念应该是从使用者的角度来说的。也就是说如果使用者想先前使用给外设做DMA的buffer的话,必须先做unmap操作。想象中unmap操作中就会做一个invalid cache的操作。这样才能保证驱动拿到的buffer的操作是正确的。
描述的是一个安全的操作flow,而不是物理上的某种限制。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP