diff options
| author | Chris Lattner <sabre@nondot.org> | 2006-01-19 00:40:39 +0000 | 
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2006-01-19 00:40:39 +0000 | 
| commit | d693b7943a2687fd6afae509733861bc43296034 (patch) | |
| tree | 4c757394bfcaf8b01d95343c6acd916a3af2ab8b /llvm/lib/Transforms | |
| parent | 7599b6e4af74b94a54fac555a3721e843279293f (diff) | |
| download | bcm5719-llvm-d693b7943a2687fd6afae509733861bc43296034.tar.gz bcm5719-llvm-d693b7943a2687fd6afae509733861bc43296034.zip | |
Don't internalize llvm.global[cd]tor unless there are uses of it.  This
unbreaks front-ends that don't use __main (like the new CFE).
llvm-svn: 25429
Diffstat (limited to 'llvm/lib/Transforms')
| -rw-r--r-- | llvm/lib/Transforms/IPO/Internalize.cpp | 12 | 
1 files changed, 9 insertions, 3 deletions
| diff --git a/llvm/lib/Transforms/IPO/Internalize.cpp b/llvm/lib/Transforms/IPO/Internalize.cpp index 427545e4de1..d583d888684 100644 --- a/llvm/lib/Transforms/IPO/Internalize.cpp +++ b/llvm/lib/Transforms/IPO/Internalize.cpp @@ -109,7 +109,7 @@ bool InternalizePass::runOnModule(Module &M) {    // Never internalize the llvm.used symbol.  It is used to implement    // attribute((used)).    ExternalNames.insert("llvm.used"); -         +      // Never internalize anchors used by the debugger, else the debugger won't    // find them.    ExternalNames.insert("llvm.dbg.translation_units"); @@ -125,13 +125,19 @@ bool InternalizePass::runOnModule(Module &M) {        // the list if it's empty.        //        if (I->hasAppendingLinkage() && (I->getName() == "llvm.global_ctors" || -                                       I->getName() == "llvm.global_dtors")) +                                       I->getName() == "llvm.global_dtors")) {          I->setConstant(true); +         +        // If the global ctors/dtors list has no uses, do not internalize it, as +        // there is no __main in this program, so the asmprinter should handle +        // it. +        if (I->use_empty()) continue; +      }        I->setLinkage(GlobalValue::InternalLinkage);        Changed = true;        ++NumGlobals; -      DEBUG(std::cerr << "Internalizing gvar " << I->getName() << "\n"); +      DEBUG(std::cerr << "Internalized gvar " << I->getName() << "\n");      }    return Changed; | 

