Blame 0001-Driver-Prefer-vendor-supplied-gcc-toolchain.patch

b9ae4c5
From 69d981a5d41d481556bd38f8d668d7f1177ac2b4 Mon Sep 17 00:00:00 2001
b9ae4c5
From: Tom Stellard <tstellar@redhat.com>
b9ae4c5
Date: Thu, 18 Jan 2018 02:57:51 +0000
b9ae4c5
Subject: [PATCH] Driver: Prefer vendor supplied gcc toolchain
b9ae4c5
b9ae4c5
Summary:
b9ae4c5
This patch fixes an issue on Fedora where if you had the x86_64 cross
b9ae4c5
compiler installed on your x86_64 system, then clang would use that compiler
b9ae4c5
as the default toolchain.  This was happening because the cross compiler
b9ae4c5
is installed to /usr/lib/gcc/x86_64-linux-gnu/ and this directory comes before
b9ae4c5
the default compiler directory (/usr/lib/gcc/x86_64-redhat-linux/) in the search
b9ae4c5
list.
b9ae4c5
b9ae4c5
This patch re-orders the search list so that vendor supplied gcc toolchains
b9ae4c5
are selected before toolchains with a generic target, which should prevent
b9ae4c5
these kind of issues on other OSes too.
b9ae4c5
b9ae4c5
Subscribers: srhines, cfe-commits
b9ae4c5
b9ae4c5
Differential Revision: https://reviews.llvm.org/D42608
b9ae4c5
---
b9ae4c5
 lib/Driver/ToolChains/Gnu.cpp | 45 ++++++++++++++++++++++---------------------
b9ae4c5
 1 file changed, 23 insertions(+), 22 deletions(-)
b9ae4c5
b9ae4c5
diff --git a/lib/Driver/ToolChains/Gnu.cpp b/lib/Driver/ToolChains/Gnu.cpp
b9ae4c5
index 7845781..9cec316 100644
b9ae4c5
--- a/lib/Driver/ToolChains/Gnu.cpp
b9ae4c5
+++ b/lib/Driver/ToolChains/Gnu.cpp
b9ae4c5
@@ -1709,8 +1709,8 @@ bool Generic_GCC::GCCInstallationDetector::getBiarchSibling(Multilib &M) const {
b9ae4c5
   // lifetime or initialization issues.
b9ae4c5
   static const char *const AArch64LibDirs[] = {"/lib64", "/lib"};
b9ae4c5
   static const char *const AArch64Triples[] = {
b9ae4c5
-      "aarch64-none-linux-gnu", "aarch64-linux-gnu", "aarch64-linux-android",
b9ae4c5
-      "aarch64-redhat-linux", "aarch64-suse-linux"};
b9ae4c5
+      "aarch64-redhat-linux", "aarch64-suse-linux",
b9ae4c5
+      "aarch64-none-linux-gnu", "aarch64-linux-gnu", "aarch64-linux-android"};
b9ae4c5
   static const char *const AArch64beLibDirs[] = {"/lib"};
b9ae4c5
   static const char *const AArch64beTriples[] = {"aarch64_be-none-linux-gnu",
b9ae4c5
                                                  "aarch64_be-linux-gnu"};
b9ae4c5
@@ -1718,10 +1718,11 @@ bool Generic_GCC::GCCInstallationDetector::getBiarchSibling(Multilib &M) const {
b9ae4c5
   static const char *const ARMLibDirs[] = {"/lib"};
b9ae4c5
   static const char *const ARMTriples[] = {"arm-linux-gnueabi",
b9ae4c5
                                            "arm-linux-androideabi"};
b9ae4c5
-  static const char *const ARMHFTriples[] = {"arm-linux-gnueabihf",
b9ae4c5
-                                             "armv7hl-redhat-linux-gnueabi",
b9ae4c5
+  static const char *const ARMHFTriples[] = {"armv7hl-redhat-linux-gnueabi",
b9ae4c5
                                              "armv6hl-suse-linux-gnueabi",
b9ae4c5
-                                             "armv7hl-suse-linux-gnueabi"};
b9ae4c5
+                                             "armv7hl-suse-linux-gnueabi",
b9ae4c5
+                                             "arm-linux-gnueabihf",
b9ae4c5
+  };
b9ae4c5
   static const char *const ARMebLibDirs[] = {"/lib"};
b9ae4c5
   static const char *const ARMebTriples[] = {"armeb-linux-gnueabi",
b9ae4c5
                                              "armeb-linux-androideabi"};
b9ae4c5
@@ -1730,19 +1731,19 @@ bool Generic_GCC::GCCInstallationDetector::getBiarchSibling(Multilib &M) const {
b9ae4c5
 
b9ae4c5
   static const char *const X86_64LibDirs[] = {"/lib64", "/lib"};
b9ae4c5
   static const char *const X86_64Triples[] = {
b9ae4c5
-      "x86_64-linux-gnu",       "x86_64-unknown-linux-gnu",
b9ae4c5
-      "x86_64-pc-linux-gnu",    "x86_64-redhat-linux6E",
b9ae4c5
-      "x86_64-redhat-linux",    "x86_64-suse-linux",
b9ae4c5
-      "x86_64-manbo-linux-gnu", "x86_64-linux-gnu",
b9ae4c5
-      "x86_64-slackware-linux", "x86_64-linux-android",
b9ae4c5
+      "x86_64-redhat-linux6E",    "x86_64-redhat-linux",
b9ae4c5
+      "x86_64-suse-linux",        "x86_64-slackware-linux",
b9ae4c5
+      "x86_64-manbo-linux-gnu",   "x86_64-linux-gnu",
b9ae4c5
+      "x86_64-unknown-linux-gnu", "x86_64-pc-linux-gnu",
b9ae4c5
+      "x86_64-linux-gnu",         "x86_64-linux-android",
b9ae4c5
       "x86_64-unknown-linux"};
b9ae4c5
   static const char *const X32LibDirs[] = {"/libx32"};
b9ae4c5
   static const char *const X86LibDirs[] = {"/lib32", "/lib"};
b9ae4c5
   static const char *const X86Triples[] = {
b9ae4c5
-      "i686-linux-gnu",       "i686-pc-linux-gnu",     "i486-linux-gnu",
b9ae4c5
-      "i386-linux-gnu",       "i386-redhat-linux6E",   "i686-redhat-linux",
b9ae4c5
-      "i586-redhat-linux",    "i386-redhat-linux",     "i586-suse-linux",
b9ae4c5
-      "i486-slackware-linux", "i686-montavista-linux", "i686-linux-android",
b9ae4c5
+      "i386-redhat-linux6E",   "i686-redhat-linux", "i586-redhat-linuxll",
b9ae4c5
+      "i386-redhat-linux",     "i586-suse-linux",   "i486-slackware-linux",
b9ae4c5
+      "i686-montavista-linux", "i686-linux-gnu",    "i686-pc-linux-gnu",
b9ae4c5
+      "i486-linux-gnu",        "i386-linux-gnu",    "i686-linux-android",
b9ae4c5
       "i586-linux-gnu"};
b9ae4c5
 
b9ae4c5
   static const char *const MIPSLibDirs[] = {"/lib"};
b9ae4c5
@@ -1772,16 +1773,16 @@ bool Generic_GCC::GCCInstallationDetector::getBiarchSibling(Multilib &M) const {
b9ae4c5
 
b9ae4c5
   static const char *const PPCLibDirs[] = {"/lib32", "/lib"};
b9ae4c5
   static const char *const PPCTriples[] = {
b9ae4c5
-      "powerpc-linux-gnu", "powerpc-unknown-linux-gnu", "powerpc-linux-gnuspe",
b9ae4c5
-      "powerpc-suse-linux", "powerpc-montavista-linuxspe"};
b9ae4c5
+      "powerpc-suse-linux", "powerpc-montavista-linuxspe",
b9ae4c5
+      "powerpc-linux-gnu", "powerpc-unknown-linux-gnu", "powerpc-linux-gnuspe"};
b9ae4c5
   static const char *const PPC64LibDirs[] = {"/lib64", "/lib"};
b9ae4c5
   static const char *const PPC64Triples[] = {
b9ae4c5
-      "powerpc64-linux-gnu", "powerpc64-unknown-linux-gnu",
b9ae4c5
-      "powerpc64-suse-linux", "ppc64-redhat-linux"};
b9ae4c5
+      "powerpc64-suse-linux", "ppc64-redhat-linux",
b9ae4c5
+      "powerpc64-linux-gnu", "powerpc64-unknown-linux-gnu"};
b9ae4c5
   static const char *const PPC64LELibDirs[] = {"/lib64", "/lib"};
b9ae4c5
   static const char *const PPC64LETriples[] = {
b9ae4c5
-      "powerpc64le-linux-gnu", "powerpc64le-unknown-linux-gnu",
b9ae4c5
-      "powerpc64le-suse-linux", "ppc64le-redhat-linux"};
b9ae4c5
+      "powerpc64le-suse-linux", "ppc64le-redhat-linux",
b9ae4c5
+      "powerpc64le-linux-gnu", "powerpc64le-unknown-linux-gnu"};
b9ae4c5
 
b9ae4c5
   static const char *const SPARCv8LibDirs[] = {"/lib32", "/lib"};
b9ae4c5
   static const char *const SPARCv8Triples[] = {"sparc-linux-gnu",
b9ae4c5
@@ -1792,8 +1793,8 @@ bool Generic_GCC::GCCInstallationDetector::getBiarchSibling(Multilib &M) const {
b9ae4c5
 
b9ae4c5
   static const char *const SystemZLibDirs[] = {"/lib64", "/lib"};
b9ae4c5
   static const char *const SystemZTriples[] = {
b9ae4c5
-      "s390x-linux-gnu", "s390x-unknown-linux-gnu", "s390x-ibm-linux-gnu",
b9ae4c5
-      "s390x-suse-linux", "s390x-redhat-linux"};
b9ae4c5
+      "s390x-ibm-linux-gnu", "s390x-suse-linux", "s390x-redhat-linux",
b9ae4c5
+      "s390x-linux-gnu", "s390x-unknown-linux-gnu"};
b9ae4c5
 
b9ae4c5
   // Solaris.
b9ae4c5
   static const char *const SolarisSPARCLibDirs[] = {"/gcc"};
b9ae4c5
-- 
b9ae4c5
1.8.3.1
b9ae4c5