forked from OSchip/llvm-project
[asan] do not treat inline asm calls as indirect calls
llvm-svn: 220985
This commit is contained in:
parent
e9ab42df0c
commit
ea48bdc702
|
@ -1408,12 +1408,14 @@ void AddressSanitizer::InjectCoverageForIndirectCalls(
|
|||
for (auto I : IndirCalls) {
|
||||
IRBuilder<> IRB(I);
|
||||
CallSite CS(I);
|
||||
Value *Callee = CS.getCalledValue();
|
||||
if (dyn_cast<InlineAsm>(Callee)) continue;
|
||||
GlobalVariable *CalleeCache = new GlobalVariable(
|
||||
*F.getParent(), Ty, false, GlobalValue::PrivateLinkage,
|
||||
Constant::getNullValue(Ty), "__asan_gen_callee_cache");
|
||||
CalleeCache->setAlignment(kCacheAlignment);
|
||||
IRB.CreateCall2(AsanCovIndirCallFunction,
|
||||
IRB.CreatePointerCast(CS.getCalledValue(), IntptrTy),
|
||||
IRB.CreatePointerCast(Callee, IntptrTy),
|
||||
IRB.CreatePointerCast(CalleeCache, IntptrTy));
|
||||
}
|
||||
}
|
||||
|
|
|
@ -79,6 +79,7 @@ entry:
|
|||
%1 = load void (%struct.StructWithVptr*)** %vtable, align 8
|
||||
tail call void %1(%struct.StructWithVptr* %foo)
|
||||
tail call void %1(%struct.StructWithVptr* %foo)
|
||||
tail call void asm sideeffect "", ""()
|
||||
ret void
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue