| vkernel | |
|---|---|
| Original author | Matthew Dillon |
| Developer | DragonFly BSD |
| Initial release | DragonFly BSD § 1.8 (30 January 2007; 18 years ago (2007-01-30))[1][2] |
| Repository | sys/vkernel.h,dev/virtual/vkernel/,vm/vm_vmspace.c, … |
| Written in | C |
| Operating system | DragonFly BSD |
| Type | OS-level virtualisation, virtualised userspace kernel |
| Licence | BSD Licence |
| Website | vkernel(7) |
Avirtual kernel architecture (vkernel) is anoperating systemvirtualisation paradigm where kernel code can be compiled to run in theuser space, for example, to ease debugging of various kernel-level components,[3][4][5] in addition to general-purpose virtualisation and compartmentalisation ofsystem resources. It is used byDragonFly BSD in its vkernel implementation since DragonFly 1.7,[2] having been first revealed in September 2006 (19 years ago) (2006-09),[3][6] and first released in the stable branch with DragonFly 1.8 in January 2007 (18 years ago) (2007-01).[1][7][8][9]
The long-term goal, in addition to easing kernel development, is to make it easier to support internet-connectedcomputer clusters without compromising localsecurity.[3][4]
Similar concepts exist in other operating systems as well; in Linux, a similar virtualisation concept is known asuser-mode Linux;[10][7] whereas inNetBSD since the summer of 2007, it has been the initial focus of therump kernel infrastructure.[11]
Thevirtual kernel concept is nearly the exact opposite of theunikernel concept — withvkernel, kernel components get to run in userspace to ease kernel development and debugging, supported by a regular operating system kernel; whereas with aunikernel, userspace-level components get to run directly in kernel space for extra performance, supported by baremetal hardware or a hardware virtualisation stack. However, both vkernels and unikernels can be used for similar tasks as well, for example, to self-contain software to a virtualised environment with low overhead. In fact, NetBSD'srump kernel, originally having a focus of running kernel components in userspace, has since shifted into the unikernel space as well (going after theanykernel moniker for supporting both paradigms).
The vkernel concept is different from aFreeBSD jail in that a jail is only meant for resource isolation, and cannot be used to develop and test new kernel functionality in the userland, because each jail is sharing the same kernel.[7] (DragonFly, however, still hasFreeBSD jail support as well.[7])
In DragonFly, the vkernel can be thought of as a first-classcomputer architecture, comparable to i386 or amd64, and, according toMatthew Dillon circa 2007, can be used as a starting point for porting DragonFly BSD to new architectures.[12]
DragonFly's vkernel is supported by the host kernel through newsystem calls that help manage virtual memory address space (vmspace) —vmspace_create() et al.,[3][9][13] as well as extensions to several existing system calls likemmap'smadvise —mcontrol.[9][14][15]
UML runs the Linux kernel as a userspace process, analogous to DragonFly BSD's virtual kernels … allow for a quick recompile-restart cycle and can be debugged easily with standard gdb.
Introduce RUMPs - Runnable Userspace Meta-Programs