about summary refs log tree commit diff
path: root/frida_mode/test/osx-lib/harness2.c
diff options
context:
space:
mode:
authorvan Hauser <vh@thc.org>2021-07-27 12:01:48 +0200
committerGitHub <noreply@github.com>2021-07-27 12:01:48 +0200
commita772cb0d00dbe5607da930e0ddadcbb438535835 (patch)
tree82c5941cfde10552d72a9c4cb376d724fd98071a /frida_mode/test/osx-lib/harness2.c
parent30679edc1a3c04f386bfb96af33c65c0b818e9b8 (diff)
parent58636fd54e869f1b4c256529721a194ca6ce4e6d (diff)
downloadafl++-a772cb0d00dbe5607da930e0ddadcbb438535835.tar.gz
Merge pull request #1044 from WorksButNotTested/osx-lib
Osx lib
Diffstat (limited to 'frida_mode/test/osx-lib/harness2.c')
-rw-r--r--frida_mode/test/osx-lib/harness2.c40
1 files changed, 40 insertions, 0 deletions
diff --git a/frida_mode/test/osx-lib/harness2.c b/frida_mode/test/osx-lib/harness2.c
new file mode 100644
index 00000000..83983c99
--- /dev/null
+++ b/frida_mode/test/osx-lib/harness2.c
@@ -0,0 +1,40 @@
+#include <string.h>
+#include <assert.h>
+#include <stdio.h>
+#include <stdlib.h>
+#include <dlfcn.h>
+
+
+extern void crashme(const uint8_t *Data, size_t Size);
+
+int LLVMFuzzerTestOneInput(const unsigned char* data, size_t size){
+    crashme(data, size);
+    return 0;
+}
+
+void run (int argc, const char * argv[])
+{
+    for (int i = 1; i < argc; i++) {
+        fprintf(stderr, "Running: %s\n", argv[i]);
+        FILE *f = fopen(argv[i], "r");
+        assert(f);
+        fseek(f, 0, SEEK_END);
+        size_t len = ftell(f);
+        fseek(f, 0, SEEK_SET);
+        unsigned char *buf = (unsigned char*)malloc(len);
+        size_t n_read = fread(buf, 1, len, f);
+        fclose(f);
+        assert(n_read == len);
+        LLVMFuzzerTestOneInput(buf, len);
+        free(buf);
+        fprintf(stderr, "Done:    %s: (%zd bytes)\n", argv[i], n_read);
+    }
+}
+
+int main(int argc, const char * argv[])
+{
+
+    run(argc, argv);
+
+    return 0;
+}