diff options
-rw-r--r-- | llvm/lib/Analysis/ModuleSummaryAnalysis.cpp | 5 | ||||
-rw-r--r-- | llvm/test/Bitcode/thinlto-function-summary-callgraph-cast.ll | 16 |
2 files changed, 17 insertions, 4 deletions
diff --git a/llvm/lib/Analysis/ModuleSummaryAnalysis.cpp b/llvm/lib/Analysis/ModuleSummaryAnalysis.cpp index 8d1e7ee770f..d54fb700200 100644 --- a/llvm/lib/Analysis/ModuleSummaryAnalysis.cpp +++ b/llvm/lib/Analysis/ModuleSummaryAnalysis.cpp @@ -280,8 +280,9 @@ computeFunctionSummary(ModuleSummaryIndex &Index, const Module &M, // Skip inline assembly calls. if (CI && CI->isInlineAsm()) continue; - assert(CalledValue && !isa<Constant>(CalledValue) && - "Expected indirect call"); + // Skip direct calls. + if (!CalledValue || isa<Constant>(CalledValue)) + continue; uint32_t NumVals, NumCandidates; uint64_t TotalCount; diff --git a/llvm/test/Bitcode/thinlto-function-summary-callgraph-cast.ll b/llvm/test/Bitcode/thinlto-function-summary-callgraph-cast.ll index b377ba8f00d..45801c9a74d 100644 --- a/llvm/test/Bitcode/thinlto-function-summary-callgraph-cast.ll +++ b/llvm/test/Bitcode/thinlto-function-summary-callgraph-cast.ll @@ -5,8 +5,10 @@ ; CHECK: <GLOBALVAL_SUMMARY_BLOCK ; CHECK-NEXT: <VERSION -; "op7=1" is a call to "callee" function. -; CHECK-NEXT: <PERMODULE {{.*}} op7=1 op8=[[ALIASID:[0-9]+]]/> +; "op7" is a call to "callee" function. +; CHECK-NEXT: <PERMODULE {{.*}} op7=3 op8=[[ALIASID:[0-9]+]]/> +; "another_caller" has only references but no calls. +; CHECK-NEXT: <PERMODULE {{.*}} op4=3 {{.*}} op7={{[0-9]+}}/> ; CHECK-NEXT: <PERMODULE {{.*}} op0=[[ALIASEEID:[0-9]+]] ; CHECK-NEXT: <ALIAS {{.*}} op0=[[ALIASID]] {{.*}} op2=[[ALIASEEID]]/> ; CHECK-NEXT: </GLOBALVAL_SUMMARY_BLOCK> @@ -21,6 +23,12 @@ define void @caller() { ret void } +define void @another_caller() { + ; Test calls that aren't handled either as direct or indirect. + call void select (i1 icmp eq (i32* @global, i32* null), void ()* @f, void ()* @g)() + ret void +} + declare void @callee(...) @analias = alias void (...), bitcast (void ()* @aliasee to void (...)*) @@ -29,3 +37,7 @@ define void @aliasee() { entry: ret void } + +declare void @f() +declare void @g() +@global = extern_weak global i32 |