aboutsummaryrefslogtreecommitdiff
path: root/examples/custom_mutators
diff options
context:
space:
mode:
authorvan Hauser <vh@thc.org>2020-05-12 16:32:40 +0200
committervan Hauser <vh@thc.org>2020-05-12 16:32:40 +0200
commit61779547733699dfe6710a74529e02d515364aa4 (patch)
treee790f66d634f78f329437fe5e98abb5f1453dd0f /examples/custom_mutators
parent7b40d7b9420b2e3adb7d9afa88610199718dedba (diff)
downloadafl++-61779547733699dfe6710a74529e02d515364aa4.tar.gz
fix custom mutators and add real test cases
Diffstat (limited to 'examples/custom_mutators')
-rw-r--r--examples/custom_mutators/README.md3
-rw-r--r--examples/custom_mutators/example.py1
-rw-r--r--examples/custom_mutators/simple_example.c74
3 files changed, 78 insertions, 0 deletions
diff --git a/examples/custom_mutators/README.md b/examples/custom_mutators/README.md
index 6fc7be6c..99fb9da3 100644
--- a/examples/custom_mutators/README.md
+++ b/examples/custom_mutators/README.md
@@ -6,6 +6,9 @@ See [docs/custom_mutators.md](../docs/custom_mutators.md) for more information
Note that if you compile with python3.7 you must use python3 scripts, and if
you use python2.7 to compile python2 scripts!
+simple_example.c - most simplest example. generates a random sized buffer
+ filled with 'A'
+
example.c - this is a simple example written in C and should be compiled to a
shared library. Use make to compile it and produce libexamplemutator.so
diff --git a/examples/custom_mutators/example.py b/examples/custom_mutators/example.py
index 9e95eed6..3c3fa8c1 100644
--- a/examples/custom_mutators/example.py
+++ b/examples/custom_mutators/example.py
@@ -21,6 +21,7 @@ COMMANDS = [
b"GET",
b"PUT",
b"DEL",
+ b"AAAAAAAAAAAAAAAAA",
]
diff --git a/examples/custom_mutators/simple_example.c b/examples/custom_mutators/simple_example.c
new file mode 100644
index 00000000..a351d787
--- /dev/null
+++ b/examples/custom_mutators/simple_example.c
@@ -0,0 +1,74 @@
+// This simple example just creates random buffer <= 100 filled with 'A'
+// needs -I /path/to/AFLplusplus/include
+#include "custom_mutator_helpers.h"
+
+#include <stdint.h>
+#include <stdlib.h>
+#include <string.h>
+#include <stdio.h>
+
+#ifndef _FIXED_CHAR
+ #define 0x41
+#endif
+
+typedef struct my_mutator {
+
+ afl_t *afl;
+
+ // Reused buffers:
+ BUF_VAR(u8, fuzz);
+
+} my_mutator_t;
+
+my_mutator_t *afl_custom_init(afl_t *afl, unsigned int seed) {
+
+ srand(seed);
+ my_mutator_t *data = calloc(1, sizeof(my_mutator_t));
+ if (!data) {
+
+ perror("afl_custom_init alloc");
+ return NULL;
+
+ }
+
+ data->afl = afl;
+
+ return data;
+
+}
+
+size_t afl_custom_fuzz(my_mutator_t *data, uint8_t *buf, size_t buf_size,
+ u8 **out_buf, uint8_t *add_buf,
+ size_t add_buf_size, // add_buf can be NULL
+ size_t max_size) {
+
+ int size = (rand() % 100) + 1;
+ if (size > max_size) size = max_size;
+ u8 *mutated_out = maybe_grow(BUF_PARAMS(data, fuzz), size);
+ if (!mutated_out) {
+
+ *out_buf = NULL;
+ perror("custom mutator allocation (maybe_grow)");
+ return 0; /* afl-fuzz will very likely error out after this. */
+
+ }
+
+ memset(mutated_out, _FIXED_CHAR, size);
+
+ *out_buf = mutated_out;
+ return size;
+
+}
+
+/**
+ * Deinitialize everything
+ *
+ * @param data The data ptr from afl_custom_init
+ */
+void afl_custom_deinit(my_mutator_t *data) {
+
+ free(data->fuzz_buf);
+ free(data);
+
+}
+