From 3a071284e01512e82215c9b2aba73892dd654e8d Mon Sep 17 00:00:00 2001 From: Peter Collingbourne Date: Tue, 30 Dec 2014 22:52:33 +0000 Subject: [PATCH] RTDyldMemoryManager.cpp: Make the reference to __morestack weak. This fixes the DSO build for now. Eventually we should develop some other mechanism to make this work correctly with DSOs. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@225014 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/ExecutionEngine/RTDyldMemoryManager.cpp | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/lib/ExecutionEngine/RTDyldMemoryManager.cpp b/lib/ExecutionEngine/RTDyldMemoryManager.cpp index 975954b538a..2a5e4f83228 100644 --- a/lib/ExecutionEngine/RTDyldMemoryManager.cpp +++ b/lib/ExecutionEngine/RTDyldMemoryManager.cpp @@ -13,6 +13,7 @@ #include "llvm/Config/config.h" #include "llvm/ExecutionEngine/RTDyldMemoryManager.h" +#include "llvm/Support/Compiler.h" #include "llvm/Support/DynamicLibrary.h" #include "llvm/Support/ErrorHandling.h" #include @@ -212,7 +213,7 @@ ARM_MATH_IMPORTS(ARM_MATH_DECL) #if defined(__linux__) && defined(__GLIBC__) && \ (defined(__i386__) || defined(__x86_64__)) -extern "C" void __morestack(); +extern "C" LLVM_ATTRIBUTE_WEAK void __morestack(); #endif uint64_t @@ -241,7 +242,8 @@ RTDyldMemoryManager::getSymbolAddressInProcess(const std::string &Name) { #if defined(__i386__) || defined(__x86_64__) // __morestack lives in libgcc, a static library. - if (Name == "__morestack") return (uint64_t)&__morestack; + if (&__morestack && Name == "__morestack") + return (uint64_t)&__morestack; #endif #endif // __linux__ && __GLIBC__ -- 2.34.1