diff options
author | Chris Lattner <sabre@nondot.org> | 2004-12-03 07:16:51 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2004-12-03 07:16:51 +0000 |
commit | 33306c0b8c0eda81e92a5c17efe86a23a7f5aea0 (patch) | |
tree | 52d6c140b924904089dee9cc71bcf7d512674e7c /lib/ExecutionEngine/JIT/Intercept.cpp | |
parent | 1d656455829c491aba63b7101e0a5207370aefb9 (diff) | |
download | external_llvm-33306c0b8c0eda81e92a5c17efe86a23a7f5aea0.zip external_llvm-33306c0b8c0eda81e92a5c17efe86a23a7f5aea0.tar.gz external_llvm-33306c0b8c0eda81e92a5c17efe86a23a7f5aea0.tar.bz2 |
Do not look here for elegance.
This fixes the ugly darwin "cannot find symbols starting with __" issue.
Thanks for Owen/resistor for testing this out for me.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@18454 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/ExecutionEngine/JIT/Intercept.cpp')
-rw-r--r-- | lib/ExecutionEngine/JIT/Intercept.cpp | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/lib/ExecutionEngine/JIT/Intercept.cpp b/lib/ExecutionEngine/JIT/Intercept.cpp index 93d349f..669b6ba 100644 --- a/lib/ExecutionEngine/JIT/Intercept.cpp +++ b/lib/ExecutionEngine/JIT/Intercept.cpp @@ -99,6 +99,30 @@ void *JIT::getPointerToNamedFunction(const std::string &Name) { void *Ptr = sys::DynamicLibrary::SearchForAddressOfSymbol(Name); if (Ptr) return Ptr; + // If this is darwin, it has some funky issues, try to solve them here. Some + // important symbols are marked 'private external' which doesn't allow + // SearchForAddressOfSymbol to find them. As such, we special case them here, + // there is only a small handful of them. +#ifdef __APPLE__ + { + extern void *__ashldi3; if (Name == "__ashldi3") return &__ashldi3; + extern void *__ashrdi3; if (Name == "__ashrdi3") return &__ashrdi3; + extern void *__cmpdi2; if (Name == "__cmpdi2") return &__cmpdi2; + extern void *__divdi3; if (Name == "__divdi3") return &__divdi3; + extern void *__eprintf; if (Name == "__eprintf") return &__eprintf; + extern void *__fixdfdi; if (Name == "__fixdfdi") return &__fixdfdi; + extern void *__fixsfdi; if (Name == "__fixsfdi") return &__fixsfdi; + extern void *__fixunsdfdi; if (Name == "__fixunsdfdi") return &__fixunsdfdi; + extern void *__fixunssfdi; if (Name == "__fixunssfdi") return &__fixunssfdi; + extern void *__floatdidf; if (Name == "__floatdidf") return &__floatdidf; + extern void *__floatdisf; if (Name == "__floatdisf") return &__floatdisf; + extern void *__lshrdi3; if (Name == "__lshrdi3") return &__lshrdi3; + extern void *__moddi3; if (Name == "__moddi3") return &__moddi3; + extern void *__udivdi3; if (Name == "__udivdi3") return &__udivdi3; + extern void *__umoddi3; if (Name == "__umoddi3") return &__umoddi3; + } +#endif + std::cerr << "ERROR: Program used external function '" << Name << "' which could not be resolved!\n"; abort(); |