From 0611d0141919bd8edf62ed043814a5d175177241 Mon Sep 17 00:00:00 2001 From: Zachary Turner Date: Wed, 27 Aug 2014 17:06:22 +0000 Subject: Limit the symbol search in DynamicLibrary to the module that was opened. Differential Revision: http://reviews.llvm.org/D5030 Reviewed By: Reid Kleckner, Rafael Espindola llvm-svn: 216563 --- llvm/lib/Support/DynamicLibrary.cpp | 11 +++++++++-- 1 file changed, 9 insertions(+), 2 deletions(-) (limited to 'llvm/lib/Support/DynamicLibrary.cpp') diff --git a/llvm/lib/Support/DynamicLibrary.cpp b/llvm/lib/Support/DynamicLibrary.cpp index d2b551e8a0a..40072636608 100644 --- a/llvm/lib/Support/DynamicLibrary.cpp +++ b/llvm/lib/Support/DynamicLibrary.cpp @@ -56,8 +56,15 @@ static DenseSet *OpenedHandles = nullptr; DynamicLibrary DynamicLibrary::getPermanentLibrary(const char *filename, std::string *errMsg) { SmartScopedLock lock(*SymbolsMutex); - - void *handle = dlopen(filename, RTLD_LAZY|RTLD_GLOBAL); + int flags = RTLD_LAZY | RTLD_GLOBAL; +#if defined(__APPLE__) + // RTLD_FIRST is an apple specific flag which causes dlsym() to search only + // the module specified in |filename|, and not dependent modules. This + // behavior would be desirable for other platforms as well, except that + // there's not a good way to implement it. + flags |= RTLD_FIRST; +#endif + void *handle = dlopen(filename, flags); if (!handle) { if (errMsg) *errMsg = dlerror(); return DynamicLibrary(); -- cgit v1.2.3