From e2a812447639d3a5ca012834e804ce5320be3ea2 Mon Sep 17 00:00:00 2001 From: Brian Gaeke Date: Fri, 10 Oct 2003 16:55:42 +0000 Subject: Add my abstracted dynamic linker support files. llvm-svn: 9008 --- llvm/lib/Support/DynamicLinker.cpp | 42 ++++++++++++++++++++++++++++++++++++++ 1 file changed, 42 insertions(+) create mode 100644 llvm/lib/Support/DynamicLinker.cpp (limited to 'llvm/lib/Support/DynamicLinker.cpp') diff --git a/llvm/lib/Support/DynamicLinker.cpp b/llvm/lib/Support/DynamicLinker.cpp new file mode 100644 index 00000000000..7c52d3bb5b1 --- /dev/null +++ b/llvm/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 + +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 ()); +} -- cgit v1.2.3