UniFuzzer is a fuzzing tool for closed-source binaries based on Unicorn and LibFuzzer. Currently it supports fuzzing 32-bits LSB ELF files on ARM/MIPS, which are usually seen in IoT devices.
Features
.c
file in the directory callback
, which should contain the following callbacks:void onLibLoad(const char *libName, void *baseAddr, void *ucBaseAddr)
: It’s invoked each time an dependent library is loaded in Unicorn.int uniFuzzerInit(uc_engine *uc)
: It’s invoked just after all the binaries been loaded in Unicorn. Stack/heap/registers can be setup up here.int uniFuzzerBeforeExec(uc_engine *uc, const uint8_t *data, size_t len)
: It’s invoked before each round of fuzzing execution.int uniFuzzerAfterExec(uc_engine *uc)
: It’s invoked after each round of fuzzing execution.Also Read – ISPY : Eternalblue/Bluekeep Scanner & Exploit
make
and get the fuzzing tool named uf
.uniFuzzer uses the following environment variables as parameters:
UF_TARGET
: Path of the target ELF fileUF_PRELOAD
: Path of the preload library. Please make sure that the library has the same architecture as the target.UF_LIBPATH
: Paths in which the dependent libraries reside. Use :
to separate multiple paths.And the fuzzing can be started using the following command:
UF_TARGET=<target> [UF_PRELOAD=<preload>] UF_LIBPATH=<libPath> ./uf
There comes a demo for basic usage. The demo contains the following files:
vuln()
which is vulnerable to stack/heap overflow.printf()
and simplified malloc()/free()
.vuln()
function.First, please install gcc for mipsel (package gcc-mipsel-linux-gnu
on Debian) to build the demo:
# the target binary
# ‘-Xlinker –hash-style=sysv’ tells gcc to use ‘DT_HASH’ instead of ‘DT_GNU_HASH’ for symbol lookup
# since currently uniFuzzer does not support ‘DT_GNU_HASH’ mipsel-linux-gnu-gcc demo-vuln.c -Xlinker –hash-style=sysv -no-pie -o demo-vuln
# the preload library mipsel-linux-gnu-gcc -shared -fPIC -nostdlib -Xlinker –hash-style=sysv demo-libcpreload.c -o demo-libcpreload.so
Or you can just use the file demo-vuln
and demo-libcpreload.so
, which are compiled using the commands above.
Next, run make
to build uniFuzzer. Please note that if you compiled the MIPS demo by yourself, then some addresses might be different from the prebuilt one and demo-callback.c
should be updated accordingly.
Finally, make sure that the libc library of MIPS is ready. On Debian it’s in /usr/mipsel-linux-gnu/lib/
after installing the package libc6-mipsel-cross
, and that’s what UF_LIBPATH
should be:
UF_TARGET=<path to demo-vuln> UF_PRELOAD=<path to demo-libcpreload.so> UF_LIBPATH=<lib path for MIPS> ./uf
Unicorn clears the JIT cache of QEMU due to this issue, which slows down the speed of fuzzing since the target binary would have to be JIT re-compiled during each round of execution.
We can comment out tb_flush(env);
as stated in that issue for performance.
GNU_HASH
IFUNC
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…