add bitcode support.
authorChris Lattner <sabre@nondot.org>
Sun, 6 May 2007 05:56:58 +0000 (05:56 +0000)
committerChris Lattner <sabre@nondot.org>
Sun, 6 May 2007 05:56:58 +0000 (05:56 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@36853 91177308-0d34-0410-b5e6-96231b3b80d8

tools/llvm-ld/Makefile
tools/llvm-ld/llvm-ld.cpp

index dc8bffb742bf3017ab8a5ba9c151b37ce9778841..b22035b93154ae3c3a0780c6e4b287041eb6d007 100644 (file)
@@ -10,7 +10,7 @@
 LEVEL = ../..
 
 TOOLNAME = llvm-ld
-LINK_COMPONENTS = ipo scalaropts linker archive bcreader bcwriter
+LINK_COMPONENTS = ipo scalaropts linker archive bcwriter bitwriter
 REQUIRES_EH := 1
 
 include $(LEVEL)/Makefile.common
index 4be651b65de86f6e7e2f3a25762e99fa1f8fb7b4..2aa6d18350edc373f62b7294e404348e9de3080c 100644 (file)
@@ -25,7 +25,7 @@
 #include "llvm/System/Program.h"
 #include "llvm/Module.h"
 #include "llvm/PassManager.h"
-#include "llvm/Bytecode/Reader.h"
+#include "llvm/Bitcode/ReaderWriter.h"
 #include "llvm/Bytecode/Writer.h"
 #include "llvm/Target/TargetData.h"
 #include "llvm/Target/TargetMachine.h"
@@ -33,6 +33,7 @@
 #include "llvm/Support/CommandLine.h"
 #include "llvm/Support/FileUtilities.h"
 #include "llvm/Support/ManagedStatic.h"
+#include "llvm/Support/MemoryBuffer.h"
 #include "llvm/Support/Streams.h"
 #include "llvm/Support/SystemUtils.h"
 #include "llvm/System/Signals.h"
@@ -40,6 +41,8 @@
 #include <memory>
 using namespace llvm;
 
+cl::opt<bool> Bitcode("bitcode");
+
 // Input/Output Options
 static cl::list<std::string> InputFilenames(cl::Positional, cl::OneOrMore,
   cl::desc("<input bytecode files>"));
@@ -224,8 +227,12 @@ void GenerateBytecode(Module* M, const std::string& FileName) {
   sys::RemoveFileOnSignal(sys::Path(FileName));
 
   // Write it out
-  OStream L(Out);
-  WriteBytecodeToFile(M, L, !DisableCompression);
+  if (Bitcode) {
+    WriteBitcodeToFile(M, Out);
+  } else {
+    OStream L(Out);
+    WriteBytecodeToFile(M, L, !DisableCompression);
+  }
 
   // Close the bytecode file.
   Out.close();
@@ -547,7 +554,7 @@ int main(int argc, char **argv, char **envp) {
           args[2] = tmp_output.c_str();
           args[3] = 0;
           if (0 == sys::Program::ExecuteAndWait(prog, args, 0,0,0,0, &ErrMsg)) {
-            if (tmp_output.isBytecodeFile()) {
+            if (tmp_output.isBytecodeFile() || tmp_output.isBitcodeFile()) {
               sys::Path target(RealBytecodeOutput);
               target.eraseFromDisk();
               if (tmp_output.renamePathOnDisk(target, &ErrMsg))