Bumps [jidicula/clang-format-action](https://github.com/jidicula/clang-format-action) from 4.14.0 to 4.15.0. <details> <summary>Release notes</summary> <p><em>Sourced from <a href="https://github.com/jidicula/clang-format-action/releases">jidicula/clang-format-action's releases</a>.</em></p> <blockquote> <h2>v4.15.0</h2> <h2>What's Changed</h2> <ul> <li>build: bump docker/build-push-action from 6.9.0 to 6.10.0 by <a href="https://github.com/dependabot"><code>@dependabot</code></a> in <a href="https://redirect.github.com/jidicula/clang-format-action/pull/225">jidicula/clang-format-action#225</a></li> <li>build: bump docker/build-push-action from 6.10.0 to 6.12.0 by <a href="https://github.com/dependabot"><code>@dependabot</code></a> in <a href="https://redirect.github.com/jidicula/clang-format-action/pull/230">jidicula/clang-format-action#230</a></li> <li>build: bump docker/build-push-action from 6.12.0 to 6.13.0 by <a href="https://github.com/dependabot"><code>@dependabot</code></a> in <a href="https://redirect.github.com/jidicula/clang-format-action/pull/231">jidicula/clang-format-action#231</a></li> <li>build: bump docker/login-action from 3.3.0 to 3.4.0 by <a href="https://github.com/dependabot"><code>@dependabot</code></a> in <a href="https://redirect.github.com/jidicula/clang-format-action/pull/238">jidicula/clang-format-action#238</a></li> <li>build: bump docker/build-push-action from 6.13.0 to 6.15.0 by <a href="https://github.com/dependabot"><code>@dependabot</code></a> in <a href="https://redirect.github.com/jidicula/clang-format-action/pull/233">jidicula/clang-format-action#233</a></li> <li>build: bump docker/metadata-action from 5.6.1 to 5.7.0 by <a href="https://github.com/dependabot"><code>@dependabot</code></a> in <a href="https://redirect.github.com/jidicula/clang-format-action/pull/234">jidicula/clang-format-action#234</a></li> <li>Add clang-format 20 image build by <a href="https://github.com/offa"><code>@offa</code></a> in <a href="https://redirect.github.com/jidicula/clang-format-action/pull/239">jidicula/clang-format-action#239</a></li> <li>build: Fix Ubuntu distro for clang-format-20 by <a href="https://github.com/jidicula"><code>@jidicula</code></a> in <a href="https://redirect.github.com/jidicula/clang-format-action/pull/240">jidicula/clang-format-action#240</a></li> <li>Add clang-format 20 by <a href="https://github.com/offa"><code>@offa</code></a> in <a href="https://redirect.github.com/jidicula/clang-format-action/pull/237">jidicula/clang-format-action#237</a></li> <li>docs: Prepare for v4.15.0 by <a href="https://github.com/jidicula"><code>@jidicula</code></a> in <a href="https://redirect.github.com/jidicula/clang-format-action/pull/241">jidicula/clang-format-action#241</a></li> </ul> <h2>New Contributors</h2> <ul> <li><a href="https://github.com/offa"><code>@offa</code></a> made their first contribution in <a href="https://redirect.github.com/jidicula/clang-format-action/pull/239">jidicula/clang-format-action#239</a> 🎉</li> </ul> <p><strong>Full Changelog</strong>: <a href="https://github.com/jidicula/clang-format-action/compare/v4.14.0...v4.15.0">https://github.com/jidicula/clang-format-action/compare/v4.14.0...v4.15.0</a></p> </blockquote> </details> <details> <summary>Commits</summary> <ul> <li><a href="4726374d1a"><code>4726374</code></a> docs: Prepare for v4.15.0 (<a href="https://redirect.github.com/jidicula/clang-format-action/issues/241">#241</a>)</li> <li><a href="da40ba9cab"><code>da40ba9</code></a> Add clang-format 20 (<a href="https://redirect.github.com/jidicula/clang-format-action/issues/237">#237</a>)</li> <li><a href="87adf5cde9"><code>87adf5c</code></a> build: Fix Ubuntu distro for clang-format-20 (<a href="https://redirect.github.com/jidicula/clang-format-action/issues/240">#240</a>)</li> <li><a href="69a43b0ead"><code>69a43b0</code></a> Add clang-format 20 image build (<a href="https://redirect.github.com/jidicula/clang-format-action/issues/239">#239</a>)</li> <li><a href="1781d20875"><code>1781d20</code></a> build: bump docker/metadata-action from 5.6.1 to 5.7.0 (<a href="https://redirect.github.com/jidicula/clang-format-action/issues/234">#234</a>)</li> <li><a href="c98140178a"><code>c981401</code></a> build: bump docker/build-push-action from 6.13.0 to 6.15.0 (<a href="https://redirect.github.com/jidicula/clang-format-action/issues/233">#233</a>)</li> <li><a href="06a6cbd3bb"><code>06a6cbd</code></a> build: bump docker/login-action from 3.3.0 to 3.4.0 (<a href="https://redirect.github.com/jidicula/clang-format-action/issues/238">#238</a>)</li> <li><a href="fbe58bf588"><code>fbe58bf</code></a> build: bump docker/build-push-action from 6.12.0 to 6.13.0 (<a href="https://redirect.github.com/jidicula/clang-format-action/issues/231">#231</a>)</li> <li><a href="a815d879b3"><code>a815d87</code></a> build: bump docker/build-push-action from 6.10.0 to 6.12.0 (<a href="https://redirect.github.com/jidicula/clang-format-action/issues/230">#230</a>)</li> <li><a href="bbe2072f30"><code>bbe2072</code></a> build: bump docker/build-push-action from 6.9.0 to 6.10.0 (<a href="https://redirect.github.com/jidicula/clang-format-action/issues/225">#225</a>)</li> <li>See full diff in <a href="https://github.com/jidicula/clang-format-action/compare/v4.14.0...v4.15.0">compare view</a></li> </ul> </details> <br /> [](https://docs.github.com/en/github/managing-security-vulnerabilities/about-dependabot-security-updates#about-compatibility-scores) Dependabot will resolve any conflicts with this PR as long as you don't alter it yourself. You can also trigger a rebase manually by commenting `@dependabot rebase`. [//]: # (dependabot-automerge-start) [//]: # (dependabot-automerge-end) --- <details> <summary>Dependabot commands and options</summary> <br /> You can trigger Dependabot actions by commenting on this PR: - `@dependabot rebase` will rebase this PR - `@dependabot recreate` will recreate this PR, overwriting any edits that have been made to it - `@dependabot merge` will merge this PR after your CI passes on it - `@dependabot squash and merge` will squash and merge this PR after your CI passes on it - `@dependabot cancel merge` will cancel a previously requested merge and block automerging - `@dependabot reopen` will reopen this PR if it is closed - `@dependabot close` will close this PR and stop Dependabot recreating it. You can achieve the same result by closing it manually - `@dependabot show <dependency name> ignore conditions` will show all of the ignore conditions of the specified dependency - `@dependabot ignore this major version` will close this PR and stop Dependabot creating any more for this major version (unless you reopen the PR or upgrade to it yourself) - `@dependabot ignore this minor version` will close this PR and stop Dependabot creating any more for this minor version (unless you reopen the PR or upgrade to it yourself) - `@dependabot ignore this dependency` will close this PR and stop Dependabot creating any more for this dependency (unless you reopen the PR or upgrade to it yourself) </details>
Windows User Space Emulator
A high-performance Windows process emulator that operates at syscall level, providing full control over process execution through comprehensive hooking capabilities.
Perfect for security research, malware analysis, and DRM research where fine-grained control over process execution is required.
Built in C++ and powered by the Unicorn Engine.
Key Features
- 🔄 Syscall-Level Emulation
- Instead of reimplementing Windows APIs, the emulator operates at the syscall level, allowing it to leverage existing system DLLs
- 📝 Advanced Memory Management
- Supports Windows-specific memory types including reserved, committed, built on top of Unicorn's memory management
- 📦 Complete PE Loading
- Handles executable and DLL loading with proper memory mapping, relocations, and TLS
- ⚡ Exception Handling
- Implements Windows structured exception handling (SEH) with proper exception dispatcher and unwinding support
- 🧵 Threading Support
- Provides a scheduled (round-robin) threading model
- 💾 State Management
- Supports both full state serialization and
fast in-memory snapshots(currently broken 😕)
- Supports both full state serialization and
- 💻 Debugging Interface
- Implements GDB serial protocol for integration with common debugging tools (IDA Pro, GDB, LLDB, VS Code, ...)
Note
The project is still in a very early, prototypical state. The code still needs a lot of cleanup and many features and syscalls need to be implemented. However, constant progress is being made :)
Preview
YouTube Overview
Click here for the slides.
Build Instructions
Prerequisites
- Windows 64-bit (click here for cross-platform status)
- CMake
- Git
Getting Started
Clone the repository with submodules:
git clone https://github.com/momo5502/emulator.git
cd emulator
git submodule update --init --recursive
Run the following commands in an x64 Development Command Prompt
Visual Studio 2022
cmake --preset=vs2022
Solution will be generated at build/vs2022/emulator.sln
Ninja
Debug build:
cmake --workflow --preset=debug
Release build:
cmake --workflow --preset=release
Dumping the Registry
The emulator needs a registry dump to run, otherwise it will print Bad hive file errors.
You can create one by running the src/tools/grab-registry.bat script as administrator.
This will create a registry folder that needs to be placed in the working directory of the emulator.
Running Tests
The project uses CTest for testing. Choose your preferred method:
Visual Studio:
- Build the
RUN_TESTStarget
Ninja:
cd build/release # or build/debug
ctest

