0

0

使用QEMU-KVM进行硬件直通虚拟化时需要修改的内核参数与BIOS设置

betcha

betcha

发布时间:2025-10-31 10:55:02

|

320人浏览过

|

来源于php中文网

原创

启用IOMMU和设备直通需在BIOS开启VT-x/AMD-V、VT-d/AMD-Vi并关闭Secure Boot;Linux内核参数添加intel_iommu=on或amd_iommu=on及iommu=pt,绑定设备到vfio-pci驱动;最后通过dmesg、lspci和IOMMU组检查验证配置。

使用qemu-kvm进行硬件直通虚拟化时需要修改的内核参数与bios设置

在使用 QEMU-KVM 实现硬件直通(如 GPU、USB 控制器或 NVMe 设备)时,需要正确配置系统内核参数和 BIOS 设置,以启用 IOMMU 功能并确保设备能够被安全地分配给虚拟机。以下是关键的设置项。

BIOS 设置

硬件直通依赖于 CPU 和芯片组对 IOMMU 的支持,需在 BIOS 中手动开启相关功能:

  • 启用 VT-x / AMD-V:Intel 平台称为 Intel Virtualization Technology,AMD 平台为 SVM Mode。这是基本的 CPU 虚拟化支持。
  • 启用 VT-d / AMD-Vi:Intel 平台需开启 Intel VT-d(Virtualization Technology for Directed I/O),AMD 平台需开启 IOMMU。该功能允许设备直接访问内存并通过 IOMMU 进行地址隔离与映射。
  • 关闭安全启动(Secure Boot):某些发行版的 Linux 内核模块(如 vfio-pci)无法通过安全启动验证,建议关闭以避免加载失败。

Linux 内核参数配置

在 GRUB 配置文件(通常是 /etc/default/grub)中修改 GRUB_CMDLINE_LINUX 参数,使内核启动时启用 IOMMU 并预留目标设备。

站长俱乐部购物系统
站长俱乐部购物系统

功能介绍:1、模块化的程序设计,使得前台页面设计与程序设计几乎完全分离。在前台页面采用过程调用方法。在修改页面设计时只需要在相应位置调用设计好的过程就可以了。另外,这些过程还提供了不同的调用参数,以实现不同的效果;2、阅读等级功能,可以加密产品,进行收费管理;3、可以完全可视化编辑文章内容,所见即所得;4、无组件上传文件,服务器无需安装任何上传组件,无需支持FSO,即可上传文件。可限制文件上传的类

下载
  • Intel 平台添加
    iommu=pt intel_iommu=on
    其中 intel_iommu=on 启用 Intel VT-d 支持,iommu=pt 表示仅将 IOMMU 用于直通设备,减少性能开销。
  • AMD 平台添加
    iommu=pt amd_iommu=on
    amd_iommu=on 启用 AMD-Vi,iommu=pt 同样优化映射行为。
  • 绑定设备到 vfio 驱动
    通过设备的 PCI ID(如 vfio-pci.ids=10de:1c82,10de:0fb9)在启动时强制由 vfio-pci 驱动接管,防止主机占用。例如:
    vfio-pci.ids=10de:1c82,10de:0fb9
  • 其他可选参数
    pcie_acs_override=downstream,multifunction —— 强制启用 ACS 支持,用于隔离共用 PCIe 根端口的设备(慎用,存在安全隐患)。

验证设置是否生效

重启后可通过以下命令确认配置成功:

  • 检查内核参数:
    cat /proc/cmdline 应包含上述添加的参数。
  • 确认 IOMMU 是否启用:
    dmesg | grep -i iommu 应显示“Enabled”或“IOMMU enabled”。
  • 查看设备是否被 vfio 驱动接管:
    lspci -nnk -s 显示 Kernel driver in use: vfio-pci。
  • 检查 IOMMU 分组:
    find /sys/kernel/iommu_groups/ -type l 可查看各设备所属 IOMMU 组,理想情况每个设备独占一组。

基本上就这些。只要 BIOS 开启虚拟化支持,内核参数正确,并确保设备被 vfio 安全接管,硬件直通就能稳定运行。不复杂但容易忽略细节。

相关专题

更多
default gateway怎么配置
default gateway怎么配置

配置default gateway的步骤:1、了解网络环境;2、获取路由器IP地址;3、登录路由器管理界面;4、找到并配置WAN口设置;5、配置默认网关;6、保存设置并退出;7、检查网络连接是否正常。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

220

2023.12.07

磁盘配额是什么
磁盘配额是什么

磁盘配额是计算机中指定磁盘的储存限制,就是管理员可以为用户所能使用的磁盘空间进行配额限制,每一用户只能使用最大配额范围内的磁盘空间。php中文网为大家提供各种磁盘配额相关的内容,教程,供大家免费下载安装。

1350

2023.06.21

如何安装LINUX
如何安装LINUX

本站专题提供如何安装LINUX的相关教程文章,还有相关的下载、课程,大家可以免费体验。

704

2023.06.29

linux find
linux find

find是linux命令,它将档案系统内符合 expression 的档案列出来。可以指要档案的名称、类别、时间、大小、权限等不同资讯的组合,只有完全相符的才会被列出来。find根据下列规则判断 path 和 expression,在命令列上第一个 - ( ) , ! 之前的部分为 path,之后的是 expression。还有指DOS 命令 find,Excel 函数 find等。本站专题提供linux find相关教程文章,还有相关

294

2023.06.30

linux修改文件名
linux修改文件名

本专题为大家提供linux修改文件名相关的文章,这些文章可以帮助用户快速轻松地完成文件名的修改工作,大家可以免费体验。

776

2023.07.05

linux系统安装教程
linux系统安装教程

linux系统是一种可以免费使用,自由传播,多用户、多任务、多线程、多CPU的操作系统。本专题提供linux系统安装教程相关的文章,大家可以免费体验。

573

2023.07.06

linux查看文件夹大小
linux查看文件夹大小

Linux是一种自由和开放源码的类Unix操作系统,存在着许多不同的Linux版本,但它们都使用了Linux内核。Linux可安装在各种计算机硬件设备中,比如手机、平板电脑、路由器、视频游戏控制台、台式计算机、大型机和超级计算机。linux怎么查看文件夹大小呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

547

2023.07.20

linux查看ip命令
linux查看ip命令

本专题为大家提供linux查看ip命令相关文章内容,感兴趣的朋友可以免费下载体验试试。

297

2023.07.20

C++多线程相关合集
C++多线程相关合集

本专题整合了C++多线程相关教程,阅读专题下面的的文章了解更多详细内容。

0

2026.01.21

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.5万人学习

Git 教程
Git 教程

共21课时 | 2.8万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号