diff options
| author | Andrea Fioraldi <andreafioraldi@gmail.com> | 2019-11-11 15:53:24 +0100 | 
|---|---|---|
| committer | GitHub <noreply@github.com> | 2019-11-11 15:53:24 +0100 | 
| commit | 388f4ae30240f2a675afa5b1febded00284ad450 (patch) | |
| tree | 5ac20b7c7deff76fe4bb9269b1f684e48e2736a0 /include/afl-fuzz.h | |
| parent | 01d55372441960c435af8f3bd6b61d1302042728 (diff) | |
| parent | f1fbea96f625a5af9b5321cb98acfc3378b5343e (diff) | |
| download | afl++-388f4ae30240f2a675afa5b1febded00284ad450.tar.gz | |
Merge pull request #106 from vanhauser-thc/radamsa
Radamsa
Diffstat (limited to 'include/afl-fuzz.h')
| -rw-r--r-- | include/afl-fuzz.h | 24 | 
1 files changed, 18 insertions, 6 deletions
| diff --git a/include/afl-fuzz.h b/include/afl-fuzz.h index 90f3b419..342205df 100644 --- a/include/afl-fuzz.h +++ b/include/afl-fuzz.h @@ -163,7 +163,8 @@ enum { /* 15 */ STAGE_HAVOC, /* 16 */ STAGE_SPLICE, /* 17 */ STAGE_PYTHON, - /* 18 */ STAGE_CUSTOM_MUTATOR + /* 18 */ STAGE_RADAMSA, + /* 19 */ STAGE_CUSTOM_MUTATOR }; @@ -288,6 +289,9 @@ extern char* power_names[POWER_SCHEDULES_NUM]; extern u8 schedule; /* Power schedule (default: EXPLORE)*/ extern u8 havoc_max_mult; +extern u8 use_radamsa; +extern size_t (*radamsa_mutate_ptr)(u8*, size_t, u8*, size_t, u32); + extern u8 skip_deterministic, /* Skip deterministic stages? */ force_deterministic, /* Force deterministic stages? */ use_splicing, /* Recombine input files? */ @@ -404,6 +408,9 @@ extern u64 stage_finds[32], /* Patterns found per fuzz stage */ extern u32 rand_cnt; /* Random number counter */ #endif +extern u32 rand_seed[2]; +extern s64 init_seed; + extern u64 total_cal_us, /* Total calibration time (us) */ total_cal_cycles; /* Total calibration cycles */ @@ -647,11 +654,9 @@ static inline u32 UR(u32 limit) { #else if (!fixed_seed && unlikely(!rand_cnt--)) { - u32 seed[2]; - - ck_read(dev_urandom_fd, &seed, sizeof(seed), "/dev/urandom"); - srandom(seed[0]); - rand_cnt = (RESEED_RNG / 2) + (seed[1] % RESEED_RNG); + ck_read(dev_urandom_fd, &rand_seed, sizeof(rand_seed), "/dev/urandom"); + srandom(rand_seed[0]); + rand_cnt = (RESEED_RNG / 2) + (rand_seed[1] % RESEED_RNG); } @@ -660,6 +665,13 @@ static inline u32 UR(u32 limit) { } +static inline u32 get_rand_seed() { + + if (fixed_seed) return (u32)init_seed; + return rand_seed[0]; + +} + /* Find first power of two greater or equal to val (assuming val under 2^63). */ | 
