前言
春节假期老高正在享受天伦之乐,新视频等开春复工之后再录制发出
1、i915-sriov作者已经半年左右停更了。
2、曾经在23年4月做过n100机器的视频,其中使用的就是sriov核显演示。
(此文章更新了之前部分操作因为pve和内核的升级失效的问题)
3、有群友小伙伴建议我重新总结一下sriov虚拟核显的流程
总有小伙伴问两种核显直通的方式怎么选?直接放优缺点对比上来,各位小伙伴自行选择。
物理核显直通 vs SRIOV vGPU的优缺点对比:
优点 | 缺点 | |
物理核显直通 | 1、性能强 2、支持物理显示输出 (VGA/DP/HDMI/Type-C) 3、兼容性好,不妨碍PVE升级。 | 独占(不支持直通给多个虚拟机) 直通后,PVE宿主不能同时用核显。 |
SRIOV虚拟核显直通 | 可分为多个VF虚拟显卡, 给不同的虚拟机使用。 | 1、性能拆分(分成多个VF显卡具体如何分配性能不详) 如N100等不建议超过3个VF显卡,具有性能高核显的处理器可以分为最高7个); 2、不支持物理显示输出,虽可使用Todesk等软件远程桌面,但CPU占用率较高。在作为服务器的小主机上,让原本紧张的资源更加捉襟见肘。 3、对内核header依赖(6.1-6.5),PVE升级受限。 4、兼容性稳定性一般,部分流媒体软件硬解/转码功能受限。 |
以下适用于PVE8,以N100为例
在操作之前,首先检查BIOS中开启一下功能:
- Intel VMX虚拟化技术
- VT-d
- SR-IOV
- Above 4GB MMIO BIOS assignment
- IOMMU
一、PVE安装:
安装完成。
启动PVE,进入WebUI
二、进入PVE后基础设置:
1、PVE8 换源(如已做过请忽略):
(1)国内清华源速度较快(南方可选择中科大较快)
将自带的源文件sources.list备份
cp /etc/apt/sources.list /etc/apt/sources.list_bak
编辑sources.list
nano /etc/apt/sources.list
deb https://mirrors.tuna.tsinghua.edu.cn/debian/ bookworm main contrib non-free non-free-firmware
deb https://mirrors.tuna.tsinghua.edu.cn/debian/ bookworm-updates main contrib non-free non-free-firmware
deb https://mirrors.tuna.tsinghua.edu.cn/debian/ bookworm-backports main contrib non-free non-free-firmware
deb https://mirrors.tuna.tsinghua.edu.cn/debian-security bookworm-security main contrib non-free non-free-firmware
(2)编辑企业源,增加pve无订阅源
nano /etc/apt/sources.list.d/pve-enterprise.list
将其中原有的proxmox句首加# 注释掉,变为:#deb https://enterprise.proxmox.com/debian/pve bookworm pve-enterprise
添加以下清华源:
deb https://mirrors.tuna.tsinghua.edu.cn/proxmox/debian/pve bookworm pve-no-subscription
ctrl+x y 回车保存退出
添加pve无订阅源
nano /etc/apt/sources.list.d/pve-no-subscription.list
#粘贴以下pve无订阅源
deb https://mirrors.tuna.tsinghua.edu.cn/proxmox/debian bookworm pve-no-subscription
ctrl+x y 回车保存退出
(3)修复源401错误(如无401报错可忽略此条)
nano /etc/apt/sources.list.d/ceph.list
将其中原有的proxmox句首加# 注释掉,变为:#deb http://download.proxmox.com/debian/ceph-quincy bookworm no-subscription
#添加中科大ceph源:
deb https://mirrors.ustc.edu.cn/proxmox/debian/ceph-quincy bookworm no-subscription
#更新
apt update && apt dist-upgrade -y
2、顺便把LXC更换为清华源:
#备份APLInfo.pm
cp /usr/share/perl5/PVE/APLInfo.pm /usr/share/perl5/PVE/APLInfo.pm_back
#更换为清华源:
sed -i 's|http://download.proxmox.com|https://mirrors.tuna.tsinghua.edu.cn/proxmox|g' /usr/share/perl5/PVE/APLInfo.pm
#重启服务后生效
systemctl restart pvedaemon.service
#重启
reboot
三、升级内核、headers和firmware
在以上操作升级完成并重启之后,查看目前内核版本
uname -a
i915-sriov目前支持6.1~6.5内核,根据以上uname-a反馈信息,注意调整以下header安装与其相同的版本。
比如反馈的内核版本为:Linux pve 6.5.11-4-pve
安装header与以上反馈的当前内核版本相同,命令行如下:
apt update && apt install pve-headers-$(uname -r)
#注意如遇报错,可尝试直接执行apt install pve-headers-6.5(与uname-a返回的内核大版本号一致)
#重启
reboot
四、编译i915-sriov驱动
安装git工具及dkms
apt install -y git build-* dkms
拖库
git clone https://github.com/strongtz/i915-sriov-dkms.git
cd i915-sriov-dkms
nano dkms.conf
#第一行改为PACKAGE_NAME="i915-sriov-dkms"
#第二行改为PACKAGE_VERSION="6.1"
此处强迫症可以改为6.5,因向下兼容使用默认的6.1也可
ctrl+x y 回车保存退出
添加安装sriov模块
在i915-sriov-dkms目录下,运行
dkms add .
dkms install -m i915-sriov-dkms -v 6.1
经过漫长等待完成后,检查安装是否成功,运行
modinfo i915|grep vf
反馈如下表示成功:
parm: max_vfs:Limit number of virtual functions to allocate. (0 = no VFs [default]; N = allow up to N VFs) (uint)
如无反馈安装不成功请删除此模块,重新安装,直至有以上成功反馈信息。
dkms remove -m i915-sriov-dkms -v 6.1
dkms install -m i915-sriov-dkms -v 6.1
五、设置直通和i915guc
nano /etc/default/grub
在quiet后添加intel_iommu=on i915.enable_guc=3 i915.max_vfs=7
改成GRUB_CMDLINE_LINUX_DEFAULT="quiet intel_iommu=on i915.enable_guc=3 i915.max_vfs=7"
ctrl+x y 回车保存退出
更新grub和initramfs
update-grub
update-initramfs -u
六、安装sysfsutils,对新手友好方便对VF核显数量设置(不建议使用开机自启脚本rc.local,增加不必要的风险)
apt install -y sysfsutils
添加以下VFs参数,N100建议最高3,可自定义数量,建议按需设置,设置1个时性能最强。
echo "devices/pci0000:00/0000:00:02.0/sriov_numvfs = 3" > /etc/sysfs.conf
重启
reboot
lspci检查直通的虚拟显卡,显示如下:
00:02.0 VGA compatible controller: Intel Corporation Device 46d1(物理核显)
00:02.1 VGA compatible controller: Intel Corporation Device 46d1(虚拟核显1)
00:02.2 VGA compatible controller: Intel Corporation Device 46d1(虚拟核显2)
00:02.3 VGA compatible controller: Intel Corporation Device 46d1(虚拟核显3)
注:物理核显02.0不能直通出去(可以映射给LXC),否则物理核显本体被独占,所有虚拟核显消失。
虚拟核显越多,性能越低。只需要1个时,虚拟1个核显即可。
七、将虚拟核显添加到虚拟机中,如Win10/11
硬件内注意事项:
内存:4GiB (或者更多)
CPU类别:host (硬解建议给全部核心,比如N100 4cores)
BIOS:OVMF(UEFI)
显示:默认标准 核显直通后可改为无(none) *注意选择无(none)时在虚拟机控制台界面会报错【VM 100 qmp command 'set_password' failed - Could not set password】这是正常的。如此长时间报错导致虚拟Win死机时,可以改为标准VGA(std)(见pve官方论坛)
机型:pc-q35
直通SRIOV核显:勾选主GPU、ROM-Bar,不要勾选所有功能
PCI设备虚拟核显:安装Win时建议不添加,Win装完关机添加虚拟核显时不要勾选主GPU,安装驱动并重启后不报错工作正常后,可以更改为主GPU,并且可以添加虚拟vGPU显示虚拟桌面(如VirtIO-GPU)。
注意添加PVE虚拟vGPU,可能导致流媒体软件时受到2个显卡影响,从而导致调用显卡渲染器失败。只需要删掉虚拟vGPU显卡即可。
八、配置虚拟机conf文件
因为Intel的驱动将pciid固定到02.0 ,我们使用02.1/2/3等sriov核显时,不能被正常驱动,即便是直通的sriov核显中勾选了PCI-Express显示正常驱动,但是也会因为pciid的原因导致一些软件工作不正常,比如流媒体Jellyfin Emby等无法硬解和转码。
我们需要在虚拟机conf中把直通的核显指定地址
nano /etc/pve/qemu-server/虚拟机序号.conf
添加:
args: -set device.hostpci0.addr=02.0 -set device.hostpci0.x-igd-gms=0x2
ctrl+x y 回车保存退出
Windows虚拟机
为了提高Win虚拟机的性能,建议安装VirtIO的全部驱动,iso下载地址:
https://fedorapeople.org/groups/virt/virtio-win/direct-downloads/stable-virtio/virtio-win.iso
英特尔® Arc™ 和锐炬® Xe 显卡 (intel.cn)
https://www.intel.cn/content/www/cn/zh/download/785597/intel-arc-iris-xe-graphics-windows.html
参考引用:
https://github.com/strongtz/i915-sriov-dkms
如有转载或部分引用请保留老高频道及视频连接,注明出处,谢谢合作!
感谢您的关注订阅🙏,三连投币转发 充电是对我最大的支持和鼓励!🙏我会继续努力做出更多的高质量视频!加爱折腾的群和讨论组:https://diyforfun.565856.xyz/ 爱折腾的老高欢迎您加入和有着共同折腾爱好的朋友们一起:折腾的开心!开心的折腾!
感谢老高!教程都是 wind10/11,如果使用 ubuntu 虚拟机,如何设置直通的显卡呢?
@codingiran Linux下应该很简单。估计不挂vbios可能都行。和win的大同小异,具体你可以自己试试。hdmi音频有可能不出声。貌似11代intel的U设置了HD Audio Configuration之后原本虚拟Win下HDMi音频没有的问题可以修复。但是改了设置后Linux可能没hdmi音频了。
老高好~我跟着您之前的教程把显卡直通给了win,但最近发现win和linux下同时需要显卡(就一个12代核显)
请问这种情况下是只能使用sriov了吗?
@xyz星人 是啊,那就只能sriov了。或者再加个独显。sriov可以按照这个教程来。
@爱折腾的老高 老高好~想请教一下,我有一个1135g7的nuc,想Windows和nas通过sroiv瓜分xe核显,但是还想装个rx6600独显,把黑苹果通给它,这三个系统可以这种方式同时直通吗?
@nightmr sriov问题很多,独显直通给黑果问题应该不大。具体你可以自己尝试下。
@爱折腾的老高 谢谢老高的解答!
请教老高,把VGPU直通给Windows后,可以让HDMI显示虚拟机的画面么?
@wander 他们有折腾虚拟显示的。或多或少有点问题。如果你客户端性能够强网速够快,可以用微软远程桌面,照样可以调用核显。看网页啥的都可以硬解。如果只有1个显卡的需求,还是推荐用物理核显直通的方式。这样稳定性、性能更强。
@爱折腾的老高 请教老高,物理直通核显给win10后,安装英特尔核显驱动无效,应该怎么弄?
@Jackylong 你留言的这篇是sriov,不是物理核显直通。另外如果物理核显直通设置无误,驱动可以安装的。官网下载就可以。
cpu是12450h
老高好,我按照上面的步骤对我的 Intel 11(Tigerlake) 进行核显直通,但是一直无法在启动时成功使用核显,表现为在设备管理器里驱动异常和任务管理器里看不到GPU,这是上面原因呢?多次尝试都没有成功实现核显直通
@liuyd 这篇是sriov虚拟核显直通。首先确认你的cpu是11代tigerlake及以上的 intel有核显的cpu。然后在bios里开启文章开头的那些功能参数。然后才是下面一步一步去做。
老高好,AMD的核显是不是就over了? 能不能出一期PVE下使用无线网卡做管理口的教程,看了视频买了个GMK M6,不想再买USB网卡了
@Jacksonchow 不建议用无线网卡做管理口,因为无线网络的不稳定性决定的,像障碍物、同频段信号干扰、乃至温度、湿度等都会对无线信号造成影响。而管理口作为虚拟机系统的管理之用,属于重中之重,整个虚拟机虚拟交换都依赖管理口和绑定其上的虚拟交换虚拟网桥来实现的。建议使用有线网卡作为管理口接交换机,使用起来比较方便。无线网卡可以直通给其他虚拟机如Win来使用的。
@爱折腾的老高 谢谢,看来还是买个USB网卡来做管理口了,M6两个口有点少,本来想在PVE里直通给ROS的~~8125BG与Exsi 8.0暂时无缘哈~~
7月19日,作者近期正在更新此项目,我按照作者文档测试了下,最新pve内核直通windows报错,lxc调用主核显和分出来的核显使用不了qsv,vaapi正常但转码非常慢,问题应该还挺大的。
@忧郁的二狗子 好消息。是作者又要更新了。坏消息是问题还是一堆。还是用物理核显直通吧。又稳性能又强,显示输出也舒服。sriov除非是加入到Linux内核更新里去。否则以后每次升级Linux可能sriov又不兼容了。
@爱折腾的老高 感谢老高的回复,今天又折腾了一天,目前直通vm虚拟机正常工作了,分别·测试了debian和windows,但是主核显lxc下工作仍然存在一些问题。sriov确实稳定性一般,我也是个人需要多张sriov出来的显卡工作,看来以后只能尽可能避免升级系统了。
不管直接直通还是SRION,windows安装完驱动后设备提示,有问题代码43,以前我用n6000时就有这个问题,那时候解决办法是使用windows更新里面的驱动,n100在windows更新里面没有驱动,不知道怎么搞了
@hao args没设置好。再就是vbios确认没问题。这样才不会错误代码43.正常设置好之后驱动就可以自行官网下载安装新版就可以了。sriov不建议搞了,问题太多
@爱折腾的老高 我用别人的hdmi输出到显示器的教程成功了,加了个n100.rom,反正不知道哪一步有问题,估计就是缺这个
大佬有尝试在kvm+virt-manager平台下做11代Tiger laker平台的sriov直通么,我在ubuntu 22.04下按照git上https://github.com/strongtz/i915-sriov-dkms的标准步骤做,最后win11虚拟机里能看到显卡,但是报驱动43错误,主机内核6.5,这种该如何解决?(直通是直接在virt-manager中添加pci设备做的)
@istone sriov有些问题。不好解决。
i915驱动现在支持最新的Linux内核了~
@xyz星人 好消息
请教UP主,intel 金牌7505是不是不能用sriov虚拟核显?
@cnowen TigerLake理论上支持。不过SRIOV问题比较多。依赖内核,不能随便升级。而且不少系统驱动支持不完善。