aboutsummaryrefslogtreecommitdiff
path: root/frida_mode/test
diff options
context:
space:
mode:
authorWorksButNotTested <62701594+WorksButNotTested@users.noreply.github.com>2021-05-17 19:02:45 +0100
committerGitHub <noreply@github.com>2021-05-17 20:02:45 +0200
commite40c0c2da16f14dfddb5641f6f825903879534a9 (patch)
tree363135f288fd63253471a0455ebadd24a512a1ce /frida_mode/test
parent9d50ae7468970412177c9e08edf7f32ff9fdf1ce (diff)
downloadafl++-e40c0c2da16f14dfddb5641f6f825903879534a9.tar.gz
FASAN Support (#918)
* FASAN Support * Fix handling of Address Sanitizer DSO * Changes to identification of Address Sanitizer DSO Co-authored-by: Your Name <you@example.com>
Diffstat (limited to 'frida_mode/test')
-rw-r--r--frida_mode/test/fasan/GNUmakefile156
-rw-r--r--frida_mode/test/fasan/Makefile18
-rw-r--r--frida_mode/test/fasan/test.c85
3 files changed, 259 insertions, 0 deletions
diff --git a/frida_mode/test/fasan/GNUmakefile b/frida_mode/test/fasan/GNUmakefile
new file mode 100644
index 00000000..22689395
--- /dev/null
+++ b/frida_mode/test/fasan/GNUmakefile
@@ -0,0 +1,156 @@
+PWD:=$(shell pwd)/
+ROOT:=$(shell realpath $(PWD)../../..)/
+BUILD_DIR:=$(PWD)build/
+
+TEST_DATA_DIR:=$(BUILD_DIR)in/
+TEST_DATA_FILE:=$(TEST_DATA_DIR)in
+FRIDA_OUT:=$(BUILD_DIR)frida-out
+
+TEST_SRC:=$(PWD)/test.c
+TEST_BIN:=$(BUILD_DIR)test
+
+CFLAGS+=-fPIC \
+ -D_GNU_SOURCE \
+ -g \
+ -fno-omit-frame-pointer \
+ -Wno-stringop-overflow \
+
+LDFLAGS+=-ldl \
+
+ifdef DEBUG
+CFLAGS+=-Werror \
+ -Wall \
+ -Wextra \
+ -Wpointer-arith
+else
+CFLAGS+=-Wno-pointer-arith
+endif
+
+ifndef ARCH
+
+ARCH=$(shell uname -m)
+ifeq "$(ARCH)" "aarch64"
+ ARCH:=arm64
+endif
+
+ifeq "$(ARCH)" "i686"
+ ARCH:=x86
+endif
+endif
+
+ifeq "$(ARCH)" "x86"
+LIBASAN_FILE:=libclang_rt.asan-i386.so
+endif
+
+ifeq "$(ARCH)" "x64"
+LIBASAN_FILE:=libclang_rt.asan-x86_64.so
+endif
+
+ifeq "$(ARCH)" "aarch64"
+LIBASAN_FILE:=libclang_rt.asan-aarch64.so
+endif
+
+# LIBASAN:=/usr/lib/llvm-10/lib/clang/10.0.0/lib/linux/libclang_rt.asan-x86_64.so
+# LIBASAN:=/usr/lib/x86_64-linux-gnu/libasan.so.6.0.0
+
+LLVM_CONFIG ?= llvm-config
+ifeq "$(shell test -e '$(shell which $(LLVM_CONFIG))' && echo 1)" "1"
+ $(info Found llvm-config: '$(shell which $(LLVM_CONFIG))')
+else
+ $(warning Cannot find llvm-config)
+endif
+
+LLVM_BINDIR = $(shell $(LLVM_CONFIG) --bindir 2>/dev/null)/
+$(info LLVM_BINDIR: $(LLVM_BINDIR))
+
+CLANG ?= $(LLVM_BINDIR)clang
+ifeq "$(shell test -e '$(CLANG)' && echo 1)" "1"
+ $(info Found clang: '$(CLANG)')
+else
+ $(warning Cannot find clang)
+endif
+
+CLANGVER = $(shell $(CLANG) --version | sed -E -ne '/^.*version\ (1?[0-9]\.[0-9]\.[0-9]).*/s//\1/p')
+$(info Clang version $(CLANGVER))
+
+LLVM_LIBDIR = $(shell $(LLVM_CONFIG) --libdir 2>/dev/null)
+$(info LLVM_LIBDIR: $(LLVM_LIBDIR))
+
+LIBASAN:=$(LLVM_LIBDIR)/clang/$(CLANGVER)/lib/linux/$(LIBASAN_FILE)
+
+ifeq "$(shell test -e '$(LIBASAN)' && echo 1)" "1"
+ $(info Found Address Sanitizer DSO: '$(LIBASAN)')
+else
+ $(error Error cannot find Address Sanitizer DSO)
+endif
+
+
+.PHONY: all clean format frida-noasan frida debug run
+
+############################## ALL #############################################
+
+all: $(TEST_BIN)
+
+$(TEST_BIN): $(TEST_SRC) GNUmakefile | $(BUILD_DIR)
+ $(CC) \
+ $(CFLAGS) \
+ $(LDFLAGS) \
+ -o $@ \
+ $<
+
+$(BUILD_DIR):
+ mkdir -p $(BUILD_DIR)
+
+############################# TESTS ############################################
+
+$(TEST_DATA_DIR): | $(BUILD_DIR)
+ mkdir -p $@
+
+$(TEST_DATA_FILE): | $(TEST_DATA_DIR)
+ echo -n "TUODATM" > $@
+
+frida-noasan: $(TEST_BIN) $(TEST_DATA_FILE)
+ $(ROOT)afl-fuzz \
+ -D \
+ -O \
+ -i $(TEST_DATA_DIR) \
+ -o $(FRIDA_OUT) \
+ -- \
+ $(TEST_BIN)
+
+
+frida: $(TEST_BIN) $(TEST_DATA_FILE)
+ AFL_PRELOAD=/usr/lib/llvm-10/lib/clang/10.0.0/lib/linux/libclang_rt.asan-x86_64.so \
+ AFL_USE_FASAN=1 \
+ $(ROOT)afl-fuzz \
+ -D \
+ -O \
+ -i $(TEST_DATA_DIR) \
+ -o $(FRIDA_OUT) \
+ -- \
+ $(TEST_BIN)
+
+debug: $(TEST_BIN) $(TEST_DATA_FILE)
+ gdb \
+ --ex 'set environment LD_PRELOAD=$(LIBASAN):$(ROOT)afl-frida-trace.so' \
+ --ex 'set environment ASAN_OPTIONS=detect_leaks=false,halt_on_error=0' \
+ --ex 'set environment AFL_USE_FASAN=1' \
+ --ex 'set disassembly-flavor intel' \
+ --ex 'r < $(TEST_DATA_FILE)' \
+ --args $(TEST_BIN) \
+
+run: $(TEST_BIN) $(TEST_DATA_FILE)
+ LD_PRELOAD=$(LIBASAN):$(ROOT)afl-frida-trace.so \
+ ASAN_OPTIONS=detect_leaks=false \
+ AFL_USE_FASAN=1 \
+ $(TEST_BIN) < $(TEST_DATA_FILE)
+
+############################# CLEAN ############################################
+clean:
+ rm -rf $(BUILD_DIR)
+
+############################# FORMAT ###########################################
+format:
+ cd $(ROOT) && echo $(TEST_SRC) | xargs -L1 ./.custom-format.py -i
+
+############################# RUN #############################################
diff --git a/frida_mode/test/fasan/Makefile b/frida_mode/test/fasan/Makefile
new file mode 100644
index 00000000..a7bf44c7
--- /dev/null
+++ b/frida_mode/test/fasan/Makefile
@@ -0,0 +1,18 @@
+all:
+ @echo trying to use GNU make...
+ @gmake all || echo please install GNUmake
+
+clean:
+ @gmake clean
+
+frida-noasan:
+ @gmake frida-noasan
+
+frida:
+ @gmake frida
+
+debug:
+ @gmake debug
+
+run:
+ @gmake run \ No newline at end of file
diff --git a/frida_mode/test/fasan/test.c b/frida_mode/test/fasan/test.c
new file mode 100644
index 00000000..a7d03017
--- /dev/null
+++ b/frida_mode/test/fasan/test.c
@@ -0,0 +1,85 @@
+#include <stdbool.h>
+#include <stdlib.h>
+#include <stdio.h>
+#include <stdint.h>
+#include <string.h>
+#include <unistd.h>
+
+#define LOG(x) \
+ do { \
+ \
+ char buf[] = x; \
+ write(STDOUT_FILENO, buf, sizeof(buf)); \
+ \
+ } while (false);
+
+void test(char data) {
+
+ char *buf = malloc(10);
+
+ if (buf == NULL) return;
+
+ switch (data) {
+
+ /* Underflow */
+ case 'U':
+ LOG("Underflow\n");
+ buf[-1] = '\0';
+ free(buf);
+ break;
+ /* Overflow */
+ case 'O':
+ LOG("Overflow\n");
+ buf[10] = '\0';
+ free(buf);
+ break;
+ /* Double free */
+ case 'D':
+ LOG("Double free\n");
+ free(buf);
+ free(buf);
+ break;
+ /* Use after free */
+ case 'A':
+ LOG("Use after free\n");
+ free(buf);
+ buf[0] = '\0';
+ break;
+ /* Test Limits (OK) */
+ case 'T':
+ LOG("Test-Limits - No Error\n");
+ buf[0] = 'A';
+ buf[9] = 'I';
+ free(buf);
+ break;
+ case 'M':
+ LOG("Memset too many\n");
+ memset(buf, '\0', 11);
+ free(buf);
+ break;
+ default:
+ LOG("Nop - No Error\n");
+ break;
+
+ }
+
+}
+
+int main(int argc, char **argv) {
+
+ char input = '\0';
+
+ if (read(STDIN_FILENO, &input, 1) < 0) {
+
+ LOG("Failed to read stdin\n");
+ return 1;
+
+ }
+
+ test(input);
+
+ LOG("DONE\n");
+ return 0;
+
+}
+