From: Chris Lattner Date: Thu, 29 Jan 2009 04:43:42 +0000 (+0000) Subject: Fix PR3424, a static constructor ordering issue. Patch by Robert Schuster! X-Git-Url: http://plrg.eecs.uci.edu/git/?a=commitdiff_plain;h=cee3e7cb6830664a0b228211923589b5d72c93d4;p=oota-llvm.git Fix PR3424, a static constructor ordering issue. Patch by Robert Schuster! git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@63269 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/System/DynamicLibrary.cpp b/lib/System/DynamicLibrary.cpp index 970266f3438..3bf172c22b3 100644 --- a/lib/System/DynamicLibrary.cpp +++ b/lib/System/DynamicLibrary.cpp @@ -18,11 +18,14 @@ #include // Collection of symbol name/value pairs to be searched prior to any libraries. -static std::map g_symbols; +std::map &g_symbols() { + static std::map symbols; + return symbols; +} void llvm::sys::DynamicLibrary::AddSymbol(const char* symbolName, void *symbolValue) { - g_symbols[symbolName] = symbolValue; + g_symbols()[symbolName] = symbolValue; } // It is not possible to use ltdl.c on VC++ builds as the terms of its LGPL @@ -76,8 +79,8 @@ void* DynamicLibrary::SearchForAddressOfSymbol(const char* symbolName) { // check_ltdl_initialization(); // First check symbols added via AddSymbol(). - std::map::iterator I = g_symbols.find(symbolName); - if (I != g_symbols.end()) + std::map::iterator I = g_symbols().find(symbolName); + if (I != g_symbols().end()) return I->second; // Now search the libraries.