Я пытаюсь заставить GPU проходить через виртуальную машину. Я следил за этим видео https://www.youtube.com/watch?v=6FI31QDtyy4. Разница между тем, что я делал, и тем, что он делал в видео, была в модулях конфигурации mkinitcpio, вместо этого я использовал 'MODULES =(vfio_pci vfio vfio_iommu_type1 vfio_virqfd)', потому что видео было немного устаревшим.
Так что я сделал
- Добавьте intel_iommu = on в параметрах grub
- Проверил, что моя система поддерживает IOMMU, я запустил 'dmesg | grep -e DMAR -e IOMMU '
- Добавление параметров vfio-pci ids = 10de:10f0,10de:1b81 'в vfio.conf
- Модификация mkinitcpio.conf как описано выше
- Запуск mkinitcpio -p linux
- Изменение qemu.conf (вероятно, не связано)
- Выполнение 'systemctl enable --now libvirtd' и 'systemctl enable virtlogd.socket'
- Перезагрузитесь и вернитесь к Windows 10 (НЕ ДВОЙНОЙ. Я запускаю arch от USB STICK (НЕ LIVE USB)) (Пробовал добавить vm, но не получилось, потому что я не делал ntfs-3g штуковину)
- Вернулся из Windows 10 и добавил 'UUID = 061A04D11A04C023 /media /Data / ntfs-3g по умолчанию 0 0' в fstab
- Изменено 'GRUB_CMDLINE_LINUX_DEFAULT = "quiet" "на" GRUB_CMDLINE_LINUX_DEFAULT = "quiet intel_iommu = on" "в / etc / default / grub
- Перезагрузился и застрял на "Загрузка версии 240 (когда я удаляю intel_iommu = on из params, он загружался просто отлично)
Первая загрузка, которая работала на iommu, я использовал мой GPU в качестве вывода. Я попробовал iGPU после того, как GPU не работал при последней загрузке (Нет сигнала). Также я проверил официальную вики Arch по прохождению PCI, и шаги были довольно похожи
/etc/mkinitcpio.conf:
# vim:set ft=sh
# MODULES
# The following modules are loaded before any boot hooks are
# run. Advanced users may wish to specify all system modules
# in this array. For instance:
# MODULES=(piix ide_disk reiserfs)
MODULES=(vfio_pci vfio vfio_iommu_type1 vfio_virqfd)
# BINARIES
# This setting includes any additional binaries a given user may
# wish into the CPIO image. This is run last, so it may be used to
# override the actual binaries included by a given hook
# BINARIES are dependency parsed, so you may safely ignore libraries
BINARIES=()
# FILES
# This setting is similar to BINARIES above, however, files are added
# as-is and are not parsed in any way. This is useful for config files.
FILES=()
# HOOKS
# This is the most important setting in this file. The HOOKS control the
# modules and scripts added to the image, and what happens at boot time.
# Order is important, and it is recommended that you do not change the
# order in which HOOKS are added. Run 'mkinitcpio -H <hook name>' for
# help on a given hook.
# 'base' is _required_ unless you know precisely what you are doing.
# 'udev' is _required_ in order to automatically load modules
# 'filesystems' is _required_ unless you specify your fs modules in MODULES
# Examples:
## This setup specifies all modules in the MODULES setting above.
## No raid, lvm2, or encrypted root is needed.
# HOOKS=(base)
#
## This setup will autodetect all modules for your system and should
## work as a sane default
# HOOKS=(base udev autodetect block filesystems)
#
## This setup will generate a 'full' image which supports most systems.
## No autodetection is done.
# HOOKS=(base udev block filesystems)
#
## This setup assembles a pata mdadm array with an encrypted root FS.
## Note: See 'mkinitcpio -H mdadm' for more information on raid devices.
# HOOKS=(base udev block mdadm encrypt filesystems)
#
## This setup loads an lvm2 volume group on a usb device.
# HOOKS=(base udev block lvm2 filesystems)
#
## NOTE: If you have /usr on a separate partition, you MUST include the
# usr, fsck and shutdown hooks.
HOOKS=(base udev autodetect modconf block filesystems keyboard fsck)
# COMPRESSION
# Use this to compress the initramfs image. By default, gzip compression
# is used. Use 'cat' to create an uncompressed image.
#COMPRESSION="gzip"
#COMPRESSION="bzip2"
#COMPRESSION="lzma"
#COMPRESSION="xz"
#COMPRESSION="lzop"
#COMPRESSION="lz4"
# COMPRESSION_OPTIONS
# Additional options for the compressor
#COMPRESSION_OPTIONS=()
/etc/modprobe.d/vfio.conf:
options vfio-pci ids=10de:10f0,10de:1b81
Версия ядра: 4.20.10-arch1-1-ARCH
Информация об оборудовании (lshw):
cube-arch
description: Desktop Computer
product: B360M-HD3 (Default string)
vendor: Gigabyte Technology Co., Ltd.
version: Default string
serial: Default string
width: 4294967295 bits
capabilities: smbios-3.1 dmi-3.1 smp vsyscall32
configuration: boot=normal chassis=desktop family=Default string sku=Default string uuid=E002D503-5E04-7905-ED06-310700080009
*-core
description: Motherboard
product: B360M HD3
vendor: Gigabyte Technology Co., Ltd.
physical id: 0
version: x.x
serial: Default string
slot: Default string
*-firmware
description: BIOS
vendor: American Megatrends Inc.
physical id: 0
version: F4
date: 04/19/2018
size: 64KiB
capacity: 15MiB
capabilities: pci upgrade shadowing cdboot bootselect socketedrom edd int13floppy1200 int13floppy720 int13floppy2880 int5printscreen int14serial int17printer acpi usb biosbootspecification uefi
*-memory
description: System Memory
physical id: 3a
slot: System board or motherboard
size: 16GiB
*-bank:0
description: DIMM DDR4 Synchronous 2133 MHz (0.5 ns)
product: F4-3000C16-8GISB
vendor: Fujitsu
physical id: 0
serial: 00000000
slot: ChannelA-DIMM0
size: 8GiB
width: 64 bits
clock: 2133MHz (0.5ns)
*-bank:1
description: [empty]
physical id: 1
slot: ChannelA-DIMM1
*-bank:2
description: DIMM DDR4 Synchronous 2133 MHz (0.5 ns)
product: F4-3000C16-8GISB
vendor: Fujitsu
physical id: 2
serial: 00000000
slot: ChannelB-DIMM0```