mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2024-12-13 20:32:21 +00:00
Clean up code dealing with RTLD_SELF differences on Sparc and X86.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@7362 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
df38dae949
commit
d94a50f99d
@ -54,11 +54,12 @@ void *VM::getPointerToNamedFunction(const std::string &Name) {
|
|||||||
if (Name == "atexit") return (void*)&jit_atexit;
|
if (Name == "atexit") return (void*)&jit_atexit;
|
||||||
|
|
||||||
// If it's an external function, look it up in the process image...
|
// If it's an external function, look it up in the process image...
|
||||||
#if defined(i386) || defined(__i386__) || defined(__x86__)
|
// On Sparc, RTLD_SELF is already defined and it's not zero
|
||||||
void *Ptr = dlsym(0, Name.c_str());
|
// Linux/x86 wants to use a 0, other systems may differ
|
||||||
#elif defined(sparc) || defined(__sparc__) || defined(__sparcv9)
|
#ifndef RTLD_SELF
|
||||||
void *Ptr = dlsym(RTLD_SELF, Name.c_str());
|
#define RTLD_SELF 0
|
||||||
#endif
|
#endif
|
||||||
|
void *Ptr = dlsym(RTLD_SELF, Name.c_str());
|
||||||
if (Ptr == 0) {
|
if (Ptr == 0) {
|
||||||
std::cerr << "WARNING: Cannot resolve fn '" << Name
|
std::cerr << "WARNING: Cannot resolve fn '" << Name
|
||||||
<< "' using a dummy noop function instead!\n";
|
<< "' using a dummy noop function instead!\n";
|
||||||
@ -67,4 +68,3 @@ void *VM::getPointerToNamedFunction(const std::string &Name) {
|
|||||||
|
|
||||||
return Ptr;
|
return Ptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user