summaryrefslogtreecommitdiffstats
path: root/llvm/lib
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2004-05-27 20:53:10 +0000
committerChris Lattner <sabre@nondot.org>2004-05-27 20:53:10 +0000
commitdb3da22f4b42f64295eec38b5ad3d441c0b76e3c (patch)
treedca9dbd6d1c35c5d07fe290ed55b3387f495e8e4 /llvm/lib
parent94aac779e1f435503ef9c11c67b755c65d90b856 (diff)
downloadbcm5719-llvm-db3da22f4b42f64295eec38b5ad3d441c0b76e3c.tar.gz
bcm5719-llvm-db3da22f4b42f64295eec38b5ad3d441c0b76e3c.zip
Add DynamicLinker support for systems that provide windows.h
llvm-svn: 13851
Diffstat (limited to 'llvm/lib')
-rw-r--r--llvm/lib/Support/DynamicLinker.cpp31
1 files changed, 23 insertions, 8 deletions
diff --git a/llvm/lib/Support/DynamicLinker.cpp b/llvm/lib/Support/DynamicLinker.cpp
index 801f93b5ba3..cf00bea2db8 100644
--- a/llvm/lib/Support/DynamicLinker.cpp
+++ b/llvm/lib/Support/DynamicLinker.cpp
@@ -21,6 +21,7 @@
#include "Support/DynamicLinker.h"
#include "Config/dlfcn.h"
+#include "Config/windows.h"
#include <cassert>
using namespace llvm;
@@ -31,6 +32,16 @@ bool llvm::LinkDynamicObject (const char *filename, std::string *ErrorMessage) {
return true;
}
return false;
+#elif defined(HAVE_WINDOWS_H)
+ if (LoadLibrary(filename))
+ return false;
+ if (ErrorMessage) {
+ char Buffer[100];
+ // FIXME: This should use FormatMessage
+ sprintf(Buffer, "Windows error code %d\n", GetLastError());
+ *ErrorMessage = Buffer;
+ }
+ return true;
#else
assert (0 && "Dynamic object linking not implemented for this platform");
#endif
@@ -38,18 +49,22 @@ bool llvm::LinkDynamicObject (const char *filename, std::string *ErrorMessage) {
void *llvm::GetAddressOfSymbol (const char *symbolName) {
#if defined (HAVE_DLOPEN)
-#ifdef RTLD_DEFAULT
- return dlsym (RTLD_DEFAULT, symbolName);
-#else
- static void* CurHandle = dlopen(0, RTLD_LAZY);
- return dlsym(CurHandle, symbolName);
-#endif
+# ifdef RTLD_DEFAULT
+ return dlsym (RTLD_DEFAULT, symbolName);
+# else
+ static void* CurHandle = dlopen(0, RTLD_LAZY);
+ return dlsym(CurHandle, symbolName);
+# endif
+#elif defined(HAVE_WINDOWS_H)
+ static HMODULE ModHandle = NULL;
+ if (ModHandle == 0) ModHandle = GetModuleHandle(NULL);
+ return (void*)GetProcAddress(ModHandle, symbolName);
#else
assert (0 && "Dynamic symbol lookup not implemented for this platform");
#endif
}
// soft, cushiony C++ interface.
-void *llvm::GetAddressOfSymbol (const std::string &symbolName) {
- return GetAddressOfSymbol (symbolName.c_str ());
+void *llvm::GetAddressOfSymbol(const std::string &symbolName) {
+ return GetAddressOfSymbol(symbolName.c_str());
}
OpenPOWER on IntegriCloud