diff options
| -rw-r--r-- | llvm/lib/ExecutionEngine/JIT/Intercept.cpp | 10 | 
1 files changed, 5 insertions, 5 deletions
diff --git a/llvm/lib/ExecutionEngine/JIT/Intercept.cpp b/llvm/lib/ExecutionEngine/JIT/Intercept.cpp index ba49bbde05d..10fd97015f2 100644 --- a/llvm/lib/ExecutionEngine/JIT/Intercept.cpp +++ b/llvm/lib/ExecutionEngine/JIT/Intercept.cpp @@ -54,11 +54,12 @@ void *VM::getPointerToNamedFunction(const std::string &Name) {    if (Name == "atexit") return (void*)&jit_atexit;    // If it's an external function, look it up in the process image... -#if defined(i386) || defined(__i386__) || defined(__x86__) -  void *Ptr = dlsym(0, Name.c_str()); -#elif defined(sparc) || defined(__sparc__) || defined(__sparcv9) -  void *Ptr = dlsym(RTLD_SELF, Name.c_str()); +  // On Sparc, RTLD_SELF is already defined and it's not zero +  // Linux/x86 wants to use a 0, other systems may differ +#ifndef RTLD_SELF +#define RTLD_SELF 0  #endif +  void *Ptr = dlsym(RTLD_SELF, Name.c_str());    if (Ptr == 0) {      std::cerr << "WARNING: Cannot resolve fn '" << Name  	      << "' using a dummy noop function instead!\n"; @@ -67,4 +68,3 @@ void *VM::getPointerToNamedFunction(const std::string &Name) {    return Ptr;  } -  | 

