aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorvan Hauser <vh@thc.org>2020-12-08 11:07:11 +0100
committervan Hauser <vh@thc.org>2020-12-08 11:07:11 +0100
commit46156957bd120dc8d8bcd9da72f83574902c654f (patch)
tree2d45a69204f0ba0d1353f9d29fbfc159829eddad
parent2f4166d5d6aca701e5583afe2421284e492d2446 (diff)
downloadafl++-46156957bd120dc8d8bcd9da72f83574902c654f.tar.gz
fix aflfast changes
-rw-r--r--include/afl-fuzz.h2
-rw-r--r--src/afl-fuzz-one.c11
-rw-r--r--src/afl-fuzz-queue.c73
-rw-r--r--utils/aflpp_driver/aflpp_qemu_driver.c2
4 files changed, 61 insertions, 27 deletions
diff --git a/include/afl-fuzz.h b/include/afl-fuzz.h
index 6ce032df..2f2d31d3 100644
--- a/include/afl-fuzz.h
+++ b/include/afl-fuzz.h
@@ -169,7 +169,7 @@ struct queue_entry {
u32 tc_ref; /* Trace bytes ref count */
double perf_score, /* performance score */
- weight;
+ weight;
u8 *testcase_buf; /* The testcase buffer, if loaded. */
diff --git a/src/afl-fuzz-one.c b/src/afl-fuzz-one.c
index a48afffb..e6fa6064 100644
--- a/src/afl-fuzz-one.c
+++ b/src/afl-fuzz-one.c
@@ -445,10 +445,13 @@ u8 fuzz_one_original(afl_state_t *afl) {
if (unlikely(afl->not_on_tty)) {
- ACTF("Fuzzing test case #%u (%u total, %llu uniq crashes found, perf_score=%0.0f, exec_us=%llu, hits=%u, map=%u)...",
- afl->current_entry, afl->queued_paths, afl->unique_crashes,
- afl->queue_cur->perf_score, afl->queue_cur->exec_us,
- afl->n_fuzz[afl->queue_cur->n_fuzz_entry], afl->queue_cur->bitmap_size);
+ ACTF(
+ "Fuzzing test case #%u (%u total, %llu uniq crashes found, "
+ "perf_score=%0.0f, exec_us=%llu, hits=%u, map=%u)...",
+ afl->current_entry, afl->queued_paths, afl->unique_crashes,
+ afl->queue_cur->perf_score, afl->queue_cur->exec_us,
+ likely(afl->n_fuzz) ? afl->n_fuzz[afl->queue_cur->n_fuzz_entry] : 0,
+ afl->queue_cur->bitmap_size);
fflush(stdout);
}
diff --git a/src/afl-fuzz-queue.c b/src/afl-fuzz-queue.c
index 1e997c55..071e4a4c 100644
--- a/src/afl-fuzz-queue.c
+++ b/src/afl-fuzz-queue.c
@@ -42,7 +42,8 @@ inline u32 select_next_queue_entry(afl_state_t *afl) {
}
-double compute_weight(afl_state_t *afl, struct queue_entry *q, double avg_exec_us, double avg_bitmap_size) {
+double compute_weight(afl_state_t *afl, struct queue_entry *q,
+ double avg_exec_us, double avg_bitmap_size) {
u32 hits = afl->n_fuzz[q->n_fuzz_entry];
if (hits == 0) hits = 1;
@@ -55,13 +56,15 @@ double compute_weight(afl_state_t *afl, struct queue_entry *q, double avg_exec_u
if (q->favored) weight *= 5;
return weight;
+
}
/* create the alias table that allows weighted random selection - expensive */
void create_alias_table(afl_state_t *afl) {
- u32 n = afl->queued_paths, i = 0, a, g;
+ u32 n = afl->queued_paths, i = 0, a, g;
+ double sum = 0;
afl->alias_table =
(u32 *)afl_realloc((void **)&afl->alias_table, n * sizeof(u32));
@@ -80,34 +83,62 @@ void create_alias_table(afl_state_t *afl) {
memset((void *)afl->alias_table, 0, n * sizeof(u32));
memset((void *)afl->alias_probability, 0, n * sizeof(double));
- double avg_exec_us = 0.0;
- double avg_bitmap_size = 0.0;
- for (i = 0; i < n; i++) {
+ if (likely(afl->schedule >= FAST && afl->schedule <= RARE)) {
- struct queue_entry *q = afl->queue_buf[i];
- avg_exec_us += q->exec_us;
- avg_bitmap_size += log(q->bitmap_size);
+ double avg_exec_us = 0.0;
+ double avg_bitmap_size = 0.0;
+ for (i = 0; i < n; i++) {
- }
- avg_exec_us /= afl->queued_paths;
- avg_bitmap_size /= afl->queued_paths;
+ struct queue_entry *q = afl->queue_buf[i];
+ avg_exec_us += q->exec_us;
+ avg_bitmap_size += log(q->bitmap_size);
- double sum = 0;
- for (i = 0; i < n; i++) {
+ }
+
+ avg_exec_us /= afl->queued_paths;
+ avg_bitmap_size /= afl->queued_paths;
+
+ for (i = 0; i < n; i++) {
- struct queue_entry *q = afl->queue_buf[i];
+ struct queue_entry *q = afl->queue_buf[i];
+
+ if (!q->disabled) {
+
+ q->weight = compute_weight(afl, q, avg_exec_us, avg_bitmap_size);
+ q->perf_score = calculate_score(afl, q);
+
+ }
+
+ sum += q->weight;
- if (!q->disabled) {
- q->weight = compute_weight(afl, q, avg_exec_us, avg_bitmap_size);
- q->perf_score = calculate_score(afl, q);
}
- sum += q->weight;
+ for (i = 0; i < n; i++) {
- }
+ P[i] = (afl->queue_buf[i]->weight * n) / sum;
+
+ }
+
+ } else {
+
+ for (i = 0; i < n; i++) {
+
+ struct queue_entry *q = afl->queue_buf[i];
+
+ if (!q->disabled) { q->perf_score = calculate_score(afl, q); }
+
+ sum += q->perf_score;
- for (i = 0; i < n; i++)
- P[i] = (afl->queue_buf[i]->weight * n) / sum;
+ }
+
+ for (i = 0; i < n; i++) {
+
+ struct queue_entry *q = afl->queue_buf[i];
+ P[i] = (q->perf_score * n) / sum;
+
+ }
+
+ }
int nS = 0, nL = 0, s;
for (s = (s32)n - 1; s >= 0; --s) {
diff --git a/utils/aflpp_driver/aflpp_qemu_driver.c b/utils/aflpp_driver/aflpp_qemu_driver.c
index cb3b86d0..a0c02833 100644
--- a/utils/aflpp_driver/aflpp_qemu_driver.c
+++ b/utils/aflpp_driver/aflpp_qemu_driver.c
@@ -7,7 +7,7 @@ int LLVMFuzzerTestOneInput(const uint8_t *Data, size_t Size);
__attribute__((weak)) int LLVMFuzzerInitialize(int *argc, char ***argv);
#define kMaxAflInputSize (1 * 1024 * 1024);
-static uint8_t AflInputBuf[kMaxAflInputSize];
+static uint8_t AflInputBuf[kMaxAflInputSize];
void __attribute__((noinline)) afl_qemu_driver_stdin_input(void) {