From 3983b23eac93b0e6f28ffba4b626401c5280c10f Mon Sep 17 00:00:00 2001 From: Lukas Zaoral Date: Sat, 12 Sep 2020 11:02:29 +0200 Subject: Replace llvm::CallSite with llvm::CallBase on LLVM 8+ This is in preparation for LLVM 11 as the llvm:CallSite class has been removed. --- lib/Core/Executor.cpp | 36 ++++++++++++++++++++++++++++-------- 1 file changed, 28 insertions(+), 8 deletions(-) (limited to 'lib/Core/Executor.cpp') diff --git a/lib/Core/Executor.cpp b/lib/Core/Executor.cpp index ea3fffb7..48252dbd 100644 --- a/lib/Core/Executor.cpp +++ b/lib/Core/Executor.cpp @@ -55,7 +55,9 @@ #include "llvm/ADT/StringExtras.h" #include "llvm/IR/Attributes.h" #include "llvm/IR/BasicBlock.h" +#if LLVM_VERSION_CODE < LLVM_VERSION(8, 0) #include "llvm/IR/CallSite.h" +#endif #include "llvm/IR/Constants.h" #include "llvm/IR/DataLayout.h" #include "llvm/IR/Function.h" @@ -1570,13 +1572,17 @@ void Executor::executeCall(ExecutionState &state, KInstruction *ki, Function *f, uint64_t offsets[callingArgs]; // offsets of variadic arguments uint64_t argWidth; // width of current variadic argument - CallSite cs(i); +#if LLVM_VERSION_CODE >= LLVM_VERSION(8, 0) + const CallBase &cs = cast(*i); +#else + const CallSite cs(i); +#endif for (unsigned k = funcArgs; k < callingArgs; k++) { if (cs.isByValArgument(k)) { #if LLVM_VERSION_CODE >= LLVM_VERSION(9, 0) Type *t = cs.getParamByValType(k); #else - auto arg = cs.getArgument(k); + auto arg = cs.getArgOperand(k); Type *t = arg->getType(); assert(t->isPointerTy()); t = t->getPointerElementType(); @@ -1770,8 +1776,13 @@ void Executor::executeInstruction(ExecutionState &state, KInstruction *ki) { Expr::Width to = getWidthForLLVMType(t); if (from != to) { - CallSite cs = (isa(caller) ? CallSite(cast(caller)) : - CallSite(cast(caller))); +#if LLVM_VERSION_CODE >= LLVM_VERSION(8, 0) + const CallBase &cs = cast(*caller); +#else + const CallSite cs(isa(caller) + ? CallSite(cast(caller)) + : CallSite(cast(caller))); +#endif // XXX need to check other param attrs ? #if LLVM_VERSION_CODE >= LLVM_VERSION(5, 0) @@ -2036,7 +2047,12 @@ void Executor::executeInstruction(ExecutionState &state, KInstruction *ki) { // Ignore debug intrinsic calls if (isa(i)) break; - CallSite cs(i); + +#if LLVM_VERSION_CODE >= LLVM_VERSION(8, 0) + const CallBase &cs = cast(*i); +#else + const CallSite cs(i); +#endif unsigned numArgs = cs.arg_size(); Value *fp = cs.getCalledValue(); @@ -4138,10 +4154,14 @@ size_t Executor::getAllocationAlignment(const llvm::Value *allocSite) const { type = AI->getAllocatedType(); } else if (isa(allocSite) || isa(allocSite)) { // FIXME: Model the semantics of the call to use the right alignment +#if LLVM_VERSION_CODE >= LLVM_VERSION(8, 0) + const CallBase &cs = cast(*allocSite); +#else llvm::Value *allocSiteNonConst = const_cast(allocSite); - const CallSite cs = (isa(allocSiteNonConst) - ? CallSite(cast(allocSiteNonConst)) - : CallSite(cast(allocSiteNonConst))); + const CallSite cs(isa(allocSiteNonConst) + ? CallSite(cast(allocSiteNonConst)) + : CallSite(cast(allocSiteNonConst))); +#endif llvm::Function *fn = klee::getDirectCallTarget(cs, /*moduleIsFullyLinked=*/true); if (fn) -- cgit 1.4.1