Alessandro Pistocchi via llvm-dev
2017-Jun-28 16:31 UTC
[llvm-dev] Building llvm with clang and lld on arm and the llvm arm backend relocation on position independent code
Oh, so it looks like I hit a bit of a wall there :-) I’ll take a look thanks. That bug talks about R_ARM_THM_CALL which I assume are thumb related. Will your implementation fix also R_ARM_CALL errors?> On 28 Jun 2017, at 17:15, Peter Smith <peter.smith at linaro.org> wrote: > > Hello Alessandro, > > The LLD ARM port doesn't currently support range extension thunks, > these are needed to extend the range of ARM branch relocations when > the size of the executable instructions exceeds the maximum branch > range. > > I have an implementation in review but it is a fairly large change so > it may take some time to get through the review process, I've raised > https://bugs.llvm.org/show_bug.cgi?id=33612 that has a link to the > Phab reviews. If you are willing to build your own lld with additional > changes, you might be able to test out those patches. > > Good luck > > Peter > > On 28 June 2017 at 17:09, Alessandro Pistocchi <apukfreelance at gmail.com> wrote: >> >>> On 27 Jun 2017, at 13:25, Peter Smith <peter.smith at linaro.org> wrote: >>> >>> Hello Alessandro, >>> >>> Despite the statement in the HowToCrossCompileLLVM guide "If you’re >>> using Clang as the cross-compiler, there is a problem in the LLVM ARM >>> back-end that is producing absolute relocations on >>> position-independent code (R_ARM_THM_MOVW_ABS_NC), so for now, you >>> should disable PIC:" I can't find an existing upstream PR or any >>> record that this has been fixed. If the ARM backend is still producing >>> an R_ARM_THM_MOVW_ABS_NC relocation when -fpic is given as an option >>> then it would be great to get a small reproducible example in a new >>> PR, or if there is one already to update it. >>> >>> The last time I ran into this error when trying to cross compile was >>> that a dependency not compiled by clang (libtinfo.a) library contained >>> an R_ARM_THM_MOVW_ABS_NC relocation. I don't think that this is the >>> fault of clang/llvm though, I think it was my fault in installing a >>> non pic compiled version of libtinfo.a (I'm still trying to learn how >>> Ubuntu multilibs work). >>> >>> Would it be possible for you to share the details of which objects >>> contain the R_ARM_THM_MOVW_ABS_NC relocations when compiled -fpic? >> >> Hi, the errors I get do not seen to mention R_ARM_THM_MOVW_ABS_NC. >> >> The errors are “relocation R_ARM_CALL out of range”. >> >> Today I recompiled everything from scratch with -fPIC to make sure I had no library compiled without it and I still get the same errors. >> >> Sorry, I could not find any trivial code that has the same issue yet. >> >> Following is the output of the compilation process: >> >> yawmoo at yawmoo-MRNM3AP:~/Desktop/clfs/sources/llvm-build-native-with-lld$ cmake --build . >> [ 0%] Built target LLVMDemangle >> [ 3%] Built target LLVMSupport >> [ 3%] Built target LLVMTableGen >> [ 4%] Built target obj.llvm-tblgen >> [ 4%] Built target llvm-tblgen >> [ 4%] Built target AttributeCompatFuncTableGen >> [ 4%] Built target intrinsics_gen >> [ 6%] Built target LLVMCore >> [ 6%] Built target LLVMIRReader >> [ 13%] Built target LLVMCodeGen >> [ 14%] Built target LLVMSelectionDAG >> [ 14%] Built target LLVMAsmPrinter >> [ 14%] Built target LLVMMIRParser >> [ 14%] Built target LLVMGlobalISel >> [ 14%] Built target LLVMBinaryFormat >> [ 14%] Built target LLVMBitReader >> [ 16%] Built target LLVMBitWriter >> [ 18%] Built target LLVMTransformUtils >> [ 19%] Built target LLVMInstrumentation >> [ 19%] Built target LLVMInstCombine >> [ 22%] Built target LLVMScalarOpts >> [ 22%] Built target LLVMipo >> [ 24%] Built target LLVMVectorize >> [ 24%] Built target LLVMHello_exports >> [ 24%] Built target LLVMHello >> [ 26%] Built target LLVMObjCARCOpts >> [ 26%] Built target LLVMCoroutines >> [ 26%] Built target LLVMLinker >> [ 29%] Built target LLVMAnalysis >> [ 29%] Built target llvm_vcsrevision_h >> [ 29%] Built target LLVMLTO >> [ 32%] Built target LLVMMC >> [ 32%] Built target LLVMMCParser >> [ 32%] Built target LLVMMCDisassembler >> [ 32%] Built target LLVMObject >> [ 32%] Built target LLVMObjectYAML >> [ 34%] Built target LLVMOption >> [ 36%] Built target LLVMDebugInfoDWARF >> [ 36%] Built target LLVMDebugInfoMSF >> [ 37%] Built target LLVMDebugInfoCodeView >> [ 40%] Built target LLVMDebugInfoPDB >> [ 42%] Built target LLVMSymbolize >> [ 42%] Built target LLVMExecutionEngine >> [ 42%] Built target LLVMInterpreter >> [ 42%] Built target LLVMMCJIT >> [ 42%] Built target LLVMOrcJIT >> [ 42%] Built target LLVMRuntimeDyld >> [ 42%] Built target LLVMTarget >> [ 44%] Built target ARMCommonTableGen >> [ 45%] Built target LLVMARMCodeGen >> [ 45%] Built target LLVMARMInfo >> [ 45%] Built target LLVMARMAsmParser >> [ 45%] Built target LLVMARMDisassembler >> [ 45%] Built target LLVMARMAsmPrinter >> [ 45%] Built target LLVMARMDesc >> [ 47%] Built target LLVMAsmParser >> [ 47%] Built target LLVMLineEditor >> [ 47%] Built target LLVMProfileData >> [ 47%] Built target LLVMCoverage >> [ 49%] Built target LLVMFuzzerNoMainObjects >> [ 49%] Built target LLVMFuzzerNoMain >> [ 49%] Built target LLVMFuzzer >> [ 49%] Built target LLVMPasses >> [ 49%] Built target LibOptionsTableGen >> [ 49%] Built target LLVMLibDriver >> [ 49%] Built target LLVMXRay >> [ 49%] Built target gtest >> [ 49%] Built target LLVMTestingSupport >> [ 49%] Built target FileCheck >> [ 49%] Built target llvm-PerfectShuffle >> [ 49%] Built target count >> [ 49%] Built target not >> [ 49%] Built target yaml-bench >> [ 49%] Built target LTO_exports >> [ 50%] Built target LTO >> [ 50%] Built target llvm-ar >> [ 50%] Built target llvm-ranlib >> [ 50%] Built target llvm-lib >> [ 50%] Built target llvm-config >> [ 50%] Built target llvm-lto >> [ 50%] Built target llvm-profdata >> [ 50%] Built target obj.clang-tblgen >> [ 50%] Built target clang-tblgen >> [ 55%] Built target clang-headers >> [ 55%] Built target ClangSACheckers >> [ 55%] Built target ClangCommentCommandList >> [ 55%] Built target ClangCommentCommandInfo >> [ 55%] Built target ClangAttrVisitor >> [ 55%] Built target ClangCommentHTMLNamedCharacterReferences >> [ 55%] Built target ClangAttrDump >> [ 55%] Built target ClangAttrImpl >> [ 55%] Built target ClangAttrClasses >> [ 55%] Built target ClangStmtNodes >> [ 55%] Built target ClangDeclNodes >> [ 55%] Built target ClangCommentNodes >> [ 55%] Built target ClangCommentHTMLTagsProperties >> [ 55%] Built target ClangCommentHTMLTags >> [ 55%] Built target ClangDiagnosticIndexName >> [ 55%] Built target ClangDiagnosticSerialization >> [ 55%] Built target ClangDiagnosticAnalysis >> [ 55%] Built target ClangDiagnosticAST >> [ 55%] Built target ClangDiagnosticParse >> [ 55%] Built target ClangDiagnosticLex >> [ 55%] Built target ClangDiagnosticSema >> [ 55%] Built target ClangDiagnosticComment >> [ 57%] Built target ClangDiagnosticGroups >> [ 57%] Built target ClangDiagnosticDriver >> [ 57%] Built target ClangAttrList >> [ 57%] Built target ClangDiagnosticFrontend >> [ 57%] Built target ClangAttrHasAttributeImpl >> [ 57%] Built target ClangDiagnosticCommon >> [ 57%] Built target ClangAttrSubjectMatchRuleList >> [ 57%] Built target ClangARMNeon >> [ 59%] Built target ClangAttrParserStringSwitches >> [ 59%] Built target ClangAttrSubMatchRulesParserStringSwitches >> [ 59%] Built target ClangAttrParsedAttrKinds >> [ 59%] Built target ClangAttrSpellingListIndex >> [ 59%] Built target ClangAttrParsedAttrList >> [ 59%] Built target ClangAttrParsedAttrImpl >> [ 59%] Built target ClangAttrTemplateInstantiate >> [ 59%] Built target ClangAttrPCHRead >> [ 59%] Built target ClangAttrPCHWrite >> [ 60%] Built target clangBasic >> [ 62%] Built target clangLex >> [ 62%] Built target clangParse >> [ 63%] Built target clangAST >> [ 63%] Built target clangASTMatchers >> [ 63%] Built target clangDynamicASTMatchers >> [ 65%] Built target clangSema >> [ 67%] Built target clangCodeGen >> [ 68%] Built target clangAnalysis >> [ 68%] Built target clangEdit >> [ 70%] Built target clangRewrite >> [ 72%] Built target clangARCMigrate >> [ 72%] Built target ClangDriverOptions >> [ 75%] Built target clangDriver >> [ 75%] Built target clangSerialization >> [ 77%] Built target clangFrontend >> [ 77%] Built target clangRewriteFrontend >> [ 77%] Built target clangFrontendTool >> [ 77%] Built target clangTooling >> [ 77%] Built target clangToolingCore >> [ 77%] Built target clangToolingRefactor >> [ 77%] Built target clangIndex >> [ 78%] Built target clangStaticAnalyzerCore >> [ 83%] Built target clangStaticAnalyzerCheckers >> [ 83%] Built target clangStaticAnalyzerFrontend >> [ 83%] Built target clangFormat >> [ 85%] Built target diagtool >> [ 85%] Built target clang-offload-bundler >> [ 85%] Linking CXX executable ../../../../bin/clang >> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAliasAnalysis.cpp:(function llvm::Pass* llvm::callDefaultCtor<llvm::objcarc::ObjCARCAAWrapperPass>()): relocation R_ARM_CALL out of range >> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAliasAnalysis.cpp:(function llvm::Pass* llvm::callDefaultCtor<llvm::objcarc::ObjCARCAAWrapperPass>()): relocation R_ARM_CALL out of range >> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/tools/clang/lib/StaticAnalyzer/Core/CallEvent.cpp:(function clang::ento::CXXDestructorCall* clang::ento::CallEventManager::create<clang::ento::CXXDestructorCall, clang::CXXDestructorDecl const*, clang::Stmt const*, clang::ento::MemRegion const*, bool>(clang::CXXDestructorDecl const*, clang::Stmt const*, clang::ento::MemRegion const*, bool, llvm::IntrusiveRefCntPtr<clang::ento::ProgramState const>, clang::LocationContext const*)): relocation R_ARM_CALL out of range >> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAliasAnalysis.cpp:(function llvm::Pass* llvm::callDefaultCtor<llvm::objcarc::ObjCARCAAWrapperPass>()): relocation R_ARM_CALL out of range >> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAliasAnalysis.cpp:(function llvm::Pass* llvm::callDefaultCtor<llvm::objcarc::ObjCARCAAWrapperPass>()): relocation R_ARM_CALL out of range >> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAliasAnalysis.cpp:(function llvm::Pass* llvm::callDefaultCtor<llvm::objcarc::ObjCARCAAWrapperPass>()): relocation R_ARM_CALL out of range >> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAnalysisUtils.cpp:(function llvm::cl::opt<bool, true, llvm::cl::parser<bool> >::opt<char [21], llvm::cl::desc, llvm::cl::LocationClass<bool>, llvm::cl::initializer<bool> >(char const (&) [21], llvm::cl::desc const&, llvm::cl::LocationClass<bool> const&, llvm::cl::initializer<bool> const&)): relocation R_ARM_CALL out of range >> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAnalysisUtils.cpp:(function llvm::cl::opt<bool, true, llvm::cl::parser<bool> >::opt<char [21], llvm::cl::desc, llvm::cl::LocationClass<bool>, llvm::cl::initializer<bool> >(char const (&) [21], llvm::cl::desc const&, llvm::cl::LocationClass<bool> const&, llvm::cl::initializer<bool> const&)): relocation R_ARM_CALL out of range >> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAnalysisUtils.cpp:(function llvm::cl::opt<bool, true, llvm::cl::parser<bool> >::opt<char [21], llvm::cl::desc, llvm::cl::LocationClass<bool>, llvm::cl::initializer<bool> >(char const (&) [21], llvm::cl::desc const&, llvm::cl::LocationClass<bool> const&, llvm::cl::initializer<bool> const&)): relocation R_ARM_CALL out of range >> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAnalysisUtils.cpp:(function _GLOBAL__sub_I_ObjCARCAnalysisUtils.cpp): relocation R_ARM_CALL out of range >> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::operator<<(llvm::raw_ostream&, llvm::objcarc::ARCInstKind)): relocation R_ARM_CALL out of range >> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::operator<<(llvm::raw_ostream&, llvm::objcarc::ARCInstKind)): relocation R_ARM_CALL out of range >> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::GetFunctionClass(llvm::Function const*)): relocation R_ARM_CALL out of range >> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/tools/clang/lib/StaticAnalyzer/Core/CallEvent.cpp:(function clang::ento::CXXDestructorCall* clang::ento::CallEventManager::create<clang::ento::CXXDestructorCall, clang::CXXDestructorDecl const*, clang::Stmt const*, clang::ento::MemRegion const*, bool>(clang::CXXDestructorDecl const*, clang::Stmt const*, clang::ento::MemRegion const*, bool, llvm::IntrusiveRefCntPtr<clang::ento::ProgramState const>, clang::LocationContext const*)): relocation R_ARM_CALL out of range >> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::GetFunctionClass(llvm::Function const*)): relocation R_ARM_CALL out of range >> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::GetFunctionClass(llvm::Function const*)): relocation R_ARM_CALL out of range >> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::GetFunctionClass(llvm::Function const*)): relocation R_ARM_CALL out of range >> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::GetFunctionClass(llvm::Function const*)): relocation R_ARM_CALL out of range >> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::GetFunctionClass(llvm::Function const*)): relocation R_ARM_CALL out of range >> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::GetFunctionClass(llvm::Function const*)): relocation R_ARM_CALL out of range >> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: too many errors emitted, stopping now (use -error-limit=0 to see all errors) >> clang-5.0: error: linker command failed with exit code 1 (use -v to see invocation) >> tools/clang/tools/driver/CMakeFiles/clang.dir/build.make:227: recipe for target 'bin/clang-5.0' failed >> make[2]: *** [bin/clang-5.0] Error 1 >> CMakeFiles/Makefile2:11670: recipe for target 'tools/clang/tools/driver/CMakeFiles/clang.dir/all' failed >> make[1]: *** [tools/clang/tools/driver/CMakeFiles/clang.dir/all] Error 2 >> Makefile:149: recipe for target 'all' failed >> make: *** [all] Error 2 >> yawmoo at yawmoo-MRNM3AP:~/Desktop/clfs/sources/llvm-build-native-with-lld$ >> >> >>> >>> Peter >>> >>> On 27 June 2017 at 11:47, Alessandro Pistocchi via llvm-dev >>> <llvm-dev at lists.llvm.org> wrote: >>>> >>>> On 26 Jun 2017, at 16:25, Rui Ueyama <ruiu at google.com> wrote: >>>> >>>> On Sun, Jun 25, 2017 at 6:40 AM, Alessandro Pistocchi via llvm-dev >>>> <llvm-dev at lists.llvm.org> wrote: >>>>> >>>>> Hi, >>>>> >>>>> I am trying to build a completely GNU free linux toolchain for the >>>>> raspberry pi. >>>>> >>>>> I successfully managed to compile llvm and clang for armv7 hard float ( >>>>> both as a cross compiler and as a native compiler ) together with the >>>>> following: >>>>> >>>>> Llvm with clang and lld >>>>> Clang builtins >>>>> Musl libc >>>>> libc++, libc++abi, libunwind >>>>> >>>>> All works well with the only thing to notice being the need to use -fPIC >>>>> in order to access some library functions when my own c/c++ programs access >>>>> those functions. >>>>> >>>>> The fact seems to be that musl libc exports some symbols as protected ( >>>>> probably correctly ) and lld ( probably correctly ) says it cannot preempt >>>>> those symbols. >>>>> For this reason I seem to have to use -fPIC in the C and CXX flags but >>>>> everything seems to work ok. >>>> >>>> >>>> Is this the same problem mentioned in >>>> https://bugs.llvm.org/show_bug.cgi?id=32425? >>>> >>>> >>>> My aim is to build llvm+clang+lld using llvm+clang+lld on arm ( using musl, >>>> libc++, libc++abi, libunwind and the clang builtins, no gcc runtime at all >>>> ). >>>> >>>> I think the fact that lld cannot preempt some symbols without using -fPIC is >>>> similar to the problem mentioned in >>>> https://bugs.llvm.org/show_bug.cgi?id=32425 . >>>> >>>> However I am not particularly bothered at this stage about having to use >>>> -fPIC. That would be fine. >>>> >>>> What I am struggling with is that having to use -fPIC is in conflict with >>>> the arm backend issue that creates bad relocations when building clang with >>>> -fPIC as mentioned in http://llvm.org/docs/HowToCrossCompileLLVM.html and so >>>> the build with -fPIC fails when building the clang binary. >>>> >>>> Regarding https://bugs.llvm.org/show_bug.cgi?id=32425 , please notice that >>>> contrary to what is reported there I definitely can build and execute a C >>>> hello world program without having to use -fPIC. >>>> >>>> It is only some symbols from musl that cannot be preempted by lld, not all >>>> of them. >>>> >>>> Unfortunately, when building llvm+clang+lld quite a few of those symbols are >>>> explicitly looked for by cmake and not found unless I use -fPIC. >>>> >>>> If I go ahead and build without using -fPIC then the build fails because it >>>> cannot preempt those symbols. >>>> >>>> It looks like a paradox to me and I think the solution would be to fix the >>>> fact that the arm backend does not like -fPIC as mentioned in >>>> http://llvm.org/docs/HowToCrossCompileLLVM.html . While it is probably >>>> correct that lld says it cannot preempt protected symbols, the arm backend >>>> issue is a known issue. >>>> >>>> >>>>> >>>>> Then I tried to use this compiler ( both the cross compiler and the native >>>>> compiler ) to compile llvm + clang + lld ( I want to have the toolchain >>>>> built with itself, again without any GNU software involved ) but when >>>>> building the clang executable I ran into the arm relocation problems >>>>> mentioned here in the “Hacks” section when using -fPIC: >>>>> http://llvm.org/docs/HowToCrossCompileLLVM.html . >>>>> On the other hand, I seem to need -fPIC otherwise cmake fails to find some >>>>> libc functions such as futimes/futimens and many others. If I use -fPIC for >>>>> CFLAGS but not for CXXFLAGS then cmake finds those symbols but then >>>>> obviously fails at a later stage with lld unable to preempt those symbols. >>>>> >>>>> This seems to be a conflict I cannot solve without someone within the llvm >>>>> team fixing the arm relocation problem. Is there any estimate of when this >>>>> could happen? I am happy to spend the time testing any solutions by building >>>>> my own toolchain until it succeeds. Or is there any other solution? >>>>> >>>>> Thank you, >>>>> Alex >>>>> >>>>> >>>>> _______________________________________________ >>>>> LLVM Developers mailing list >>>>> llvm-dev at lists.llvm.org >>>>> http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev >>>> >>>> >>>> >>>> _______________________________________________ >>>> LLVM Developers mailing list >>>> llvm-dev at lists.llvm.org >>>> http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev >>>> >>
Peter Smith via llvm-dev
2017-Jun-28 16:36 UTC
[llvm-dev] Building llvm with clang and lld on arm and the llvm arm backend relocation on position independent code
Yes it should cover the following relocations: R_ARM_CALL (ARM BL/BLX) R_ARM_JUMP24 (ARM B) R_ARM_THM_CALL (Thumb BL/BLX) R_ARM_THM_JUMP19 (Thumb conditional B<cc>.w) R_ARM_THM_JMP24 (Thumb unconditional B.w) Peter On 28 June 2017 at 17:31, Alessandro Pistocchi <apukfreelance at gmail.com> wrote:> Oh, so it looks like I hit a bit of a wall there :-) I’ll take a look thanks. > > That bug talks about R_ARM_THM_CALL which I assume are thumb related. > > Will your implementation fix also R_ARM_CALL errors? > >> On 28 Jun 2017, at 17:15, Peter Smith <peter.smith at linaro.org> wrote: >> >> Hello Alessandro, >> >> The LLD ARM port doesn't currently support range extension thunks, >> these are needed to extend the range of ARM branch relocations when >> the size of the executable instructions exceeds the maximum branch >> range. >> >> I have an implementation in review but it is a fairly large change so >> it may take some time to get through the review process, I've raised >> https://bugs.llvm.org/show_bug.cgi?id=33612 that has a link to the >> Phab reviews. If you are willing to build your own lld with additional >> changes, you might be able to test out those patches. >> >> Good luck >> >> Peter >> >> On 28 June 2017 at 17:09, Alessandro Pistocchi <apukfreelance at gmail.com> wrote: >>> >>>> On 27 Jun 2017, at 13:25, Peter Smith <peter.smith at linaro.org> wrote: >>>> >>>> Hello Alessandro, >>>> >>>> Despite the statement in the HowToCrossCompileLLVM guide "If you’re >>>> using Clang as the cross-compiler, there is a problem in the LLVM ARM >>>> back-end that is producing absolute relocations on >>>> position-independent code (R_ARM_THM_MOVW_ABS_NC), so for now, you >>>> should disable PIC:" I can't find an existing upstream PR or any >>>> record that this has been fixed. If the ARM backend is still producing >>>> an R_ARM_THM_MOVW_ABS_NC relocation when -fpic is given as an option >>>> then it would be great to get a small reproducible example in a new >>>> PR, or if there is one already to update it. >>>> >>>> The last time I ran into this error when trying to cross compile was >>>> that a dependency not compiled by clang (libtinfo.a) library contained >>>> an R_ARM_THM_MOVW_ABS_NC relocation. I don't think that this is the >>>> fault of clang/llvm though, I think it was my fault in installing a >>>> non pic compiled version of libtinfo.a (I'm still trying to learn how >>>> Ubuntu multilibs work). >>>> >>>> Would it be possible for you to share the details of which objects >>>> contain the R_ARM_THM_MOVW_ABS_NC relocations when compiled -fpic? >>> >>> Hi, the errors I get do not seen to mention R_ARM_THM_MOVW_ABS_NC. >>> >>> The errors are “relocation R_ARM_CALL out of range”. >>> >>> Today I recompiled everything from scratch with -fPIC to make sure I had no library compiled without it and I still get the same errors. >>> >>> Sorry, I could not find any trivial code that has the same issue yet. >>> >>> Following is the output of the compilation process: >>> >>> yawmoo at yawmoo-MRNM3AP:~/Desktop/clfs/sources/llvm-build-native-with-lld$ cmake --build . >>> [ 0%] Built target LLVMDemangle >>> [ 3%] Built target LLVMSupport >>> [ 3%] Built target LLVMTableGen >>> [ 4%] Built target obj.llvm-tblgen >>> [ 4%] Built target llvm-tblgen >>> [ 4%] Built target AttributeCompatFuncTableGen >>> [ 4%] Built target intrinsics_gen >>> [ 6%] Built target LLVMCore >>> [ 6%] Built target LLVMIRReader >>> [ 13%] Built target LLVMCodeGen >>> [ 14%] Built target LLVMSelectionDAG >>> [ 14%] Built target LLVMAsmPrinter >>> [ 14%] Built target LLVMMIRParser >>> [ 14%] Built target LLVMGlobalISel >>> [ 14%] Built target LLVMBinaryFormat >>> [ 14%] Built target LLVMBitReader >>> [ 16%] Built target LLVMBitWriter >>> [ 18%] Built target LLVMTransformUtils >>> [ 19%] Built target LLVMInstrumentation >>> [ 19%] Built target LLVMInstCombine >>> [ 22%] Built target LLVMScalarOpts >>> [ 22%] Built target LLVMipo >>> [ 24%] Built target LLVMVectorize >>> [ 24%] Built target LLVMHello_exports >>> [ 24%] Built target LLVMHello >>> [ 26%] Built target LLVMObjCARCOpts >>> [ 26%] Built target LLVMCoroutines >>> [ 26%] Built target LLVMLinker >>> [ 29%] Built target LLVMAnalysis >>> [ 29%] Built target llvm_vcsrevision_h >>> [ 29%] Built target LLVMLTO >>> [ 32%] Built target LLVMMC >>> [ 32%] Built target LLVMMCParser >>> [ 32%] Built target LLVMMCDisassembler >>> [ 32%] Built target LLVMObject >>> [ 32%] Built target LLVMObjectYAML >>> [ 34%] Built target LLVMOption >>> [ 36%] Built target LLVMDebugInfoDWARF >>> [ 36%] Built target LLVMDebugInfoMSF >>> [ 37%] Built target LLVMDebugInfoCodeView >>> [ 40%] Built target LLVMDebugInfoPDB >>> [ 42%] Built target LLVMSymbolize >>> [ 42%] Built target LLVMExecutionEngine >>> [ 42%] Built target LLVMInterpreter >>> [ 42%] Built target LLVMMCJIT >>> [ 42%] Built target LLVMOrcJIT >>> [ 42%] Built target LLVMRuntimeDyld >>> [ 42%] Built target LLVMTarget >>> [ 44%] Built target ARMCommonTableGen >>> [ 45%] Built target LLVMARMCodeGen >>> [ 45%] Built target LLVMARMInfo >>> [ 45%] Built target LLVMARMAsmParser >>> [ 45%] Built target LLVMARMDisassembler >>> [ 45%] Built target LLVMARMAsmPrinter >>> [ 45%] Built target LLVMARMDesc >>> [ 47%] Built target LLVMAsmParser >>> [ 47%] Built target LLVMLineEditor >>> [ 47%] Built target LLVMProfileData >>> [ 47%] Built target LLVMCoverage >>> [ 49%] Built target LLVMFuzzerNoMainObjects >>> [ 49%] Built target LLVMFuzzerNoMain >>> [ 49%] Built target LLVMFuzzer >>> [ 49%] Built target LLVMPasses >>> [ 49%] Built target LibOptionsTableGen >>> [ 49%] Built target LLVMLibDriver >>> [ 49%] Built target LLVMXRay >>> [ 49%] Built target gtest >>> [ 49%] Built target LLVMTestingSupport >>> [ 49%] Built target FileCheck >>> [ 49%] Built target llvm-PerfectShuffle >>> [ 49%] Built target count >>> [ 49%] Built target not >>> [ 49%] Built target yaml-bench >>> [ 49%] Built target LTO_exports >>> [ 50%] Built target LTO >>> [ 50%] Built target llvm-ar >>> [ 50%] Built target llvm-ranlib >>> [ 50%] Built target llvm-lib >>> [ 50%] Built target llvm-config >>> [ 50%] Built target llvm-lto >>> [ 50%] Built target llvm-profdata >>> [ 50%] Built target obj.clang-tblgen >>> [ 50%] Built target clang-tblgen >>> [ 55%] Built target clang-headers >>> [ 55%] Built target ClangSACheckers >>> [ 55%] Built target ClangCommentCommandList >>> [ 55%] Built target ClangCommentCommandInfo >>> [ 55%] Built target ClangAttrVisitor >>> [ 55%] Built target ClangCommentHTMLNamedCharacterReferences >>> [ 55%] Built target ClangAttrDump >>> [ 55%] Built target ClangAttrImpl >>> [ 55%] Built target ClangAttrClasses >>> [ 55%] Built target ClangStmtNodes >>> [ 55%] Built target ClangDeclNodes >>> [ 55%] Built target ClangCommentNodes >>> [ 55%] Built target ClangCommentHTMLTagsProperties >>> [ 55%] Built target ClangCommentHTMLTags >>> [ 55%] Built target ClangDiagnosticIndexName >>> [ 55%] Built target ClangDiagnosticSerialization >>> [ 55%] Built target ClangDiagnosticAnalysis >>> [ 55%] Built target ClangDiagnosticAST >>> [ 55%] Built target ClangDiagnosticParse >>> [ 55%] Built target ClangDiagnosticLex >>> [ 55%] Built target ClangDiagnosticSema >>> [ 55%] Built target ClangDiagnosticComment >>> [ 57%] Built target ClangDiagnosticGroups >>> [ 57%] Built target ClangDiagnosticDriver >>> [ 57%] Built target ClangAttrList >>> [ 57%] Built target ClangDiagnosticFrontend >>> [ 57%] Built target ClangAttrHasAttributeImpl >>> [ 57%] Built target ClangDiagnosticCommon >>> [ 57%] Built target ClangAttrSubjectMatchRuleList >>> [ 57%] Built target ClangARMNeon >>> [ 59%] Built target ClangAttrParserStringSwitches >>> [ 59%] Built target ClangAttrSubMatchRulesParserStringSwitches >>> [ 59%] Built target ClangAttrParsedAttrKinds >>> [ 59%] Built target ClangAttrSpellingListIndex >>> [ 59%] Built target ClangAttrParsedAttrList >>> [ 59%] Built target ClangAttrParsedAttrImpl >>> [ 59%] Built target ClangAttrTemplateInstantiate >>> [ 59%] Built target ClangAttrPCHRead >>> [ 59%] Built target ClangAttrPCHWrite >>> [ 60%] Built target clangBasic >>> [ 62%] Built target clangLex >>> [ 62%] Built target clangParse >>> [ 63%] Built target clangAST >>> [ 63%] Built target clangASTMatchers >>> [ 63%] Built target clangDynamicASTMatchers >>> [ 65%] Built target clangSema >>> [ 67%] Built target clangCodeGen >>> [ 68%] Built target clangAnalysis >>> [ 68%] Built target clangEdit >>> [ 70%] Built target clangRewrite >>> [ 72%] Built target clangARCMigrate >>> [ 72%] Built target ClangDriverOptions >>> [ 75%] Built target clangDriver >>> [ 75%] Built target clangSerialization >>> [ 77%] Built target clangFrontend >>> [ 77%] Built target clangRewriteFrontend >>> [ 77%] Built target clangFrontendTool >>> [ 77%] Built target clangTooling >>> [ 77%] Built target clangToolingCore >>> [ 77%] Built target clangToolingRefactor >>> [ 77%] Built target clangIndex >>> [ 78%] Built target clangStaticAnalyzerCore >>> [ 83%] Built target clangStaticAnalyzerCheckers >>> [ 83%] Built target clangStaticAnalyzerFrontend >>> [ 83%] Built target clangFormat >>> [ 85%] Built target diagtool >>> [ 85%] Built target clang-offload-bundler >>> [ 85%] Linking CXX executable ../../../../bin/clang >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAliasAnalysis.cpp:(function llvm::Pass* llvm::callDefaultCtor<llvm::objcarc::ObjCARCAAWrapperPass>()): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAliasAnalysis.cpp:(function llvm::Pass* llvm::callDefaultCtor<llvm::objcarc::ObjCARCAAWrapperPass>()): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/tools/clang/lib/StaticAnalyzer/Core/CallEvent.cpp:(function clang::ento::CXXDestructorCall* clang::ento::CallEventManager::create<clang::ento::CXXDestructorCall, clang::CXXDestructorDecl const*, clang::Stmt const*, clang::ento::MemRegion const*, bool>(clang::CXXDestructorDecl const*, clang::Stmt const*, clang::ento::MemRegion const*, bool, llvm::IntrusiveRefCntPtr<clang::ento::ProgramState const>, clang::LocationContext const*)): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAliasAnalysis.cpp:(function llvm::Pass* llvm::callDefaultCtor<llvm::objcarc::ObjCARCAAWrapperPass>()): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAliasAnalysis.cpp:(function llvm::Pass* llvm::callDefaultCtor<llvm::objcarc::ObjCARCAAWrapperPass>()): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAliasAnalysis.cpp:(function llvm::Pass* llvm::callDefaultCtor<llvm::objcarc::ObjCARCAAWrapperPass>()): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAnalysisUtils.cpp:(function llvm::cl::opt<bool, true, llvm::cl::parser<bool> >::opt<char [21], llvm::cl::desc, llvm::cl::LocationClass<bool>, llvm::cl::initializer<bool> >(char const (&) [21], llvm::cl::desc const&, llvm::cl::LocationClass<bool> const&, llvm::cl::initializer<bool> const&)): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAnalysisUtils.cpp:(function llvm::cl::opt<bool, true, llvm::cl::parser<bool> >::opt<char [21], llvm::cl::desc, llvm::cl::LocationClass<bool>, llvm::cl::initializer<bool> >(char const (&) [21], llvm::cl::desc const&, llvm::cl::LocationClass<bool> const&, llvm::cl::initializer<bool> const&)): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAnalysisUtils.cpp:(function llvm::cl::opt<bool, true, llvm::cl::parser<bool> >::opt<char [21], llvm::cl::desc, llvm::cl::LocationClass<bool>, llvm::cl::initializer<bool> >(char const (&) [21], llvm::cl::desc const&, llvm::cl::LocationClass<bool> const&, llvm::cl::initializer<bool> const&)): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAnalysisUtils.cpp:(function _GLOBAL__sub_I_ObjCARCAnalysisUtils.cpp): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::operator<<(llvm::raw_ostream&, llvm::objcarc::ARCInstKind)): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::operator<<(llvm::raw_ostream&, llvm::objcarc::ARCInstKind)): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::GetFunctionClass(llvm::Function const*)): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/tools/clang/lib/StaticAnalyzer/Core/CallEvent.cpp:(function clang::ento::CXXDestructorCall* clang::ento::CallEventManager::create<clang::ento::CXXDestructorCall, clang::CXXDestructorDecl const*, clang::Stmt const*, clang::ento::MemRegion const*, bool>(clang::CXXDestructorDecl const*, clang::Stmt const*, clang::ento::MemRegion const*, bool, llvm::IntrusiveRefCntPtr<clang::ento::ProgramState const>, clang::LocationContext const*)): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::GetFunctionClass(llvm::Function const*)): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::GetFunctionClass(llvm::Function const*)): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::GetFunctionClass(llvm::Function const*)): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::GetFunctionClass(llvm::Function const*)): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::GetFunctionClass(llvm::Function const*)): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::GetFunctionClass(llvm::Function const*)): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: too many errors emitted, stopping now (use -error-limit=0 to see all errors) >>> clang-5.0: error: linker command failed with exit code 1 (use -v to see invocation) >>> tools/clang/tools/driver/CMakeFiles/clang.dir/build.make:227: recipe for target 'bin/clang-5.0' failed >>> make[2]: *** [bin/clang-5.0] Error 1 >>> CMakeFiles/Makefile2:11670: recipe for target 'tools/clang/tools/driver/CMakeFiles/clang.dir/all' failed >>> make[1]: *** [tools/clang/tools/driver/CMakeFiles/clang.dir/all] Error 2 >>> Makefile:149: recipe for target 'all' failed >>> make: *** [all] Error 2 >>> yawmoo at yawmoo-MRNM3AP:~/Desktop/clfs/sources/llvm-build-native-with-lld$ >>> >>> >>>> >>>> Peter >>>> >>>> On 27 June 2017 at 11:47, Alessandro Pistocchi via llvm-dev >>>> <llvm-dev at lists.llvm.org> wrote: >>>>> >>>>> On 26 Jun 2017, at 16:25, Rui Ueyama <ruiu at google.com> wrote: >>>>> >>>>> On Sun, Jun 25, 2017 at 6:40 AM, Alessandro Pistocchi via llvm-dev >>>>> <llvm-dev at lists.llvm.org> wrote: >>>>>> >>>>>> Hi, >>>>>> >>>>>> I am trying to build a completely GNU free linux toolchain for the >>>>>> raspberry pi. >>>>>> >>>>>> I successfully managed to compile llvm and clang for armv7 hard float ( >>>>>> both as a cross compiler and as a native compiler ) together with the >>>>>> following: >>>>>> >>>>>> Llvm with clang and lld >>>>>> Clang builtins >>>>>> Musl libc >>>>>> libc++, libc++abi, libunwind >>>>>> >>>>>> All works well with the only thing to notice being the need to use -fPIC >>>>>> in order to access some library functions when my own c/c++ programs access >>>>>> those functions. >>>>>> >>>>>> The fact seems to be that musl libc exports some symbols as protected ( >>>>>> probably correctly ) and lld ( probably correctly ) says it cannot preempt >>>>>> those symbols. >>>>>> For this reason I seem to have to use -fPIC in the C and CXX flags but >>>>>> everything seems to work ok. >>>>> >>>>> >>>>> Is this the same problem mentioned in >>>>> https://bugs.llvm.org/show_bug.cgi?id=32425? >>>>> >>>>> >>>>> My aim is to build llvm+clang+lld using llvm+clang+lld on arm ( using musl, >>>>> libc++, libc++abi, libunwind and the clang builtins, no gcc runtime at all >>>>> ). >>>>> >>>>> I think the fact that lld cannot preempt some symbols without using -fPIC is >>>>> similar to the problem mentioned in >>>>> https://bugs.llvm.org/show_bug.cgi?id=32425 . >>>>> >>>>> However I am not particularly bothered at this stage about having to use >>>>> -fPIC. That would be fine. >>>>> >>>>> What I am struggling with is that having to use -fPIC is in conflict with >>>>> the arm backend issue that creates bad relocations when building clang with >>>>> -fPIC as mentioned in http://llvm.org/docs/HowToCrossCompileLLVM.html and so >>>>> the build with -fPIC fails when building the clang binary. >>>>> >>>>> Regarding https://bugs.llvm.org/show_bug.cgi?id=32425 , please notice that >>>>> contrary to what is reported there I definitely can build and execute a C >>>>> hello world program without having to use -fPIC. >>>>> >>>>> It is only some symbols from musl that cannot be preempted by lld, not all >>>>> of them. >>>>> >>>>> Unfortunately, when building llvm+clang+lld quite a few of those symbols are >>>>> explicitly looked for by cmake and not found unless I use -fPIC. >>>>> >>>>> If I go ahead and build without using -fPIC then the build fails because it >>>>> cannot preempt those symbols. >>>>> >>>>> It looks like a paradox to me and I think the solution would be to fix the >>>>> fact that the arm backend does not like -fPIC as mentioned in >>>>> http://llvm.org/docs/HowToCrossCompileLLVM.html . While it is probably >>>>> correct that lld says it cannot preempt protected symbols, the arm backend >>>>> issue is a known issue. >>>>> >>>>> >>>>>> >>>>>> Then I tried to use this compiler ( both the cross compiler and the native >>>>>> compiler ) to compile llvm + clang + lld ( I want to have the toolchain >>>>>> built with itself, again without any GNU software involved ) but when >>>>>> building the clang executable I ran into the arm relocation problems >>>>>> mentioned here in the “Hacks” section when using -fPIC: >>>>>> http://llvm.org/docs/HowToCrossCompileLLVM.html . >>>>>> On the other hand, I seem to need -fPIC otherwise cmake fails to find some >>>>>> libc functions such as futimes/futimens and many others. If I use -fPIC for >>>>>> CFLAGS but not for CXXFLAGS then cmake finds those symbols but then >>>>>> obviously fails at a later stage with lld unable to preempt those symbols. >>>>>> >>>>>> This seems to be a conflict I cannot solve without someone within the llvm >>>>>> team fixing the arm relocation problem. Is there any estimate of when this >>>>>> could happen? I am happy to spend the time testing any solutions by building >>>>>> my own toolchain until it succeeds. Or is there any other solution? >>>>>> >>>>>> Thank you, >>>>>> Alex >>>>>> >>>>>> >>>>>> _______________________________________________ >>>>>> LLVM Developers mailing list >>>>>> llvm-dev at lists.llvm.org >>>>>> http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev >>>>> >>>>> >>>>> >>>>> _______________________________________________ >>>>> LLVM Developers mailing list >>>>> llvm-dev at lists.llvm.org >>>>> http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev >>>>> >>> >
Alessandro Pistocchi via llvm-dev
2017-Jun-28 16:53 UTC
[llvm-dev] Building llvm with clang and lld on arm and the llvm arm backend relocation on position independent code
Cool thanks I'll give it a go :-) Sent from my iPhone> On 28 Jun 2017, at 18:36, Peter Smith <peter.smith at linaro.org> wrote: > > Yes it should cover the following relocations: > R_ARM_CALL (ARM BL/BLX) > R_ARM_JUMP24 (ARM B) > R_ARM_THM_CALL (Thumb BL/BLX) > R_ARM_THM_JUMP19 (Thumb conditional B<cc>.w) > R_ARM_THM_JMP24 (Thumb unconditional B.w) > > Peter > > >> On 28 June 2017 at 17:31, Alessandro Pistocchi <apukfreelance at gmail.com> wrote: >> Oh, so it looks like I hit a bit of a wall there :-) I’ll take a look thanks. >> >> That bug talks about R_ARM_THM_CALL which I assume are thumb related. >> >> Will your implementation fix also R_ARM_CALL errors? >> >>> On 28 Jun 2017, at 17:15, Peter Smith <peter.smith at linaro.org> wrote: >>> >>> Hello Alessandro, >>> >>> The LLD ARM port doesn't currently support range extension thunks, >>> these are needed to extend the range of ARM branch relocations when >>> the size of the executable instructions exceeds the maximum branch >>> range. >>> >>> I have an implementation in review but it is a fairly large change so >>> it may take some time to get through the review process, I've raised >>> https://bugs.llvm.org/show_bug.cgi?id=33612 that has a link to the >>> Phab reviews. If you are willing to build your own lld with additional >>> changes, you might be able to test out those patches. >>> >>> Good luck >>> >>> Peter >>> >>>> On 28 June 2017 at 17:09, Alessandro Pistocchi <apukfreelance at gmail.com> wrote: >>>> >>>>> On 27 Jun 2017, at 13:25, Peter Smith <peter.smith at linaro.org> wrote: >>>>> >>>>> Hello Alessandro, >>>>> >>>>> Despite the statement in the HowToCrossCompileLLVM guide "If you’re >>>>> using Clang as the cross-compiler, there is a problem in the LLVM ARM >>>>> back-end that is producing absolute relocations on >>>>> position-independent code (R_ARM_THM_MOVW_ABS_NC), so for now, you >>>>> should disable PIC:" I can't find an existing upstream PR or any >>>>> record that this has been fixed. If the ARM backend is still producing >>>>> an R_ARM_THM_MOVW_ABS_NC relocation when -fpic is given as an option >>>>> then it would be great to get a small reproducible example in a new >>>>> PR, or if there is one already to update it. >>>>> >>>>> The last time I ran into this error when trying to cross compile was >>>>> that a dependency not compiled by clang (libtinfo.a) library contained >>>>> an R_ARM_THM_MOVW_ABS_NC relocation. I don't think that this is the >>>>> fault of clang/llvm though, I think it was my fault in installing a >>>>> non pic compiled version of libtinfo.a (I'm still trying to learn how >>>>> Ubuntu multilibs work). >>>>> >>>>> Would it be possible for you to share the details of which objects >>>>> contain the R_ARM_THM_MOVW_ABS_NC relocations when compiled -fpic? >>>> >>>> Hi, the errors I get do not seen to mention R_ARM_THM_MOVW_ABS_NC. >>>> >>>> The errors are “relocation R_ARM_CALL out of range”. >>>> >>>> Today I recompiled everything from scratch with -fPIC to make sure I had no library compiled without it and I still get the same errors. >>>> >>>> Sorry, I could not find any trivial code that has the same issue yet. >>>> >>>> Following is the output of the compilation process: >>>> >>>> yawmoo at yawmoo-MRNM3AP:~/Desktop/clfs/sources/llvm-build-native-with-lld$ cmake --build . >>>> [ 0%] Built target LLVMDemangle >>>> [ 3%] Built target LLVMSupport >>>> [ 3%] Built target LLVMTableGen >>>> [ 4%] Built target obj.llvm-tblgen >>>> [ 4%] Built target llvm-tblgen >>>> [ 4%] Built target AttributeCompatFuncTableGen >>>> [ 4%] Built target intrinsics_gen >>>> [ 6%] Built target LLVMCore >>>> [ 6%] Built target LLVMIRReader >>>> [ 13%] Built target LLVMCodeGen >>>> [ 14%] Built target LLVMSelectionDAG >>>> [ 14%] Built target LLVMAsmPrinter >>>> [ 14%] Built target LLVMMIRParser >>>> [ 14%] Built target LLVMGlobalISel >>>> [ 14%] Built target LLVMBinaryFormat >>>> [ 14%] Built target LLVMBitReader >>>> [ 16%] Built target LLVMBitWriter >>>> [ 18%] Built target LLVMTransformUtils >>>> [ 19%] Built target LLVMInstrumentation >>>> [ 19%] Built target LLVMInstCombine >>>> [ 22%] Built target LLVMScalarOpts >>>> [ 22%] Built target LLVMipo >>>> [ 24%] Built target LLVMVectorize >>>> [ 24%] Built target LLVMHello_exports >>>> [ 24%] Built target LLVMHello >>>> [ 26%] Built target LLVMObjCARCOpts >>>> [ 26%] Built target LLVMCoroutines >>>> [ 26%] Built target LLVMLinker >>>> [ 29%] Built target LLVMAnalysis >>>> [ 29%] Built target llvm_vcsrevision_h >>>> [ 29%] Built target LLVMLTO >>>> [ 32%] Built target LLVMMC >>>> [ 32%] Built target LLVMMCParser >>>> [ 32%] Built target LLVMMCDisassembler >>>> [ 32%] Built target LLVMObject >>>> [ 32%] Built target LLVMObjectYAML >>>> [ 34%] Built target LLVMOption >>>> [ 36%] Built target LLVMDebugInfoDWARF >>>> [ 36%] Built target LLVMDebugInfoMSF >>>> [ 37%] Built target LLVMDebugInfoCodeView >>>> [ 40%] Built target LLVMDebugInfoPDB >>>> [ 42%] Built target LLVMSymbolize >>>> [ 42%] Built target LLVMExecutionEngine >>>> [ 42%] Built target LLVMInterpreter >>>> [ 42%] Built target LLVMMCJIT >>>> [ 42%] Built target LLVMOrcJIT >>>> [ 42%] Built target LLVMRuntimeDyld >>>> [ 42%] Built target LLVMTarget >>>> [ 44%] Built target ARMCommonTableGen >>>> [ 45%] Built target LLVMARMCodeGen >>>> [ 45%] Built target LLVMARMInfo >>>> [ 45%] Built target LLVMARMAsmParser >>>> [ 45%] Built target LLVMARMDisassembler >>>> [ 45%] Built target LLVMARMAsmPrinter >>>> [ 45%] Built target LLVMARMDesc >>>> [ 47%] Built target LLVMAsmParser >>>> [ 47%] Built target LLVMLineEditor >>>> [ 47%] Built target LLVMProfileData >>>> [ 47%] Built target LLVMCoverage >>>> [ 49%] Built target LLVMFuzzerNoMainObjects >>>> [ 49%] Built target LLVMFuzzerNoMain >>>> [ 49%] Built target LLVMFuzzer >>>> [ 49%] Built target LLVMPasses >>>> [ 49%] Built target LibOptionsTableGen >>>> [ 49%] Built target LLVMLibDriver >>>> [ 49%] Built target LLVMXRay >>>> [ 49%] Built target gtest >>>> [ 49%] Built target LLVMTestingSupport >>>> [ 49%] Built target FileCheck >>>> [ 49%] Built target llvm-PerfectShuffle >>>> [ 49%] Built target count >>>> [ 49%] Built target not >>>> [ 49%] Built target yaml-bench >>>> [ 49%] Built target LTO_exports >>>> [ 50%] Built target LTO >>>> [ 50%] Built target llvm-ar >>>> [ 50%] Built target llvm-ranlib >>>> [ 50%] Built target llvm-lib >>>> [ 50%] Built target llvm-config >>>> [ 50%] Built target llvm-lto >>>> [ 50%] Built target llvm-profdata >>>> [ 50%] Built target obj.clang-tblgen >>>> [ 50%] Built target clang-tblgen >>>> [ 55%] Built target clang-headers >>>> [ 55%] Built target ClangSACheckers >>>> [ 55%] Built target ClangCommentCommandList >>>> [ 55%] Built target ClangCommentCommandInfo >>>> [ 55%] Built target ClangAttrVisitor >>>> [ 55%] Built target ClangCommentHTMLNamedCharacterReferences >>>> [ 55%] Built target ClangAttrDump >>>> [ 55%] Built target ClangAttrImpl >>>> [ 55%] Built target ClangAttrClasses >>>> [ 55%] Built target ClangStmtNodes >>>> [ 55%] Built target ClangDeclNodes >>>> [ 55%] Built target ClangCommentNodes >>>> [ 55%] Built target ClangCommentHTMLTagsProperties >>>> [ 55%] Built target ClangCommentHTMLTags >>>> [ 55%] Built target ClangDiagnosticIndexName >>>> [ 55%] Built target ClangDiagnosticSerialization >>>> [ 55%] Built target ClangDiagnosticAnalysis >>>> [ 55%] Built target ClangDiagnosticAST >>>> [ 55%] Built target ClangDiagnosticParse >>>> [ 55%] Built target ClangDiagnosticLex >>>> [ 55%] Built target ClangDiagnosticSema >>>> [ 55%] Built target ClangDiagnosticComment >>>> [ 57%] Built target ClangDiagnosticGroups >>>> [ 57%] Built target ClangDiagnosticDriver >>>> [ 57%] Built target ClangAttrList >>>> [ 57%] Built target ClangDiagnosticFrontend >>>> [ 57%] Built target ClangAttrHasAttributeImpl >>>> [ 57%] Built target ClangDiagnosticCommon >>>> [ 57%] Built target ClangAttrSubjectMatchRuleList >>>> [ 57%] Built target ClangARMNeon >>>> [ 59%] Built target ClangAttrParserStringSwitches >>>> [ 59%] Built target ClangAttrSubMatchRulesParserStringSwitches >>>> [ 59%] Built target ClangAttrParsedAttrKinds >>>> [ 59%] Built target ClangAttrSpellingListIndex >>>> [ 59%] Built target ClangAttrParsedAttrList >>>> [ 59%] Built target ClangAttrParsedAttrImpl >>>> [ 59%] Built target ClangAttrTemplateInstantiate >>>> [ 59%] Built target ClangAttrPCHRead >>>> [ 59%] Built target ClangAttrPCHWrite >>>> [ 60%] Built target clangBasic >>>> [ 62%] Built target clangLex >>>> [ 62%] Built target clangParse >>>> [ 63%] Built target clangAST >>>> [ 63%] Built target clangASTMatchers >>>> [ 63%] Built target clangDynamicASTMatchers >>>> [ 65%] Built target clangSema >>>> [ 67%] Built target clangCodeGen >>>> [ 68%] Built target clangAnalysis >>>> [ 68%] Built target clangEdit >>>> [ 70%] Built target clangRewrite >>>> [ 72%] Built target clangARCMigrate >>>> [ 72%] Built target ClangDriverOptions >>>> [ 75%] Built target clangDriver >>>> [ 75%] Built target clangSerialization >>>> [ 77%] Built target clangFrontend >>>> [ 77%] Built target clangRewriteFrontend >>>> [ 77%] Built target clangFrontendTool >>>> [ 77%] Built target clangTooling >>>> [ 77%] Built target clangToolingCore >>>> [ 77%] Built target clangToolingRefactor >>>> [ 77%] Built target clangIndex >>>> [ 78%] Built target clangStaticAnalyzerCore >>>> [ 83%] Built target clangStaticAnalyzerCheckers >>>> [ 83%] Built target clangStaticAnalyzerFrontend >>>> [ 83%] Built target clangFormat >>>> [ 85%] Built target diagtool >>>> [ 85%] Built target clang-offload-bundler >>>> [ 85%] Linking CXX executable ../../../../bin/clang >>>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAliasAnalysis.cpp:(function llvm::Pass* llvm::callDefaultCtor<llvm::objcarc::ObjCARCAAWrapperPass>()): relocation R_ARM_CALL out of range >>>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAliasAnalysis.cpp:(function llvm::Pass* llvm::callDefaultCtor<llvm::objcarc::ObjCARCAAWrapperPass>()): relocation R_ARM_CALL out of range >>>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/tools/clang/lib/StaticAnalyzer/Core/CallEvent.cpp:(function clang::ento::CXXDestructorCall* clang::ento::CallEventManager::create<clang::ento::CXXDestructorCall, clang::CXXDestructorDecl const*, clang::Stmt const*, clang::ento::MemRegion const*, bool>(clang::CXXDestructorDecl const*, clang::Stmt const*, clang::ento::MemRegion const*, bool, llvm::IntrusiveRefCntPtr<clang::ento::ProgramState const>, clang::LocationContext const*)): relocation R_ARM_CALL out of range >>>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAliasAnalysis.cpp:(function llvm::Pass* llvm::callDefaultCtor<llvm::objcarc::ObjCARCAAWrapperPass>()): relocation R_ARM_CALL out of range >>>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAliasAnalysis.cpp:(function llvm::Pass* llvm::callDefaultCtor<llvm::objcarc::ObjCARCAAWrapperPass>()): relocation R_ARM_CALL out of range >>>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAliasAnalysis.cpp:(function llvm::Pass* llvm::callDefaultCtor<llvm::objcarc::ObjCARCAAWrapperPass>()): relocation R_ARM_CALL out of range >>>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAnalysisUtils.cpp:(function llvm::cl::opt<bool, true, llvm::cl::parser<bool> >::opt<char [21], llvm::cl::desc, llvm::cl::LocationClass<bool>, llvm::cl::initializer<bool> >(char const (&) [21], llvm::cl::desc const&, llvm::cl::LocationClass<bool> const&, llvm::cl::initializer<bool> const&)): relocation R_ARM_CALL out of range >>>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAnalysisUtils.cpp:(function llvm::cl::opt<bool, true, llvm::cl::parser<bool> >::opt<char [21], llvm::cl::desc, llvm::cl::LocationClass<bool>, llvm::cl::initializer<bool> >(char const (&) [21], llvm::cl::desc const&, llvm::cl::LocationClass<bool> const&, llvm::cl::initializer<bool> const&)): relocation R_ARM_CALL out of range >>>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAnalysisUtils.cpp:(function llvm::cl::opt<bool, true, llvm::cl::parser<bool> >::opt<char [21], llvm::cl::desc, llvm::cl::LocationClass<bool>, llvm::cl::initializer<bool> >(char const (&) [21], llvm::cl::desc const&, llvm::cl::LocationClass<bool> const&, llvm::cl::initializer<bool> const&)): relocation R_ARM_CALL out of range >>>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAnalysisUtils.cpp:(function _GLOBAL__sub_I_ObjCARCAnalysisUtils.cpp): relocation R_ARM_CALL out of range >>>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::operator<<(llvm::raw_ostream&, llvm::objcarc::ARCInstKind)): relocation R_ARM_CALL out of range >>>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::operator<<(llvm::raw_ostream&, llvm::objcarc::ARCInstKind)): relocation R_ARM_CALL out of range >>>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::GetFunctionClass(llvm::Function const*)): relocation R_ARM_CALL out of range >>>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/tools/clang/lib/StaticAnalyzer/Core/CallEvent.cpp:(function clang::ento::CXXDestructorCall* clang::ento::CallEventManager::create<clang::ento::CXXDestructorCall, clang::CXXDestructorDecl const*, clang::Stmt const*, clang::ento::MemRegion const*, bool>(clang::CXXDestructorDecl const*, clang::Stmt const*, clang::ento::MemRegion const*, bool, llvm::IntrusiveRefCntPtr<clang::ento::ProgramState const>, clang::LocationContext const*)): relocation R_ARM_CALL out of range >>>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::GetFunctionClass(llvm::Function const*)): relocation R_ARM_CALL out of range >>>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::GetFunctionClass(llvm::Function const*)): relocation R_ARM_CALL out of range >>>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::GetFunctionClass(llvm::Function const*)): relocation R_ARM_CALL out of range >>>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::GetFunctionClass(llvm::Function const*)): relocation R_ARM_CALL out of range >>>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::GetFunctionClass(llvm::Function const*)): relocation R_ARM_CALL out of range >>>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::GetFunctionClass(llvm::Function const*)): relocation R_ARM_CALL out of range >>>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: too many errors emitted, stopping now (use -error-limit=0 to see all errors) >>>> clang-5.0: error: linker command failed with exit code 1 (use -v to see invocation) >>>> tools/clang/tools/driver/CMakeFiles/clang.dir/build.make:227: recipe for target 'bin/clang-5.0' failed >>>> make[2]: *** [bin/clang-5.0] Error 1 >>>> CMakeFiles/Makefile2:11670: recipe for target 'tools/clang/tools/driver/CMakeFiles/clang.dir/all' failed >>>> make[1]: *** [tools/clang/tools/driver/CMakeFiles/clang.dir/all] Error 2 >>>> Makefile:149: recipe for target 'all' failed >>>> make: *** [all] Error 2 >>>> yawmoo at yawmoo-MRNM3AP:~/Desktop/clfs/sources/llvm-build-native-with-lld$ >>>> >>>> >>>>> >>>>> Peter >>>>> >>>>> On 27 June 2017 at 11:47, Alessandro Pistocchi via llvm-dev >>>>> <llvm-dev at lists.llvm.org> wrote: >>>>>> >>>>>> On 26 Jun 2017, at 16:25, Rui Ueyama <ruiu at google.com> wrote: >>>>>> >>>>>> On Sun, Jun 25, 2017 at 6:40 AM, Alessandro Pistocchi via llvm-dev >>>>>> <llvm-dev at lists.llvm.org> wrote: >>>>>>> >>>>>>> Hi, >>>>>>> >>>>>>> I am trying to build a completely GNU free linux toolchain for the >>>>>>> raspberry pi. >>>>>>> >>>>>>> I successfully managed to compile llvm and clang for armv7 hard float ( >>>>>>> both as a cross compiler and as a native compiler ) together with the >>>>>>> following: >>>>>>> >>>>>>> Llvm with clang and lld >>>>>>> Clang builtins >>>>>>> Musl libc >>>>>>> libc++, libc++abi, libunwind >>>>>>> >>>>>>> All works well with the only thing to notice being the need to use -fPIC >>>>>>> in order to access some library functions when my own c/c++ programs access >>>>>>> those functions. >>>>>>> >>>>>>> The fact seems to be that musl libc exports some symbols as protected ( >>>>>>> probably correctly ) and lld ( probably correctly ) says it cannot preempt >>>>>>> those symbols. >>>>>>> For this reason I seem to have to use -fPIC in the C and CXX flags but >>>>>>> everything seems to work ok. >>>>>> >>>>>> >>>>>> Is this the same problem mentioned in >>>>>> https://bugs.llvm.org/show_bug.cgi?id=32425? >>>>>> >>>>>> >>>>>> My aim is to build llvm+clang+lld using llvm+clang+lld on arm ( using musl, >>>>>> libc++, libc++abi, libunwind and the clang builtins, no gcc runtime at all >>>>>> ). >>>>>> >>>>>> I think the fact that lld cannot preempt some symbols without using -fPIC is >>>>>> similar to the problem mentioned in >>>>>> https://bugs.llvm.org/show_bug.cgi?id=32425 . >>>>>> >>>>>> However I am not particularly bothered at this stage about having to use >>>>>> -fPIC. That would be fine. >>>>>> >>>>>> What I am struggling with is that having to use -fPIC is in conflict with >>>>>> the arm backend issue that creates bad relocations when building clang with >>>>>> -fPIC as mentioned in http://llvm.org/docs/HowToCrossCompileLLVM.html and so >>>>>> the build with -fPIC fails when building the clang binary. >>>>>> >>>>>> Regarding https://bugs.llvm.org/show_bug.cgi?id=32425 , please notice that >>>>>> contrary to what is reported there I definitely can build and execute a C >>>>>> hello world program without having to use -fPIC. >>>>>> >>>>>> It is only some symbols from musl that cannot be preempted by lld, not all >>>>>> of them. >>>>>> >>>>>> Unfortunately, when building llvm+clang+lld quite a few of those symbols are >>>>>> explicitly looked for by cmake and not found unless I use -fPIC. >>>>>> >>>>>> If I go ahead and build without using -fPIC then the build fails because it >>>>>> cannot preempt those symbols. >>>>>> >>>>>> It looks like a paradox to me and I think the solution would be to fix the >>>>>> fact that the arm backend does not like -fPIC as mentioned in >>>>>> http://llvm.org/docs/HowToCrossCompileLLVM.html . While it is probably >>>>>> correct that lld says it cannot preempt protected symbols, the arm backend >>>>>> issue is a known issue. >>>>>> >>>>>> >>>>>>> >>>>>>> Then I tried to use this compiler ( both the cross compiler and the native >>>>>>> compiler ) to compile llvm + clang + lld ( I want to have the toolchain >>>>>>> built with itself, again without any GNU software involved ) but when >>>>>>> building the clang executable I ran into the arm relocation problems >>>>>>> mentioned here in the “Hacks” section when using -fPIC: >>>>>>> http://llvm.org/docs/HowToCrossCompileLLVM.html . >>>>>>> On the other hand, I seem to need -fPIC otherwise cmake fails to find some >>>>>>> libc functions such as futimes/futimens and many others. If I use -fPIC for >>>>>>> CFLAGS but not for CXXFLAGS then cmake finds those symbols but then >>>>>>> obviously fails at a later stage with lld unable to preempt those symbols. >>>>>>> >>>>>>> This seems to be a conflict I cannot solve without someone within the llvm >>>>>>> team fixing the arm relocation problem. Is there any estimate of when this >>>>>>> could happen? I am happy to spend the time testing any solutions by building >>>>>>> my own toolchain until it succeeds. Or is there any other solution? >>>>>>> >>>>>>> Thank you, >>>>>>> Alex >>>>>>> >>>>>>> >>>>>>> _______________________________________________ >>>>>>> LLVM Developers mailing list >>>>>>> llvm-dev at lists.llvm.org >>>>>>> http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev >>>>>> >>>>>> >>>>>> >>>>>> _______________________________________________ >>>>>> LLVM Developers mailing list >>>>>> llvm-dev at lists.llvm.org >>>>>> http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-dev >>>>>> >>>> >>
Shoaib Meenai via llvm-dev
2017-Jun-28 17:36 UTC
[llvm-dev] Building llvm with clang and lld on arm and the llvm arm backend relocation on position independent code
I've successfully used Peter's patches to get past those relocation errors. On 6/28/17, 9:36 AM, "llvm-dev on behalf of Peter Smith via llvm-dev" <llvm-dev-bounces at lists.llvm.org on behalf of llvm-dev at lists.llvm.org> wrote: Yes it should cover the following relocations: R_ARM_CALL (ARM BL/BLX) R_ARM_JUMP24 (ARM B) R_ARM_THM_CALL (Thumb BL/BLX) R_ARM_THM_JUMP19 (Thumb conditional B<cc>.w) R_ARM_THM_JMP24 (Thumb unconditional B.w) Peter On 28 June 2017 at 17:31, Alessandro Pistocchi <apukfreelance at gmail.com> wrote: > Oh, so it looks like I hit a bit of a wall there :-) I’ll take a look thanks. > > That bug talks about R_ARM_THM_CALL which I assume are thumb related. > > Will your implementation fix also R_ARM_CALL errors? > >> On 28 Jun 2017, at 17:15, Peter Smith <peter.smith at linaro.org> wrote: >> >> Hello Alessandro, >> >> The LLD ARM port doesn't currently support range extension thunks, >> these are needed to extend the range of ARM branch relocations when >> the size of the executable instructions exceeds the maximum branch >> range. >> >> I have an implementation in review but it is a fairly large change so >> it may take some time to get through the review process, I've raised >> https://urldefense.proofpoint.com/v2/url?u=https-3A__bugs.llvm.org_show-5Fbug.cgi-3Fid-3D33612&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=MoG8NHuM6pLu1J1B-yHnV-uqDvXgdp72ydIhDlNyQ9Q&s=RpqKAJtCInfokC4ejkvv1e1hbMx22g7c6-v8JNuzOrY&e= that has a link to the >> Phab reviews. If you are willing to build your own lld with additional >> changes, you might be able to test out those patches. >> >> Good luck >> >> Peter >> >> On 28 June 2017 at 17:09, Alessandro Pistocchi <apukfreelance at gmail.com> wrote: >>> >>>> On 27 Jun 2017, at 13:25, Peter Smith <peter.smith at linaro.org> wrote: >>>> >>>> Hello Alessandro, >>>> >>>> Despite the statement in the HowToCrossCompileLLVM guide "If you’re >>>> using Clang as the cross-compiler, there is a problem in the LLVM ARM >>>> back-end that is producing absolute relocations on >>>> position-independent code (R_ARM_THM_MOVW_ABS_NC), so for now, you >>>> should disable PIC:" I can't find an existing upstream PR or any >>>> record that this has been fixed. If the ARM backend is still producing >>>> an R_ARM_THM_MOVW_ABS_NC relocation when -fpic is given as an option >>>> then it would be great to get a small reproducible example in a new >>>> PR, or if there is one already to update it. >>>> >>>> The last time I ran into this error when trying to cross compile was >>>> that a dependency not compiled by clang (libtinfo.a) library contained >>>> an R_ARM_THM_MOVW_ABS_NC relocation. I don't think that this is the >>>> fault of clang/llvm though, I think it was my fault in installing a >>>> non pic compiled version of libtinfo.a (I'm still trying to learn how >>>> Ubuntu multilibs work). >>>> >>>> Would it be possible for you to share the details of which objects >>>> contain the R_ARM_THM_MOVW_ABS_NC relocations when compiled -fpic? >>> >>> Hi, the errors I get do not seen to mention R_ARM_THM_MOVW_ABS_NC. >>> >>> The errors are “relocation R_ARM_CALL out of range”. >>> >>> Today I recompiled everything from scratch with -fPIC to make sure I had no library compiled without it and I still get the same errors. >>> >>> Sorry, I could not find any trivial code that has the same issue yet. >>> >>> Following is the output of the compilation process: >>> >>> yawmoo at yawmoo-MRNM3AP:~/Desktop/clfs/sources/llvm-build-native-with-lld$ cmake --build . >>> [ 0%] Built target LLVMDemangle >>> [ 3%] Built target LLVMSupport >>> [ 3%] Built target LLVMTableGen >>> [ 4%] Built target obj.llvm-tblgen >>> [ 4%] Built target llvm-tblgen >>> [ 4%] Built target AttributeCompatFuncTableGen >>> [ 4%] Built target intrinsics_gen >>> [ 6%] Built target LLVMCore >>> [ 6%] Built target LLVMIRReader >>> [ 13%] Built target LLVMCodeGen >>> [ 14%] Built target LLVMSelectionDAG >>> [ 14%] Built target LLVMAsmPrinter >>> [ 14%] Built target LLVMMIRParser >>> [ 14%] Built target LLVMGlobalISel >>> [ 14%] Built target LLVMBinaryFormat >>> [ 14%] Built target LLVMBitReader >>> [ 16%] Built target LLVMBitWriter >>> [ 18%] Built target LLVMTransformUtils >>> [ 19%] Built target LLVMInstrumentation >>> [ 19%] Built target LLVMInstCombine >>> [ 22%] Built target LLVMScalarOpts >>> [ 22%] Built target LLVMipo >>> [ 24%] Built target LLVMVectorize >>> [ 24%] Built target LLVMHello_exports >>> [ 24%] Built target LLVMHello >>> [ 26%] Built target LLVMObjCARCOpts >>> [ 26%] Built target LLVMCoroutines >>> [ 26%] Built target LLVMLinker >>> [ 29%] Built target LLVMAnalysis >>> [ 29%] Built target llvm_vcsrevision_h >>> [ 29%] Built target LLVMLTO >>> [ 32%] Built target LLVMMC >>> [ 32%] Built target LLVMMCParser >>> [ 32%] Built target LLVMMCDisassembler >>> [ 32%] Built target LLVMObject >>> [ 32%] Built target LLVMObjectYAML >>> [ 34%] Built target LLVMOption >>> [ 36%] Built target LLVMDebugInfoDWARF >>> [ 36%] Built target LLVMDebugInfoMSF >>> [ 37%] Built target LLVMDebugInfoCodeView >>> [ 40%] Built target LLVMDebugInfoPDB >>> [ 42%] Built target LLVMSymbolize >>> [ 42%] Built target LLVMExecutionEngine >>> [ 42%] Built target LLVMInterpreter >>> [ 42%] Built target LLVMMCJIT >>> [ 42%] Built target LLVMOrcJIT >>> [ 42%] Built target LLVMRuntimeDyld >>> [ 42%] Built target LLVMTarget >>> [ 44%] Built target ARMCommonTableGen >>> [ 45%] Built target LLVMARMCodeGen >>> [ 45%] Built target LLVMARMInfo >>> [ 45%] Built target LLVMARMAsmParser >>> [ 45%] Built target LLVMARMDisassembler >>> [ 45%] Built target LLVMARMAsmPrinter >>> [ 45%] Built target LLVMARMDesc >>> [ 47%] Built target LLVMAsmParser >>> [ 47%] Built target LLVMLineEditor >>> [ 47%] Built target LLVMProfileData >>> [ 47%] Built target LLVMCoverage >>> [ 49%] Built target LLVMFuzzerNoMainObjects >>> [ 49%] Built target LLVMFuzzerNoMain >>> [ 49%] Built target LLVMFuzzer >>> [ 49%] Built target LLVMPasses >>> [ 49%] Built target LibOptionsTableGen >>> [ 49%] Built target LLVMLibDriver >>> [ 49%] Built target LLVMXRay >>> [ 49%] Built target gtest >>> [ 49%] Built target LLVMTestingSupport >>> [ 49%] Built target FileCheck >>> [ 49%] Built target llvm-PerfectShuffle >>> [ 49%] Built target count >>> [ 49%] Built target not >>> [ 49%] Built target yaml-bench >>> [ 49%] Built target LTO_exports >>> [ 50%] Built target LTO >>> [ 50%] Built target llvm-ar >>> [ 50%] Built target llvm-ranlib >>> [ 50%] Built target llvm-lib >>> [ 50%] Built target llvm-config >>> [ 50%] Built target llvm-lto >>> [ 50%] Built target llvm-profdata >>> [ 50%] Built target obj.clang-tblgen >>> [ 50%] Built target clang-tblgen >>> [ 55%] Built target clang-headers >>> [ 55%] Built target ClangSACheckers >>> [ 55%] Built target ClangCommentCommandList >>> [ 55%] Built target ClangCommentCommandInfo >>> [ 55%] Built target ClangAttrVisitor >>> [ 55%] Built target ClangCommentHTMLNamedCharacterReferences >>> [ 55%] Built target ClangAttrDump >>> [ 55%] Built target ClangAttrImpl >>> [ 55%] Built target ClangAttrClasses >>> [ 55%] Built target ClangStmtNodes >>> [ 55%] Built target ClangDeclNodes >>> [ 55%] Built target ClangCommentNodes >>> [ 55%] Built target ClangCommentHTMLTagsProperties >>> [ 55%] Built target ClangCommentHTMLTags >>> [ 55%] Built target ClangDiagnosticIndexName >>> [ 55%] Built target ClangDiagnosticSerialization >>> [ 55%] Built target ClangDiagnosticAnalysis >>> [ 55%] Built target ClangDiagnosticAST >>> [ 55%] Built target ClangDiagnosticParse >>> [ 55%] Built target ClangDiagnosticLex >>> [ 55%] Built target ClangDiagnosticSema >>> [ 55%] Built target ClangDiagnosticComment >>> [ 57%] Built target ClangDiagnosticGroups >>> [ 57%] Built target ClangDiagnosticDriver >>> [ 57%] Built target ClangAttrList >>> [ 57%] Built target ClangDiagnosticFrontend >>> [ 57%] Built target ClangAttrHasAttributeImpl >>> [ 57%] Built target ClangDiagnosticCommon >>> [ 57%] Built target ClangAttrSubjectMatchRuleList >>> [ 57%] Built target ClangARMNeon >>> [ 59%] Built target ClangAttrParserStringSwitches >>> [ 59%] Built target ClangAttrSubMatchRulesParserStringSwitches >>> [ 59%] Built target ClangAttrParsedAttrKinds >>> [ 59%] Built target ClangAttrSpellingListIndex >>> [ 59%] Built target ClangAttrParsedAttrList >>> [ 59%] Built target ClangAttrParsedAttrImpl >>> [ 59%] Built target ClangAttrTemplateInstantiate >>> [ 59%] Built target ClangAttrPCHRead >>> [ 59%] Built target ClangAttrPCHWrite >>> [ 60%] Built target clangBasic >>> [ 62%] Built target clangLex >>> [ 62%] Built target clangParse >>> [ 63%] Built target clangAST >>> [ 63%] Built target clangASTMatchers >>> [ 63%] Built target clangDynamicASTMatchers >>> [ 65%] Built target clangSema >>> [ 67%] Built target clangCodeGen >>> [ 68%] Built target clangAnalysis >>> [ 68%] Built target clangEdit >>> [ 70%] Built target clangRewrite >>> [ 72%] Built target clangARCMigrate >>> [ 72%] Built target ClangDriverOptions >>> [ 75%] Built target clangDriver >>> [ 75%] Built target clangSerialization >>> [ 77%] Built target clangFrontend >>> [ 77%] Built target clangRewriteFrontend >>> [ 77%] Built target clangFrontendTool >>> [ 77%] Built target clangTooling >>> [ 77%] Built target clangToolingCore >>> [ 77%] Built target clangToolingRefactor >>> [ 77%] Built target clangIndex >>> [ 78%] Built target clangStaticAnalyzerCore >>> [ 83%] Built target clangStaticAnalyzerCheckers >>> [ 83%] Built target clangStaticAnalyzerFrontend >>> [ 83%] Built target clangFormat >>> [ 85%] Built target diagtool >>> [ 85%] Built target clang-offload-bundler >>> [ 85%] Linking CXX executable ../../../../bin/clang >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAliasAnalysis.cpp:(function llvm::Pass* llvm::callDefaultCtor<llvm::objcarc::ObjCARCAAWrapperPass>()): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAliasAnalysis.cpp:(function llvm::Pass* llvm::callDefaultCtor<llvm::objcarc::ObjCARCAAWrapperPass>()): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/tools/clang/lib/StaticAnalyzer/Core/CallEvent.cpp:(function clang::ento::CXXDestructorCall* clang::ento::CallEventManager::create<clang::ento::CXXDestructorCall, clang::CXXDestructorDecl const*, clang::Stmt const*, clang::ento::MemRegion const*, bool>(clang::CXXDestructorDecl const*, clang::Stmt const*, clang::ento::MemRegion const*, bool, llvm::IntrusiveRefCntPtr<clang::ento::ProgramState const>, clang::LocationContext const*)): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAliasAnalysis.cpp:(function llvm::Pass* llvm::callDefaultCtor<llvm::objcarc::ObjCARCAAWrapperPass>()): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAliasAnalysis.cpp:(function llvm::Pass* llvm::callDefaultCtor<llvm::objcarc::ObjCARCAAWrapperPass>()): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAliasAnalysis.cpp:(function llvm::Pass* llvm::callDefaultCtor<llvm::objcarc::ObjCARCAAWrapperPass>()): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAnalysisUtils.cpp:(function llvm::cl::opt<bool, true, llvm::cl::parser<bool> >::opt<char [21], llvm::cl::desc, llvm::cl::LocationClass<bool>, llvm::cl::initializer<bool> >(char const (&) [21], llvm::cl::desc const&, llvm::cl::LocationClass<bool> const&, llvm::cl::initializer<bool> const&)): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAnalysisUtils.cpp:(function llvm::cl::opt<bool, true, llvm::cl::parser<bool> >::opt<char [21], llvm::cl::desc, llvm::cl::LocationClass<bool>, llvm::cl::initializer<bool> >(char const (&) [21], llvm::cl::desc const&, llvm::cl::LocationClass<bool> const&, llvm::cl::initializer<bool> const&)): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAnalysisUtils.cpp:(function llvm::cl::opt<bool, true, llvm::cl::parser<bool> >::opt<char [21], llvm::cl::desc, llvm::cl::LocationClass<bool>, llvm::cl::initializer<bool> >(char const (&) [21], llvm::cl::desc const&, llvm::cl::LocationClass<bool> const&, llvm::cl::initializer<bool> const&)): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCAnalysisUtils.cpp:(function _GLOBAL__sub_I_ObjCARCAnalysisUtils.cpp): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::operator<<(llvm::raw_ostream&, llvm::objcarc::ARCInstKind)): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::operator<<(llvm::raw_ostream&, llvm::objcarc::ARCInstKind)): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::GetFunctionClass(llvm::Function const*)): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/tools/clang/lib/StaticAnalyzer/Core/CallEvent.cpp:(function clang::ento::CXXDestructorCall* clang::ento::CallEventManager::create<clang::ento::CXXDestructorCall, clang::CXXDestructorDecl const*, clang::Stmt const*, clang::ento::MemRegion const*, bool>(clang::CXXDestructorDecl const*, clang::Stmt const*, clang::ento::MemRegion const*, bool, llvm::IntrusiveRefCntPtr<clang::ento::ProgramState const>, clang::LocationContext const*)): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::GetFunctionClass(llvm::Function const*)): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::GetFunctionClass(llvm::Function const*)): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::GetFunctionClass(llvm::Function const*)): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::GetFunctionClass(llvm::Function const*)): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::GetFunctionClass(llvm::Function const*)): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: /home/yawmoo/Desktop/clfs/sources/llvm/lib/Analysis/ObjCARCInstKind.cpp:(function llvm::objcarc::GetFunctionClass(llvm::Function const*)): relocation R_ARM_CALL out of range >>> /home/yawmoo/Desktop/clfs/llvm-cross-tools-lld/bin/ld.lld: error: too many errors emitted, stopping now (use -error-limit=0 to see all errors) >>> clang-5.0: error: linker command failed with exit code 1 (use -v to see invocation) >>> tools/clang/tools/driver/CMakeFiles/clang.dir/build.make:227: recipe for target 'bin/clang-5.0' failed >>> make[2]: *** [bin/clang-5.0] Error 1 >>> CMakeFiles/Makefile2:11670: recipe for target 'tools/clang/tools/driver/CMakeFiles/clang.dir/all' failed >>> make[1]: *** [tools/clang/tools/driver/CMakeFiles/clang.dir/all] Error 2 >>> Makefile:149: recipe for target 'all' failed >>> make: *** [all] Error 2 >>> yawmoo at yawmoo-MRNM3AP:~/Desktop/clfs/sources/llvm-build-native-with-lld$ >>> >>> >>>> >>>> Peter >>>> >>>> On 27 June 2017 at 11:47, Alessandro Pistocchi via llvm-dev >>>> <llvm-dev at lists.llvm.org> wrote: >>>>> >>>>> On 26 Jun 2017, at 16:25, Rui Ueyama <ruiu at google.com> wrote: >>>>> >>>>> On Sun, Jun 25, 2017 at 6:40 AM, Alessandro Pistocchi via llvm-dev >>>>> <llvm-dev at lists.llvm.org> wrote: >>>>>> >>>>>> Hi, >>>>>> >>>>>> I am trying to build a completely GNU free linux toolchain for the >>>>>> raspberry pi. >>>>>> >>>>>> I successfully managed to compile llvm and clang for armv7 hard float ( >>>>>> both as a cross compiler and as a native compiler ) together with the >>>>>> following: >>>>>> >>>>>> Llvm with clang and lld >>>>>> Clang builtins >>>>>> Musl libc >>>>>> libc++, libc++abi, libunwind >>>>>> >>>>>> All works well with the only thing to notice being the need to use -fPIC >>>>>> in order to access some library functions when my own c/c++ programs access >>>>>> those functions. >>>>>> >>>>>> The fact seems to be that musl libc exports some symbols as protected ( >>>>>> probably correctly ) and lld ( probably correctly ) says it cannot preempt >>>>>> those symbols. >>>>>> For this reason I seem to have to use -fPIC in the C and CXX flags but >>>>>> everything seems to work ok. >>>>> >>>>> >>>>> Is this the same problem mentioned in >>>>> https://urldefense.proofpoint.com/v2/url?u=https-3A__bugs.llvm.org_show-5Fbug.cgi-3Fid-3D32425-3F&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=MoG8NHuM6pLu1J1B-yHnV-uqDvXgdp72ydIhDlNyQ9Q&s=NukMRJ9yTsw5j3ENYmb5P6xnVjqZDGr_RtEBf88y-aI&e= >>>>> >>>>> >>>>> My aim is to build llvm+clang+lld using llvm+clang+lld on arm ( using musl, >>>>> libc++, libc++abi, libunwind and the clang builtins, no gcc runtime at all >>>>> ). >>>>> >>>>> I think the fact that lld cannot preempt some symbols without using -fPIC is >>>>> similar to the problem mentioned in >>>>> https://urldefense.proofpoint.com/v2/url?u=https-3A__bugs.llvm.org_show-5Fbug.cgi-3Fid-3D32425&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=MoG8NHuM6pLu1J1B-yHnV-uqDvXgdp72ydIhDlNyQ9Q&s=9sykAqiCyyRAxvbFBkT7xc41tFV4gbqVNlLPtuZwgEo&e= . >>>>> >>>>> However I am not particularly bothered at this stage about having to use >>>>> -fPIC. That would be fine. >>>>> >>>>> What I am struggling with is that having to use -fPIC is in conflict with >>>>> the arm backend issue that creates bad relocations when building clang with >>>>> -fPIC as mentioned in https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_docs_HowToCrossCompileLLVM.html&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=MoG8NHuM6pLu1J1B-yHnV-uqDvXgdp72ydIhDlNyQ9Q&s=ZDjTpKgbVvk-6KPfK36_iXsQkmN0tZo-GFLmojAfWdI&e= and so >>>>> the build with -fPIC fails when building the clang binary. >>>>> >>>>> Regarding https://urldefense.proofpoint.com/v2/url?u=https-3A__bugs.llvm.org_show-5Fbug.cgi-3Fid-3D32425&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=MoG8NHuM6pLu1J1B-yHnV-uqDvXgdp72ydIhDlNyQ9Q&s=9sykAqiCyyRAxvbFBkT7xc41tFV4gbqVNlLPtuZwgEo&e= , please notice that >>>>> contrary to what is reported there I definitely can build and execute a C >>>>> hello world program without having to use -fPIC. >>>>> >>>>> It is only some symbols from musl that cannot be preempted by lld, not all >>>>> of them. >>>>> >>>>> Unfortunately, when building llvm+clang+lld quite a few of those symbols are >>>>> explicitly looked for by cmake and not found unless I use -fPIC. >>>>> >>>>> If I go ahead and build without using -fPIC then the build fails because it >>>>> cannot preempt those symbols. >>>>> >>>>> It looks like a paradox to me and I think the solution would be to fix the >>>>> fact that the arm backend does not like -fPIC as mentioned in >>>>> https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_docs_HowToCrossCompileLLVM.html&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=MoG8NHuM6pLu1J1B-yHnV-uqDvXgdp72ydIhDlNyQ9Q&s=ZDjTpKgbVvk-6KPfK36_iXsQkmN0tZo-GFLmojAfWdI&e= . While it is probably >>>>> correct that lld says it cannot preempt protected symbols, the arm backend >>>>> issue is a known issue. >>>>> >>>>> >>>>>> >>>>>> Then I tried to use this compiler ( both the cross compiler and the native >>>>>> compiler ) to compile llvm + clang + lld ( I want to have the toolchain >>>>>> built with itself, again without any GNU software involved ) but when >>>>>> building the clang executable I ran into the arm relocation problems >>>>>> mentioned here in the “Hacks” section when using -fPIC: >>>>>> https://urldefense.proofpoint.com/v2/url?u=http-3A__llvm.org_docs_HowToCrossCompileLLVM.html&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=MoG8NHuM6pLu1J1B-yHnV-uqDvXgdp72ydIhDlNyQ9Q&s=ZDjTpKgbVvk-6KPfK36_iXsQkmN0tZo-GFLmojAfWdI&e= . >>>>>> On the other hand, I seem to need -fPIC otherwise cmake fails to find some >>>>>> libc functions such as futimes/futimens and many others. If I use -fPIC for >>>>>> CFLAGS but not for CXXFLAGS then cmake finds those symbols but then >>>>>> obviously fails at a later stage with lld unable to preempt those symbols. >>>>>> >>>>>> This seems to be a conflict I cannot solve without someone within the llvm >>>>>> team fixing the arm relocation problem. Is there any estimate of when this >>>>>> could happen? I am happy to spend the time testing any solutions by building >>>>>> my own toolchain until it succeeds. Or is there any other solution? >>>>>> >>>>>> Thank you, >>>>>> Alex >>>>>> >>>>>> >>>>>> _______________________________________________ >>>>>> LLVM Developers mailing list >>>>>> llvm-dev at lists.llvm.org >>>>>> https://urldefense.proofpoint.com/v2/url?u=http-3A__lists.llvm.org_cgi-2Dbin_mailman_listinfo_llvm-2Ddev&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=MoG8NHuM6pLu1J1B-yHnV-uqDvXgdp72ydIhDlNyQ9Q&s=elMtK81LIlpU0bdvd9Zwk2UtgI9He36ddrHDrVDKt94&e= >>>>> >>>>> >>>>> >>>>> _______________________________________________ >>>>> LLVM Developers mailing list >>>>> llvm-dev at lists.llvm.org >>>>> https://urldefense.proofpoint.com/v2/url?u=http-3A__lists.llvm.org_cgi-2Dbin_mailman_listinfo_llvm-2Ddev&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=MoG8NHuM6pLu1J1B-yHnV-uqDvXgdp72ydIhDlNyQ9Q&s=elMtK81LIlpU0bdvd9Zwk2UtgI9He36ddrHDrVDKt94&e= >>>>> >>> > _______________________________________________ LLVM Developers mailing list llvm-dev at lists.llvm.org https://urldefense.proofpoint.com/v2/url?u=http-3A__lists.llvm.org_cgi-2Dbin_mailman_listinfo_llvm-2Ddev&d=DwIGaQ&c=5VD0RTtNlTh3ycd41b3MUw&r=o3kDXzdBUE3ljQXKeTWOMw&m=MoG8NHuM6pLu1J1B-yHnV-uqDvXgdp72ydIhDlNyQ9Q&s=elMtK81LIlpU0bdvd9Zwk2UtgI9He36ddrHDrVDKt94&e=
Reasonably Related Threads
- Building llvm with clang and lld on arm and the llvm arm backend relocation on position independent code
- Building llvm with clang and lld on arm and the llvm arm backend relocation on position independent code
- Building llvm with clang and lld on arm and the llvm arm backend relocation on position independent code
- Building llvm with clang and lld on arm and the llvm arm backend relocation on position independent code
- Building llvm with clang and lld on arm and the llvm arm backend relocation on position independent code