[llvm-branch-commits] [llvm-branch] r81033 - /llvm/branches/release_26/lib/System/Unix/Host.inc

Tanya Lattner tonic at nondot.org
Fri Sep 4 12:52:18 PDT 2009


Author: tbrethou
Date: Fri Sep  4 14:52:18 2009
New Revision: 81033

URL: http://llvm.org/viewvc/llvm-project?rev=81033&view=rev
Log:
Merge 80863 from mainline.
Improve llvm::getHostTriple for some cases where the LLVM_HOSTTRIPLE is not
reliable.


Modified:
    llvm/branches/release_26/lib/System/Unix/Host.inc

Modified: llvm/branches/release_26/lib/System/Unix/Host.inc
URL: http://llvm.org/viewvc/llvm-project/llvm/branches/release_26/lib/System/Unix/Host.inc?rev=81033&r1=81032&r2=81033&view=diff

==============================================================================
--- llvm/branches/release_26/lib/System/Unix/Host.inc (original)
+++ llvm/branches/release_26/lib/System/Unix/Host.inc Fri Sep  4 14:52:18 2009
@@ -16,7 +16,8 @@
 //===          is guaranteed to work on *all* UNIX variants.
 //===----------------------------------------------------------------------===//
 
-#include <llvm/Config/config.h>
+#include "llvm/Config/config.h"
+#include "llvm/ADT/StringRef.h"
 #include "Unix.h"
 #include <sys/utsname.h>
 #include <string>
@@ -33,10 +34,47 @@
 }
 
 std::string sys::getHostTriple() {
-  // FIXME: Derive more directly instead of relying on the autoconf
-  // generated variable.
+  // FIXME: Derive directly instead of relying on the autoconf generated
+  // variable.
 
-  std::string Triple = LLVM_HOSTTRIPLE;
+  StringRef HostTripleString(LLVM_HOSTTRIPLE);
+  std::pair<StringRef, StringRef> ArchSplit = HostTripleString.split('-');
+  
+  // Normalize the arch, since the host triple may not actually match the host.
+  std::string Arch = ArchSplit.first;
+
+  // It would be nice to do this in terms of llvm::Triple, but that is in
+  // Support which is layered above us.
+#if defined(__x86_64__)
+  Arch = "x86_64";
+#elif defined(__i386__)
+  Arch = "i386";
+#elif defined(__ppc64__)
+  Arch = "powerpc64";
+#elif defined(__ppc__)
+  Arch = "powerpc";
+#elif defined(__arm__)
+
+  // FIXME: We need to pick the right ARM triple (which involves querying the
+  // chip). However, for now this is most important for LLVM arch selection, so
+  // we only need to make sure to distinguish ARM and Thumb.
+#  if defined(__thumb__)
+  Arch = "thumb";
+#  else
+  Arch = "arm";
+#  endif
+
+#else
+
+  // FIXME: When enough auto-detection is in place, this should just
+  // #error. Then at least the arch selection is done, and we only need the OS
+  // etc selection to kill off the use of LLVM_HOSTTRIPLE.
+
+#endif
+
+  std::string Triple(Arch);
+  Triple += '-';
+  Triple += ArchSplit.second;
 
   // Force i<N>86 to i386.
   if (Triple[0] == 'i' && isdigit(Triple[1]) && 





More information about the llvm-branch-commits mailing list