aboutsummaryrefslogtreecommitdiff
path: root/instrumentation
diff options
context:
space:
mode:
Diffstat (limited to 'instrumentation')
-rw-r--r--instrumentation/afl-compiler-rt.o.c31
1 files changed, 29 insertions, 2 deletions
diff --git a/instrumentation/afl-compiler-rt.o.c b/instrumentation/afl-compiler-rt.o.c
index db7ac7b0..b94e3dc9 100644
--- a/instrumentation/afl-compiler-rt.o.c
+++ b/instrumentation/afl-compiler-rt.o.c
@@ -327,6 +327,31 @@ static void __afl_map_shm(void) {
}
+ if (!id_str) {
+
+ u32 val = 0;
+ u8 *ptr;
+
+ if ((ptr = getenv("AFL_MAP_SIZE")) != NULL) val = atoi(ptr);
+
+ if (val > MAP_INITIAL_SIZE) {
+
+ __afl_map_size = val;
+ __afl_final_loc = val;
+ __afl_area_ptr_dummy = malloc(__afl_map_size);
+ if (!__afl_area_ptr_dummy) {
+
+ fprintf(stderr,
+ "Error: AFL++ could not aquire %u bytes of memory, exiting!\n",
+ __afl_map_size);
+ exit(-1);
+
+ }
+
+ }
+
+ }
+
/* If we're running under AFL, attach to the appropriate region, replacing the
early-stage __afl_area_initial region that is needed to allow some really
hacky .init code to work correctly in projects such as OpenSSL. */
@@ -465,7 +490,9 @@ static void __afl_map_shm(void) {
}
- } else if (_is_sancov && __afl_area_ptr != __afl_area_initial) {
+ } else if (_is_sancov && __afl_area_ptr != __afl_area_initial &&
+
+ __afl_area_ptr != __afl_area_ptr_dummy) {
free(__afl_area_ptr);
__afl_area_ptr = NULL;
@@ -487,7 +514,7 @@ static void __afl_map_shm(void) {
fprintf(stderr,
"DEBUG: (2) id_str %s, __afl_area_ptr %p, __afl_area_initial %p, "
"__afl_area_ptr_dummy %p, __afl_map_addr 0x%llx, MAP_SIZE "
- "%u, __afl_final_loc %u, __afl_map_size %u,"
+ "%u, __afl_final_loc %u, __afl_map_size %u, "
"max_size_forkserver %u/0x%x\n",
id_str == NULL ? "<null>" : id_str, __afl_area_ptr,
__afl_area_initial, __afl_area_ptr_dummy, __afl_map_addr, MAP_SIZE,