[cfe-commits] r67107 - in /cfe/trunk/lib/Driver: HostInfo.cpp ToolChains.h

Daniel Dunbar daniel at zuster.org
Tue Mar 17 14:38:01 PDT 2009


Author: ddunbar
Date: Tue Mar 17 16:38:00 2009
New Revision: 67107

URL: http://llvm.org/viewvc/llvm-project?rev=67107&view=rev
Log:
Driver: Stub out generic GCC tool chain implementation.

Added:
    cfe/trunk/lib/Driver/ToolChains.h
Modified:
    cfe/trunk/lib/Driver/HostInfo.cpp

Modified: cfe/trunk/lib/Driver/HostInfo.cpp
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Driver/HostInfo.cpp?rev=67107&r1=67106&r2=67107&view=diff

==============================================================================
--- cfe/trunk/lib/Driver/HostInfo.cpp (original)
+++ cfe/trunk/lib/Driver/HostInfo.cpp Tue Mar 17 16:38:00 2009
@@ -17,6 +17,8 @@
 #include "llvm/ADT/StringMap.h"
 #include "llvm/Support/Compiler.h"
 
+#include "ToolChains.h"
+
 #include <cassert>
  
 using namespace clang::driver;
@@ -96,15 +98,14 @@
 
   ToolChain *&TC = ToolChains[ArchName];
   if (!TC) {
-    TC = 0;
-#if 0
-    if (ArchName == "i386")
-      TC = new Darwin_X86_ToolChain(ArchName);
-    else if (ArchName == "x86_64")
-      TC = new Darwin_X86_ToolChain(ArchName);
+    if (strcmp(ArchName, "i386") == 0 || strcmp(ArchName, "x86_64") == 0)
+      TC = new toolchains::Generic_GCC(*this, ArchName, 
+                                       getPlatformName().c_str(), 
+                                       getOSName().c_str());
     else
-      TC = new Darwin_GCC_ToolChain(ArchName);
-#endif
+      TC = new toolchains::Generic_GCC(*this, ArchName, 
+                                       getPlatformName().c_str(), 
+                                       getOSName().c_str());
   }
 
   return TC;
@@ -156,7 +157,9 @@
   
   ToolChain *&TC = ToolChains[ArchName];
   if (!TC)
-    TC = 0; //new Generic_GCC_ToolChain(ArchName);
+    TC = new toolchains::Generic_GCC(*this, ArchName, 
+                                     getPlatformName().c_str(), 
+                                     getOSName().c_str());
 
   return 0;
 }

Added: cfe/trunk/lib/Driver/ToolChains.h
URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/Driver/ToolChains.h?rev=67107&view=auto

==============================================================================
--- cfe/trunk/lib/Driver/ToolChains.h (added)
+++ cfe/trunk/lib/Driver/ToolChains.h Tue Mar 17 16:38:00 2009
@@ -0,0 +1,54 @@
+//===--- ToolChains.h - ToolChain Implementations ---------------*- C++ -*-===//
+//
+//                     The LLVM Compiler Infrastructure
+//
+// This file is distributed under the University of Illinois Open Source
+// License. See LICENSE.TXT for details.
+//
+//===----------------------------------------------------------------------===//
+
+#ifndef CLANG_LIB_DRIVER_TOOLCHAINS_H_
+#define CLANG_LIB_DRIVER_TOOLCHAINS_H_
+
+#include "clang/Driver/ToolChain.h"
+
+#include "llvm/Support/Compiler.h"
+
+namespace clang {
+namespace driver {
+namespace toolchains VISIBILITY_HIDDEN {
+
+class Generic_GCC : public ToolChain {
+public:
+  Generic_GCC(const HostInfo &Host, const char *Arch, const char *Platform, 
+              const char *OS) : ToolChain(Host, Arch, Platform, OS) {
+  }
+
+  virtual ArgList *TranslateArgs(ArgList &Args) const { return &Args; }
+
+  virtual Tool &SelectTool(const Compilation &C, const JobAction &JA) const {
+    return *((Tool*) 0);
+  }
+
+  virtual bool IsMathErrnoDefault() const { return true; }
+
+  virtual bool IsUnwindTablesDefault() const { 
+    // FIXME: Gross; we should probably have some separate target definition,
+    // possibly even reusing the one in clang.
+    return getArchName() == "x86_64";
+  }
+
+  virtual const char *GetDefaultRelocationModel() const {
+    return "static";
+  }
+
+  virtual const char *GetForcedPicModel() const {
+    return 0;
+  }
+};
+
+} // end namespace toolchains
+} // end namespace driver
+} // end namespace clang
+
+#endif





More information about the cfe-commits mailing list