November 10, Wednesday 14:15, Room 303, Jacobs Building
The Turtles Project: Design and
Implementation of Nested Virtualization
Lecturer : Muli Ben-Yehuda
Lecturer homepage : http://www.mulix.org/
Affiliation : IBM Research
Haifa
In classical machine virtualization, a hypervisor runs multiple
operating systems simultaneously, each on its own virtual
machine. In nested virtualization, a hypervisor can run multiple
other hypervisors with their associated virtual machines. As
operating systems gain hypervisor functionality---Microsoft Windows
7 already runs Windows XP in a virtual machine---nested
virtualization will become necessary in hypervisors that wish to
host them.
We present the design, implementation, analysis, and evaluation of
high-performance nested virtualization on Intel x86-based
systems. The Turtles project, which is part of the Linux/KVM
hypervisor, runs multiple unmodified hypervisors (e.g., KVM and
VMware) and operating systems (e.g., Linux and Windows). Despite the
lack of architectural support for nested virtualization in the x86
architecture, it can achieve performance that is within 6-8% of
single-level (non-nested) virtualization for common workloads,
through multi-dimensional paging for MMU virtualization and
multi-level device assignment for I/O virtualization.
Joint work with M. D. Day, Z. Dubitzky, M. Factor, N. Har'El,
A. Gordon, A. Liguori, O. Wasserman, and B.-A. Yassour.