about summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--include/afl-fuzz.h9
-rw-r--r--src/afl-fuzz-init.c33
2 files changed, 39 insertions, 3 deletions
diff --git a/include/afl-fuzz.h b/include/afl-fuzz.h
index 4912b3f0..ff26c894 100644
--- a/include/afl-fuzz.h
+++ b/include/afl-fuzz.h
@@ -78,8 +78,15 @@
 /* For systems that have sched_setaffinity; right now just Linux, but one
    can hope... */
 
-#ifdef __linux__
+#if defined (__linux__) || defined(__FreeBSD__)
 #define HAVE_AFFINITY 1
+#if defined(__FreeBSD__)
+#include <sys/cpuset.h>
+#include <sys/user.h>
+#include <pthread.h>
+#include <pthread_np.h>
+#define cpu_set_t cpuset_t
+#endif
 #endif                                                         /* __linux__ */
 
 #ifndef SIMPLE_FILES
diff --git a/src/afl-fuzz-init.c b/src/afl-fuzz-init.c
index de16f901..cb340107 100644
--- a/src/afl-fuzz-init.c
+++ b/src/afl-fuzz-init.c
@@ -32,8 +32,6 @@
 
 void bind_to_free_cpu(void) {
 
-  DIR*           d;
-  struct dirent* de;
   cpu_set_t      c;
 
   u8  cpu_used[4096] = {0};
@@ -48,6 +46,9 @@ void bind_to_free_cpu(void) {
 
   }
 
+#if defined(__linux__)
+  DIR*           d;
+  struct dirent* de;
   d = opendir("/proc");
 
   if (!d) {
@@ -112,6 +113,30 @@ void bind_to_free_cpu(void) {
   }
 
   closedir(d);
+#elif defined(__FreeBSD__)
+  struct kinfo_proc *procs;
+  size_t nprocs;
+  size_t proccount;
+  int s_name[] = {CTL_KERN, KERN_PROC, KERN_PROC_ALL};
+  size_t s_name_l = sizeof(s_name)/sizeof(s_name[0]);
+
+  if (sysctl(s_name, s_name_l, NULL, &nprocs, NULL, 0) != 0) return;
+  proccount = nprocs / sizeof(*procs);
+  nprocs = nprocs * 4/3;
+
+  procs = ck_alloc(nprocs);
+  if (sysctl(s_name, s_name_l, procs, &nprocs, NULL, 0) != 0) {
+    ck_free(procs);
+    return;
+  }
+
+  for (i = 0; i < proccount; i ++) {
+     if (procs[i].ki_oncpu < sizeof(cpu_used))
+       cpu_used[procs[i].ki_oncpu] = 1;
+  }
+
+  ck_free(procs);
+#endif
 
   for (i = 0; i < cpu_core_count; ++i)
     if (!cpu_used[i]) break;
@@ -138,7 +163,11 @@ void bind_to_free_cpu(void) {
   CPU_ZERO(&c);
   CPU_SET(i, &c);
 
+#if defined(__linux__)
   if (sched_setaffinity(0, sizeof(c), &c)) PFATAL("sched_setaffinity failed");
+#elif defined(__FreeBSD__)
+  if (pthread_setaffinity_np(pthread_self(), sizeof(c), &c)) PFATAL("pthread_setaffinity failed");
+#endif
 
 }