Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/SinaKarvandi/Hypervisor-From-Scratch
Source code of a multiple series of tutorials about the hypervisor. Available at: https://rayanfam.com/tutorials
https://github.com/SinaKarvandi/Hypervisor-From-Scratch
ept hidden-hook hypervisor tutorial vmx vt-x
Last synced: 5 days ago
JSON representation
Source code of a multiple series of tutorials about the hypervisor. Available at: https://rayanfam.com/tutorials
- Host: GitHub
- URL: https://github.com/SinaKarvandi/Hypervisor-From-Scratch
- Owner: SinaKarvandi
- License: mit
- Created: 2018-09-03T21:01:34.000Z (about 6 years ago)
- Default Branch: master
- Last Pushed: 2024-07-13T13:15:25.000Z (4 months ago)
- Last Synced: 2024-08-02T16:48:23.099Z (3 months ago)
- Topics: ept, hidden-hook, hypervisor, tutorial, vmx, vt-x
- Language: C
- Homepage: https://rayanfam.com/tutorials
- Size: 29.7 MB
- Stars: 2,142
- Watchers: 55
- Forks: 294
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-qubes-os - Hipervisor From Scratch - Source code of a multiple series of tutorials about the hypervisor. (Optics and Extra Info / Extra Info)
README
Hypervisor From Scratch
A tutorial on creating a hypervisor from scratch
All the parts »
Part 1
·
Part 2
·
Part 3
·
Part 4
·
Part 5
·
Part 6
·
Part 7
·
Part 8
**If you're looking to use a hypervisor for analysis and reverse engineering tasks, check out [HyperDbg](https://github.com/HyperDbg/HyperDbg) Debugger. It's a hypervisor-based debugger designed specifically for analyzing, fuzzing, and reversing applications. A free and comprehensive tutorial on hypervisor-based reverse engineering is available at [OpenSecurityTraining2's website](https://ost2.fyi/dbg3301) (_preferred_) and [YouTube](https://www.youtube.com/playlist?list=PLUFkSN0XLZ-kF1f143wlw8ujlH2A45nZY), which demonstrates numerous practical examples on how to utilize hypervisors for reverse engineering.**
**Notice**: The _**Hypervisor From Scratch**_ tutorial is completely revised in **August 2022**. Codes from all parts are updated, unnecessary details are removed, and new explanations and materials are added to the tutorial.
# Hypervisor From Scratch
Source code of a multiple series of tutorials about the hypervisor.
Available at: https://rayanfam.com/tutorials
**Part 1 - Basic Concepts & Configure Testing Environment**
(https://rayanfam.com/topics/hypervisor-from-scratch-part-1)**Part 2 - Entering VMX Operation**
(https://rayanfam.com/topics/hypervisor-from-scratch-part-2)**Part 3 - Setting up Our First Virtual Machine**
(https://rayanfam.com/topics/hypervisor-from-scratch-part-3)**Part 4 - Address Translation Using Extended Page Table (EPT)**
(https://rayanfam.com/topics/hypervisor-from-scratch-part-4)**Part 5 - Setting up VMCS & Running Guest Code**
(https://rayanfam.com/topics/hypervisor-from-scratch-part-5)**Part 6 - Virtualizing An Already Running System**
(https://rayanfam.com/topics/hypervisor-from-scratch-part-6)**Part 7 - Using EPT & Page-Level Monitoring Features**
(https://rayanfam.com/topics/hypervisor-from-scratch-part-7)**Part 8 - How To Do Magic With Hypervisor!**
(https://rayanfam.com/topics/hypervisor-from-scratch-part-8)## Note
**Note**: please keep in mind that hypervisors change over time because new features are added to the operating systems or using new technologies. For example, updates to Meltdown & Spectre have made a lot of changes to the hypervisors, so if you want to use Hypervisor From Scratch in your projects, research, or whatever, you have to use the driver from the latest parts of these tutorial series as this tutorial is actively updated and changes are applied to the newer parts (earlier parts keep untouched) so you might encounter errors and instability problems in the earlier parts thus make sure to use the latest parts in real-world projects.
## Compile & Install
In order to compile this project, you have to use Windows Driver Kit (WDK), first install Visual Studio, then install WDK. After that, you can compile it.
## Environment
All the drivers are tested on both physical-machine, and VMWare Workstations's nested-virtualization, from part 8 support to Hyper-V is added, which means that you can test part 8 and newer parts on physical-machine, VMWare Workstation's nested-virtualization, and Hyper-V's nested-virtualization.
## Other Articles & Projects
If you want to know more about hypervisors, you can visit the [awesome virtualization](https://github.com/Wenzel/awesome-virtualization) repo.
## Credits
This series is written by:
- Sina Karvandi
- Petr BenešSpecial Thanks to these guys for their help and contributions:
- Alex Ionescu
- Satoshi Tanda
- Liran Alon
- gerhart
- Daax
- Noteworthy
- ivs
- Artem Shishkin
- Shahriar
- Ahmad
- ...and many other people who helped to solve the problems## License
**Hypervisor From Scratch** is licensed under an **MIT** license.
[contributors-shield]: https://img.shields.io/github/contributors/othneildrew/Best-README-Template.svg?style=flat-square
[contributors-url]: https://github.com/SinaKarvandi/Hypervisor-From-Scratch/graphs/contributors
[forks-shield]: https://img.shields.io/github/forks/othneildrew/Best-README-Template.svg?style=flat-square
[forks-url]: https://github.com/SinaKarvandi/Hypervisor-From-Scratch/network/members
[stars-shield]: https://img.shields.io/github/stars/othneildrew/Best-README-Template.svg?style=flat-square
[stars-url]: https://github.com/SinaKarvandi/Hypervisor-From-Scratch/stargazers
[issues-shield]: https://img.shields.io/github/issues/othneildrew/Best-README-Template.svg?style=flat-square
[issues-url]: https://github.com/SinaKarvandi/Hypervisor-From-Scratch/issues