]> granicus.if.org Git - clang/commitdiff
It turns out -fno-cxa-atexit just produces broken code, so disable it on Solaris...
authorDavid Chisnall <csdavec@swan.ac.uk>
Tue, 28 Feb 2012 19:15:06 +0000 (19:15 +0000)
committerDavid Chisnall <csdavec@swan.ac.uk>
Tue, 28 Feb 2012 19:15:06 +0000 (19:15 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@151648 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Driver/Tools.cpp

index de27d09c3849c0b02eebd0252f84739e1b9b8854..c215724c56c0ccac414323ccbcc898266e3fa4ca 100644 (file)
@@ -2079,7 +2079,6 @@ void Clang::ConstructJob(Compilation &C, const JobAction &JA,
     !Args.hasFlag(options::OPT_fuse_cxa_atexit, options::OPT_fno_use_cxa_atexit,
                   getToolChain().getTriple().getOS() != llvm::Triple::Cygwin &&
                   getToolChain().getTriple().getOS() != llvm::Triple::MinGW32 &&
-                  getToolChain().getTriple().getOS() != llvm::Triple::Solaris &&
                   getToolChain().getTriple().getArch() !=
                   llvm::Triple::hexagon))
     CmdArgs.push_back("-fno-use-cxa-atexit");
@@ -4252,6 +4251,7 @@ void solaris::Link::ConstructJob(Compilation &C, const JobAction &JA,
       CmdArgs.push_back(Args.MakeArgString(LibPath + "values-Xa.o"));
       CmdArgs.push_back(Args.MakeArgString(GCCLibPath + "crtbegin.o"));
     } else {
+      CmdArgs.push_back(Args.MakeArgString(LibPath + "cxa_finalize.o"));
       CmdArgs.push_back(Args.MakeArgString(LibPath + "crti.o"));
       CmdArgs.push_back(Args.MakeArgString(LibPath + "values-Xa.o"));
       CmdArgs.push_back(Args.MakeArgString(GCCLibPath + "crtbegin.o"));