Design and Implementation of the VirtuOS Operating System

dc.contributor.authorNikolaev, Ruslanen
dc.contributor.committeechairBack, Godmar V.en
dc.contributor.committeememberTilevich, Elien
dc.contributor.committeememberGupta, Bidyuten
dc.contributor.committeememberKafura, Dennis G.en
dc.contributor.committeememberButt, Ali R.en
dc.contributor.departmentComputer Scienceen
dc.date.accessioned2014-01-22T09:00:07Zen
dc.date.available2014-01-22T09:00:07Zen
dc.date.issued2014-01-21en
dc.description.abstractMost operating systems provide protection and isolation to user processes, but not to critical system components such as device drivers or other systems code. Consequently, failures in these components often lead to system failures. VirtuOS is an operating system that exploits a new method of decomposition to protect against such failures. VirtuOS exploits virtualization to isolate and protect vertical slices of existing OS kernels in separate service domains. Each service domain represents a partition of an existing kernel, which implements a subset of that kernel's functionality. Service domains directly service system calls from user processes. VirtuOS exploits an exceptionless model, avoiding the cost of a system call trap in many cases. We illustrate how to apply exceptionless system calls across virtualized domains. To demonstrate the viability of VirtuOS's approach, we implemented a prototype based on the Linux kernel and Xen hypervisor. We created and evaluated a network and a storage service domain. Our prototype retains compatibility with existing applications, can survive the failure of individual service domains while outperforming alternative approaches such as isolated driver domains and even exceeding the performance of native Linux for some multithreaded workloads. The evaluation of VirtuOS revealed costs due to decomposition, memory management, and communication, which necessitated a fine-grained analysis to understand their impact on the system's performance. The interaction of virtual machines with multiple underlying software and hardware layers in virtualized environment makes this task difficult. Moreover, performance analysis tools commonly used in native environments were not available in virtualized environments. Our work addresses this problem to enable an in-depth performance analysis of VirtuOS. Our Perfctr-Xen framework provides capabilities for per-thread analysis with both accumulative event counts and interrupt-driven event sampling. Perfctr-Xen is a flexible and generic tool, supports different modes of virtualization, and can be used for many applications outside of VirtuOS.en
dc.description.degreePh. D.en
dc.format.mediumETDen
dc.identifier.othervt_gsexam:2099en
dc.identifier.urihttp://hdl.handle.net/10919/24964en
dc.publisherVirginia Techen
dc.rightsIn Copyrighten
dc.rights.urihttp://rightsstatements.org/vocab/InC/1.0/en
dc.subjectoperating systemsen
dc.subjecthypervisoren
dc.subjectmicrokernelen
dc.subjectdriver isolationen
dc.subjectprofilersen
dc.subjectperfctren
dc.subjectXenen
dc.subjectvirtualizationen
dc.subjectIOMMUen
dc.subjectexceptionless system callsen
dc.titleDesign and Implementation of the VirtuOS Operating Systemen
dc.typeDissertationen
thesis.degree.disciplineComputer Science and Applicationsen
thesis.degree.grantorVirginia Polytechnic Institute and State Universityen
thesis.degree.leveldoctoralen
thesis.degree.namePh. D.en

Files

Original bundle
Now showing 1 - 1 of 1
Loading...
Thumbnail Image
Name:
Nikolaev_R_D_2013.pdf
Size:
1.1 MB
Format:
Adobe Portable Document Format
Description: