diff options
Diffstat (limited to 'llvm/lib')
-rw-r--r-- | llvm/lib/Support/DynamicLibrary.cpp | 26 | ||||
-rw-r--r-- | llvm/lib/Support/Windows/DynamicLibrary.inc | 39 |
2 files changed, 14 insertions, 51 deletions
diff --git a/llvm/lib/Support/DynamicLibrary.cpp b/llvm/lib/Support/DynamicLibrary.cpp index d3983fb4437..74d94d33d5a 100644 --- a/llvm/lib/Support/DynamicLibrary.cpp +++ b/llvm/lib/Support/DynamicLibrary.cpp @@ -68,34 +68,10 @@ DynamicLibrary DynamicLibrary::getPermanentLibrary(const char *filename, handle = RTLD_DEFAULT; #endif - DynamicLibrary dyLib = addPermanentLibraryWithLock(handle, lock, !filename); - // If we've already loaded this library, dlclose() the handle in order to // keep the internal refcount at +1. - if (!dyLib.isValid()) { - if (errMsg) - *errMsg = (filename) ? std::string(filename) : std::string() + - ": Library already loaded"; + if (!OpenedHandles->insert(handle).second) dlclose(handle); - } - - return dyLib; -} - -DynamicLibrary DynamicLibrary::addPermanentLibrary(void *handle) { - SmartScopedLock<true> lock(*SymbolsMutex); - return addPermanentLibraryWithLock(handle, lock, false); -} - -DynamicLibrary DynamicLibrary::addPermanentLibraryWithLock(void *handle, - sys::SmartScopedLock<true> &, - bool isMainExec) { - // If we've already loaded this library, tell the caller. - // FIXME: Note that multiple requests for adding the main executable is not - // considered as an error. If we don't want to treat the main executable as a - // special case we need to do a cleanup in the MCJIT tests and API. - if (!OpenedHandles->insert(handle).second && !isMainExec) - return DynamicLibrary(); return DynamicLibrary(handle); } diff --git a/llvm/lib/Support/Windows/DynamicLibrary.inc b/llvm/lib/Support/Windows/DynamicLibrary.inc index 85685668fa1..87dde46de3c 100644 --- a/llvm/lib/Support/Windows/DynamicLibrary.inc +++ b/llvm/lib/Support/Windows/DynamicLibrary.inc @@ -9,6 +9,8 @@ // // This file provides the Win32 specific implementation of DynamicLibrary. // +// FIXME: This file leaks OpenedHandles! +// //===----------------------------------------------------------------------===// #include "WindowsSupport.h" @@ -33,7 +35,7 @@ using namespace sys; typedef BOOL (WINAPI *fpEnumerateLoadedModules)(HANDLE,PENUMLOADED_MODULES_CALLBACK64,PVOID); static fpEnumerateLoadedModules fEnumerateLoadedModules; -static llvm::ManagedStatic<DenseSet<HMODULE> > OpenedHandles; +static DenseSet<HMODULE> *OpenedHandles; static bool loadDebugHelp(void) { HMODULE hLib = ::LoadLibraryW(L"Dbghelp.dll"); @@ -57,6 +59,9 @@ DynamicLibrary DynamicLibrary::getPermanentLibrary(const char *filename, if (!filename) { // When no file is specified, enumerate all DLLs and EXEs in the process. + if (OpenedHandles == 0) + OpenedHandles = new DenseSet<HMODULE>(); + if (!fEnumerateLoadedModules) { if (!loadDebugHelp()) { assert(false && "These APIs should always be available"); @@ -76,7 +81,7 @@ DynamicLibrary DynamicLibrary::getPermanentLibrary(const char *filename, MakeErrMsg(errMsg, std::string(filename) + ": Can't convert to UTF-16"); return DynamicLibrary(); } - + HMODULE a_handle = LoadLibraryW(filenameUnicode.data()); if (a_handle == 0) { @@ -84,33 +89,15 @@ DynamicLibrary DynamicLibrary::getPermanentLibrary(const char *filename, return DynamicLibrary(); } - DynamicLibrary dyLib = addPermanentLibraryWithLock(a_handle, lock, !filename); + if (OpenedHandles == 0) + OpenedHandles = new DenseSet<HMODULE>(); + // If we've already loaded this library, FreeLibrary() the handle in order to // keep the internal refcount at +1. - if (!dyLib.isValid()) { - MakeErrMsg(errMsg, std::string(filename) + ": Already loaded"); + if (!OpenedHandles->insert(a_handle).second) FreeLibrary(a_handle); - } - - return dyLib; -} - -DynamicLibrary DynamicLibrary::addPermanentLibrary(void *handle) { - SmartScopedLock<true> lock(*SymbolsMutex); - return addPermanentLibraryWithLock(handle, lock, false); -} - -DynamicLibrary DynamicLibrary::addPermanentLibraryWithLock(void *handle, - sys::SmartScopedLock<true> &, - bool isMainExec) { - // If we've already loaded this library, tell the caller. - // FIXME: Note that multiple requests for adding the main executable is not - // considered as an error. If we don't want to treat the main executable as a - // special case we need to do a cleanup in the MCJIT tests and API. - if (!OpenedHandles->insert((const HMODULE)handle).second && !isMainExec) - return DynamicLibrary(); - return DynamicLibrary((HMODULE)handle); + return DynamicLibrary(a_handle); } // Stack probing routines are in the support library (e.g. libgcc), but we don't @@ -150,7 +137,7 @@ void* DynamicLibrary::SearchForAddressOfSymbol(const char* symbolName) { } // Now search the libraries. - if (OpenedHandles.isConstructed()) { + if (OpenedHandles) { for (DenseSet<HMODULE>::iterator I = OpenedHandles->begin(), E = OpenedHandles->end(); I != E; ++I) { FARPROC ptr = GetProcAddress((HMODULE)*I, symbolName); |