From 3c60df7cceb23aa9ef9c82174d9e2546f5339fb2 Mon Sep 17 00:00:00 2001 From: Volodymyr Sapsai Date: Fri, 17 Nov 2017 18:28:05 +0000 Subject: [PATCH] [ThinLTO] Remove too aggressive assertion in building function call graph. The assertion was introduced in r317853 but there are cases when a call isn't handled either as direct or indirect. In this case we add a reference graph edge but not a call graph edge. Reviewers: tejohnson Reviewed By: tejohnson Subscribers: mehdi_amini, inglorion, eraman, hiraditya, efriedma, llvm-commits Differential Revision: https://reviews.llvm.org/D40056 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@318540 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/Analysis/ModuleSummaryAnalysis.cpp | 5 +++-- .../thinlto-function-summary-callgraph-cast.ll | 16 ++++++++++++++-- 2 files changed, 17 insertions(+), 4 deletions(-) diff --git a/lib/Analysis/ModuleSummaryAnalysis.cpp b/lib/Analysis/ModuleSummaryAnalysis.cpp index 8d1e7ee770f..d54fb700200 100644 --- a/lib/Analysis/ModuleSummaryAnalysis.cpp +++ b/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(CalledValue) && - "Expected indirect call"); + // Skip direct calls. + if (!CalledValue || isa(CalledValue)) + continue; uint32_t NumVals, NumCandidates; uint64_t TotalCount; diff --git a/test/Bitcode/thinlto-function-summary-callgraph-cast.ll b/test/Bitcode/thinlto-function-summary-callgraph-cast.ll index b377ba8f00d..45801c9a74d 100644 --- a/test/Bitcode/thinlto-function-summary-callgraph-cast.ll +++ b/test/Bitcode/thinlto-function-summary-callgraph-cast.ll @@ -5,8 +5,10 @@ ; CHECK: +; "op7" is a call to "callee" function. +; CHECK-NEXT: +; "another_caller" has only references but no calls. +; CHECK-NEXT: ; CHECK-NEXT: ; CHECK-NEXT: @@ -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