aboutsummaryrefslogtreecommitdiffstats
path: root/lib/System/DynamicLibrary.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2010-04-09 20:45:04 +0000
committerChris Lattner <sabre@nondot.org>2010-04-09 20:45:04 +0000
commita3872cd664c9d9fd08524e27ea258cff32fe6fc8 (patch)
tree31267a53e38be19682f5395c271d5191c9e2766f /lib/System/DynamicLibrary.cpp
parent3716552fc25a3c4ea11094b44126071017a2224b (diff)
downloadexternal_llvm-a3872cd664c9d9fd08524e27ea258cff32fe6fc8.zip
external_llvm-a3872cd664c9d9fd08524e27ea258cff32fe6fc8.tar.gz
external_llvm-a3872cd664c9d9fd08524e27ea258cff32fe6fc8.tar.bz2
add minix support, patch by Kees van Reeuwijk! PR6797
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@100895 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/System/DynamicLibrary.cpp')
-rw-r--r--lib/System/DynamicLibrary.cpp14
1 files changed, 14 insertions, 0 deletions
diff --git a/lib/System/DynamicLibrary.cpp b/lib/System/DynamicLibrary.cpp
index d6f3140..ebc8acf 100644
--- a/lib/System/DynamicLibrary.cpp
+++ b/lib/System/DynamicLibrary.cpp
@@ -44,6 +44,7 @@ void llvm::sys::DynamicLibrary::AddSymbol(const char* symbolName,
#else
+#if HAVE_DLFCN_H
#include <dlfcn.h>
using namespace llvm;
using namespace llvm::sys;
@@ -68,6 +69,17 @@ bool DynamicLibrary::LoadLibraryPermanently(const char *Filename,
OpenedHandles->push_back(H);
return false;
}
+#else
+
+using namespace llvm;
+using namespace llvm::sys;
+
+bool DynamicLibrary::LoadLibraryPermanently(const char *Filename,
+ std::string *ErrMsg) {
+ if (ErrMsg) *ErrMsg = "dlopen() not supported on this platform";
+ return true;
+}
+#endif
namespace llvm {
void *SearchForAddressOfSpecialSymbol(const char* symbolName);
@@ -84,6 +96,7 @@ void* DynamicLibrary::SearchForAddressOfSymbol(const char* symbolName) {
return I->second;
}
+#if HAVE_DLFCN_H
// Now search the libraries.
if (OpenedHandles) {
for (std::vector<void *>::iterator I = OpenedHandles->begin(),
@@ -95,6 +108,7 @@ void* DynamicLibrary::SearchForAddressOfSymbol(const char* symbolName) {
}
}
}
+#endif
if (void *Result = llvm::SearchForAddressOfSpecialSymbol(symbolName))
return Result;