aboutsummaryrefslogtreecommitdiff
path: root/include
diff options
context:
space:
mode:
authorvan Hauser <vh@thc.org>2020-10-10 10:36:48 +0200
committerGitHub <noreply@github.com>2020-10-10 10:36:48 +0200
commitc075003bd24f476347c665c49a5fb438ba055668 (patch)
tree60048085f605ed408d88f0f52339596f89199e74 /include
parent1ab83d7d893e6d8259e3212316a4b0912b630b22 (diff)
parent4cb4772e2af9511c2320de833a81bc43500cef14 (diff)
downloadafl++-c075003bd24f476347c665c49a5fb438ba055668.tar.gz
Merge pull request #571 from Edznux/statsd_implem
Statsd support implementation
Diffstat (limited to 'include')
-rw-r--r--include/afl-fuzz.h25
-rw-r--r--include/config.h8
-rw-r--r--include/envs.h4
3 files changed, 35 insertions, 2 deletions
diff --git a/include/afl-fuzz.h b/include/afl-fuzz.h
index fb661ce5..e9d148e9 100644
--- a/include/afl-fuzz.h
+++ b/include/afl-fuzz.h
@@ -65,6 +65,8 @@
#include <dlfcn.h>
#include <sched.h>
+#include <netdb.h>
+
#include <sys/wait.h>
#include <sys/time.h>
#ifndef USEMMAP
@@ -76,6 +78,7 @@
#include <sys/mman.h>
#include <sys/ioctl.h>
#include <sys/file.h>
+#include <sys/types.h>
#if defined(__APPLE__) || defined(__FreeBSD__) || defined(__OpenBSD__) || \
defined(__NetBSD__) || defined(__DragonFly__)
@@ -352,11 +355,12 @@ typedef struct afl_env_vars {
afl_dumb_forksrv, afl_import_first, afl_custom_mutator_only, afl_no_ui,
afl_force_ui, afl_i_dont_care_about_missing_crashes, afl_bench_just_one,
afl_bench_until_crash, afl_debug_child_output, afl_autoresume,
- afl_cal_fast, afl_cycle_schedules, afl_expand_havoc;
+ afl_cal_fast, afl_cycle_schedules, afl_expand_havoc, afl_statsd;
u8 *afl_tmpdir, *afl_custom_mutator_library, *afl_python_module, *afl_path,
*afl_hang_tmout, *afl_forksrv_init_tmout, *afl_skip_crashes, *afl_preload,
- *afl_max_det_extras;
+ *afl_max_det_extras, *afl_statsd_host, *afl_statsd_port,
+ *afl_statsd_tags_flavor;
} afl_env_vars_t;
@@ -634,6 +638,16 @@ typedef struct afl_state {
u64 plot_prev_qc, plot_prev_uc, plot_prev_uh, plot_prev_ed;
u64 stats_last_stats_ms, stats_last_plot_ms, stats_last_ms, stats_last_execs;
+
+ /* StatsD */
+ u64 statsd_last_send_ms;
+ struct sockaddr_in statsd_server;
+ int statsd_sock;
+ char * statsd_tags_flavor;
+ char * statsd_tags_format;
+ char * statsd_metric_format;
+ int statsd_metric_format_type;
+
double stats_avg_exec;
u8 *clean_trace;
@@ -957,6 +971,13 @@ void maybe_update_plot_file(afl_state_t *, double, double);
void show_stats(afl_state_t *);
void show_init_stats(afl_state_t *);
+/* StatsD */
+
+void statsd_setup_format(afl_state_t *afl);
+int statsd_socket_init(afl_state_t *afl);
+int statsd_send_metric(afl_state_t *afl);
+int statsd_format_metric(afl_state_t *afl, char *buff, size_t bufflen);
+
/* Run */
fsrv_run_result_t fuzz_run_target(afl_state_t *, afl_forkserver_t *fsrv, u32);
diff --git a/include/config.h b/include/config.h
index 5df604e7..7dd045e3 100644
--- a/include/config.h
+++ b/include/config.h
@@ -41,6 +41,14 @@
#define USE_COLOR
+/* StatsD config
+ Config can be adjusted via AFL_STATSD_HOST and AFL_STATSD_PORT environment
+ variable.
+*/
+#define STATSD_UPDATE_SEC 1
+#define STATSD_DEFAULT_PORT 8125
+#define STATSD_DEFAULT_HOST "127.0.0.1"
+
/* If you want to have the original afl internal memory corruption checks.
Disabled by default for speed. it is better to use "make ASAN_BUILD=1". */
diff --git a/include/envs.h b/include/envs.h
index 3a06aa2a..51520312 100644
--- a/include/envs.h
+++ b/include/envs.h
@@ -135,6 +135,10 @@ static char *afl_environment_variables[] = {
"AFL_SKIP_BIN_CHECK",
"AFL_SKIP_CPUFREQ",
"AFL_SKIP_CRASHES",
+ "AFL_STATSD",
+ "AFL_STATSD_HOST",
+ "AFL_STATSD_PORT",
+ "AFL_STATSD_TAGS_FLAVOR",
"AFL_TMIN_EXACT",
"AFL_TMPDIR",
"AFL_TOKEN_FILE",