[llvm-commits] [llvm] r68118 - in /llvm/trunk: include/llvm/System/Host.h lib/System/Unix/Host.inc lib/System/Win32/Host.inc

Daniel Dunbar daniel at zuster.org
Tue Mar 31 10:30:15 PDT 2009


Author: ddunbar
Date: Tue Mar 31 12:30:15 2009
New Revision: 68118

URL: http://llvm.org/viewvc/llvm-project?rev=68118&view=rev
Log:
Add llvm::sys::getHostTriple and remove
llvm::sys::getOS{Name,Version}.

Right now the implementation just derives from LLVM_HOSTTRIPLE (which
is wrong, but it doesn't look like we have a define for the target
triple). Ideally this routine would actually be able to compute the
triple for targets we care about.

Modified:
    llvm/trunk/include/llvm/System/Host.h
    llvm/trunk/lib/System/Unix/Host.inc
    llvm/trunk/lib/System/Win32/Host.inc

Modified: llvm/trunk/include/llvm/System/Host.h
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/include/llvm/System/Host.h?rev=68118&r1=68117&r2=68118&view=diff

==============================================================================
--- llvm/trunk/include/llvm/System/Host.h (original)
+++ llvm/trunk/include/llvm/System/Host.h Tue Mar 31 12:30:15 2009
@@ -32,13 +32,15 @@
     return !isLittleEndianHost();
   }
 
-  /// getOSName() - Return the name of the host operating system or "" if
-  /// unknown.
-  std::string getOSName();
+  /// getHostTriple() - Return the target triple of the running
+  /// system.
+  ///
+  /// The target triple is a string in the format of:
+  ///   CPU_TYPE-VENDOR-OPERATING_SYSTEM
+  /// or
+  ///   CPU_TYPE-VENDOR-KERNEL-OPERATING_SYSTEM
+  std::string getHostTriple();
 
-  /// getOSVersion() - Return the operating system version as a string or
-  /// "" if unknown.
-  std::string getOSVersion();
 }
 }
 

Modified: llvm/trunk/lib/System/Unix/Host.inc
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/System/Unix/Host.inc?rev=68118&r1=68117&r2=68118&view=diff

==============================================================================
--- llvm/trunk/lib/System/Unix/Host.inc (original)
+++ llvm/trunk/lib/System/Unix/Host.inc Tue Mar 31 12:30:15 2009
@@ -23,20 +23,36 @@
 
 using namespace llvm;
 
-std::string llvm::sys::getOSName() {
+static std::string getOSVersion() {
   struct utsname info;
 
   if (uname(&info))
     return "";
 
-  return info.sysname;
+  return info.release;
 }
 
-std::string llvm::sys::getOSVersion() {
-  struct utsname info;
-
-  if (uname(&info))
-    return "";
+std::string sys::getHostTriple() {
+  // FIXME: Derive more directly instead of relying on the autoconf
+  // generated variable.
+
+  std::string Triple = LLVM_HOSTTRIPLE;
+
+  // Force i<N>86 to i386.
+  if (Triple[0] == 'i' && isdigit(Triple[1]) && 
+      Triple[2] == '8' && Triple[3] == '6')
+    Triple[1] = '3';
+
+  // On darwin, we want to update the version to match that of the
+  // host.    
+  std::string::size_type DarwinDashIdx = Triple.find("-darwin");
+  if (DarwinDashIdx != std::string::npos) {
+    Triple.resize(DarwinDashIdx + strlen("-darwin"));
+    
+    // Only add the major part of the os version.
+    std::string Version = getOSVersion();
+    Triple += Version.substr(0, Version.find('.'));
+  }
 
-  return info.release;
+  return Triple;
 }

Modified: llvm/trunk/lib/System/Win32/Host.inc
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/System/Win32/Host.inc?rev=68118&r1=68117&r2=68118&view=diff

==============================================================================
--- llvm/trunk/lib/System/Win32/Host.inc (original)
+++ llvm/trunk/lib/System/Win32/Host.inc Tue Mar 31 12:30:15 2009
@@ -17,21 +17,7 @@
 
 using namespace llvm;
 
-std::string sys::getOSName() {
-  return "Windows";
-}
-
-std::string sys::getOSVersion() {
-  OSVERSIONINFO osvi;
-
-  memset(&osvi, 0, sizeof(osvi));
-  osvi.dwOSVersionInfoSize = sizeof(OSVERSIONINFO);
-
-  if (!GetVersionEx(&osvi))
-    return "";
-
-  char buf[64];
-  sprintf(buf, "%d.%d", (int)osvi.dwMajorVersion, (int)osvi.dwMinorVersion);
-
-  return buf;
+std::string sys::getHostTriple() {
+  // FIXME: Adapt to running version.
+  return LLVM_HOSTTRIPLE;
 }





More information about the llvm-commits mailing list