当前位置: 首页 > news >正文

做报名网站软件园

做报名网站,软件园,深圳传媒公司有哪些,哈尔滨旅游网页设计一、DMA的引入 Non-DMA:CPU直接与设备进行数据交互,CPU的负载会随着数据的读写而增加; DMA:CPU不参与数据的直接传输,DMA Controller负责Device与Memory之间的数据搬运,并以中断信号的形式通知CPU&#xf…

一、DMA的引入

Non-DMA:CPU直接与设备进行数据交互,CPU的负载会随着数据的读写而增加;
DMA:CPU不参与数据的直接传输,DMA Controller负责Device与Memory之间的数据搬运,并以中断信号的形式通知CPU;
可以看出,DMA可以提高CPU的使用率。

二、IOMMU与DMA的关系

可以看出,IOMMU是DMA过程中的一环,也是实现DMA的一种手段。(当然DMA也可以不走IOMMU,但是有的安全隐患)

三、IOMMU的作用

1、IOMMU是设备访问物理地址的媒介, IOMMU使得设备无法直接访问物理地址,大大增加了设备进行DMA攻击的难度。(安全性)

2、部分设备的引脚数较少,导致其位数较低,无法寻址到整个物理内存空间。(成本原因?越多引脚意味着更大的寻址范围(越多的bit位))

以目前主流的32位设备为例,其在物理内存中直接寻址的范围是[0, 4GB)。但是,现代操作系统的内存往往大于4GB。如果设备申请DMA时,内核为设备分配的DMA buffer的地址高于4GB(以下简称为“high buffer”),则设备将无法寻址到它。
有了IOMMU以后,IOMMU就可以在[0, 4GB)范围内分配一段与高地址buffer长度相同的内存,让设备能够直接寻址(以下称为“low buffer”)。设备向low buffer写入后,IOMMU就会将low buffer中的内容,复制到high buffer,而后通知CPU从high buffer读取内容。反之亦然——CPU向high buffer写入后,IOMMU就会将high buffer中的内容,复制到low buffer,而后通知设备从low buffer读取内容。这样,CPU和设备都能读取到对方写入的内容。这样在high buffer和low buffer之间复制内容的操作,在IOMMU机制中被称为“sync”或“bounce”。(重点)

读者可能会想,内存的复制,在内核中,不就是调用memcpy()函数来实现的吗?没错,这就是本文要介绍的IOMMU的软件实现方式——SWIOTLB。之所以说是软件实现,是因为sync操作在底层正是调用memcpy()函数,这完全是软件实现的。

四、IOMMU的分类

1、软件IOMMU(SWIOTLB)

2、硬件IOMMU(Intel IOMMU、AMD IOMMU)(与各个厂商的硬件实现有关)

五、SWIOTLB

SWIOTLB(software input/output table translation lookaside buffer)(软件IO地址转换缓冲区)

SWIOTLB的作用在于,使得寻址能力较低、无法直接寻址到内核所分配的DMA buffer的那些设备,也能够进行DMA操作

在目前主流的Linux操作系统中,SWIOTLB发挥作用的场合并不多见。这主要是由于以下原因:

现代的外部设备,通常都是32位或64位设备。64位设备毫无疑问可以直接寻址整个物理内存空间;而32位设备能够直接寻址的范围也达到了4G。如果操作系统运行内存不大于4G,则所有内存都可以被这些设备直接寻址到,此时设备的DMA操作,就无需SWIOTLB的辅助。
相比硬件IOMMU,SWIOTLB存在memcpy()操作,需要CPU的参与(cpu性能比不上dma控制器?),降低了效率,这是软件实现的固有弊端。
如果启动参数中同时启用SWIOTLB和硬件IOMMU(例如Intel IOMMU),那么当Linux系统启动完成后,SWIOTLB将会被禁用,而仅保留硬件IOMMU。

如果关闭IOMMU,dma 默认不会走iommu(硬件方式),而是走传统的swiotlb方式的dma(软件方式);缺点是效率较低。

六、关闭IOMMU的方式

1、grub命令行中添加 iommu.passthrough=0 参数

2、acpi表或者dts中不配置相应的smmu节点(保证不会正常设备驱动匹配)

参考ARM SMMU原理与IOMMU技术(“VT-d” DMA、I/O虚拟化、内存虚拟化)_asid pasid-CSDN博客

未完待续,持续更新

参考文章:

看完秒懂:Linux DMA mapping机制分析_dma map single-CSDN博客

Linux x86-64 IOMMU详解(一)——IOMMU简介_ioxumux-CSDN博客

http://www.yayakq.cn/news/162310/

相关文章:

  • 淮南专业网站建设网龙沧州网站制作
  • 男女做暖暖的试看网站建设部门网站
  • 怎样自己做网站赚钱吗wordpress文章审核发邮件
  • 有了自己的网站怎样做后台wordpress 点击 排名
  • 营销型网站建设是什么意思网站建设的解决方案
  • 思行做网站线上销售水果营销方案
  • 网站开发交流群中信国际建设公司网站
  • 外贸网站建设公司服务电子商务网站建设与维护试卷答案
  • 做网站用c 还是php哈尔滨市建工建设有限公司
  • 佛山建站 网站 商城东光网站建设淘宝店铺装修
  • 网站建设新技术wordpress调用文章内容图片
  • 免费做视频网站苏宁易购网站建设情况
  • 做的网站在百度上搜不出来的百度做网站电话多少
  • 国泰君安建设工程官方网站梵克雅宝耳钉
  • 沈阳网站推广排名方案页游和做网站
  • 以前老网站wordpress ico 上传
  • 惠州建站方案莱芜东风街
  • 为什么做网站结构优化网页制作基础教程电子工业出版社
  • 外贸网站布局用台式机做网站服务器
  • 有哪些做婚品的网站中国纪检监察报官首页
  • qq教程网站源码排版设计模板网站
  • wordpress the postgoogleseo推广
  • 我想做服装网站怎么做珠海网站建设知识
  • wordpress 模板4列插件安阳网站关键词优化
  • 收废品做网站求一个好看的网站
  • 做国外的网站wordpress面向对象
  • 上海网站建设的公司wordpress 优惠券 插件
  • 深圳网站建设哪家好做个手机app需要多少钱
  • 滕州网站建设培训恢复最近删除的网站
  • 国内优秀设计网站站长微信投票网站怎么做