aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMichael Rodler <michael.rodler@paluno.uni-due.de>2021-02-15 19:14:28 +0100
committerMichael Rodler <michael.rodler@paluno.uni-due.de>2021-02-15 19:14:28 +0100
commit6caec2169cef890ba8a62715c2c26cc0608626e3 (patch)
treeed0ac5ff80ceb30ee4b7dc8f2ee0b4663e69525a
parent52124813524fb0a28543066e70c86396931270a3 (diff)
downloadAFLplusplus-6caec2169cef890ba8a62715c2c26cc0608626e3.tar.gz
Revert "llvm bug workaround for lto extint"
This reverts commit e3a5c31307f323452dc4b5288e0d19a02b596a33.
-rw-r--r--docs/Changelog.md1
-rw-r--r--include/envs.h1
-rw-r--r--instrumentation/cmplog-instructions-pass.cc39
-rw-r--r--qemu_mode/libqasan/dlmalloc.c5
-rw-r--r--src/afl-cc.c2
-rw-r--r--src/afl-fuzz-redqueen.c1
6 files changed, 4 insertions, 45 deletions
diff --git a/docs/Changelog.md b/docs/Changelog.md
index e2482f8f..71ef4c2c 100644
--- a/docs/Changelog.md
+++ b/docs/Changelog.md
@@ -49,7 +49,6 @@ sending a mail to <afl-users+subscribe@googlegroups.com>.
CLANG for old afl-clang
- fixed a potential crash in the LAF feature
- workaround for llvm 13
- - workaround for llvm internal lto bug that lets not bitcast from _ExtInt()
- qemuafl
- QASan (address sanitizer for Qemu) ported to qemuafl!
See qemu_mode/libqasan/README.md
diff --git a/include/envs.h b/include/envs.h
index 36667ebc..4313e053 100644
--- a/include/envs.h
+++ b/include/envs.h
@@ -16,7 +16,6 @@ static char *afl_environment_deprecated[] = {
static char *afl_environment_variables[] = {
- "_AFL_LTO_COMPILE",
"AFL_ALIGNED_ALLOC",
"AFL_ALLOW_TMP",
"AFL_ANALYZE_HEX",
diff --git a/instrumentation/cmplog-instructions-pass.cc b/instrumentation/cmplog-instructions-pass.cc
index 9cd99f85..50ade9fd 100644
--- a/instrumentation/cmplog-instructions-pass.cc
+++ b/instrumentation/cmplog-instructions-pass.cc
@@ -114,8 +114,6 @@ bool CmpLogInstructions::hookInstrs(Module &M) {
IntegerType *Int64Ty = IntegerType::getInt64Ty(C);
IntegerType *Int128Ty = IntegerType::getInt128Ty(C);
- char *is_lto = getenv("_AFL_LTO_COMPILE");
-
#if LLVM_VERSION_MAJOR < 9
Constant *
#else
@@ -268,20 +266,10 @@ bool CmpLogInstructions::hookInstrs(Module &M) {
unsigned int max_size = Val->getType()->getIntegerBitWidth(), cast_size;
unsigned char do_cast = 0;
- if (!SI->getNumCases() || max_size < 16) { continue; }
-
- if (max_size % 8) {
-
- if (is_lto) {
+ if (!SI->getNumCases() || max_size < 16 || max_size % 8) {
- continue; // LTO cannot bitcast from _ExtInt() :(
-
- } else {
-
- max_size = (((max_size / 8) + 1) * 8);
- do_cast = 1;
-
- }
+ // if (!be_quiet) errs() << "skip trivial switch..\n";
+ continue;
}
@@ -298,7 +286,6 @@ bool CmpLogInstructions::hookInstrs(Module &M) {
}
- if (is_lto) { continue; } // LTO cannot bitcast _ExtInt() :(
max_size = 128;
do_cast = 1;
@@ -315,7 +302,6 @@ bool CmpLogInstructions::hookInstrs(Module &M) {
cast_size = max_size;
break;
default:
- if (is_lto) { continue; } // LTO cannot bitcast _ExtInt() :(
cast_size = 128;
do_cast = 1;
@@ -504,22 +490,7 @@ bool CmpLogInstructions::hookInstrs(Module &M) {
}
- if (!max_size || max_size < 16) { continue; }
-
- if (max_size % 8) {
-
- if (is_lto) {
-
- continue; // LTO cannot bitcast from _ExtInt() :(
-
- } else {
-
- max_size = (((max_size / 8) + 1) * 8);
- do_cast = 1;
-
- }
-
- }
+ if (!max_size || max_size % 8 || max_size < 16) { continue; }
if (max_size > 128) {
@@ -531,7 +502,6 @@ bool CmpLogInstructions::hookInstrs(Module &M) {
}
- if (is_lto) { continue; } // LTO cannot bitcast from _ExtInt() :(
max_size = 128;
do_cast = 1;
@@ -548,7 +518,6 @@ bool CmpLogInstructions::hookInstrs(Module &M) {
cast_size = max_size;
break;
default:
- if (is_lto) { continue; } // LTO cannot bitcast from _ExtInt() :(
cast_size = 128;
do_cast = 1;
diff --git a/qemu_mode/libqasan/dlmalloc.c b/qemu_mode/libqasan/dlmalloc.c
index aff58ad5..bace0ff6 100644
--- a/qemu_mode/libqasan/dlmalloc.c
+++ b/qemu_mode/libqasan/dlmalloc.c
@@ -3917,7 +3917,6 @@ static void internal_malloc_stats(mstate m) {
\
} else if (RTCHECK(B == smallbin_at(M, I) || \
\
- \
(ok_address(M, B) && B->fd == P))) { \
\
F->bk = B; \
@@ -4129,7 +4128,6 @@ static void internal_malloc_stats(mstate m) {
\
} else \
\
- \
CORRUPTION_ERROR_ACTION(M); \
if (R != 0) { \
\
@@ -4146,7 +4144,6 @@ static void internal_malloc_stats(mstate m) {
\
} else \
\
- \
CORRUPTION_ERROR_ACTION(M); \
\
} \
@@ -4159,14 +4156,12 @@ static void internal_malloc_stats(mstate m) {
\
} else \
\
- \
CORRUPTION_ERROR_ACTION(M); \
\
} \
\
} else \
\
- \
CORRUPTION_ERROR_ACTION(M); \
\
} \
diff --git a/src/afl-cc.c b/src/afl-cc.c
index 959c9a6f..d41f79a2 100644
--- a/src/afl-cc.c
+++ b/src/afl-cc.c
@@ -1875,8 +1875,6 @@ int main(int argc, char **argv, char **envp) {
edit_params(argc, argv, envp);
- if (lto_mode) { setenv("_AFL_LTO_COMPILE", "1", 1); }
-
if (debug) {
DEBUGF("cd '%s';", getthecwd());
diff --git a/src/afl-fuzz-redqueen.c b/src/afl-fuzz-redqueen.c
index cf65d3c1..275af9c8 100644
--- a/src/afl-fuzz-redqueen.c
+++ b/src/afl-fuzz-redqueen.c
@@ -1547,7 +1547,6 @@ static u8 cmp_fuzz(afl_state_t *afl, u32 key, u8 *orig_buf, u8 *buf, u8 *cbuf,
is_n = 1;
}
-
#endif
for (i = 0; i < loggeds; ++i) {