linux性能优化基础——iommu相关配置

此篇文档介绍了IOMMU相关的信息:

https://blog.chaosjohn.com/Check-VT-D-or-IOMMU-under-Linux.html

iommu和vt-d都是io半虚拟化的一种技术,两者很接近,只不过iommu是AMD的,vt-d是Intel的。

IO半虚拟化对比IO虚拟化,主要是虚拟机可直接和IO设备通信,而不必走VMM虚拟出来的虚拟IO设备。举例来说,VMguest系统可以直接访问物理显卡并调用其资源,而不必通过VMM虚拟出来的显卡调用资源。

linux中检查IOMMU是否开启

一般可以在主板BIOS/UEFI中可以找到,但是如果该硬件不支持虚拟化或者硬件固件被阉割但是实际上vt-d/iommu是被启用的。所以通过BIOS/UEFI固件并不能保证一定可以看到IOMMU信息。

正确的方法是通过dmesg命令查看。因为如果vt-d或者ioMmu开启并被使用,系统就会配置和启动DMA重映射,所以通过观察DMA是否启动来得知iommu是否开启。

执行以下命令:

dmesg | grep -i dmar

可以得到如下结果:

[    0.144034] DMAR: IOMMU enabled
[    0.779260] DMAR: Host address width 52
...

[    0.779305] DMAR-IR: Queued invalidation will be enabled to support x2apic and Intr-remapping.
[    0.781570] DMAR-IR: Enabled IRQ remapping in x2apic mode
...
[    3.776139] DMAR: Intel(R) Virtualization Technology for Directed I/O

可以看到有“IOMMU enabled”的信息,这说明此运行时系统打开了IOMMU。

除了用dmesg,还可以通过cat /proc/cmdline指令查看iommu是否打开。cmdline中的参数会被内核执行命令行时获取并解析,但不代表该一定能够起作用,也有发现cmdline中某配置被设置为enabling但是实际上系统却并没有打开它的情况。

posted @   goto2091  阅读(5142)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
点击右上角即可分享
微信分享提示