Remove a linear walk to find the default FPU for a given CPU by directly
authorChandler Carruth <chandlerc@gmail.com>
Sun, 30 Aug 2015 09:01:38 +0000 (09:01 +0000)
committerChandler Carruth <chandlerc@gmail.com>
Sun, 30 Aug 2015 09:01:38 +0000 (09:01 +0000)
expanding the .def file within a StringSwitch.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@246377 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Support/TargetParser.cpp

index 3280035dca9457210b3c21c814491a50d5d91f6b..4f5d9acba51973d0da7b34ef900d38e66d3a49f2 100644 (file)
@@ -110,13 +110,12 @@ struct {
   const char *NameCStr;
   size_t NameLength;
   ARM::ArchKind ArchID;
   const char *NameCStr;
   size_t NameLength;
   ARM::ArchKind ArchID;
-  ARM::FPUKind DefaultFPU;
   bool Default; // is $Name the default CPU for $ArchID ?
 
   StringRef getName() const { return StringRef(NameCStr, NameLength); }
 } CPUNames[] = {
 #define ARM_CPU_NAME(NAME, ID, DEFAULT_FPU, IS_DEFAULT) \
   bool Default; // is $Name the default CPU for $ArchID ?
 
   StringRef getName() const { return StringRef(NameCStr, NameLength); }
 } CPUNames[] = {
 #define ARM_CPU_NAME(NAME, ID, DEFAULT_FPU, IS_DEFAULT) \
-  { NAME, sizeof(NAME) - 1, ID, DEFAULT_FPU, IS_DEFAULT },
+  { NAME, sizeof(NAME) - 1, ID, IS_DEFAULT },
 #include "llvm/Support/ARMTargetParser.def"
 };
 
 #include "llvm/Support/ARMTargetParser.def"
 };
 
@@ -151,11 +150,11 @@ unsigned llvm::ARM::getFPURestriction(unsigned FPUKind) {
 }
 
 unsigned llvm::ARM::getDefaultFPU(StringRef CPU) {
 }
 
 unsigned llvm::ARM::getDefaultFPU(StringRef CPU) {
-  for (const auto C : CPUNames) {
-    if (CPU == C.getName())
-      return C.DefaultFPU;
-  }
-  return ARM::FK_INVALID;
+  return StringSwitch<unsigned>(CPU)
+#define ARM_CPU_NAME(NAME, ID, DEFAULT_FPU, IS_DEFAULT) \
+    .Case(NAME, DEFAULT_FPU)
+#include "llvm/Support/ARMTargetParser.def"
+    .Default(ARM::FK_INVALID);
 }
 
 bool llvm::ARM::getHWDivFeatures(unsigned HWDivKind,
 }
 
 bool llvm::ARM::getHWDivFeatures(unsigned HWDivKind,