diff options
author | Rafael Espindola <rafael.espindola@gmail.com> | 2011-03-06 23:41:34 +0000 |
---|---|---|
committer | Rafael Espindola <rafael.espindola@gmail.com> | 2011-03-06 23:41:34 +0000 |
commit | 871cfde1c27b0a05f1ce05754620d873a8e4c18f (patch) | |
tree | 65df49a231cb01fda203c6181abd60dc91dffff0 /llvm/lib/Transforms/IPO/Internalize.cpp | |
parent | b86f5f41063acccda3f9a6638ba9a4ce5bc2b26a (diff) | |
download | bcm5719-llvm-871cfde1c27b0a05f1ce05754620d873a8e4c18f.tar.gz bcm5719-llvm-871cfde1c27b0a05f1ce05754620d873a8e4c18f.zip |
Don't internalize available_externally functions. We already did the right
thing for variables.
llvm-svn: 127138
Diffstat (limited to 'llvm/lib/Transforms/IPO/Internalize.cpp')
-rw-r--r-- | llvm/lib/Transforms/IPO/Internalize.cpp | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/llvm/lib/Transforms/IPO/Internalize.cpp b/llvm/lib/Transforms/IPO/Internalize.cpp index 9b9ebad4722..8b7253ed758 100644 --- a/llvm/lib/Transforms/IPO/Internalize.cpp +++ b/llvm/lib/Transforms/IPO/Internalize.cpp @@ -126,6 +126,8 @@ bool InternalizePass::runOnModule(Module &M) { // FIXME: maybe use private linkage? for (Module::iterator I = M.begin(), E = M.end(); I != E; ++I) if (!I->isDeclaration() && // Function must be defined here + // Available externally is really just a "declaration with a body". + !I->hasAvailableExternallyLinkage() && !I->hasLocalLinkage() && // Can't already have internal linkage !ExternalNames.count(I->getName())) {// Not marked to keep external? I->setLinkage(GlobalValue::InternalLinkage); |