/Cheng-fuzz

Fuzzing with the generated argument and environment variable

Primary LanguageCApache License 2.0Apache-2.0

Cheng-fuzz

Fuzzing with the generated argument and environment variable. It is based on Yuan-fuzz and Qiling example. You can see more detail in it.

Architecture

  • White Area: Original AFL++
  • Green Area: Pre-processing and Qiling harness

We based on the multi-argument fuzz testing method proposed by SQ-Fuzz and Yuan-Fuzz to generate the command-line arguments in the mutation stage of AFL++. The method can test the environment variables of the target, and we pass the information through forkserver and set it so that the overall performance can be compatible with that of the AFL++.

We perform complete fuzz testing with little performance penalty on MIPS architecture by integrating the environment variable and combinations of parameters with the Qiling framework.

Usage

Install libxml2 / Qiling v1.2.4 / Ghidra 10.1.1 / radare2 first.

Then, the same installation method as AFL++(v3.15a). (Of course, you should install some dependent packages)

Build it like this:

$ make distrib

The command line usage of Cheng-fuzz is similar to Yuan-fuzz.

# Compile the target program
$ export CC=~/Cheng-fuzz/afl-clang-fast
$ export CXX=~/Cheng-fuzz/afl-clang-fast++
$ export AFL_LLVM_INSTRUMENT=AFL
$ export AFL_USE_ASAN=1
$ ./configure --disable-shared
$ make

# Fuzzing
$ ./afl-fuzz -i [testcase_dir] -o [out_dir] -k [~/XML_PATH/parameters.xml] -m none -- [Target program]

If you want to use Qiling harness and Unicorn-mode:

$ ./afl-fuzz -i [testcase_dir] -o [out_dir] -m none -U -- python3 qiling_harness.py @@

Of course you need to make modest changes to qiling_harness.py and config/wufuzz.cfg.

Basic xml Rule

Cheng-fuzz's xml rule is different from Yuan-fuzz. Here is a simple example.

<root>
    <ARGUMENT>
        <MUST>false</MUST>
        <ELEMENT>rot</ELEMENT>
        <ELEMENT>flip</ELEMENT>
    </ARGUMENT>
    <ARGUMENT>
        <MUST>true</MUST>
        <ELEMENT>@@</ELEMENT>
    </ARGUMENT>
    <ARGUMENT>
        <MUST>false</MUST>
        <ELEMENT>-i 10</ELEMENT>
        <ELEMENT>-i 100</ELEMENT>
    </ARGUMENT>
    <ENVIRONMENT>
        <NAME>ENV1</NAME>
        <MUST>true</MUST>
        <ELEMENT>VALUE_1</ELEMENT>
        <ELEMENT>VALUE_2</ELEMENT>
    </ENVIRONMENT>
    <ENVIRONMENT>
        <NAME>ENV2</NAME>
        <MUST>false</MUST>
        <ELEMENT>VALUE2_1</ELEMENT>
    </ENVIRONMENT>
</root>

Difference:

Bug Reported

libsixel

  1. libsixel/libsixel#25 (CVE-2021-40656)
  2. libsixel/libsixel#27 (CVE-2021-41715)
  3. saitoha/libsixel#156 (CVE-2022-27044)
  4. saitoha/libsixel#157 (CVE-2022-27046)

Bento4

  1. axiomatic-systems/Bento4#708 (CVE-2022-31282)
  2. axiomatic-systems/Bento4#702 (CVE-2022-31285)
  3. axiomatic-systems/Bento4#703 (CVE-2022-31287)
  4. axiomatic-systems/Bento4#704
  5. axiomatic-systems/Bento4#705
  6. axiomatic-systems/Bento4#706
  7. axiomatic-systems/Bento4#707
  8. axiomatic-systems/Bento4#709

Thanks

Use SQ-fuzz, Yuan-fuzz and AFLplusplus to modify.