This gist is almost entirely not unlike Derek Seaman's awesome blog:
Proxmox VE 8: Windows 11 vGPU (VT-d) Passthrough with Intel Alder Lake
As such please refer to that for pictures, here i will capture the command lines I used as i sequence the commands a little differently so it makes more logic to me.
This gists assumes you are not running ZFS and are not passing any other PCIE devices (as both of these can require addtional steps - see Derek's blog for more info)
This gist assumes you are not running proxmox in UEFI Secure boot - if you are please refer entirely to dereks blog.
ALSO pleas refere to the comments section as folks have found workarounds and probably corrections (if the mistakes remain in my write up it is because i have't yet tested the corrections)
Note:i made no changes to the BIOS defaults on the Intel Nuc 13th Gen. This just worked as-is.
this gist is part of this series
apt update && apt install pve-headers-$(uname -r)
apt install git sysfsutils dkms build-* unzip -y
This allow you to run vainfo, intel_gpu_top for testing and non-free versions of the encoding driver - without this you will not AFAIK be able to encoding with this GPU. This was missed in EVERY guide i saw for this vGPU, so not sure, but i had terrible issues until i did this.
edits the sources list with nano /etc/apt/sources.list
add the following lines:
#non-free firmwares
deb http://deb.debian.org/debian bookworm non-free-firmware
#non-free drivers and components
deb http://deb.debian.org/debian bookworm non-free
and save the file
apt update && apt install intel-media-va-driver-non-free intel-gpu-tools vainfo
This next step copies a driver missing on proxmox installs and will remove the -2 error for this file in dmesg.
wget -r -nd -e robots=no -A '*.bin' --accept-regex '/plain/' https://git.kernel.org/pub/scm/linux/kernel/git/firmware/linux-firmware.git/tree/i915/adlp_dmc.bin
cp adlp_dmc.bin /lib/firmware/i915/
cd ~
git clone https://github.com/strongtz/i915-sriov-dkms.git
cd i915-sriov-dkms
nano dkms.conf
change these two lines as follows:
PACKAGE_NAME="i915-sriov-dkms"
PACKAGE_VERSION="6.5"
save the file
cd ~
mv i915-sriov-dkms/ /usr/src/i915-sriov-dkms-6.5
dkms install --force -m i915-sriov-dkms -v 6.5
and use dkms status to verify the module is now installed
edit the grub fle with nano /etc/default/grub
change this line in the file
GRUB_CMDLINE_LINUX_DEFAULT="quiet intel_iommu=on iommu=pt i915.enable_guc=3 i915.max_vfs=7"
note: if you have already made modifications to this line in your grub file for other purposes you should also still keep those items
finally run
update-grub
update-initramfs -u
use lspci | grep VGA t find the bus number
you should see something like this:
root@pve2:~# lspci | grep VGA
00:02.0 VGA compatible controller: Intel Corporation Raptor Lake-P [Iris Xe Graphics] (rev 04)
take the number on the far left and add to the sysfs.conf as follows - note all the proceeding zeros on the bus path are needed
echo "devices/pci0000:00/0000:00:02.0/sriov_numvfs = 7" > /etc/sysfs.conf
REBOOT
check devices with dmesg | grep i915
the last two lines should read as follows:
[    7.591662] [drm] Initialized i915 1.6.0 20201103 for 0000:00:02.7 on minor 7
[    7.591818] i915 0000:00:02.0: Enabled 7 VFs
if they don't then check all steps carefully
validate with vainfo you should see no errors (note this needs the drivers and tool i said to install at the top)
and vainfo --display drm --device /dev/dri/cardN where N is a number from 0 to 7 - this will show you the acceleration endpoints for each VF
monitor any VF renderer in real time with intel_gpu_top -d drm:/dev/dri/renderD128 there is one per VF - to see them all use ls -l /dev/dri
- navigate to Datacenter > Resource Mappings
- click addin PCI devices
- name the pool something like vGPU-Pool
- map all 7 VFs for pve 1 but NOT the root device i.e 0000:00:02.x not 0000:00:02
- click create
- on the created pool lcikc the plus button next to vGPU-Pool
- select mapping on node = pve 2, ad all devices and click create
- repeat for pve3
The pool should now look like this:
Note: machines with PCI pass through devices cannot be live migrated, they must be shutdown, migrated offline to the new node and then started.
update the kernel using proxox ui
dkms install -m i915-sriov-dkms -v 6.5 --force
reboot


Hello everyone, has anyone of you encountered a similar problem and managed to solve it?
I tried different versions of the firmware by replacing the files with other versions, but it didn't solve my problem. I also installed different versions of the kernel, but it's still the same. Maybe someone has a suggestion what I should check/do. The whole situation happened after my last update of proxmox to the latest version. (I had a Pin made for the kernel, but it also stopped working)
#root@pve:~# dmesg | grep i915
[ 0.000000] Command line: BOOT_IMAGE=/boot/vmlinuz-6.5.13-3-pve root=/dev/mapper/pve-root ro quiet intel_iommu=on iommu=pt i915.enable_guc=3 i915.max_vfs=7
[ 0.054742] Kernel command line: BOOT_IMAGE=/boot/vmlinuz-6.5.13-3-pve root=/dev/mapper/pve-root ro quiet intel_iommu=on iommu=pt i915.enable_guc=3 i915.max_vfs=7
[ 3.945953] i915 0000:00:02.0: Running in SR-IOV PF mode
[ 3.947527] i915 0000:00:02.0: [drm] VT-d active for gfx access
[ 3.947657] i915 0000:00:02.0: vgaarb: deactivate vga console
[ 3.947835] i915 0000:00:02.0: [drm] Using Transparent Hugepages
[ 3.948592] i915 0000:00:02.0: vgaarb: changed VGA decodes: olddecodes=io+mem,decodes=io+mem:owns=io+mem
[ 3.950131] mei_hdcp 0000:00:16.0-b638ab7e-94e2-4ea2-a552-d1c54b627f04: bound 0000:00:02.0 (ops i915_hdcp_ops [i915])
[ 3.957507] i915 0000:00:02.0: [drm] Finished loading DMC firmware i915/adlp_dmc.bin (v2.20)
[ 3.963975] i915 0000:00:02.0: [drm] GT0: GuC firmware i915/adlp_guc_70.bin version 70.20.0
[ 3.963987] i915 0000:00:02.0: [drm] GT0: HuC firmware i915/tgl_huc.bin version 7.9.3
[ 3.991256] i915 0000:00:02.0: [drm] GT0: HuC: authenticated for all workloads!
[ 3.993557] i915 0000:00:02.0: [drm] GT0: GUC: submission enabled
[ 3.993565] i915 0000:00:02.0: [drm] GT0: GUC: SLPC enabled
[ 3.994172] i915 0000:00:02.0: [drm] GuC RC: enabled
[ 3.994273] i915 0000:00:02.0: [drm] ERROR GT0: GUC: mmio request 0x4100: failure 201/0
[ 3.994282] i915 0000:00:02.0: [drm] ERROR GT0: Failed to retrieve hwconfig table: -ENOENT
[ 3.996642] mei_pxp 0000:00:16.0-fbf6fcf1-96cf-4e2e-a6a6-1bab8cbe36b1: bound 0000:00:02.0 (ops i915_pxp_tee_component_ops [i915])
[ 3.996923] i915 0000:00:02.0: [drm] Protected Xe Path (PXP) protected content support initialized
[ 4.093060] [drm] Initialized i915 1.6.0 20201103 for 0000:00:02.0 on minor 0
[ 4.095823] snd_hda_intel 0000:00:1f.3: bound 0000:00:02.0 (ops i915_audio_component_bind_ops [i915])
[ 4.096487] i915 0000:00:02.0: 7 VFs could be associated with this PF
[ 4.096943] i915 0000:00:02.0: [drm] Cannot find any crtc or sizes
[ 4.097410] i915 0000:00:02.0: [drm] Cannot find any crtc or sizes
[ 5.511500] i915 0000:00:02.0: vgaarb: changed VGA decodes: olddecodes=io+mem,decodes=none:owns=io+mem
[ 5.511591] i915 0000:00:02.1: enabling device (0000 -> 0002)
[ 5.511622] i915 0000:00:02.1: Running in SR-IOV VF mode
[ 5.512192] i915 0000:00:02.1: [drm] GT0: GUC: interface version 0.1.9.0
[ 5.512823] i915 0000:00:02.1: [drm] VT-d active for gfx access
[ 5.512848] i915 0000:00:02.1: [drm] Using Transparent Hugepages
[ 5.513420] i915 0000:00:02.1: [drm] GT0: GUC: interface version 0.1.9.0
[ 5.514095] i915 0000:00:02.1: GuC firmware PRELOADED version 1.9 submission:SR-IOV VF
[ 5.514097] i915 0000:00:02.1: HuC firmware PRELOADED
[ 5.514294] i915 0000:00:02.1: [drm] ERROR GT0: GUC: mmio request 0x4100: failure 201/0
[ 5.514300] i915 0000:00:02.1: [drm] ERROR GT0: Failed to retrieve hwconfig table: -ENOENT
[ 5.516606] i915 0000:00:02.1: [drm] Protected Xe Path (PXP) protected content support initialized
[ 5.516613] i915 0000:00:02.1: [drm] PMU not supported for this GPU.
[ 5.516726] [drm] Initialized i915 1.6.0 20201103 for 0000:00:02.1 on minor 1
[ 5.517069] i915 0000:00:02.0: vgaarb: changed VGA decodes: olddecodes=none,decodes=none:owns=io+mem
[ 5.517072] i915 0000:00:02.1: vgaarb: changed VGA decodes: olddecodes=io+mem,decodes=none:owns=none
[ 5.517144] i915 0000:00:02.2: enabling device (0000 -> 0002)
[ 5.517168] i915 0000:00:02.2: Running in SR-IOV VF mode
[ 5.517558] i915 0000:00:02.2: [drm] GT0: GUC: interface version 0.1.9.0
[ 5.518188] i915 0000:00:02.2: [drm] VT-d active for gfx access
[ 5.518219] i915 0000:00:02.2: [drm] Using Transparent Hugepages
[ 5.518779] i915 0000:00:02.2: [drm] GT0: GUC: interface version 0.1.9.0
[ 5.519425] i915 0000:00:02.2: GuC firmware PRELOADED version 1.9 submission:SR-IOV VF
[ 5.519428] i915 0000:00:02.2: HuC firmware PRELOADED
[ 5.519719] i915 0000:00:02.2: [drm] ERROR GT0: GUC: mmio request 0x4100: failure 201/0
[ 5.519725] i915 0000:00:02.2: [drm] ERROR GT0: Failed to retrieve hwconfig table: -ENOENT
[ 5.521718] i915 0000:00:02.2: [drm] Protected Xe Path (PXP) protected content support initialized
[ 5.521723] i915 0000:00:02.2: [drm] PMU not supported for this GPU.
[ 5.521827] [drm] Initialized i915 1.6.0 20201103 for 0000:00:02.2 on minor 2
[ 5.522168] i915 0000:00:02.0: vgaarb: changed VGA decodes: olddecodes=none,decodes=none:owns=io+mem
[ 5.522171] i915 0000:00:02.1: vgaarb: changed VGA decodes: olddecodes=none,decodes=none:owns=none
[ 5.522174] i915 0000:00:02.2: vgaarb: changed VGA decodes: olddecodes=io+mem,decodes=none:owns=none
[ 5.522249] i915 0000:00:02.3: enabling device (0000 -> 0002)
[ 5.522274] i915 0000:00:02.3: Running in SR-IOV VF mode
[ 5.522556] i915 0000:00:02.3: [drm] GT0: GUC: interface version 0.1.9.0
[ 5.523003] i915 0000:00:02.3: [drm] VT-d active for gfx access
[ 5.523028] i915 0000:00:02.3: [drm] Using Transparent Hugepages
[ 5.523579] i915 0000:00:02.3: [drm] GT0: GUC: interface version 0.1.9.0
[ 5.524223] i915 0000:00:02.3: GuC firmware PRELOADED version 1.9 submission:SR-IOV VF
[ 5.524226] i915 0000:00:02.3: HuC firmware PRELOADED
[ 5.524472] i915 0000:00:02.3: [drm] ERROR GT0: GUC: mmio request 0x4100: failure 201/0
[ 5.524478] i915 0000:00:02.3: [drm] ERROR GT0: Failed to retrieve hwconfig table: -ENOENT
[ 5.526378] i915 0000:00:02.3: [drm] Protected Xe Path (PXP) protected content support initialized
[ 5.526384] i915 0000:00:02.3: [drm] PMU not supported for this GPU.
[ 5.526474] [drm] Initialized i915 1.6.0 20201103 for 0000:00:02.3 on minor 3
[ 5.526777] i915 0000:00:02.0: vgaarb: changed VGA decodes: olddecodes=none,decodes=none:owns=io+mem
[ 5.526780] i915 0000:00:02.1: vgaarb: changed VGA decodes: olddecodes=none,decodes=none:owns=none
[ 5.526783] i915 0000:00:02.2: vgaarb: changed VGA decodes: olddecodes=none,decodes=none:owns=none
[ 5.526786] i915 0000:00:02.3: vgaarb: changed VGA decodes: olddecodes=io+mem,decodes=none:owns=none
[ 5.526863] i915 0000:00:02.4: enabling device (0000 -> 0002)
[ 5.526886] i915 0000:00:02.4: Running in SR-IOV VF mode
[ 5.527198] i915 0000:00:02.4: [drm] GT0: GUC: interface version 0.1.9.0
[ 5.527629] i915 0000:00:02.4: [drm] VT-d active for gfx access
[ 5.527651] i915 0000:00:02.4: [drm] Using Transparent Hugepages
[ 5.528174] i915 0000:00:02.4: [drm] GT0: GUC: interface version 0.1.9.0
[ 5.528842] i915 0000:00:02.4: GuC firmware PRELOADED version 1.9 submission:SR-IOV VF
[ 5.528844] i915 0000:00:02.4: HuC firmware PRELOADED
[ 5.529131] i915 0000:00:02.4: [drm] ERROR GT0: GUC: mmio request 0x4100: failure 201/0
[ 5.529137] i915 0000:00:02.4: [drm] ERROR GT0: Failed to retrieve hwconfig table: -ENOENT
[ 5.530962] i915 0000:00:02.4: [drm] Protected Xe Path (PXP) protected content support initialized
[ 5.530968] i915 0000:00:02.4: [drm] PMU not supported for this GPU.
[ 5.531059] [drm] Initialized i915 1.6.0 20201103 for 0000:00:02.4 on minor 4
[ 5.531388] i915 0000:00:02.0: vgaarb: changed VGA decodes: olddecodes=none,decodes=none:owns=io+mem
[ 5.531391] i915 0000:00:02.1: vgaarb: changed VGA decodes: olddecodes=none,decodes=none:owns=none
[ 5.531394] i915 0000:00:02.2: vgaarb: changed VGA decodes: olddecodes=none,decodes=none:owns=none
[ 5.531397] i915 0000:00:02.3: vgaarb: changed VGA decodes: olddecodes=none,decodes=none:owns=none
[ 5.531400] i915 0000:00:02.4: vgaarb: changed VGA decodes: olddecodes=io+mem,decodes=none:owns=none
[ 5.531476] i915 0000:00:02.5: enabling device (0000 -> 0002)
[ 5.531500] i915 0000:00:02.5: Running in SR-IOV VF mode
[ 5.531723] i915 0000:00:02.5: [drm] GT0: GUC: interface version 0.1.9.0
[ 5.532229] i915 0000:00:02.5: [drm] VT-d active for gfx access
[ 5.532254] i915 0000:00:02.5: [drm] Using Transparent Hugepages
[ 5.532727] i915 0000:00:02.5: [drm] GT0: GUC: interface version 0.1.9.0
[ 5.533433] i915 0000:00:02.5: GuC firmware PRELOADED version 1.9 submission:SR-IOV VF
[ 5.533435] i915 0000:00:02.5: HuC firmware PRELOADED
[ 5.533649] i915 0000:00:02.5: [drm] ERROR GT0: GUC: mmio request 0x4100: failure 201/0
[ 5.533656] i915 0000:00:02.5: [drm] ERROR GT0: Failed to retrieve hwconfig table: -ENOENT
[ 5.535872] i915 0000:00:02.5: [drm] Protected Xe Path (PXP) protected content support initialized
[ 5.535878] i915 0000:00:02.5: [drm] PMU not supported for this GPU.
[ 5.535973] [drm] Initialized i915 1.6.0 20201103 for 0000:00:02.5 on minor 5
[ 5.536279] i915 0000:00:02.0: vgaarb: changed VGA decodes: olddecodes=none,decodes=none:owns=io+mem
[ 5.536282] i915 0000:00:02.1: vgaarb: changed VGA decodes: olddecodes=none,decodes=none:owns=none
[ 5.536285] i915 0000:00:02.2: vgaarb: changed VGA decodes: olddecodes=none,decodes=none:owns=none
[ 5.536288] i915 0000:00:02.3: vgaarb: changed VGA decodes: olddecodes=none,decodes=none:owns=none
[ 5.536291] i915 0000:00:02.4: vgaarb: changed VGA decodes: olddecodes=none,decodes=none:owns=none
[ 5.536294] i915 0000:00:02.5: vgaarb: changed VGA decodes: olddecodes=io+mem,decodes=none:owns=none
[ 5.536362] i915 0000:00:02.6: enabling device (0000 -> 0002)
[ 5.536386] i915 0000:00:02.6: Running in SR-IOV VF mode
[ 5.536629] i915 0000:00:02.6: [drm] GT0: GUC: interface version 0.1.9.0
[ 5.537129] i915 0000:00:02.6: [drm] VT-d active for gfx access
[ 5.537153] i915 0000:00:02.6: [drm] Using Transparent Hugepages
[ 5.537638] i915 0000:00:02.6: [drm] GT0: GUC: interface version 0.1.9.0
[ 5.538326] i915 0000:00:02.6: GuC firmware PRELOADED version 1.9 submission:SR-IOV VF
[ 5.538328] i915 0000:00:02.6: HuC firmware PRELOADED
[ 5.538525] i915 0000:00:02.6: [drm] ERROR GT0: GUC: mmio request 0x4100: failure 201/0
[ 5.538532] i915 0000:00:02.6: [drm] ERROR GT0: Failed to retrieve hwconfig table: -ENOENT
[ 5.540772] i915 0000:00:02.6: [drm] Protected Xe Path (PXP) protected content support initialized
[ 5.540779] i915 0000:00:02.6: [drm] PMU not supported for this GPU.
[ 5.540917] [drm] Initialized i915 1.6.0 20201103 for 0000:00:02.6 on minor 6
[ 5.541250] i915 0000:00:02.0: vgaarb: changed VGA decodes: olddecodes=none,decodes=none:owns=io+mem
[ 5.541253] i915 0000:00:02.1: vgaarb: changed VGA decodes: olddecodes=none,decodes=none:owns=none
[ 5.541256] i915 0000:00:02.2: vgaarb: changed VGA decodes: olddecodes=none,decodes=none:owns=none
[ 5.541260] i915 0000:00:02.3: vgaarb: changed VGA decodes: olddecodes=none,decodes=none:owns=none
[ 5.541262] i915 0000:00:02.4: vgaarb: changed VGA decodes: olddecodes=none,decodes=none:owns=none
[ 5.541265] i915 0000:00:02.5: vgaarb: changed VGA decodes: olddecodes=none,decodes=none:owns=none
[ 5.541268] i915 0000:00:02.6: vgaarb: changed VGA decodes: olddecodes=io+mem,decodes=none:owns=none
[ 5.541342] i915 0000:00:02.7: enabling device (0000 -> 0002)
[ 5.541367] i915 0000:00:02.7: Running in SR-IOV VF mode
[ 5.541613] i915 0000:00:02.7: [drm] GT0: GUC: interface version 0.1.9.0
[ 5.542121] i915 0000:00:02.7: [drm] VT-d active for gfx access
[ 5.542148] i915 0000:00:02.7: [drm] Using Transparent Hugepages
[ 5.542647] i915 0000:00:02.7: [drm] GT0: GUC: interface version 0.1.9.0
[ 5.543342] i915 0000:00:02.7: GuC firmware PRELOADED version 1.9 submission:SR-IOV VF
[ 5.543344] i915 0000:00:02.7: HuC firmware PRELOADED
[ 5.543543] i915 0000:00:02.7: [drm] ERROR GT0: GUC: mmio request 0x4100: failure 201/0
[ 5.543550] i915 0000:00:02.7: [drm] ERROR GT0: Failed to retrieve hwconfig table: -ENOENT
[ 5.545724] i915 0000:00:02.7: [drm] Protected Xe Path (PXP) protected content support initialized
[ 5.545731] i915 0000:00:02.7: [drm] PMU not supported for this GPU.
[ 5.545866] [drm] Initialized i915 1.6.0 20201103 for 0000:00:02.7 on minor 7
[ 5.546073] i915 0000:00:02.0: Enabled 7 VFs