about summary refs log tree commit diff
path: root/custom_mutators/gramatron/README.md
blob: 8aa0cc44b9f94df6370ec2ed206b81d53c9d7a6a (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
# GramaTron

GramaTron is a coverage-guided fuzzer that uses grammar automatons to perform
grammar-aware fuzzing.  Technical details about our framework are available in
the [ISSTA'21 paper](https://nebelwelt.net/files/21ISSTA.pdf). The artifact to
reproduce the experiments presented in the paper are present in `artifact/`.
Instructions to run a sample campaign and incorporate new grammars is presented
below:

## Compiling

Execute `./build_gramatron_mutator.sh`.

## Running

You have to set the grammar file to use with `GRAMATRON_AUTOMATION`:

```
export AFL_DISABLE_TRIM=1
export AFL_CUSTOM_MUTATOR_ONLY=1
export AFL_CUSTOM_MUTATOR_LIBRARY=./gramatron.so
export GRAMATRON_AUTOMATION=grammars/ruby/source_automata.json
afl-fuzz -i in -o out -- ./target
```

## Adding and testing a new grammar

- Specify in a JSON format for CFG. Examples are correspond `source.json` files.
- Run the automaton generation script (in `src/gramfuzz-mutator/preprocess`)
  which will place the generated automaton in the same folder.

  ```
  ./preprocess/prep_automaton.sh <grammar_file> <start_symbol> [stack_limit]

  E.g., ./preprocess/prep_automaton.sh ~/grammars/ruby/source.json PROGRAM
  ```

- If the grammar has no self-embedding rules, then you do not need to pass the
  stack limit parameter. However, if it does have self-embedding rules, then you
  need to pass the stack limit parameter. We recommend starting with `5` and
  then increasing it if you need more complexity.
- To sanity-check that the automaton is generating inputs as expected, you can
  use the `test` binary housed in `src/gramfuzz-mutator`.

  ```
  ./test SanityCheck <automaton_file>

  E.g., ./test SanityCheck ~/grammars/ruby/source_automata.json
  ```