summaryrefslogtreecommitdiff
path: root/lib/Linker
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2007-05-06 06:02:13 +0000
committerChris Lattner <sabre@nondot.org>2007-05-06 06:02:13 +0000
commit1a019e5ffd0d8643ddffc7ed5736eb78065c5f88 (patch)
treed69f7bb65c5a27607d7018c9734eedd13c12e0f3 /lib/Linker
parent5e3c9f96d7526743e9ed02aa03bc684ea0b7f12c (diff)
downloadllvm-1a019e5ffd0d8643ddffc7ed5736eb78065c5f88.tar.gz
llvm-1a019e5ffd0d8643ddffc7ed5736eb78065c5f88.tar.bz2
llvm-1a019e5ffd0d8643ddffc7ed5736eb78065c5f88.tar.xz
add bitcode support
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@36855 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Linker')
-rw-r--r--lib/Linker/LinkArchives.cpp1
-rw-r--r--lib/Linker/LinkItems.cpp2
-rw-r--r--lib/Linker/Linker.cpp24
3 files changed, 23 insertions, 4 deletions
diff --git a/lib/Linker/LinkArchives.cpp b/lib/Linker/LinkArchives.cpp
index 95ac1ab1fd..e6a3b8a523 100644
--- a/lib/Linker/LinkArchives.cpp
+++ b/lib/Linker/LinkArchives.cpp
@@ -16,7 +16,6 @@
#include "llvm/Module.h"
#include "llvm/ModuleProvider.h"
#include "llvm/ADT/SetOperations.h"
-#include "llvm/Bytecode/Reader.h"
#include "llvm/Bytecode/Archive.h"
#include "llvm/Config/config.h"
#include <memory>
diff --git a/lib/Linker/LinkItems.cpp b/lib/Linker/LinkItems.cpp
index ad7ae65209..50efe46bd1 100644
--- a/lib/Linker/LinkItems.cpp
+++ b/lib/Linker/LinkItems.cpp
@@ -83,6 +83,7 @@ bool Linker::LinkInLibrary(const std::string& Lib, bool& is_native) {
return warning("Supposed library '" + Lib + "' isn't a library.");
case sys::Bytecode_FileType:
+ case sys::Bitcode_FileType:
case sys::CompressedBytecode_FileType:
// LLVM ".so" file.
if (LinkInFile(Pathname, is_native))
@@ -175,6 +176,7 @@ bool Linker::LinkInFile(const sys::Path &File, bool &is_native) {
return error("Cannot link archive '" + File.toString() + "'");
break;
+ case sys::Bitcode_FileType:
case sys::Bytecode_FileType:
case sys::CompressedBytecode_FileType: {
verbose("Linking bytecode file '" + File.toString() + "'");
diff --git a/lib/Linker/Linker.cpp b/lib/Linker/Linker.cpp
index d7959b41e7..bfa30044dc 100644
--- a/lib/Linker/Linker.cpp
+++ b/lib/Linker/Linker.cpp
@@ -14,11 +14,15 @@
#include "llvm/Linker.h"
#include "llvm/Module.h"
#include "llvm/Bytecode/Reader.h"
+#include "llvm/Bitcode/ReaderWriter.h"
#include "llvm/Config/config.h"
+#include "llvm/Support/MemoryBuffer.h"
#include "llvm/Support/Streams.h"
#include "llvm/Support/Compressor.h"
using namespace llvm;
+static const bool Bitcode = false;
+
Linker::Linker(const std::string& progname, const std::string& modname, unsigned flags)
: Composite(0)
, LibPaths()
@@ -100,9 +104,21 @@ Linker::releaseModule() {
std::auto_ptr<Module>
Linker::LoadObject(const sys::Path &FN) {
std::string ParseErrorMessage;
- Module *Result = ParseBytecodeFile(FN.toString(),
- Compressor::decompressToNewBuffer,
- &ParseErrorMessage);
+ Module *Result = 0;
+
+ const std::string &FNS = FN.toString();
+ if (Bitcode) {
+ std::auto_ptr<MemoryBuffer> Buffer(
+ MemoryBuffer::getFileOrSTDIN(&FNS[0], FNS.size()));
+ if (Buffer.get())
+ Result = ParseBitcodeFile(Buffer.get(), &ParseErrorMessage);
+ else
+ ParseErrorMessage = "Error reading file '" + FNS + "'";
+
+ } else {
+ Result = ParseBytecodeFile(FNS, Compressor::decompressToNewBuffer,
+ &ParseErrorMessage);
+ }
if (Result)
return std::auto_ptr<Module>(Result);
Error = "Bytecode file '" + FN.toString() + "' could not be loaded";
@@ -137,6 +153,8 @@ static inline sys::Path IsLibrary(const std::string& Name,
return FullPath;
if (FullPath.isBytecodeFile()) // .so file containing bytecode?
return FullPath;
+ if (FullPath.isBitcodeFile()) // .so file containing bitcode?
+ return FullPath;
// Not found .. fall through