Fuzzer runs with argv information and uses k-means clustering to group seed.
Written and maintained by zodf0055980 <zodf0055980@gmail.com>
Based on American Fuzzy Lop by Michal Zalewski
There are a lot of command line arguments in the common binary, but common fuzzer only runs with one command line argument, so it cannot find some errors through the special command line. For instance, in CVE-2020-27843 I found, it have out of bound read with 8 argv and crafted input. Therefore, I made a fuzzer that can generate argv at runtime.
Yuan-fuzz is a fuzzer implementing a technique to generate argv in addition fuzzing stage named arg_gen. It can help to fuzz binary target that has a lot of argv can use.
It also can use k-means clustering to the group in the seed pool to improve seed selection, just like the k-means-AFL I made.
- Cannot use
-i -
to resume fuzzer. - Cannot use without
-s xmlfile
, maybe you can try k-means-AFL I made. - Allow use other format to write argv info file, likes json
- Release English paper, I did in traditional Chinese now.
If you have any other questions, you are welcome to create issue and I will try my best to solve them.
Install libxml2 first.
Build it.
$ make
Use -h
--help
to know target program options, and use it to write XML file to help fuzzing.
I give some XML examples here, maybe could help to write XML file.
We also implement our seed selection. You should open our seed selection server first if you want to use it.
$ python3 group_seed.py [port]
The command line usage of Yuan-fuzz is similar to AFL.
$ Yuan-fuzz -i [testcase_dir] -o [output_dir] -s [~/XML_PATH/parameters.xml] [-p [port]] -- [Target program]
I also implement two command that can help arg_gen stage.
-w - let file_path in front of argv
-r - argv random initial
Use libjpeg-turbo to be example.
$ git clone git@github.com:libjpeg-turbo/libjpeg-turbo.git
Build with instrumentation, you can use other compiler.
$ export CC=~/Yuan-fuzz/afl-gcc
$ export CXX=~/Yuan-fuzz/afl-g++
$ export AFL_USE_ASAN=1 ;
$ cd libjpeg-turbo
$ mkdir build && cd build
$ cmake -G"Unix Makefiles" ..
$ make
Run fuzzer
$ python3 group_seed.py 8888
# Another Terminal
$ Yuan-fuzz -i ./testcases/images/jpeg -o fuzz_output -m none -s ./xml/libjpeg-turbo/djpeg/parameters.xml -p 8888 -- ~/TARGET_PATH/libjpeg-turbo/build/djpeg
If your xml file have a lot of argv, maybe you have to change some define value in parse.h.
Yuan-fuzz can parallel fuzz with other afl-base fuzzer, likely AFLplusplus. However, Yuan-fuzz can only be used in -S mode. And please check argv information file is same with master run.
for example:
# afl++
$ ./afl-fuzz -i ./testcases/images/jpeg -o ~/jpeg-out -M master -m none -- ~/afl-target/libjpeg-turbo/build/djpeg -outfile /dev/null @@
# Yuan-fuzz
$ ./Yuan-fuzz -i ./testcases/images/jpeg -o ~/jpeg-out -S slave1 -m none -s ~/Yuan-fuzz/xml/libjpeg-turbo/djpeg/parameters.xml -- ~/afl-target/libjpeg-turbo/build/djpeg
It will have addition subdirectories created within the output directory and updated in real time.
- queue_info/queue
- queue_info/crashes
- queue_info/hangs
It save all seed running parameters and one-to-one correspondence with seed in queue, crashes, hangs subdirectories.
- libjpeg-turbo/libjpeg-turbo#441 (CVE-2020-35538)
- https://sourceware.org/bugzilla/show_bug.cgi?id=26774
- https://sourceware.org/bugzilla/show_bug.cgi?id=26805
- https://sourceware.org/bugzilla/show_bug.cgi?id=26809
- uclouvain/openjpeg#1283 (CVE-2020-27814)
- uclouvain/openjpeg#1284 (CVE-2020-27823)
- uclouvain/openjpeg#1286 (CVE-2020-27824)
- uclouvain/openjpeg#1293 (CVE-2020-27841)
- uclouvain/openjpeg#1294 (CVE-2020-27842)
- uclouvain/openjpeg#1297 (CVE-2020-27843)
- uclouvain/openjpeg#1299 (CVE-2020-27844)
- uclouvain/openjpeg#1302 (CVE-2020-27845)
- jasper-software/jasper#252 (CVE-2020-27828)
- jasper-software/jasper#263
- https://bugs.chromium.org/p/aomedia/issues/detail?id=2905&q=&can=1 (CVE-2020-36130)
- https://bugs.chromium.org/p/aomedia/issues/detail?id=2911&q=&can=1 (CVE-2020-36131)
- https://bugs.chromium.org/p/aomedia/issues/detail?id=2912&q=&can=1 (CVE-2020-36129)
- https://bugs.chromium.org/p/aomedia/issues/detail?id=2913&q=&can=1 (CVE-2020-36133)
- https://bugs.chromium.org/p/aomedia/issues/detail?id=2914&q=&can=1 (CVE-2020-36134)
- https://bugs.chromium.org/p/aomedia/issues/detail?id=2910&q=&can=1 (CVE-2020-36135)
- LibreDWG/libredwg#320
- LibreDWG/libredwg#323
- LibreDWG/libredwg#324 (CVE-2021-28236)
- LibreDWG/libredwg#321
- LibreDWG/libredwg#325 (CVE-2021-28237) (non release code-path)
- https://gitlab.gnome.org/GNOME/libxml2/-/issues/231 (CVE-2021-3516)
- https://gitlab.gnome.org/GNOME/libxml2/-/issues/235 (CVE-2021-3517)
- https://gitlab.gnome.org/GNOME/libxml2/-/issues/237 (CVE-2021-3518)
Use SQ-fuzz to modify.