Не удалось загрузить Windows 11 qemu/libvirt с физического раздела диска – ошибка 0xc0000001

Вопрос или проблема

Моя конечная цель – загрузить ту же физическую раздел на диске как основную ОС (как вы загружаете Windows каждый день, чтобы прояснить…) И повторно использовать тот же раздел для загрузки ВМ внутри qemu/libvirt.

Для этого я создал ‘виртуальный диск’ с помощью device mapper. Виртуальный диск предназначен для:

  • предоставления другого EFI-раздела (через loop-устройство и файл в файловой системе) – это необходимо, чтобы Windows думала, что она одна на ПК (ну… технически… это нужно, чтобы избежать того, чтобы grub вмешивался в мою ВМ)
  • и для маскирования linux-раздела (который я уже смонтировал для чтения и записи… так что, вероятно, хорошая идея не монтировать его дважды, нет?)

Оттуда я создаю ВМ в libvirt с передачей TPM. Передача, похоже, работает как и ожидалось – я могу загружаться либо с физического, либо с виртуального, и я могу войти в систему с помощью PIN-кода.

В ходе своих тестов я обнаружил, что я определенно должен отключить Быструю загрузку в Windows (что в основном является гибернацией?) – так что это сделано

Теперь:
проблема:

  • Я могу загрузиться с физического устройства, используя этот диск
  • Я могу загрузиться с ВМ, определенной в VirtualBox, с помощью этого диска
  • Я Изначально мог загрузиться в libvirt (virt-manager). НО после применения всех обновлений – больше не могу…
  • Я также извлек командную строку (ps -fe и много vi) и пытался запустить qemu напрямую из командной строки – но получаю ту же проблему.

Я думаю, что исчерпал все причины, которые могу вспомнить.

  • Я много раз воссоздавал BCD в Windows (помните: у меня разные EFI-разделы…) – рассматриваю, может быть, изменение в технологии диска…
  • Я попытался ‘починить’ свою Windows (с установочного носителя)
  • Я применил обновления из виртуальной машины – и произошло много плохих вещей (ВМ больше не может загрузиться после этого – но физическая машина в порядке)
  • Я применил обновления из физической загрузки – и, как вы и ожидали; обновления работают, и система прекрасно работает потом, ЗАИСКЛЮЧЕНИЕМ того, что она больше не может загрузиться как ВМ…
  • Я ДУМАЮ, что заметил, что если я применяю большие изменения внутри ВМ (например, связывая Windows с моим OneDrive – что тогда синхронизирует все файлы), система не загрузится после этого.
  • Если мне удается загрузиться в Безопасном режиме, моя система видит раздел C: и, похоже, довольна им (никаких ошибок…)
  • Я запустил sfc /scannow (нет ошибок) и BOOTREC /SCANOS; BOOTREC /FIXMBR; BOOTREC /FIXBOOT; BOOTREC /REBUILDBCD. Но без удачи (я имею в виду: они работают нормально, но система все еще отказывается запускаться)

У меня больше нет вариантов.

Кроме того, есть одна вещь, которая меня озадачивает: тот же (виртуальный) диск будет работать из ВМ на VirtualBox

Есть ли какие-либо подсказки о том, куда смотреть / что изменить в моем определении ВМ / почему это не получается?
(что угодно… я на грани отчаяния на данном этапе)

Для справки: вот определение libvirt xml:

<domain type="kvm">
  <name>winvirt</name>
  <uuid>42ee3d0e-2ccd-4427-9bc4-565b277c30b9</uuid>
  <metadata>
    <libosinfo:libosinfo xmlns:libosinfo="http://libosinfo.org/xmlns/libvirt/domain/1.0">
      <libosinfo:os id="http://microsoft.com/win/11"/>
    </libosinfo:libosinfo>
  </metadata>
  <memory unit="KiB">8388608</memory>
  <currentMemory unit="KiB">8388608</currentMemory>
  <vcpu placement="static">4</vcpu>
  <os firmware="efi">
    <type arch="x86_64" machine="pc-q35-8.2">hvm</type>
    <firmware>
      <feature enabled='yes' name="enrolled-keys"/>
      <feature enabled='yes' name="secure-boot"/>
    </firmware>
    <loader readonly='yes' secure="yes" type="pflash">/usr/share/OVMF/OVMF_CODE_4M.ms.fd</loader>
    <nvram template="/usr/share/OVMF/OVMF_VARS_4M.ms.fd">/var/lib/libvirt/qemu/nvram/winvirt_VARS.fd</nvram>
    <bootmenu enable="yes"/>
  </os>
  <features>
    <acpi/>
    <apic/>
    <hyperv mode="custom">
      <relaxed state="on"/>
      <vapic state="on"/>
      <spinlocks state="on" retries="8191"/>
    </hyperv>
    <vmport state="off"/>
    <smm state="on"/>
  </features>
  <cpu mode="host-passthrough" check='none' migratable="on"/>
  <clock offset="localtime">
    <timer name="rtc" tickpolicy='catchup'/>
    <timer name="pit" tickpolicy='delay'/>
    <timer name="hpet" present="no"/>
    <timer name="hypervclock" present="yes"/>
  </clock>
  <on_poweroff>destroy</on_poweroff>
  <on_reboot>restart</on_reboot>
  <on_crash>destroy</on_crash>
  <pm>
    <suspend-to-mem enabled='no'/>
    <suspend-to-disk enabled='no'/>
  </pm>
  <devices>
    <emulator>/usr/bin/qemu-system-x86_64</emulator>
    <disk type="file" device="cdrom">
      <driver name="qemu" type="raw"/>
      <source file="/data/isos/Win11_23H2_EnglishInternational_x64.iso"/>
      <target dev='sdb' bus="sata"/>
      <readonly/>
      <boot order="1"/>
      <address type="drive" controller="0" bus="0" target="0" unit="1"/>
    </disk>
    <disk type="file" device="cdrom">
      <driver name="qemu" type="raw"/>
      <source file="/data/isos/virtio-win-0.1.262.iso"/>
      <target dev='sdc' bus="sata"/>
      <readonly/>
      <address type="drive" controller="0" bus="0" target="0" unit="2"/>
    </disk>
    <disk type="block" device="disk">
      <driver name="qemu" type="raw" cache="none" discard='unmap'/>
      <source dev='/dev/mapper/lbd'/>
      <backingStore/>
      <target dev='vda' bus="virtio"/>
      <shareable/>
      <boot order="2"/>
      <address type="pci" domain='0x0000' bus="0x07" slot="0x00" function='0x0'/>
    </disk>
    <controller type="usb" index='0' model="qemu-xhci" ports="15">
      <address type="pci" domain='0x0000' bus="0x02" slot="0x00" function='0x0'/>
    </controller>
    <controller type="pci" index='0' model="pcie-root"/>
    <controller type="pci" index='1' model="pcie-root-port">
      <model name="pcie-root-port"/>
      <target chassis="1" port="0x10"/>
      <address type="pci" domain='0x0000' bus="0x00" slot="0x02" function='0x0' multifunction='on'/>
    </controller>
    <controller type="pci" index='2' model="pcie-root-port">
      <model name="pcie-root-port"/>
      <target chassis="2" port="0x11"/>
      <address type="pci" domain='0x0000' bus="0x00" slot="0x02" function='0x1'/>
    </controller>
    <controller type="pci" index='3' model="pcie-root-port">
      <model name="pcie-root-port"/>
      <target chassis="3" port="0x12"/>
      <address type="pci" domain='0x0000' bus="0x00" slot="0x02" function='0x2'/>
    </controller>
    <controller type="pci" index='4' model="pcie-root-port">
      <model name="pcie-root-port"/>
      <target chassis="4" port="0x13"/>
      <address type="pci" domain='0x0000' bus="0x00" slot="0x02" function='0x3'/>
    </controller>
    <controller type="pci" index='5' model="pcie-root-port">
      <model name="pcie-root-port"/>
      <target chassis="5" port="0x14"/>
      <address type="pci" domain='0x0000' bus="0x00" slot="0x02" function='0x4'/>
    </controller>
    <controller type="pci" index='6' model="pcie-root-port">
      <model name="pcie-root-port"/>
      <target chassis="6" port="0x15"/>
      <address type="pci" domain='0x0000' bus="0x00" slot="0x02" function='0x5'/>
    </controller>
    <controller type="pci" index='7' model="pcie-root-port">
      <model name="pcie-root-port"/>
      <target chassis="7" port="0x16"/>
      <address type="pci" domain='0x0000' bus="0x00" slot="0x02" function='0x6'/>
    </controller>
    <controller type="pci" index='8' model="pcie-root-port">
      <model name="pcie-root-port"/>
      <target chassis="8" port="0x17"/>
      <address type="pci" domain='0x0000' bus="0x00" slot="0x02" function='0x7'/>
    </controller>
    <controller type="pci" index='9' model="pcie-root-port">
      <model name="pcie-root-port"/&>
      <target chassis="9" port="0x18"/>
      <address type="pci" domain='0x0000' bus="0x00" slot="0x03" function='0x0' multifunction='on'/>
    </controller>
    <controller type="pci" index='10' model="pcie-root-port">
      <model name="pcie-root-port"/>
      <target chassis="10" port="0x19"/>
      <address type="pci" domain='0x0000' bus="0x00" slot="0x03" function='0x1'/>
    </controller>
    <controller type="pci" index='11' model="pcie-root-port">
      <model name="pcie-root-port"/>
      <target chassis="11" port="0x1a"/>
      <address type="pci" domain='0x0000' bus="0x00" slot="0x03" function='0x2'/>
    </controller>
    <controller type="pci" index='12' model="pcie-root-port">
      <model name="pcie-root-port"/>
      <target chassis="12" port="0x1b"/>
      <address type="pci" domain='0x0000' bus="0x00" slot="0x03" function='0x3'/>
    </controller>
    <controller type="pci" index='13' model="pcie-root-port">
      <model name="pcie-root-port"/>
      <target chassis="13" port="0x1c"/>
      <address type="pci" domain='0x0000' bus="0x00" slot="0x03" function='0x4'/>
    </controller>
    <controller type="pci" index='14' model="pcie-root-port">
      <model name="pcie-root-port"/>
      <target chassis="14" port="0x1d"/>
      <address type="pci" domain='0x0000' bus="0x00" slot="0x03" function='0x5'/>
    </controller>
    <controller type="pci" index='15' model="pcie-root-port">
      <model name="pcie-root-port"/>
      <target chassis="15" port="0x1e"/>
      <address type="pci" domain='0x0000' bus="0x00" slot="0x03" function='0x6'/>
    </controller>
    <controller type="pci" index='16' model="pcie-to-pci-bridge">
      <model name="pcie-pci-bridge"/>
      <address type="pci" domain='0x0000' bus="0x05" slot="0x00" function='0x0'/>
    </controller>
    <controller type="sata" index='0'>
      <address type="pci" domain='0x0000' bus="0x00" slot="0x1f" function='0x2'/>
    </controller>
    <controller type="virtio-serial" index='0'>
      <address type="pci" domain='0x0000' bus="0x03" slot="0x00" function='0x0'/>
    </controller>
    <controller type="scsi" index='0' model="virtio-scsi">
      <address type="pci" domain='0x0000' bus="0x06" slot="0x00" function='0x0'/>
    </controller>
    <interface type="network">
      <mac address="52:54:00:bf:ec:a4"/>
      <source network='default'/>
      <model type="e1000e"/>
      <address type="pci" domain='0x0000' bus="0x01" slot="0x00" function='0x0'/>
    </interface>
    <serial type="pty">
      <target type="isa-serial" port="0">
        <model name="isa-serial"/>
      </target>
    </serial>
    <console type="pty">
      <target type="serial" port="0"/>
    </console>
    <channel type="spicevmc">
      <target type="virtio" name="com.redhat.spice.0"/>
      <address type="virtio-serial" controller="0" bus="0" port="1"/>
    </channel>
    <input type="tablet" bus="usb">
      <address type="usb" bus="0" port="1"/>
    </input>
    <input type="mouse" bus="ps2"/>
    <input type="keyboard" bus="ps2"/>
    <tpm model="tpm-tis">
      <backend type="passthrough">
        <device path="/dev/tpm0"/>
      </backend>
    </tpm>
    <graphics type="spice" autoport="yes">
      <listen type="address"/>
      <image compression='off'/>
    </graphics>
    <sound model="ich9">
      <address type="pci" domain='0x0000' bus="0x00" slot="0x1b" function='0x0'/>
    </sound>
    <audio id='1' type="spice"/>
    <video>
      <model type="qxl" ram='65536' vram='65536' vgamem='16384' heads="1" primary='yes'/>
      <address type="pci" domain='0x0000' bus="0x00" slot="0x01" function='0x0'/>
    </video>
    <redirdev bus="usb" type="spicevmc">
      <address type="usb" bus="0" port="2"/>
    </redirdev>
    <redirdev bus="usb" type="spicevmc">
      <address type="usb" bus="0" port="3"/>
    </redirdev>
    <watchdog model="itco" action='reset'/>
    <memballoon model="virtio">
      <address type="pci" domain='0x0000' bus="0x04" slot="0x00" function='0x0'/>
    </memballoon>
  </devices>
</domain>

И bash-скрипт, который я создал из этого:

qemu-system-x86_64 \
    -name guest=win11,debug-threads=on \
    -blockdev node-name=flash0-storage,driver=file,filename=/usr/share/OVMF/OVMF_CODE_4M.ms.fd,auto-read-only=true,discard=unmap \
    -blockdev node-name=flash0-format,driver=raw,file=flash0-storage,read-only=true \
    -blockdev node-name=flash1-storage,driver=file,filename=/home/precchia/winvirt_VARS.fd,auto-read-only=true,discard=unmap \
    -blockdev node-name=flash1-format,read-only=false,driver=raw,file=flash1-storage \
    -blockdev node-name=libvirt-2-storage,driver=host_device,filename=/dev/mapper/lbd,auto-read-only=true,discard=unmap \
    -blockdev node-name=libvirt-2-format,read-only=false,driver=raw,file=libvirt-2-storage \
    -blockdev node-name=libvirt-1-storage,driver=file,filename=/data/isos/Win11_23H2_EnglishInternational_x64.iso,auto-read-only=true,discard=unmap \
    -blockdev node-name=libvirt-1-format,read-only=true,driver=raw,file=libvirt-1-storage \
    -machine pc-q35-8.2,usb=off,vmport=off,smm=on,dump-guest-core=off,memory-backend=pc.ram,pflash0=flash0-format,pflash1=flash1-format,hpet=off,acpi=on \
    -device id=pci.1,driver=pcie-root-port,port=16,chassis=1,bus=pcie.0,multifunction=true,addr=0x2 \
    -device id=pci.2,driver=pcie-root-port,port=17,chassis=2,bus=pcie.0,addr=0x2.0x1 \
    -device id=pci.3,driver=pcie-root-port,port=18,chassis=3,bus=pcie.0,addr=0x2.0x2 \
    -device id=pci.4,driver=pcie-root-port,port=19,chassis=4,bus=pcie.0,addr=0x2.0x3 \
    -device id=pci.5,driver=pcie-root-port,port=20,chassis=5,bus=pcie.0,addr=0x2.0x4 \
    -device id=pci.6,driver=pcie-root-port,port=21,chassis=6,bus=pcie.0,addr=0x2.0x5 \
    -device id=pci.7,driver=pcie-root-port,port=22,chassis=7,bus=pcie.0,addr=0x2.0x6 \
    -device id=pci.8,driver=pcie-root-port,port=23,chassis=8,bus=pcie.0,addr=0x2.0x7 \
    -device id=pci.9,driver=pcie-root-port,port=24,chassis=9,bus=pcie.0,multifunction=true,addr=0x3 \
    -device id=pci.10,driver=pcie-root-port,port=25,chassis=10,bus=pcie.0,addr=0x3.0x1 \
    -device id=pci.11,driver=pcie-root-port,port=26,chassis=11,bus=pcie.0,addr=0x3.0x2 \
    -device id=pci.12,driver=pcie-root-port,port=27,chassis=12,bus=pcie.0,addr=0x3.0x3 \
    -device id=pci.13,driver=pcie-root-port,port=28,chassis=13,bus=pcie.0,addr=0x3.0x4 \
    -device id=pci.14,driver=pcie-root-port,port=29,chassis=14,bus=pcie.0,addr=0x3.0x5 \
    -device id=pci.15,driver=pcie-root-port,port=30,chassis=15,bus=pcie.0,addr=0x3.0x6 \
    -device id=pci.16,driver=pcie-pci-bridge,bus=pci.5,addr=0x0 \
    -device id=usb,driver=qemu-xhci,p2=15,p3=15,bus=pci.2,addr=0x0 \
    -device id=scsi0,driver=lsi,bus=pci.16,addr=0x1 \
    -device id=virtio-serial0,driver=virtio-serial-pci,bus=pci.3,addr=0x0 \
    -device id=sata0-0-0,driver=ide-hd,bus=ide.0,drive=libvirt-2-format,bootindex=2 \
    -device id=sata0-0-1,driver=ide-cd,bus=ide.1,drive=libvirt-1-format,bootindex=1 \
    -netdev id=hostnet0,type=user \
    -device id=net0,driver=e1000e,netdev=hostnet0,mac=52:54:00:bf:ec:a4,bus=pci.1,addr=0x0 \
    -chardev pty,id=charserial0 \
    -device id=serial0,driver=isa-serial,chardev=charserial0,index=0 \
    -chardev spicevmc,id=charchannel0,name=vdagent \
    -device id=channel0,driver=virtserialport,bus=virtio-serial0.0,nr=1,chardev=charchannel0,name=com.redhat.spice.0 \
    -tpmdev passthrough,id=tpm0,cancel-path=/dev/null \
    -device tpm-tis,tpmdev=tpm0 \
    -device id=input0,driver=usb-tablet,bus=usb.0,port=1 \
    -device id=video0,driver=qxl-vga,max_outputs=1,ram_size=67108864,vram_size=67108864,vram64_size_mb=0,vgamem_mb=16,bus=pcie.0,addr=0x1 \
    -chardev spicevmc,id=charredir0,name=usbredir \
    -device id=redir0,driver=usb-redir,chardev=charredir0,bus=usb.0,port=2 \
    -chardev spicevmc,id=charredir1,name=usbredir \
    -device id=redir1,driver=usb-redir,chardev=charredir1,bus=usb.0,port=3 \
    -device id=balloon0,driver=virtio-balloon-pci,bus=pci.4,addr=0x0 \
    -accel kvm \
    -cpu host,migratable=on,hv-time=on,hv-relaxed=on,hv-vapic=on,hv-spinlocks=0x1fff \
    -m size=8388608k \
    -object id=pc.ram,qom-type=memory-backend-ram,size=8589934592 \
    -overcommit mem-lock=off \
    -smp 4,sockets=4,cores=1,threads=1 \
    -uuid 42ee3d0e-2ccd-4427-9bc4-565b277c30b9 \
    -no-user-config \
    -nodefaults \
    -rtc base=localtime,driftfix=slew \
    -global kvm-pit.lost_tick_policy=delay \
    -global driver=cfi.pflash01,property=secure,value=on \
    -global ICH9-LPC.disable_s3=1 \
    -global ICH9-LPC.disable_s4=1 \
    -global ICH9-LPC.noreboot=off \
    -boot strict=on \
    -watchdog-action reset \
    -sandbox on,obsolete=deny,elevateprivileges=deny,spawn=deny,resourcecontrol=deny \
    -msg timestamp=on \
    -no-shutdown \
    -display sdl

Ответ или решение

Ошибка 0xc0000001 при загрузке Windows 11 в QEMU/Libvirt с физического диска

Если вы столкнулись с ошибкой 0xc0000001 при попытке загрузки Windows 11 из виртуальной машины, созданной с помощью QEMU/Libvirt, это может быть связано с несколькими причинами. В этой статье мы рассмотрим проблемы и возможные решения, чтобы помочь вам успешно загрузить вашу копию Windows 11 в виртуальной среде.

Понимание ошибки 0xc0000001

Ошибка 0xc0000001 обычно указывает на проблему с загрузочными данными Windows. Это может быть связано с поврежденными файлами загрузчика или неправильными настройками виртуальной машины. Основные причины могут включать:

  • Ошибки в данных BCD (Boot Configuration Data).
  • Некорректные настройки виртуальной машины.
  • Конфликтные флаги безопасности (например, Secure Boot).

Проверка конфигурации виртуальной машины

1. Обновление файла BCD

Если вы уже пробовали восстановить BCD, но безрезультатно, убедитесь, что вы используете правильный EFI-образ и что он идет в паре с настройками QEMU. Используйте следующее командное выражение для переустановки BCD:

bcdedit /export C:\BCD_Backup

Затем выполните:

bootrec /rebuildbcd

Это должно создать новый BCD. Убедитесь, что вы запускаете эти команды от имени администратора в режиме восстановления.

2. Проверка конфигурации виртуальной машины

Согласно предоставленной XML-конфигурации, убедитесь, что следующие параметры правильно настроены:

  • Используемая архитектура: убедитесь, что вы используете pc-q35-8.2 как указано. Это рекомендуется для Windows 11, и поддержка UEFI должна быть включена.
  • Secure Boot: если вы активируете Secure Boot, убедитесь, что ваша ОС поддерживает этот режим. Возможно, вам нужно временно его отключить, чтобы проверить, решает ли это проблему.

Пример настройки:

<os firmware="efi">
    <type arch="x86_64" machine="pc-q35-8.2">hvm</type>
    <loader secure="yes" readonly="yes">/usr/share/OVMF/OVMF_CODE_4M.ms.fd</loader>
    <nvram template="/usr/share/OVMF/OVMF_VARS_4M.ms.fd">/var/lib/libvirt/qemu/nvram/winvirt_VARS.fd</nvram>
</os>

3. Проверка TPM

Убедитесь, что передача TPM корректно настроена. Некоторые версии Windows требуют корректной передачи TPM для работы в среде виртуализации.

Проверка пользовательского режима и операций с диском

4. Избегайте повторного монтирования диска

Вы правильно заметили, что лекцийная функция может вызвать проблемы. Убедитесь, что использование монтированного диска выполнено правильно. Диск должен быть доступен только для виртуальной машины, и доступ к нему не должен быть осуществлен другим процессом.

5. Диск в состоянии "чтение"

Попробуйте поменять настройки диска в конфигурации Libvirt, чтобы установить модули cache на none для уменьшения уровня конфликта:

<driver name="qemu" type="raw" cache="none" discard='unmap'/>

Это может снизить проблему конфликта при запросах на чтение/запись.

Завершение

Если после проверки и изменения вышеуказанных параметров проблема не решилась, рассмотрите возможность последующего тестирования, создавая резервные копии настроек и управляя конфигурацией. Вы также можете воспользоваться средствами отладки, доступными в QEMU, для более детального анализа проблемы.

Системы виртуализации могут требовать значительной тонкой настройки, особенно при работе с физическими дисками и мультимедийными изображениями, так что внимательно следите за изменениями и их эффектами.

Если вы продолжаете сталкиваться с проблемами, возможно, стоит обратиться за помощью к профессионалам или к сообществу, использующему подобные технологии виртуализации.

Оцените материал
Добавить комментарий

Капча загружается...