Files
MiniVisorPkg/README.md

87 lines
3.7 KiB
Markdown
Raw Normal View History

2020-02-22 19:54:32 -08:00
MiniVisor
==========
2020-02-22 13:54:50 -08:00
This is a research hypervisor written as a UEFI and Windows driver for the educational purpose for Intel processors.
This MiniVisor, as a UEFI driver, provides the ability to inspect system activities even before the operating system boots, while as a Windows driver, allows developers to debug it with familiar tools like WinDbg.
Showcase
---------
2020-02-22 19:54:32 -08:00
* Loading the hypervisor from the UEFI shell.
![Readme_Showcase1.jpg](Docs/Resources/Readme_Showcase1.jpg)
* Logging boot activities and interacting with the guest.
![Readme_Showcase2.jpg](Docs/Resources/Readme_Showcase2.jpg)
2020-02-22 13:54:50 -08:00
2020-02-23 13:12:43 -08:00
* Booting Ubuntu on a bare-metal.
![Readme_Showcase3.jpg](Docs/Resources/Readme_Showcase3.jpg)
2020-02-22 13:54:50 -08:00
Motivation
-----------
The goal of this project is to share an additional learning resource for writing UEFI hypervisors with the community and researchers.
2020-02-22 19:54:32 -08:00
There are numerous open source hypervisors with small and easy-to-study implementations, but those that support booting operating systems as UEFI drivers are still not many.
2020-02-22 13:54:50 -08:00
2020-02-23 13:12:43 -08:00
Given the universality of UEFI systems on the AMD64 ecosystem and the unique ability to monitor, attack and protect the system throughout operating system startup on bare-metal systems, the authors believe that having the understanding and being able to develop this type of hypervisors are valuable for research.
2020-02-22 13:54:50 -08:00
With this goal in mind, the project aims to offer
- Straightforward and approachable codebase
- over highly-abstracted but intricate structures
- Rich comments aimed for new learners
- over just-enough for those who already know how hypervisor works
- Minimal functionality to highlight core concepts to study
- over extensibility and direct usefulness
- Extensive documentation on development environment setup
System Requirements
--------------------
Common Requirements:
- Intel VT-x and EPT supported processors
Requirements for the UEFI driver:
- UEFI-based system
2020-02-23 13:12:43 -08:00
- 64bit Windows 10, IoT Core, or Ubuntu to boot
2020-02-22 13:54:50 -08:00
Requirements for the Windows driver:
- 64bit Windows 7 and 10
See [Building and Debugging](Docs/Building_and_Debugging.md) for testing.
2020-02-22 19:54:32 -08:00
Advantages and Use Cases
------------------------
While this project does not implement any immediately useful features, UEFI-based hypervisors have multiple advantages over Windows driver-based ones and can implement unique features.
* No need of disabling Hyper-V (Virtualization Based Security) to run the custom hypervisor
* No need of enabling the test-signing mode
2020-02-23 13:12:43 -08:00
* Zero direct indicator of existence of the hypervisor from operating system perspective
2020-02-22 19:54:32 -08:00
* Installing hooks during the early boot phase and letting PatchGuard to protect them
* Detecting bootkit and early system modification
2020-02-23 13:12:43 -08:00
* Implementing operating system agnostic solutions
2020-02-22 19:54:32 -08:00
2020-02-22 13:54:50 -08:00
Limitations
------------
- Nested virtualization is not supported. The CPUID instruction reports that the VMX extension is unsupported.
2020-02-23 13:12:43 -08:00
- Booting Windows SKUs other than the listed above is not supported or tested.
2020-02-22 13:54:50 -08:00
- Sleep and resume are not supported or tested.
Acknowledgments
----------------
The authors thank for creators and maintainers of the following projects:
- [Bareflank](https://github.com/Bareflank/hypervisor) and [STM](https://github.com/jyao1/STM) -- for publishing UEFI-base hypervisors with the relatively small codebase.
- [zpp_hypervisor](https://github.com/eyalz800/zpp_hypervisor) -- for making me realize that writing UEFI-based hypervisors is viable.
- [EfiGuard](https://github.com/Mattiwatti/EfiGuard) -- for clean codebase and rich documentation for UEFI development newbies.
- [hvpp](https://github.com/wbenny/hvpp) -- for few techniques required for the UEFI environment.
- [ia32-doc](https://github.com/wbenny/ia32-doc) -- for saving me from defining thousands of constants and structures by hand.