diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2011-02-20 12:57:14 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2011-02-20 12:57:14 +0000 | 
| commit | cf099d11218cb6f6c5cce947d6738e347f07fb12 (patch) | |
| tree | d2b61ce94e654cb01a254d2195259db5f9cc3f3c /tools/llvm-ld/llvm-ld.cpp | |
| parent | 49011b52fcba02a6051957b84705159f52fae4e4 (diff) | |
Notes
Diffstat (limited to 'tools/llvm-ld/llvm-ld.cpp')
| -rw-r--r-- | tools/llvm-ld/llvm-ld.cpp | 62 | 
1 files changed, 35 insertions, 27 deletions
| diff --git a/tools/llvm-ld/llvm-ld.cpp b/tools/llvm-ld/llvm-ld.cpp index 3bbea9dc7287..cd6ce256db7b 100644 --- a/tools/llvm-ld/llvm-ld.cpp +++ b/tools/llvm-ld/llvm-ld.cpp @@ -23,7 +23,7 @@  #include "llvm/LinkAllVMCore.h"  #include "llvm/Linker.h"  #include "llvm/LLVMContext.h" -#include "llvm/System/Program.h" +#include "llvm/Support/Program.h"  #include "llvm/Module.h"  #include "llvm/PassManager.h"  #include "llvm/Bitcode/ReaderWriter.h" @@ -35,8 +35,8 @@  #include "llvm/Support/MemoryBuffer.h"  #include "llvm/Support/PrettyStackTrace.h"  #include "llvm/Support/SystemUtils.h" -#include "llvm/Support/raw_ostream.h" -#include "llvm/System/Signals.h" +#include "llvm/Support/ToolOutputFile.h" +#include "llvm/Support/Signals.h"  #include "llvm/Config/config.h"  #include <memory>  #include <cstring> @@ -98,7 +98,7 @@ static cl::list<std::string> PostLinkOpts("post-link-opts",  static cl::list<std::string> XLinker("Xlinker", cl::value_desc("option"),    cl::desc("Pass options to the system linker")); -// Compatibility options that llvm-ld ignores but are supported for  +// Compatibility options that llvm-ld ignores but are supported for  // compatibility with LD  static cl::opt<std::string> CO3("soname", cl::Hidden,    cl::desc("Compatibility option: ignored")); @@ -112,13 +112,13 @@ static cl::opt<bool> CO5("eh-frame-hdr", cl::Hidden,  static  cl::opt<std::string> CO6("h", cl::Hidden,    cl::desc("Compatibility option: ignored")); -static cl::opt<bool> CO7("start-group", cl::Hidden,  +static cl::opt<bool> CO7("start-group", cl::Hidden,    cl::desc("Compatibility option: ignored")); -static cl::opt<bool> CO8("end-group", cl::Hidden,  +static cl::opt<bool> CO8("end-group", cl::Hidden,    cl::desc("Compatibility option: ignored")); -static cl::opt<std::string> CO9("m", cl::Hidden,  +static cl::opt<std::string> CO9("m", cl::Hidden,    cl::desc("Compatibility option: ignored"));  /// This is just for convenience so it doesn't have to be passed around @@ -142,7 +142,7 @@ static void PrintAndExit(const std::string &Message, Module *M, int errcode = 1)  }  static void PrintCommand(const std::vector<const char*> &args) { -  std::vector<const char*>::const_iterator I = args.begin(), E = args.end();  +  std::vector<const char*>::const_iterator I = args.begin(), E = args.end();    for (; I != E; ++I)      if (*I)        errs() << "'" << *I << "'" << " "; @@ -178,7 +178,7 @@ static char ** CopyEnv(char ** const envp) {    // Allocate a new environment list.    char **newenv = new char* [entries]; -  if ((newenv = new char* [entries]) == NULL) +  if (newenv == NULL)      return NULL;    // Make a copy of the list.  Don't forget the NULL that ends the list. @@ -384,7 +384,7 @@ static int GenerateNative(const std::string &OutputFilename,      args.push_back("-framework");      args.push_back(Frameworks[index]);    } -       +    // Now that "args" owns all the std::strings for the arguments, call the c_str    // method to get the underlying string array.  We do this game so that the    // std::string array is guaranteed to outlive the const char* array. @@ -410,13 +410,13 @@ static int GenerateNative(const std::string &OutputFilename,  static void EmitShellScript(char **argv, Module *M) {    if (Verbose)      errs() << "Emitting Shell Script\n"; -#if defined(_WIN32) || defined(__CYGWIN__) +#if defined(_WIN32)    // Windows doesn't support #!/bin/sh style shell scripts in .exe files.  To    // support windows systems, we copy the llvm-stub.exe executable from the    // build tree to the destination file. -  std::string ErrMsg;   -  sys::Path llvmstub = FindExecutable("llvm-stub.exe", argv[0], -                                      (void *)(intptr_t)&Optimize); +  std::string ErrMsg; +  sys::Path llvmstub = PrependMainExecutablePath("llvm-stub", argv[0], +                                                 (void *)(intptr_t)&Optimize);    if (llvmstub.isEmpty())      PrintAndExit("Could not find llvm-stub.exe executable!", M); @@ -455,7 +455,7 @@ static void EmitShellScript(char **argv, Module *M) {             E = LibPaths.end(); P != E; ++P) {        FullLibraryPath = *P;        FullLibraryPath.appendComponent("lib" + *i); -      FullLibraryPath.appendSuffix(&(LTDL_SHLIB_EXT[1])); +      FullLibraryPath.appendSuffix(sys::Path::GetDLLSuffix());        if (!FullLibraryPath.isEmpty()) {          if (!FullLibraryPath.isDynamicLibrary()) {            // Not a native shared library; mark as invalid @@ -513,9 +513,20 @@ int main(int argc, char **argv, char **envp) {    LLVMContext &Context = getGlobalContext();    llvm_shutdown_obj Y;  // Call llvm_shutdown() on exit. -   + +  // Initialize passes +  PassRegistry &Registry = *PassRegistry::getPassRegistry(); +  initializeCore(Registry); +  initializeScalarOpts(Registry); +  initializeIPO(Registry); +  initializeAnalysis(Registry); +  initializeIPA(Registry); +  initializeTransformUtils(Registry); +  initializeInstCombine(Registry); +  initializeTarget(Registry); +    // Initial global variable above for convenience printing of program name. -  progname = sys::Path(argv[0]).getBasename(); +  progname = sys::path::stem(argv[0]);    // Parse the command line options    cl::ParseCommandLineOptions(argc, argv, "llvm linker\n"); @@ -527,11 +538,8 @@ int main(int argc, char **argv, char **envp) {        OutputFilename = "a.exe";      // If there is no suffix add an "exe" one. -    sys::Path ExeFile( OutputFilename ); -    if (ExeFile.getSuffix() == "") { -      ExeFile.appendSuffix("exe"); -      OutputFilename = ExeFile.str(); -    } +    if (sys::path::extension(OutputFilename).empty()) +      OutputFilename.append(".exe");    }  #endif @@ -653,8 +661,8 @@ int main(int argc, char **argv, char **envp) {        sys::RemoveFileOnSignal(AssemblyFile);        // Determine the locations of the llc and gcc programs. -      sys::Path llc = FindExecutable("llc", argv[0], -                                     (void *)(intptr_t)&Optimize); +      sys::Path llc = PrependMainExecutablePath("llc", argv[0], +                                                (void *)(intptr_t)&Optimize);        if (llc.isEmpty())          PrintAndExit("Failed to find llc", Composite.get()); @@ -680,8 +688,8 @@ int main(int argc, char **argv, char **envp) {        sys::RemoveFileOnSignal(CFile);        // Determine the locations of the llc and gcc programs. -      sys::Path llc = FindExecutable("llc", argv[0], -                                     (void *)(intptr_t)&Optimize); +      sys::Path llc = PrependMainExecutablePath("llc", argv[0], +                                                (void *)(intptr_t)&Optimize);        if (llc.isEmpty())          PrintAndExit("Failed to find llc", Composite.get()); @@ -694,7 +702,7 @@ int main(int argc, char **argv, char **envp) {        if (GenerateCFile(CFile.str(), BitcodeOutputFilename, llc, ErrMsg))          PrintAndExit(ErrMsg, Composite.get()); -      if (GenerateNative(OutputFilename, CFile.str(),  +      if (GenerateNative(OutputFilename, CFile.str(),                           NativeLinkItems, gcc, envp, ErrMsg))          PrintAndExit(ErrMsg, Composite.get());      } else { | 
