summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Analysis/LazyCallGraph.cpp
diff options
context:
space:
mode:
authorChandler Carruth <chandlerc@gmail.com>2017-07-19 04:12:25 +0000
committerChandler Carruth <chandlerc@gmail.com>2017-07-19 04:12:25 +0000
commit06a86301a10c74830f91ff427c0e69811549ddb7 (patch)
tree090985c398f580c87512d571408ed0a600f89f62 /llvm/lib/Analysis/LazyCallGraph.cpp
parentbac49e5764b99176a7f5efb2f80ea42eb46d3744 (diff)
downloadbcm5719-llvm-06a86301a10c74830f91ff427c0e69811549ddb7.tar.gz
bcm5719-llvm-06a86301a10c74830f91ff427c0e69811549ddb7.zip
[PM/LCG] Follow-up fix to r308088 to handle deletion of library
functions. In the prior commit, we provide ordering to the LCG between functions and library function definitions that they might begin to call through transformations. But we still would delete these library functions from the call graph if they became dead during inlining. While this immediately crashed, it also exposed a loss of information. We shouldn't remove definitions of library functions that can still usefully participate in the LCG-powered CGSCC optimization process. If new call edges are formed, we want to have definitions to be called. We can still remove these functions if truly dead using global-dce, etc, but removing them during the CGSCC walk is premature. This fixes a crash in the new PM when optimizing some unusual libraries that end up with "internal" lib functions such as the code in the "R" language's libraries. llvm-svn: 308417
Diffstat (limited to 'llvm/lib/Analysis/LazyCallGraph.cpp')
-rw-r--r--llvm/lib/Analysis/LazyCallGraph.cpp7
1 files changed, 6 insertions, 1 deletions
diff --git a/llvm/lib/Analysis/LazyCallGraph.cpp b/llvm/lib/Analysis/LazyCallGraph.cpp
index 5e14c0df6d0..d287f81985f 100644
--- a/llvm/lib/Analysis/LazyCallGraph.cpp
+++ b/llvm/lib/Analysis/LazyCallGraph.cpp
@@ -144,7 +144,7 @@ LazyCallGraph::LazyCallGraph(Module &M, TargetLibraryInfo &TLI) {
// synthesize reference edges to it to model the fact that LLVM can turn
// arbitrary code into a library function call.
if (isKnownLibFunction(F, TLI))
- LibFunctions.push_back(&F);
+ LibFunctions.insert(&F);
if (F.hasLocalLinkage())
continue;
@@ -1608,6 +1608,11 @@ void LazyCallGraph::removeDeadFunction(Function &F) {
assert(F.use_empty() &&
"This routine should only be called on trivially dead functions!");
+ // We shouldn't remove library functions as they are never really dead while
+ // the call graph is in use -- every function definition refers to them.
+ assert(!isLibFunction(F) &&
+ "Must not remove lib functions from the call graph!");
+
auto NI = NodeMap.find(&F);
if (NI == NodeMap.end())
// Not in the graph at all!
OpenPOWER on IntegriCloud