XCP-ng
    • Categories
    • Recent
    • Tags
    • Popular
    • Users
    • Groups
    • Register
    • Login

    GPU passthrough, Windows 11 guest, "Working properly" becomes "Code 43"

    Scheduled Pinned Locked Moved Compute
    29 Posts 4 Posters 16.6k Views 4 Watching
    Loading More Posts
    • Oldest to Newest
    • Newest to Oldest
    • Most Votes
    Reply
    • Reply as topic
    Log in to reply
    This topic has been deleted. Only users with topic management privileges can see it.
    • B Offline
      branpurn @olivierlambert
      last edited by branpurn

      @olivierlambert

      I have (and have not lost) console display output, I have never yet had it able to provide display output via HDMI/detect a wired display. EDIT: (I am actually somewhat confused why I still have console display in XOA when "VGA" in 'Advanced' settings is set to 'Off')

      EDIT: Having uninstalled the driver completely and re-installed, I now appear to consistently be getting BSOD, VIDEO_TDR_FAILURE: nvlddmkm.sys (NVIDIA generic); going to do a fresh install of Win 11 on the guest in meantime.

      1 Reply Last reply Reply Quote 0
      • olivierlambertO Offline
        olivierlambert Vates 🪐 Co-Founder CEO
        last edited by

        @dthenot do you spot any typo or mistakes in @branpurn configuration?

        1 Reply Last reply Reply Quote 0
        • T Offline
          topher @olivierlambert
          last edited by

          hello this is what I am seeing as well. When I use this gpu on bare metal it works. Within any windows VM it jsut crashes with nvlddmkm.sys. I have run DDU and the newest drivers and it is a fresh install of windows with all of the patches.

          0a6160e4-b159-4793-97c7-1a64d2561430-image.png

          4ba9d334-9589-49a7-b4b1-66d74f264716-image.png

          I have changed the vga option on and off. After putting a dongle for fake screen in the devic it seems a little better but the RDP is choppy and slow and keeps dropping off. There are posts for proxmox where you have to set it to use the second display not the default windows one, but I cant even be in RDP long enough to make that happen

          xcp-ng 8.3
          Threadripper pro 5975WX
          WRX Creator 2.0
          GPU for passthrough Nvidia Titan Xp

          T 1 Reply Last reply Reply Quote 1
          • T Offline
            topher @topher
            last edited by

            would it matter if we are using the Cirtix "windows install drivers" from advanced vs the XCPng drivers for the VM? I am using the windows update option.

            B 1 Reply Last reply Reply Quote 0
            • B Offline
              branpurn @topher
              last edited by

              @topher

              Were it to matter, I do not have drivers available in 'Advanced'/do not have access to Citrix guest tools (and the Github for XCP-ng guest tools hasn't been updated since 2019?)-- I am operating under the assumption that with PCIe passthrough, I am better worrying strictly about the baremetal video drivers at this time.

              T 1 Reply Last reply Reply Quote 0
              • T Offline
                topher @branpurn
                last edited by

                @branpurn Under advanced in XOA there is an option to install drivers with windows update. Do we need those drivers for the GPU to work probably not, but 99% of the time you should have the xen drivers installed to make the system be happy and work better.

                3f41677c-3278-4599-81d7-aa6a85e86edd-image.png

                Items within the device manager may not be installed correctly without xen drivers.

                1 Reply Last reply Reply Quote 0
                • olivierlambertO Offline
                  olivierlambert Vates 🪐 Co-Founder CEO
                  last edited by

                  I'm not sure this can be related, because PCI passthrough isn't related to PV drivers.

                  Also, ⚠ DO NOT ENABLE this option as long as you have the XCP-ng tools, this will conflict everything. Please read carefully this: https://docs.xcp-ng.org/vms/#windows

                  T 1 Reply Last reply Reply Quote 0
                  • T Offline
                    topher @olivierlambert
                    last edited by

                    @olivierlambert Understood, I only used this option from under advanced and did not manually install the xcp-ng tools.

                    1 Reply Last reply Reply Quote 0
                    • olivierlambertO Offline
                      olivierlambert Vates 🪐 Co-Founder CEO
                      last edited by

                      Even with this option enabled, you still need to install the Citrix management agent 🙂

                      B 1 Reply Last reply Reply Quote 0
                      • B Offline
                        branpurn @olivierlambert
                        last edited by branpurn

                        @olivierlambert

                        At risk of getting off topic the original issue, it sounds like I am correct in understanding guest tools are not relevant to the PCI passthrough.

                        Fresh install Win 11, it may be worth capturing the initial error pre-display driver, as the way it is languaged might be different than a typical missing driver (unconfirmed)

                        9ad95723-e9ab-4581-9929-e4d42e13024e-image.png

                        -- Shortly hereafter, BSOD, VIDEO_TDR_FAILURE (I think Windows Update detected the GPU and tried to install driver)

                        EDIT: Appears BSOD loop after WU on fresh Win 11 install grabbed the driver; I think this is similar to complete reinstall of driver on previous iteration of this Win 11 install, post-passthrough of the audio sub-device (Driver would likely not have been auto-grabbed previous install of Win 11 due to the sub-device not being present?)

                        EDIT: Trying 'cloud reset' from Win 11 recovery partition options for the heck of it... EDIT: As one might expect, not as "clean" an install as a clean format and reinstall, even when selecting "remove everything" and "clean drive"-- assumedly driver, and thus BSOD, remain with that method.

                        Anyway, getting into the weeds with Windows here. I don't think the solution lies on the OS side.

                        B 1 Reply Last reply Reply Quote 0
                        • B Offline
                          branpurn @branpurn
                          last edited by

                          @branpurn

                          Food for thought, here's all parameters for the guest,

                          params=all.txt

                          B 1 Reply Last reply Reply Quote 0
                          • B Offline
                            branpurn @branpurn
                            last edited by branpurn

                            @branpurn

                            Same result with NVIDIA's Studio Driver, "The device is working properly" (though it's not, seemingly) then upon reboot, Code 43.

                            Still somewhat confused as to why I have console display in XOA when "VGA" in 'Advanced' is set to 'Off'...

                            1a628f46-f39c-4ec1-965b-28af8e8d3fea-image.png

                            1 Reply Last reply Reply Quote 0
                            • planedropP Offline
                              planedrop Top contributor
                              last edited by

                              Just wanted to chime in here on my experience with GPU passthrough with an NVidia GPU.

                              After doing a ton of testing and troubleshooting I never actually managed to get it to work within XCP-ng due to NVidia doing everything they can to prevent "consumer" cards from working in a virtual environment.

                              I did once manage to get it working with Proxmox after literal months and 100+ hours of troubleshooting, but XCP-ng proved more difficult for this and I eventually gave up.

                              I don't necessarily fault XCP-ng for this, it's not really a natively supported or enterprise type thing, as you'd just use vGPU for those situations in most cases.

                              But after having a HUGE struggle with it on Proxmox and XCP-ng both I eventually gave up on trying to do it with consumer GPUs as the effort proved to not be worth it IMO.

                              Not trying to come in here and do the typical "you just shouldn't do that" thing that so many do lol; but just giving some insight into my experience with it. NVidia works really hard to detect any form of virtual environment to block this sort of thing which is exactly what code 43 (generally) means, the driver detected the virtual environment and blocked it.

                              T 1 Reply Last reply Reply Quote 0
                              • olivierlambertO Offline
                                olivierlambert Vates 🪐 Co-Founder CEO
                                last edited by

                                I think we had users where it worked (here on the forum) but I don't remember if it was on Windows 10 or 11 🤔

                                1 Reply Last reply Reply Quote 0
                                • T Offline
                                  topher @planedrop
                                  last edited by

                                  @planedrop That has also been my experience as well in the past. I have attempted this again recently because last year Nvidia changed the drivers in a way that code 43 should no longer be an issue with most GTX gpus that people would be trying to pass into a VM. There are many videos of this just working in Proxmox and VMware with those driver changes. I do not get the code 43 error when installing the device drivers in the VM, just BSOD as seen above and reboots. If there are special steps needed to make this work on XCP-NG it would be great if we could get that documented, the other thing is that both of these systems are running on AMD and there might be bios changes we need to make?. https://nvidia.custhelp.com/app/answers/detail/a_id/5173/~/geforce-gpu-passthrough-for-windows-virtual-machine-(beta)

                                  planedropP 1 Reply Last reply Reply Quote 0
                                  • olivierlambertO Offline
                                    olivierlambert Vates 🪐 Co-Founder CEO
                                    last edited by

                                    A detail however: most of our known working use cases are with server-grade hardware.

                                    T 1 Reply Last reply Reply Quote 0
                                    • T Offline
                                      topher @olivierlambert
                                      last edited by

                                      I have attempted this on an Intel v4 Xeon platform and had some of the same issues and could not get it working.

                                      1 Reply Last reply Reply Quote 0
                                      • olivierlambertO Offline
                                        olivierlambert Vates 🪐 Co-Founder CEO
                                        last edited by

                                        Server grade also means server grade cards 🙂

                                        T 1 Reply Last reply Reply Quote 0
                                        • planedropP Offline
                                          planedrop Top contributor @topher
                                          last edited by

                                          @topher Oh yeah I had totally forgotten about those changes. However, my understanding from that link is that you still need 2 GPUs installed in most cases for it to work right; whereas OP I believe only has a single GPU on the system.

                                          B 1 Reply Last reply Reply Quote 0
                                          • B Offline
                                            branpurn @planedrop
                                            last edited by

                                            @planedrop

                                            I have onboard Radeon graphics, and NVIDIA dGPU

                                            planedropP 1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post