A powerful LLVM plugin designed to bolster the security of Windows x64 native calls during the compilation process.
This innovative tool transparently applies stack spoofing and indirect syscalls, providing enhanced protection against potential threats.
LLVM plugin to transparently apply stack spoofing and indirect syscalls to Windows x64 native calls at compile time.
This project is a plugin meant to be used with opt, the LLVM optimizer.
Opt will use the pass included in this plugin to hook calls to Windows functions based on a config file and point those calls to a single function, which, given an ID identifying the function to be called, will apply dynamic stack obfuscation, and if the function is a syscall stub, will invoke it using “indirect syscalling”.
Usage brief: Set up a config file indicating the functions to be hooked, write your C code without caring about Windows function calls, compile with clang to generate .ir files, give them to opt along with this plugin, opt hooks functions, llc compiles the .ir to a.obj, and ld links it to an executable that automatically obfuscates function calls.
- Setup
- Usage and example
- Developer guide
- File distribution
- How the pass works
- How the dispatching system works
- Thanks
- TODO
This instructions are written for Windows, but it should be possible to setup this environment in Linux easily (still output executables can only be built for Windows x64). Tested with LLVM 16.x and 17.x.
All the commands described in the following steps are supossed to be used in an MSYS2 terminal ie they have Linux format.
pacman -S mingw-w64-x86_64-llvm
Install Clang: pacman -S mingw-w64-x86_64-clang
Install Nasm: pacman -S mingw-w64-x86_64-nasm
Install Cmake: pacman -S mingw-w64-x86_64-cmake
Install Ninja: pacman -S mingw-w64-x86_64-ninja
Install Git: pacman -S git
git clone https://github.com/janoglezcampos/llvm-yx-callobfuscator
To build this project, we will be using CMAKE. Because I find it convenient, I use VScode with the CMake extension. You can find my VSCODE config at .vscode_conf/setting.json
In any other case, launch an MSYS2 Mingw64 terminal and do exactly what I say (without checking what any of the commands Im giving you will do to your beloved machine):
Go to the root directory of this repo:
cd <whatever>/llvm-yx-obfuscator
Create a build directory and change the directory to it:
mkdir build; cd build
Choose an install location. I recommend doing this so it will be easier to either get the files in the right place or just be able to pick them up easily.
Also, the usage section will use this folder as the relative folder for accessing these files when needed, so if you add it to the PATH, the commands will work right away.
I use C:/Users/<my-user>/llvm-plugins
, but creating a folder in the project directory called install
, side by side with build
will do.
This folder will not be edited if you don’t run the install command, but you will have to go get the files in the build folder.
Configure the project; here you specify the installation folder. DCMAKE_BUILD_TYPE
will set the default mode: Debug, Release or MinSizeRel.
Depending on which generator you are using, you are going to be able to change this later or not (means you will have to reconfigure or not). I use Nija as generator, but you can use any other.
cmake -G Ninja -DCMAKE_INSTALL_PREFIX="<path_to_install_folder>" -DCMAKE_BUILD_TYPE=Release ./..
Build the project; optionally choose mode with —-config Release
(if your generator lets you):
cmake --build .
Move the generated files to the install directory you chose before.
If you don’t want to use the install “feature” of CMake, just get the files (libCallObfuscatorHelpers.a
and CallObfuscatorPlugin.dll
) from the build directory and put them in a place you remember; you will need them.
For more information click here
Prompt injection is a type of security vulnerability that can be exploited to control the…
Firefly is an advanced black-box fuzzer and not just a standard asset discovery tool. Firefly…
Winit is a robust, cross-platform library designed for creating and managing windows in Rust applications.…
In today’s digital age, convenience often comes at the cost of security. One such overlooked…
Terminal GPT (tgpt) offers a seamless way to bring the power of ChatGPT 3.5 directly…
garak checks if an LLM can be made to fail in a way we don't…