diff options
Diffstat (limited to 'lib/Support/DynamicLinker.cpp')
-rw-r--r-- | lib/Support/DynamicLinker.cpp | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/lib/Support/DynamicLinker.cpp b/lib/Support/DynamicLinker.cpp new file mode 100644 index 0000000000..7c52d3bb5b --- /dev/null +++ b/lib/Support/DynamicLinker.cpp @@ -0,0 +1,42 @@ +//===-- DynamicLinker.cpp - Implement DynamicLinker interface -------------===// +// +// Lightweight interface to dynamic library linking and loading, and dynamic +// symbol lookup functionality, in whatever form the operating system +// provides it. +// +// Possible future extensions include support for the HPUX shl_load() +// interface, the Mac OS X NSLinkModule() interface, and the Windows +// LoadLibrary() interface. +// +// Note that we assume that if dlopen() is available, then dlsym() is too. +// +//===----------------------------------------------------------------------===// + +#include "Support/DynamicLinker.h" +#include "Config/dlfcn.h" +#include <cassert> + +bool LinkDynamicObject (const char *filename, std::string *ErrorMessage) { +#if defined (HAVE_DLOPEN) + if (dlopen (filename, RTLD_NOW | RTLD_GLOBAL) == 0) { + if (ErrorMessage) *ErrorMessage = dlerror (); + return true; + } + return false; +#else + assert (0 && "Dynamic object linking not implemented for this platform"); +#endif +} + +void *GetAddressOfSymbol (const char *symbolName) { +#if defined (HAVE_DLOPEN) + return dlsym (RTLD_DEFAULT, symbolName); +#else + assert (0 && "Dynamic symbol lookup not implemented for this platform"); +#endif +} + +// soft, cushiony C++ interface. +void *GetAddressOfSymbol (const std::string &symbolName) { + return GetAddressOfSymbol (symbolName.c_str ()); +} |