summaryrefslogtreecommitdiffstats
path: root/lib/ExecutionEngine/JIT/Intercept.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2004-12-03 07:16:51 +0000
committerChris Lattner <sabre@nondot.org>2004-12-03 07:16:51 +0000
commit33306c0b8c0eda81e92a5c17efe86a23a7f5aea0 (patch)
tree52d6c140b924904089dee9cc71bcf7d512674e7c /lib/ExecutionEngine/JIT/Intercept.cpp
parent1d656455829c491aba63b7101e0a5207370aefb9 (diff)
downloadexternal_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.cpp24
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();