diff options
author | hexcoder- <heiko@hexco.de> | 2021-11-24 00:05:15 +0100 |
---|---|---|
committer | hexcoder- <heiko@hexco.de> | 2021-11-24 00:05:15 +0100 |
commit | 91f1c17c8f00a40d3e975b0a6e8c98677acef4a3 (patch) | |
tree | f668ee24508c00db6c7943aa16b60d50e82c2409 /src/afl-cc.c | |
parent | 8c4435e7ef6cad7a0d475603469e98c09d32f504 (diff) | |
download | afl++-91f1c17c8f00a40d3e975b0a6e8c98677acef4a3.tar.gz |
transform cmplog-instructions pass to new pass manager
Diffstat (limited to 'src/afl-cc.c')
-rw-r--r-- | src/afl-cc.c | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/src/afl-cc.c b/src/afl-cc.c index 9173fc4b..c70f193c 100644 --- a/src/afl-cc.c +++ b/src/afl-cc.c @@ -573,10 +573,6 @@ static void edit_params(u32 argc, char **argv, char **envp) { } -#if LLVM_MAJOR >= 13 - // fuck you llvm 13 - cc_params[cc_par_cnt++] = "-fno-experimental-new-pass-manager"; -#endif if (lto_mode && !have_c) { @@ -616,6 +612,7 @@ static void edit_params(u32 argc, char **argv, char **envp) { } else { + cc_params[cc_par_cnt++] = "-fno-experimental-new-pass-manager"; cc_params[cc_par_cnt++] = "-Xclang"; cc_params[cc_par_cnt++] = "-load"; cc_params[cc_par_cnt++] = "-Xclang"; @@ -674,11 +671,17 @@ static void edit_params(u32 argc, char **argv, char **envp) { } else { +#if LLVM_MAJOR >= 11 + cc_params[cc_par_cnt++] = "-fexperimental-new-pass-manager"; + cc_params[cc_par_cnt++] = + alloc_printf("-fpass-plugin=%s/cmplog-instructions-pass.so", obj_path); +#else cc_params[cc_par_cnt++] = "-Xclang"; cc_params[cc_par_cnt++] = "-load"; cc_params[cc_par_cnt++] = "-Xclang"; cc_params[cc_par_cnt++] = alloc_printf("%s/cmplog-instructions-pass.so", obj_path); +#endif cc_params[cc_par_cnt++] = "-Xclang"; cc_params[cc_par_cnt++] = "-load"; |