Clean up my last checkin: code is easier to read and explains the differences in
authorMisha Brukman <brukman+llvm@gmail.com>
Tue, 15 Jul 2003 15:58:26 +0000 (15:58 +0000)
committerMisha Brukman <brukman+llvm@gmail.com>
Tue, 15 Jul 2003 15:58:26 +0000 (15:58 +0000)
usage of the special file handle RTLD_SELF on Sparc/Solaris vs. 0 on Linux/x86.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@7177 91177308-0d34-0410-b5e6-96231b3b80d8

lib/ExecutionEngine/ExecutionEngine.cpp

index a661dd49b51dc3f5221f34376747c8e2f22b6c4b..74a3c867ed790d6f198f242ea0519230645a6af7 100644 (file)
@@ -362,12 +362,13 @@ void ExecutionEngine::emitGlobals() {
       // External variable reference, try to use dlsym to get a pointer to it in
       // the LLI image.
 #if defined(sparc) || defined(__sparc__) || defined(__sparcv9)
-      if (void *SymAddr = dlsym(RTLD_SELF, I->getName().c_str()))
-        GlobalAddress[I] = SymAddr;
+      // RTLD_SELF is already defined and it's not zero
 #else
-      if (void *SymAddr = dlsym(0, I->getName().c_str()))
-        GlobalAddress[I] = SymAddr;      
+      // Linux/x86 wants to use a 0, other systems may differ
+#define RTLD_SELF 0
 #endif
+      if (void *SymAddr = dlsym(RTLD_SELF, I->getName().c_str()))
+        GlobalAddress[I] = SymAddr;
       else {
         std::cerr << "Could not resolve external global address: "
                   << I->getName() << "\n";