This involves two things. The first thing is fixing the patch that adds musl target triples into our clang; previously the patch wasn't correct, as it simply added the musl triples among the GNU triples, which, when cross compiling to musl targets, resulted in clang considering the GCC cross installations for glibc and same arch for linking the crt files; this resulted in broken builds. The new patch only considers musl triples for musl targets and glibc triples for glibc targets, so even if you have two cross-gccs installed in parallel for the same arch (one for musl and one for glibc) it will not pick the wrong ones. The second thing is making clang use 64-bit long double for musl ppc targets correctly. Previously there was no logic for specifying this and that resulted in 128-bit long double using binaries emitted by clang for musl and ppc(64). With our specific gcc setup, that resulted in linking failures as the 128bit ldbl runtime funcs were not available, and even if they were, the results would be incorrect. This also replaces the old zzz-aarch64.patch with a version fixed for ppc. [ci skip] Closes: #11866 [via git-merge-pr]
82 lines
3.8 KiB
Diff
82 lines
3.8 KiB
Diff
--- a/lib/Driver/ToolChains/Gnu.cpp.orig 2019-03-30 15:08:33.136000000 +0100
|
|
+++ b/lib/Driver/ToolChains/Gnu.cpp 2019-03-30 15:10:24.666000000 +0100
|
|
@@ -2014,6 +2014,79 @@
|
|
return;
|
|
}
|
|
|
|
+ if (TargetTriple.isMusl()) {
|
|
+ static const char *const AArch64MuslTriples[] = {"aarch64-linux-musl"};
|
|
+ static const char *const ARMHFMuslTriples[] = {
|
|
+ "arm-linux-musleabihf", "armv7l-linux-musleabihf",
|
|
+ "armv7l-linux-gnueabihf"
|
|
+ };
|
|
+ static const char *const ARMMuslTriples[] = {"arm-linux-musleabi"};
|
|
+ static const char *const X86_64MuslTriples[] = {"x86_64-linux-musl"};
|
|
+ static const char *const X86MuslTriples[] = {"i686-linux-musl"};
|
|
+ static const char *const MIPSMuslTriples[] = {
|
|
+ "mips-linux-musl", "mipsel-linux-musl",
|
|
+ "mipsel-linux-muslhf", "mips-linux-muslhf"
|
|
+ };
|
|
+ static const char *const PPCMuslTriples[] = {"powerpc-linux-musl"};
|
|
+ static const char *const PPC64MuslTriples[] = {"powerpc64-linux-musl"};
|
|
+ static const char *const PPC64LEMuslTriples[] = {"powerpc64le-linux-musl"};
|
|
+
|
|
+ switch (TargetTriple.getArch()) {
|
|
+ case llvm::Triple::aarch64:
|
|
+ LibDirs.append(begin(AArch64LibDirs), end(AArch64LibDirs));
|
|
+ TripleAliases.append(begin(AArch64MuslTriples), end(AArch64MuslTriples));
|
|
+ BiarchLibDirs.append(begin(AArch64LibDirs), end(AArch64LibDirs));
|
|
+ BiarchTripleAliases.append(begin(AArch64MuslTriples), end(AArch64MuslTriples));
|
|
+ break;
|
|
+ case llvm::Triple::arm:
|
|
+ LibDirs.append(begin(ARMLibDirs), end(ARMLibDirs));
|
|
+ if (TargetTriple.getEnvironment() == llvm::Triple::MuslEABIHF) {
|
|
+ TripleAliases.append(begin(ARMHFMuslTriples), end(ARMHFMuslTriples));
|
|
+ } else {
|
|
+ TripleAliases.append(begin(ARMMuslTriples), end(ARMMuslTriples));
|
|
+ }
|
|
+ break;
|
|
+ case llvm::Triple::x86_64:
|
|
+ LibDirs.append(begin(X86_64LibDirs), end(X86_64LibDirs));
|
|
+ TripleAliases.append(begin(X86_64MuslTriples), end(X86_64MuslTriples));
|
|
+ BiarchLibDirs.append(begin(X86LibDirs), end(X86LibDirs));
|
|
+ BiarchTripleAliases.append(begin(X86MuslTriples), end(X86MuslTriples));
|
|
+ break;
|
|
+ case llvm::Triple::x86:
|
|
+ LibDirs.append(begin(X86LibDirs), end(X86LibDirs));
|
|
+ TripleAliases.append(begin(X86MuslTriples), end(X86MuslTriples));
|
|
+ BiarchLibDirs.append(begin(X86_64LibDirs), end(X86_64LibDirs));
|
|
+ BiarchTripleAliases.append(begin(X86_64MuslTriples), end(X86_64MuslTriples));
|
|
+ break;
|
|
+ case llvm::Triple::mips:
|
|
+ LibDirs.append(begin(MIPSLibDirs), end(MIPSLibDirs));
|
|
+ TripleAliases.append(begin(MIPSMuslTriples), end(MIPSMuslTriples));
|
|
+ break;
|
|
+ case llvm::Triple::ppc:
|
|
+ LibDirs.append(begin(PPCLibDirs), end(PPCLibDirs));
|
|
+ TripleAliases.append(begin(PPCMuslTriples), end(PPCMuslTriples));
|
|
+ BiarchLibDirs.append(begin(PPC64LibDirs), end(PPC64LibDirs));
|
|
+ BiarchTripleAliases.append(begin(PPC64MuslTriples), end(PPC64MuslTriples));
|
|
+ break;
|
|
+ case llvm::Triple::ppc64:
|
|
+ LibDirs.append(begin(PPC64LibDirs), end(PPC64LibDirs));
|
|
+ TripleAliases.append(begin(PPC64MuslTriples), end(PPC64MuslTriples));
|
|
+ BiarchLibDirs.append(begin(PPCLibDirs), end(PPCLibDirs));
|
|
+ BiarchTripleAliases.append(begin(PPCMuslTriples), end(PPCMuslTriples));
|
|
+ break;
|
|
+ case llvm::Triple::ppc64le:
|
|
+ LibDirs.append(begin(PPC64LELibDirs), end(PPC64LELibDirs));
|
|
+ TripleAliases.append(begin(PPC64LEMuslTriples), end(PPC64LEMuslTriples));
|
|
+ break;
|
|
+ default:
|
|
+ break;
|
|
+ }
|
|
+ TripleAliases.push_back(TargetTriple.str());
|
|
+ if (TargetTriple.str() != BiarchTriple.str())
|
|
+ BiarchTripleAliases.push_back(BiarchTriple.str());
|
|
+ return;
|
|
+ }
|
|
+
|
|
// Android targets should not use GNU/Linux tools or libraries.
|
|
if (TargetTriple.isAndroid()) {
|
|
static const char *const AArch64AndroidTriples[] = {
|