aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorhexcoder- <heiko@hexco.de>2021-04-17 21:29:50 +0200
committerhexcoder- <heiko@hexco.de>2021-04-17 21:29:50 +0200
commit00e54565ef109a6c697db77b19d1618e37092125 (patch)
tree605583f6fad53377062e9bdaacdbff25fdfaa9f8
parent70bf4b4ab03283897d37895cae2c7bc74b93ab8e (diff)
downloadafl++-00e54565ef109a6c697db77b19d1618e37092125.tar.gz
use atomic read-modify-write increment for LLVM CLASSIC
-rw-r--r--instrumentation/afl-llvm-pass.so.cc8
1 files changed, 7 insertions, 1 deletions
diff --git a/instrumentation/afl-llvm-pass.so.cc b/instrumentation/afl-llvm-pass.so.cc
index 0f773aba..70480ff9 100644
--- a/instrumentation/afl-llvm-pass.so.cc
+++ b/instrumentation/afl-llvm-pass.so.cc
@@ -388,7 +388,6 @@ bool AFLCoverage::runOnModule(Module &M) {
#endif
// other constants we need
- ConstantInt *Zero = ConstantInt::get(Int8Ty, 0);
ConstantInt *One = ConstantInt::get(Int8Ty, 1);
Value * PrevCtx = NULL; // CTX sensitive coverage
@@ -628,6 +627,10 @@ bool AFLCoverage::runOnModule(Module &M) {
/* Update bitmap */
+#if 1 /* Atomic */
+ IRB.CreateAtomicRMW(llvm::AtomicRMWInst::BinOp::Add, MapPtrIdx, One, llvm::AtomicOrdering::Monotonic);
+
+#else
LoadInst *Counter = IRB.CreateLoad(MapPtrIdx);
Counter->setMetadata(M.getMDKindID("nosanitize"), MDNode::get(C, None));
@@ -651,6 +654,7 @@ bool AFLCoverage::runOnModule(Module &M) {
* Counter + OverflowFlag -> Counter
*/
+ ConstantInt *Zero = ConstantInt::get(Int8Ty, 0);
auto cf = IRB.CreateICmpEQ(Incr, Zero);
auto carry = IRB.CreateZExt(cf, Int8Ty);
Incr = IRB.CreateAdd(Incr, carry);
@@ -660,6 +664,8 @@ bool AFLCoverage::runOnModule(Module &M) {
IRB.CreateStore(Incr, MapPtrIdx)
->setMetadata(M.getMDKindID("nosanitize"), MDNode::get(C, None));
+#endif /* non atomic case */
+
/* Update prev_loc history vector (by placing cur_loc at the head of the
vector and shuffle the other elements back by one) */