Netgate Discussion Forum
    • Categories
    • Recent
    • Tags
    • Popular
    • Users
    • Search
    • Register
    • Login

    Hyper-V

    Scheduled Pinned Locked Moved 2.4 Development Snapshots
    35 Posts 9 Posters 24.6k Views
    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.
    • O
      odietzel
      last edited by

      @johnkeates:

      I do wonder if we could get around some of this by chainloading pfSense, I've seen people loading OpenFirmware, TianoCore, OVMF and with some hacks even SeaBIOS on top of existing firmwares.

      Well, that would be too much diy toying for me. Not my style.

      And since that forked sense already went half the way to a working Hyper-V Gen2 autoinstall (of cause without console keyboard yet) i am quite sure pfSense 2.4 will offer similar support in the future. :)

      1 Reply Last reply Reply Quote 0
      • B
        bimmerdriver
        last edited by

        @johnkeates:

        @odietzel:

        @johnkeates:

        But why does it need a custom kbd or DVD driver in the first place? That stuff is so standard, it should just work out of the box, unless the UEFI implementation doesn't have normal I/O devices.

        They ripped out a lot of legacy stuff in Hyper-V gen2.

        There are some obvious devices we removed. For example, the legacy network adapter (which is an emulated device based on a DEC/Intel/Tulip 21140). Then we removed the IDE controller. And the floppy controller plus associated DMA controller. And the serial controller (COM ports). These are all things you can directly see in the VM settings.

        Then we changed other devices such as removing the legacy i8042 keyboard controller (which has an interesting side effect I will talk about in a future part), PS/2 mouse, S3 Video, the Programmable Interrupt Controller (PIC), the Programmable Interrupt Timer (PIT), the Super I/O device on which floppy support relied. We actually went even further by removing the PCI bus as well. For good measure, we also removed the speaker and the numerical co-processor. We also revised ACPI.

        Of course, when you rip this much out, you may initially think ‘could an operating system boot in this environment?’. With just the above changes, the answer would be no. Primarily because the most common ways of booting a generation 1 VM are a disk/VHD attached to an IDE controller, an ISO/DVD drive attached to an IDE controller, or PXE boot from the legacy network adapter. I’m ignoring boot from floppy (.VFD) – I’m sure not many people do this these days!

        Given that both IDE and Legacy NIC are no longer present, we had to introduce alternate boot mechanisms, and a new DVD device. We extended the UEFI firmware to be aware of software based devices (ie those using VMBus), and support booting from our software-based SCSI and Network controllers, plus the new software-based DVD device.

        https://blogs.technet.microsoft.com/jhoward/2013/10/24/hyper-v-generation-2-virtual-machines-part-1/

        I know, but UEFI provides services for I/O, there is framebuffer/console, there is graphics, there is keyboard and mouse I/O, and those are what you would use on a modern UEFI OS. Now, it could be that FreeBSD hasn't fixed that yet and simply ignores those and uses the legacy devices, but if that were the case, it wouldn't work on OVMF UEFI either, yet it does. It seems to me that the real problem is Microsoft inventing VMBus instead of using what already exists and already has support. I get that it can be implemented on all and any operating systems where you have source code access, but it cripples the hypervisor in a way that it's only paravirtualisation from that point onwards.

        In the referenced article, Microsoft says, "Our implementation is based on TianoCore, EDK II and is a UEFI 2.3.1 implementation with necessary modifications and bug-fixes", as of three years ago. That's the same code base that you're talking about. How different can it be? FreeBSD doesn't support Gen 2 VMs so it probably shouldn't be a surprise that it doesn't work properly.

        1 Reply Last reply Reply Quote 0
        • B
          bimmerdriver
          last edited by

          @johnkeates:

          @bimmerdriver:

          In the referenced article, Microsoft says, "Our implementation is based on TianoCore, EDK II and is a UEFI 2.3.1 implementation with necessary modifications and bug-fixes", as of three years ago. That's the same code base that you're talking about. How different can it be? FreeBSD doesn't support Gen 2 VMs so it probably shouldn't be a surprise that it doesn't work properly.

          Well, I don't know how different it can be. It's really strange that it would not work as it does work with OVMF which is also based on the EDK2 and TianoCore. Hell, it's practically part of TianoCore http://www.tianocore.org/ovmf/

          Well, I guess we will have to wait for BIS to be updated. Hopefully it won't take long.

          1 Reply Last reply Reply Quote 0
          • D
            Dexuan Cui
            last edited by

            Hi, I'm Dexuan From the BIS team.

            AFAIK, FreeBSD 10.3, 11 and the HEAD can't work with Hyper-V Generation-2 VM (i.e. UEFI VM) due to a loader issue.  10.2 SMP VM can't work properly either (it seems UP VM can work, as I mentioned in Bug 211746, but the keyboard definitely can't work.)

            Details are at:
            https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=195819
            https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=211746

            About why the keyboard can't work in Hyper-V UEFI VM, my understanding is: Hyper-V UEFI implementation doesn't emulate the legacy i8042 keyboard controller (UEFI spec doesn't require this legacy thing), and it seems FreeBSD kernel doesn't have the UEFI I/O service based keyboard driver(?).

            And, to enable Secure Boot with Hyper-V UEFI, I suppose FreeBSD and Microsoft need work together to sign the binary to the hypervisor.

            So, to make Hyper-V UEFI "work" at a minimal level for FreeBSD VM, we at least need to fix the loader issue in 10.3/11/HEAD, and add a keyboard driver (UEFI keyboard driver or VMBus based Hyper-V keyboard driver).
            These are in our long TODO list, and we definitely want to get them done ASAP, but unluckily we have to prioritize the tasks since actually we have very limited resources. :-(

            Please let us know if my above information is not accurate.

            1 Reply Last reply Reply Quote 0
            • O
              odietzel
              last edited by

              @Dexuan:

              AFAIK, FreeBSD 10.3, 11 and the HEAD can't work with Hyper-V Generation-2 VM (i.e. UEFI VM) due to a loader issue.

              … it seems FreeBSD kernel doesn't have the UEFI I/O service based keyboard driver(?).

              ...

              Please let us know if my above information is not accurate.

              Hi Dexuan,

              great to see your team cares, thx a lot and greets to Josh Poulson!

              It's not completly accurate.

              FreeBSD 11 / pfSense 2.4 boots fine in Hyper-V Gen2 (unsecured mode) if one converts an existing UEFI install p2v or v2v to a vhdx and uses this image as disk device. Boots fine in Server 2016 Hyper-V Gen2, network works in 10GBit mode (thats why i work on it), network performance is fair. Network pumps a little (using a x520-da2 for hn0/1 as lan/wan), but this should be enhenceable with some driver setting fine tuning.

              OpnSense, a pfSense fork, contains a autoinstaller in their FreeBSD 11 based devel version that works in HV Gen2 , so there must be some kind of working gen2 dvd driver out there.

              So what imho is needed most is a port of the LIS keyboard driver to BIS, would really be nice to have a working console. :)

              1 Reply Last reply Reply Quote 0
              • B
                bimmerdriver
                last edited by

                @odietzel:

                Hi Dexuan,

                great to see your team cares, thx a lot and greets to Josh Poulson!

                @johnkeates:

                Thanks for the update! It's great to see someone involved connect back to downstream projects and users.

                Agreed, it's nice to see.

                1 Reply Last reply Reply Quote 0
                • D
                  Dexuan Cui
                  last edited by

                  @odietzel:

                  @Dexuan:

                  AFAIK, FreeBSD 10.3, 11 and the HEAD can't work with Hyper-V Generation-2 VM (i.e. UEFI VM) due to a loader issue.

                  … it seems FreeBSD kernel doesn't have the UEFI I/O service based keyboard driver(?).

                  ...

                  Please let us know if my above information is not accurate.

                  It's not completly accurate.

                  FreeBSD 11 / pfSense 2.4 boots fine in Hyper-V Gen2 (unsecured mode) if one converts an existing UEFI install p2v or v2v to a vhdx and uses this image as disk device. Boots fine in Server 2016 Hyper-V Gen2, network works in 10GBit mode (thats why i work on it), network performance is fair. Network pumps a little (using a x520-da2 for hn0/1 as lan/wan), but this should be enhenceable with some driver setting fine tuning.

                  OpnSense, a pfSense fork, contains a autoinstaller in their FreeBSD 11 based devel version that works in HV Gen2 , so there must be some kind of working gen2 dvd driver out there.

                  So what imho is needed most is a port of the LIS keyboard driver to BIS, would really be nice to have a working console. :)

                  Thanks for the info!

                  When I said FreeBSD-11 Generation-2 VM on Hyper-V didn't work, I meant I couldn't install the VM with the FreeBSD-11 DVD (I tried FreeBSD-11.0-BETA1-amd64-dvd1.iso, and I don't think the final offcial DVD could work) due to the loader issue mentioned in FreeBSD bug 211746.

                  It looks with the p2v/v2v method the loader issue can be worked around somehow, and it looks the loader in OpenSence is good.

                  Yeah, the keyboard driver is the most needed.

                  BTW, about "gen2 dvd driver": I think in a gen-2 FreeBSD VM the existing storvsc driver should be able to properly handle the DVD device, so we don't need to add a special "dvd driver".

                  1 Reply Last reply Reply Quote 0
                  • D
                    Dexuan Cui
                    last edited by

                    @bimmerdriver:

                    @odietzel:

                    Hi Dexuan,

                    great to see your team cares, thx a lot and greets to Josh Poulson!

                    @johnkeates:

                    Thanks for the update! It's great to see someone involved connect back to downstream projects and users.

                    Agreed, it's nice to see.

                    Surely we want to better support all users of Hyper-V. :-)

                    BTW, we have a wiki page at https://wiki.freebsd.org/HyperV and you're welcome to post any "BSD VM on Hyper-V" questions to the FreeBSD Integration Services Team email (the bsdic@ email) on that page. We monitor the email daily and we respond directly and timely.

                    1 Reply Last reply Reply Quote 0
                    • D
                      Dexuan Cui
                      last edited by

                      @johnkeates:

                      @Dexuan:

                      About why the keyboard can't work in Hyper-V UEFI VM, my understanding is: Hyper-V UEFI implementation doesn't emulate the legacy i8042 keyboard controller (UEFI spec doesn't require this legacy thing), and it seems FreeBSD kernel doesn't have the UEFI I/O service based keyboard driver(?).

                      I do wonder what the Xen and KVM OVMF UEFI boot method is doing different from the Microsoft implementation. Maybe they still have that legacy controller? Or possibly a USB keyboard controller? I haven't checked for any of those, but it would make sense if that's why it does work there.

                      I'm also curious. It would be great if somebody could look into Xen/KVM on this.

                      1 Reply Last reply Reply Quote 0
                      • F
                        falumas
                        last edited by

                        Secure boot in hyper-v 2016 is now much more mainstream and is supported by the biggest Linux distributions and will surely arrive to freebsd as well. It is a feature I can live without for the moment and most likely forever in 2012r2.

                        I think secure boot is something that needs to be solved by freebsd and not pfsense.

                        Linux Secure Boot (new)
                        Linux operating systems running on generation 2 virtual machines can now boot with the Secure Boot option enabled. Ubuntu 14.04 and later, SUSE Linux Enterprise Server 12 and later, Red Hat Enterprise Linux 7.0 and later, and CentOS 7.0 and later are enabled for Secure Boot on hosts that run Windows Server 2016. Before you boot the virtual machine for the first time, you must configure the virtual machine to use the Microsoft UEFI Certificate Authority. You can do this from Hyper-V Manager, Virtual Machine Manager, or an elevated Windows Powershell session. For Windows PowerShell, run this command:

                        https://technet.microsoft.com/en-us/windows-server-docs/compute/hyper-v/what-s-new-in-hyper-v-on-windows

                        I think the response here is great and my hope is that we will get gen 2 support soon even tough it might not be in 2.4.0.

                        1 Reply Last reply Reply Quote 0
                        • B
                          bimmerdriver
                          last edited by

                          Does anyone know what the status of freebsd 11 support on generation 2 hyper-v is?

                          1 Reply Last reply Reply Quote 0
                          • ?
                            Guest
                            last edited by

                            @bimmerdriver:

                            Does anyone know what the status of freebsd 11 support on generation 2 hyper-v is?

                            I bet bsdic@microsoft.com knows.

                            1 Reply Last reply Reply Quote 0
                            • B
                              bimmerdriver
                              last edited by

                              @johnkeates:

                              @bimmerdriver:

                              Does anyone know what the status of freebsd 11 support on generation 2 hyper-v is?

                              I bet bsdic@microsoft.com knows.

                              Yes, they do know. I contacted them and heard back this morning. Generation 2 is in the development plan and is scheduled to be completed in the March 2017 time frame.

                              1 Reply Last reply Reply Quote 0
                              • E
                                epionier
                                last edited by

                                Overview: https://technet.microsoft.com/en-us/windows-server-docs/compute/hyper-v/supported-freebsd-virtual-machines-on-hyper-v

                                1 Reply Last reply Reply Quote 0
                                • P
                                  poshoholic
                                  last edited by

                                  It's been a while since this topic had posts, but it seemed appropriate to follow-up here.

                                  @johnkeates: Have you been in touch with your contacts since your reply back in November? Since we're now March, I'm curious how far out generation 2 VM support in Hyper-V might be for pfSense 2.4.

                                  1 Reply Last reply Reply Quote 0
                                  • ?
                                    Guest
                                    last edited by

                                    @poshoholic:

                                    It's been a while since this topic had posts, but it seemed appropriate to follow-up here.

                                    @johnkeates: Have you been in touch with your contacts since your reply back in November? Since we're now March, I'm curious how far out generation 2 VM support in Hyper-V might be for pfSense 2.4.

                                    You'll have to ask bimmerdriver or bsdic@microsoft.com as I don't have anything new at the moment.

                                    1 Reply Last reply Reply Quote 0
                                    • B
                                      bimmerdriver
                                      last edited by

                                      @johnkeates:

                                      @poshoholic:

                                      It's been a while since this topic had posts, but it seemed appropriate to follow-up here.

                                      @johnkeates: Have you been in touch with your contacts since your reply back in November? Since we're now March, I'm curious how far out generation 2 VM support in Hyper-V might be for pfSense 2.4.

                                      You'll have to ask bimmerdriver or bsdic@microsoft.com as I don't have anything new at the moment.

                                      I haven't heard anything since my last post. If you contact bsdic@microsoft.com, please post an update here.

                                      1 Reply Last reply Reply Quote 0
                                      • P
                                        poshoholic
                                        last edited by

                                        @bimmerdriver: I did reach out to bsdic@microsoft.com, and received a reply last night stating the following about FreeBSD generation 2 VM support:

                                        1. The HEAD can boot on Hyper-V as Generation-2 VM now (patches for https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=211746 will be pushed to stable/10 and stable/11 soon); however, Secure Boot must be disabled since it isn't supported yet.

                                        2. The virtual DVD drive in the VM doesn't work yet. They are trying to fix it. In the meantime VM images can be created by following the "Bootable UEFI memory stick or Hard Disk" section of the UEFI doc on wiki.freebsd.org.

                                        3. The keyboard of the VM doesn't work yet, but they are adding a driver for it so it should work soon.

                                        Other than that they're running more tests to see if there are other issues. Sounds like it's pretty close though.

                                        1 Reply Last reply Reply Quote 0
                                        • S
                                          stable_user
                                          last edited by

                                          Hi all!

                                          Dev team just added synthetic keyboard driver a few days ago :)

                                          https://svnweb.freebsd.org/base/stable/11/sys/dev/hyperv/input/?view=log&sortby=file&pathrev=317189

                                          Tested on fresh install of FreeBSD 11-STABLE within Hyper-V (MS 2016 Std as the host) and the keyboard works 8)

                                          It seems the FreeBSD Gen 2 VMs is closing up to the final approach…

                                          dmesg output:

                                          Copyright © 1992-2017 The FreeBSD Project.
                                          Copyright (c) 1979, 1980, 1983, 1986, 1988, 1989, 1991, 1992, 1993, 1994
                                                  The Regents of the University of California. All rights reserved.
                                          FreeBSD is a registered trademark of The FreeBSD Foundation.
                                          FreeBSD 11.0-STABLE #0 r317291: Sat Apr 22 22:51:09 CEST 2017
                                              root@abc.def:/usr/obj/usr/src/sys/CUSTOM amd64
                                          FreeBSD clang version 4.0.0 (tags/RELEASE_400/final 297347) (based on LLVM 4.0.0)
                                          SRAT: Ignoring memory at addr 0x808200000
                                          SRAT: Ignoring memory at addr 0x1000000000
                                          SRAT: Ignoring memory at addr 0x10000200000
                                          SRAT: Ignoring memory at addr 0x20000200000
                                          SRAT: Ignoring memory at addr 0x40000200000
                                          SRAT: Ignoring memory at addr 0x80000200000
                                          VT(efifb): resolution 1024x768
                                          Hyper-V Version: 10.0.14393 [SP1]
                                            Features=0x2e7f <vpruntime,tmrefcnt,synic,syntm,apic,hypercall,vpindex,reftsc,idle,tmfreq>PM Features=0x0 [C2]
                                            Features3=0xed7b2 <debug,xmmhc,idle,numa,tmfreq,syncmc,crash,npiep>Timecounter "Hyper-V" frequency 10000000 Hz quality 2000
                                          CPU: Intel(R) Xeon(R) CPU E5-2667 v4 @ 3.20GHz (3192.61-MHz K8-class CPU)
                                            Origin="GenuineIntel"  Id=0x406f1  Family=0x6  Model=0x4f  Stepping=1
                                            Features=0x1f83fbff <fpu,vme,de,pse,tsc,msr,pae,mce,cx8,apic,sep,mtrr,pge,mca,cmov,pat,pse36,mmx,fxsr,sse,sse2,ss,htt>Features2=0xfed83203 <sse3,pclmulqdq,ssse3,fma,cx16,sse4.1,sse4.2,movbe,popcnt,aesni,xsave,osxsave,avx,f16c,rdrand,hv>AMD Features=0x2c100800 <syscall,nx,page1gb,rdtscp,lm>AMD Features2=0x121 <lahf,abm,prefetch>Structured Extended Features=0x1c2b38 <bmi1,hle,avx2,bmi2,erms,rtm,nfpusg,rdseed,adx,smap>XSAVE Features=0x1 <xsaveopt>Hypervisor: Origin = "Microsoft Hv"
                                          real memory  = 34359738368 (32768 MB)
                                          avail memory = 33349726208 (31804 MB)
                                          Event timer "LAPIC" quality 100
                                          ACPI APIC Table: <vrtual microsft="">FreeBSD/SMP: Multiprocessor System Detected: 4 CPUs
                                          FreeBSD/SMP: 1 package(s) x 4 core(s)
                                          random: unblocking device.
                                          ioapic0 <version 1.1="">irqs 0-23 on motherboard
                                          Timecounter "Hyper-V-TSC" frequency 10000000 Hz quality 3000
                                          random: entropy device external interface
                                          kbd0 at kbdmux0
                                          module_register_init: MOD_LOAD (vesa, 0xffffffff80765d10, 0) error 19
                                          nexus0
                                          cryptosoft0: <software crypto="">on motherboard
                                          acpi0: <vrtual microsft="">on motherboard
                                          cpu0: <acpi cpu="">on acpi0
                                          cpu1: <acpi cpu="">on acpi0
                                          cpu2: <acpi cpu="">on acpi0
                                          cpu3: <acpi cpu="">on acpi0
                                          atrtc0: <at realtime="" clock="">port 0x70-0x71 irq 8 on acpi0
                                          Event timer "RTC" frequency 32768 Hz quality 0
                                          Timecounter "ACPI-fast" frequency 3579545 Hz quality 900
                                          acpi_timer0: <32-bit timer at 3.579545MHz> port 0x408-0x40b on acpi0
                                          vmbus0: <hyper-v vmbus="">irq 5 on acpi0
                                          Timecounters tick every 1.000 msec
                                          ipfw2 initialized, divert loadable, nat loadable, default to deny, logging disabled
                                          usb_needs_explore_all: no devclass
                                          SMP: AP CPU #3 Launched!
                                          SMP: AP CPU #2 Launched!
                                          SMP: AP CPU #1 Launched!
                                          Trying to mount root from ufs:/dev/gpt/rootfs [rw,noatime]…
                                          mountroot: waiting for device /dev/gpt/rootfs...
                                          vmbus0: version 3.0
                                          hvet0: <hyper-v event="" timer="">on vmbus0
                                          Event timer "Hyper-V" frequency 10000000 Hz quality 1000
                                          hvkbd0: <hyper-v kbd="">on vmbus0</hyper-v>
                                          hvheartbeat0: <hyper-v heartbeat="">on vmbus0
                                          hvkvp0: <hyper-v kvp="">on vmbus0
                                          hvshutdown0: <hyper-v shutdown="">on vmbus0
                                          hvtimesync0: <hyper-v timesync="">on vmbus0
                                          hvtimesync0: RTT
                                          hvvss0: <hyper-v vss="">on vmbus0
                                          storvsc0: <hyper-v scsi="">on vmbus0
                                          (probe0:storvsc0:0:0:0): storvsc scsi_status = 2
                                          hn0: <hyper-v network="" interface="">on vmbus0
                                          da0 at storvsc0 bus 0 scbus0 target 0 lun 0
                                          da0: <msft virtual="" disk="" 1.0="">Fixed Direct Access SPC-3 SCSI device
                                          da0: 300.000MB/s transfers
                                          da0: Command Queueing enabled
                                          da0: 81920MB (167772160 512 byte sectors)
                                          hn0: got notify, nvs type 128
                                          hn0: Ethernet address: 00:15:5d:08:1e:00
                                          hn0: link state changed to UP
                                          hn1: <hyper-v network="" interface="">on vmbus0
                                          hn1: got notify, nvs type 128
                                          hn1: Ethernet address: 00:15:5d:08:1e:01
                                          hn1: link state changed to UP
                                          pcib0: <hyper-v pci="" express="" pass="" through="">on vmbus0
                                          pcib0: vmbus_pcib failed to enable D0
                                          device_attach: pcib0 attach returned 92
                                          pcib0: <hyper-v pci="" express="" pass="" through="">on vmbus0
                                          pcib0: vmbus_pcib failed to enable D0
                                          device_attach: pcib0 attach returned 92</hyper-v></hyper-v></hyper-v></msft></hyper-v></hyper-v></hyper-v></hyper-v></hyper-v></hyper-v></hyper-v></hyper-v></hyper-v></at></acpi></acpi></acpi></acpi></vrtual></software></version></vrtual></xsaveopt></bmi1,hle,avx2,bmi2,erms,rtm,nfpusg,rdseed,adx,smap></lahf,abm,prefetch></syscall,nx,page1gb,rdtscp,lm></sse3,pclmulqdq,ssse3,fma,cx16,sse4.1,sse4.2,movbe,popcnt,aesni,xsave,osxsave,avx,f16c,rdrand,hv></fpu,vme,de,pse,tsc,msr,pae,mce,cx8,apic,sep,mtrr,pge,mca,cmov,pat,pse36,mmx,fxsr,sse,sse2,ss,htt></debug,xmmhc,idle,numa,tmfreq,syncmc,crash,npiep></vpruntime,tmrefcnt,synic,syntm,apic,hypercall,vpindex,reftsc,idle,tmfreq>

                                          1 Reply Last reply Reply Quote 0
                                          • B
                                            bimmerdriver
                                            last edited by

                                            Yah, really good. Looks like support for gen 2 VM is getting close.

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post
                                            Copyright 2025 Rubicon Communications LLC (Netgate). All rights reserved.