NetBSD Virtualization Status Report

Presenter Notes

netbsd

bhyvecon Tokyo 2019 - The BSD Hypervisor Conference

Author: Kamil Rytarowski

E-mail: kamil@netbsd.org

Date: March 20th, 2019

Location: Tokyo, Japan

Presenter Notes

Bio

Kamil Rytarowski (born 1987)

Krakow, Poland

NetBSD user since 6.1.

NetBSD Foundation member since 2015.

Work areas: kernel, userland, pkgsrc.

Interest: NetBSD on desktop and in particular NetBSD as a workstation.

Current activity in 3rd party software:

  • LLVM committer.
  • GDB & binutils committer.
  • NetBSD maintenance in qemu.

Presenter Notes

Topics

  • Terminology
  • NetBSD and software emulation
  • NetBSD and hardware assisted emulation
  • Future plans

Presenter Notes

Terminology

Presenter Notes

Virtualization

Virtualization is a very broad term. We refer here to running a full Operating System [instance] (guest) on another already running Operating System [instance] (host).

There are two basic types of virtualization:

  • Full software emulation.
  • Hardware assisted emulation.

Presenter Notes

Hypervisor

A hypervisor (Virtual Machine Monitor) is software, firmware, or hardware that creates and runs virtual machines.

There are two types of hypervisors:

  • Type-1 (native/bare-metal hypervisors) - running directly on hardware.
  • Type-2 (hosted hypervisors) - running as a kernel extension (module) or a userland application.

Presenter Notes

Emulation types

Software emulation VS hardware assisted emulation

Full software emulation is slower, but can support cross-CPU virtualization and is typically accessible without privileged hardware features.

Hardware assisted virtualization uses CPU specific features in order to get near native execution speed of a guest machine, but it's usually restricted to the same CPU architecture only and requires privileged kernel drivers.

Presenter Notes

NetBSD Virtualization

There are two types of virtualization in the interest of NetBSD developers and users:

  • NetBSD as a host virtualizing a given Operating System as guest.
  • NetBSD as a guest virtualized on a given Operating System as host.

Whenever applicable and expected, it's desired to support NetBSD as both guest and host Operating System.

For practical reasons it's necessary to handle NetBSD as a guest Operating System in foreign environments (such as remote VPS services) and virtualize non-NetBSD systems on a NetBSD host (such as retro computing).

Presenter Notes

NetBSD and software emulation

Presenter Notes

NetBSD and software emulation

Does it still matter in NetBSD? Yes!

Presenter Notes

NetBSD and software emulation

Software emulation matters in NetBSD in particular for:

  • Development of new ports.
  • Maintenance of existing ports.
  • Featured kernel cross-CPU debugging and introspection.

Presenter Notes

Development of new ports

NetBSD/riscv running on the Spike emulator

riscv

https://twitter.com/zmcgrew/status/1055682596812730368

Presenter Notes

Maintenance of existing ports

babylon5

http://releng.netbsd.org/test-results.html

Presenter Notes

Kernel debugging

Featured kernel cross-CPU debugging and introspection.

Powerful combination of emulator and debugger, such as Qemu + GDB (prebuilt with cross-ABI support).

 1 # Adding breakpoints on function names:
 2 (gdb) break sys_open
 3 Breakpoint 1 at 0xffffffff804b267f:
 4 file /home/dimitris/Code/netbsd-current/src/sys/kern/vfs_syscalls.c, \
 5 line 1672.
 6 [...]
 7 (gdb) ptype struct mbuf
 8 type = struct mbuf {
 9   struct m_hdr m_hdr;
10   union {
11       struct {...} MH;
12       char M_databuf[456];
13   } M_dat;
14 }

https://t.pagef.lt/working-with-the-netbsd-kernel/

Presenter Notes

NetBSD and software emulation

Probably the most frequently used software virtual machines for NetBSD guests:

  • bochs (i386)
  • giano (emips, vax)
  • gxemul (algor, arc, cats, cobalt, dreamcast, evbarm, evbmips, hpcmips, landisk, macppc, netwinder, pmax, prep, sgimips)
  • QEMU (amd64, evbarm, i386, sparc, sparc64)
  • simh (vax)
  • simics (amd64)
  • ski (ia64)
  • spike (riscv)
  • tme (sparc, sparc64, sun2, sun3)
  • xm6i (x68k)

https://www.netbsd.org/ports/emulators.html

Presenter Notes

NetBSD and software emulation

Software emulation is not good for everything, especially whenever we depend upon performance.

Performance and cost of execution are mandatory elements of practically all production work loads.

Whenever we require performance we need hardware assisted emulation.

Presenter Notes

NetBSD and hardware assisted emulation

Presenter Notes

Hardware assisted emulation as host

Due to practical reasons and current resources of the project, the main focus of hardware assisted emulation is the x86 (Intel and AMD) architecture.

However, there is some activity and interest in the aarch64 land as well.

Presenter Notes

Hardware assisted emulation as host

Currently available options:

  • VM86 (removed in mid 2017)
  • NetBSD/xen
  • NVMM (NetBSD Virtual Machine Monitor)
  • HAXM (Intel Hardware Accelerated eXecution Manager)

Presenter Notes

Goodbye to VM86

vm86

https://github.com/NetBSD/src/commit/5929a332ef850162327ea78d56ab9c1900daf71f

Presenter Notes

Good old NetBSD/xen

xen

http://wiki.netbsd.org/ports/xen/

Presenter Notes

Xen modes - timeline

800px-GuestModes.png

https://wiki.xen.org/wiki/Xen_Project_Software_Overview#Guest_Types

Presenter Notes

NetBSD/xen support

xen-howto

http://wiki.netbsd.org/ports/xen/howto/

Presenter Notes

NetBSD/xen support

Multiprocessor (SMP) support in NetBSD differs depending on the domain:

  • dom0 - not supported (without experimental patches)
  • domU - supported

The standard approach is to use NetBSD/amd64 for the dom0.

The dom0 system, plus each domU, can be either i386PAE or amd64. i386 without PAE is not supported.

For domUs, i386PAE is considered faster than amd64.

http://wiki.netbsd.org/ports/xen/howto/

Presenter Notes

HAXM and NVMM

There are two hardware accelerated engines in the NetBSD kernel.

HAXM (by Intel, ported to NetBSD by Kamil Rytarowski):

  • Multiplatform virtualization engine (NetBSD, Linux, Windows, macOS)
  • Designed for Intel CPUs and x86_64 ISA only (AMD SVM is unsupported)
  • External open-source project from Intel available through pkgsrc
  • Works with at least NetBSD 8.0, could work with older releases but not tested

NVMM (by Maxime Villard):

  • Homegrown NetBSD virtualization engine
  • Machine Independent API with NetBSD/amd64 support (Intel and AMD CPUs) as host
  • Integral part of the NetBSD distribution
  • Works with NetBSD-current and planned for future releases (starting with 9.0)

Presenter Notes

HAXM and NVMM

Both engines:

  • are supported on NetBSD with QEMU (in versions from pkgsrc).
  • require relatively recent CPUs, not older than a decade old hardware.
  • designed to behave as a backend to QEMU or similar frontend only, without full-stack software virtualization.
  • are designed to reuse drivers from QEMU.
  • combined with QEMU can run at least NetBSD, Windows, Linux and several other Operating Systems in at least a single guest version/type (like 32/64 bit).
  • can run multiple Virtual Machines with multiple VCPUs in each of them.
  • are open-source and BSD-licensed.

Presenter Notes

HAXM and NVMM

Why are there two kernel engines for the same purpose?

  • HAXM porting started much earlier than any NVMM work and targets the hardware of interest of Intel CPU users in desktop-workflows
  • NVMM started initially as AMD SVM hypervisor and is currently designed to be machine independent (AMD SVM, Intel VTx, open for other CPUs)
  • HAXM is a cross-OS hypervisor API, it's cheaper to port existing software using it to NetBSD, without (or before) remapping all the KVM APIs to NVMM
  • HAXM works with older unmodified kernels including the latest stable release 8.0, NVMM is in development in NetBSD-current and planed for future releases

All in all: HAXM allows to get the job done earlier and reduce cost of porting software to NetBSD (expanding the QEMU support for NetBSD/HAXM was a 1-liner patch), NVMM is the long term recommendation (and requires more porting).

Could HAXM and NVMM be merged? No, as both have different targets and the legacy of HAXM APIs and design choices (with accumulated technical debt) restricts it to Intel x86 desktop users. It was easier to start from scratch than totally rewrite existing code.

Presenter Notes

HAXM (Win7 32-bit guest)

haxm2.png

http://blog.netbsd.org/tnf/entry/the_hardware_assisted_virtualization_challenge

Presenter Notes

NVMM (Win10 guest)