aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorvan Hauser <vh@thc.org>2020-08-07 11:10:17 +0200
committervan Hauser <vh@thc.org>2020-08-07 11:10:17 +0200
commit5b0616614433b87b96bc72951b9a0828974e8a4e (patch)
tree06cd6cb019af7eff39c7778bab7ad4c5a000a571
parenta0fab35bbf8454c0421f7c5c5e6076f0e05b67a7 (diff)
downloadafl++-5b0616614433b87b96bc72951b9a0828974e8a4e.tar.gz
reverse cmplog temps
-rw-r--r--examples/aflpp_driver/aflpp_driver.c23
-rw-r--r--llvm_mode/afl-llvm-rt.o.c19
2 files changed, 23 insertions, 19 deletions
diff --git a/examples/aflpp_driver/aflpp_driver.c b/examples/aflpp_driver/aflpp_driver.c
index 90f9cf99..7d388799 100644
--- a/examples/aflpp_driver/aflpp_driver.c
+++ b/examples/aflpp_driver/aflpp_driver.c
@@ -106,11 +106,11 @@ If 1, close stdout at startup. If 2 close stderr; if 3 close both.
#error "Support for your platform has not been implemented"
#endif
-int __afl_sharedmem_fuzzing = 1;
-extern unsigned int * __afl_fuzz_len;
-extern unsigned char * __afl_fuzz_ptr;
-extern unsigned char * __afl_area_ptr;
-extern struct cmp_map *__afl_cmp_map;
+int __afl_sharedmem_fuzzing = 1;
+extern unsigned int * __afl_fuzz_len;
+extern unsigned char *__afl_fuzz_ptr;
+extern unsigned char *__afl_area_ptr;
+// extern struct cmp_map *__afl_cmp_map;
// libFuzzer interface is thin, so we don't include any libFuzzer headers.
int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size);
@@ -248,8 +248,9 @@ static int ExecuteFilesOnyByOne(int argc, char **argv) {
}
-__attribute__((constructor(10))) void __afl_protect(void) {
+__attribute__((constructor(1))) void __afl_protect(void) {
+ setenv("__AFL_DEFER_FORKSRV", "1", 1);
__afl_area_ptr = (unsigned char *)mmap(
(void *)0x10000, MAX_DUMMY_SIZE, PROT_READ | PROT_WRITE,
MAP_FIXED_NOREPLACE | MAP_SHARED | MAP_ANONYMOUS, -1, 0);
@@ -261,7 +262,7 @@ __attribute__((constructor(10))) void __afl_protect(void) {
__afl_area_ptr =
(unsigned char *)mmap(NULL, MAX_DUMMY_SIZE, PROT_READ | PROT_WRITE,
MAP_SHARED | MAP_ANONYMOUS, -1, 0);
- __afl_cmp_map = (struct cmp_map *)__afl_area_ptr;
+ // __afl_cmp_map = (struct cmp_map *)__afl_area_ptr;
}
@@ -305,14 +306,11 @@ int main(int argc, char **argv) {
printf("WARNING: using the deprecated call style `%s %d`\n", argv[0], N);
else if (argc > 1) {
- // if (!getenv("AFL_DRIVER_DONT_DEFER")) {
-
__afl_sharedmem_fuzzing = 0;
- munmap(__afl_area_ptr, MAX_DUMMY_SIZE);
+ munmap(__afl_area_ptr, MAX_DUMMY_SIZE); // we need to free 0x10000
+ __afl_area_ptr = NULL;
__afl_manual_init();
- // }
return ExecuteFilesOnyByOne(argc, argv);
- exit(0);
}
@@ -320,6 +318,7 @@ int main(int argc, char **argv) {
// if (!getenv("AFL_DRIVER_DONT_DEFER"))
munmap(__afl_area_ptr, MAX_DUMMY_SIZE);
+ __afl_area_ptr = NULL;
__afl_manual_init();
// Call LLVMFuzzerTestOneInput here so that coverage caused by initialization
diff --git a/llvm_mode/afl-llvm-rt.o.c b/llvm_mode/afl-llvm-rt.o.c
index 3e5db87d..22c34ae8 100644
--- a/llvm_mode/afl-llvm-rt.o.c
+++ b/llvm_mode/afl-llvm-rt.o.c
@@ -101,7 +101,7 @@ __thread u32 __afl_cmp_counter;
int __afl_sharedmem_fuzzing __attribute__((weak));
-struct cmp_map *__afl_cmp_map = (struct cmp_map *)__afl_area_initial;
+struct cmp_map *__afl_cmp_map;
/* Running in persistent mode? */
@@ -183,6 +183,11 @@ static void __afl_map_shm_fuzz() {
static void __afl_map_shm(void) {
+ // we we are not running in afl ensure the map exists
+ fprintf(stderr, "Was: %p\n", __afl_area_ptr);
+ if (!__afl_area_ptr) __afl_area_ptr = __afl_area_initial;
+ fprintf(stderr, "Is: %p\n", __afl_area_ptr);
+
char *id_str = getenv(SHM_ENV_VAR);
if (__afl_final_loc) {
@@ -943,7 +948,7 @@ void __sanitizer_cov_trace_pc_guard_init(uint32_t *start, uint32_t *stop) {
void __cmplog_ins_hook1(uint8_t arg1, uint8_t arg2) {
- if (unlikely(!__afl_cmp_map || (u8 *)__afl_cmp_map == __afl_area_ptr)) return;
+ if (unlikely(!__afl_cmp_map)) return;
uintptr_t k = (uintptr_t)__builtin_return_address(0);
k = (k >> 4) ^ (k << 8);
@@ -966,7 +971,7 @@ void __cmplog_ins_hook1(uint8_t arg1, uint8_t arg2) {
void __cmplog_ins_hook2(uint16_t arg1, uint16_t arg2) {
- if (!__afl_cmp_map) return;
+ if (unlikely(!__afl_cmp_map)) return;
uintptr_t k = (uintptr_t)__builtin_return_address(0);
k = (k >> 4) ^ (k << 8);
@@ -987,7 +992,7 @@ void __cmplog_ins_hook2(uint16_t arg1, uint16_t arg2) {
void __cmplog_ins_hook4(uint32_t arg1, uint32_t arg2) {
- if (unlikely(!__afl_cmp_map || (u8 *)__afl_cmp_map == __afl_area_ptr)) return;
+ if (unlikely(!__afl_cmp_map)) return;
uintptr_t k = (uintptr_t)__builtin_return_address(0);
k = (k >> 4) ^ (k << 8);
@@ -1008,7 +1013,7 @@ void __cmplog_ins_hook4(uint32_t arg1, uint32_t arg2) {
void __cmplog_ins_hook8(uint64_t arg1, uint64_t arg2) {
- if (unlikely(!__afl_cmp_map || (u8 *)__afl_cmp_map == __afl_area_ptr)) return;
+ if (unlikely(!__afl_cmp_map)) return;
uintptr_t k = (uintptr_t)__builtin_return_address(0);
k = (k >> 4) ^ (k << 8);
@@ -1059,7 +1064,7 @@ void __sanitizer_cov_trace_cmp8(uint64_t arg1, uint64_t arg2)
void __sanitizer_cov_trace_switch(uint64_t val, uint64_t *cases) {
- if (unlikely(!__afl_cmp_map || (u8 *)__afl_cmp_map == __afl_area_ptr)) return;
+ if (unlikely(!__afl_cmp_map)) return;
for (uint64_t i = 0; i < cases[0]; i++) {
@@ -1098,7 +1103,7 @@ static int area_is_mapped(void *ptr, size_t len) {
void __cmplog_rtn_hook(u8 *ptr1, u8 *ptr2) {
- if (unlikely(!__afl_cmp_map || (u8 *)__afl_cmp_map == __afl_area_ptr)) return;
+ if (unlikely(!__afl_cmp_map)) return;
if (!area_is_mapped(ptr1, 32) || !area_is_mapped(ptr2, 32)) return;