mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-07-30 02:25:19 +00:00
Use DynamicLibrary instances as a way to get symbols from a specific library. Preparation for upcoming (preliminary) support for plugins for the static analyzer.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@137791 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -39,7 +39,7 @@ using namespace sys;
|
||||
//=== and must not be UNIX code.
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
static std::vector<HMODULE> OpenedHandles;
|
||||
static DenseSet<HMODULE> *OpenedHandles;
|
||||
|
||||
extern "C" {
|
||||
|
||||
@@ -63,30 +63,43 @@ extern "C" {
|
||||
#endif
|
||||
stricmp(ModuleName, "msvcrt20") != 0 &&
|
||||
stricmp(ModuleName, "msvcrt40") != 0) {
|
||||
OpenedHandles.push_back((HMODULE)ModuleBase);
|
||||
OpenedHandles->push_back((HMODULE)ModuleBase);
|
||||
}
|
||||
return TRUE;
|
||||
}
|
||||
}
|
||||
|
||||
bool DynamicLibrary::LoadLibraryPermanently(const char *filename,
|
||||
std::string *ErrMsg) {
|
||||
if (filename) {
|
||||
HMODULE a_handle = LoadLibrary(filename);
|
||||
DynamicLibrary DynamicLibrary::getPermanentLibrary(const char *filename,
|
||||
std::string *errMsg) {
|
||||
if (!filename) {
|
||||
// When no file is specified, enumerate all DLLs and EXEs in the process.
|
||||
SmartScopedLock<true> lock(getMutex());
|
||||
if (OpenedHandles == 0)
|
||||
OpenedHandles = new DenseSet<HMODULE>();
|
||||
|
||||
if (a_handle == 0)
|
||||
return MakeErrMsg(ErrMsg, std::string(filename) + ": Can't open : ");
|
||||
|
||||
OpenedHandles.push_back(a_handle);
|
||||
} else {
|
||||
// When no file is specified, enumerate all DLLs and EXEs in the
|
||||
// process.
|
||||
EnumerateLoadedModules(GetCurrentProcess(), ELM_Callback, 0);
|
||||
// Dummy library that represents "search all handles".
|
||||
// This is mostly to ensure that the return value still shows up as "valid".
|
||||
return DynamicLibrary(&OpenedHandles);
|
||||
}
|
||||
|
||||
HMODULE a_handle = LoadLibrary(filename);
|
||||
|
||||
if (a_handle == 0) {
|
||||
MakeErrMsg(ErrMsg, std::string(filename) + ": Can't open : ");
|
||||
return DynamicLibrary();
|
||||
}
|
||||
|
||||
// Because we don't remember the handle, we will never free it; hence,
|
||||
// it is loaded permanently.
|
||||
return false;
|
||||
SmartScopedLock<true> lock(getMutex());
|
||||
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 (!OpenedHandles->insert(a_handle).second)
|
||||
FreeLibrary(a_handle);
|
||||
|
||||
return DynamicLibrary(a_handle);
|
||||
}
|
||||
|
||||
// Stack probing routines are in the support library (e.g. libgcc), but we don't
|
||||
@@ -101,21 +114,24 @@ bool DynamicLibrary::LoadLibraryPermanently(const char *filename,
|
||||
#undef EXPLICIT_SYMBOL2
|
||||
|
||||
void* DynamicLibrary::SearchForAddressOfSymbol(const char* symbolName) {
|
||||
SmartScopedLock<true> Lock(getMutex());
|
||||
|
||||
// First check symbols added via AddSymbol().
|
||||
if (ExplicitSymbols) {
|
||||
std::map<std::string, void *>::iterator I =
|
||||
ExplicitSymbols->find(symbolName);
|
||||
std::map<std::string, void *>::iterator E = ExplicitSymbols->end();
|
||||
if (I != E)
|
||||
return I->second;
|
||||
StringMap<void *>::iterator i = ExplicitSymbols->find(symbolName);
|
||||
|
||||
if (i != ExplicitSymbols->end())
|
||||
return i->second;
|
||||
}
|
||||
|
||||
// Now search the libraries.
|
||||
for (std::vector<HMODULE>::iterator I = OpenedHandles.begin(),
|
||||
E = OpenedHandles.end(); I != E; ++I) {
|
||||
FARPROC ptr = GetProcAddress((HMODULE)*I, symbolName);
|
||||
if (ptr) {
|
||||
return (void *)(intptr_t)ptr;
|
||||
if (OpenedHandles) {
|
||||
for (DenseSet<HMODULE>::iterator I = OpenedHandles->begin(),
|
||||
E = OpenedHandles->end(); I != E; ++I) {
|
||||
FARPROC ptr = GetProcAddress((HMODULE)*I, symbolName);
|
||||
if (ptr) {
|
||||
return (void *)(intptr_t)ptr;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -134,4 +150,14 @@ void* DynamicLibrary::SearchForAddressOfSymbol(const char* symbolName) {
|
||||
return 0;
|
||||
}
|
||||
|
||||
|
||||
void *DynamicLibrary::getAddressOfSymbol(const char *symbolName) {
|
||||
if (!isValid())
|
||||
return NULL;
|
||||
if (Data == &OpenedHandles)
|
||||
return SearchForAddressOfSymbol(symbolName);
|
||||
return (void *)(intptr_t)GetProcAddress((HMODULE)Data, symbolName);
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
Reference in New Issue
Block a user