[PATCH] D38174: [TableGen] Return StringRef from ValueTypeByHwMode::getMVTName

Simon Pilgrim via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Fri Sep 22 05:22:47 PDT 2017


RKSimon created this revision.

Avoid unnecessary std::string creations during TypeSetByHwMode::writeToStream.

Found during investigations into PR28222


Repository:
  rL LLVM

https://reviews.llvm.org/D38174

Files:
  utils/TableGen/InfoByHwMode.cpp
  utils/TableGen/InfoByHwMode.h


Index: utils/TableGen/InfoByHwMode.h
===================================================================
--- utils/TableGen/InfoByHwMode.h
+++ utils/TableGen/InfoByHwMode.h
@@ -129,7 +129,7 @@
   MVT getType(unsigned Mode) const { return get(Mode); }
   MVT &getOrCreateTypeForMode(unsigned Mode, MVT Type);
 
-  static std::string getMVTName(MVT T);
+  static StringRef getMVTName(MVT T);
   std::string getAsString() const;
   void dump() const;
 };
Index: utils/TableGen/InfoByHwMode.cpp
===================================================================
--- utils/TableGen/InfoByHwMode.cpp
+++ utils/TableGen/InfoByHwMode.cpp
@@ -70,10 +70,9 @@
   return Map.insert(std::make_pair(Mode, Type)).first->second;
 }
 
-std::string ValueTypeByHwMode::getMVTName(MVT T) {
-  std::string N = llvm::getEnumName(T.SimpleTy);
-  if (N.substr(0,5) == "MVT::")
-    N = N.substr(5);
+StringRef ValueTypeByHwMode::getMVTName(MVT T) {
+  StringRef N = llvm::getEnumName(T.SimpleTy);
+  N.consume_front("MVT::");
   return N;
 }
 
@@ -91,7 +90,7 @@
   for (unsigned i = 0, e = Pairs.size(); i != e; ++i) {
     const PairType *P = Pairs[i];
     str << '(' << getModeName(P->first)
-        << ':' << getMVTName(P->second) << ')';
+        << ':' << getMVTName(P->second).str() << ')';
     if (i != e-1)
       str << ',';
   }


-------------- next part --------------
A non-text attachment was scrubbed...
Name: D38174.116333.patch
Type: text/x-patch
Size: 1348 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20170922/faa1c145/attachment.bin>


More information about the llvm-commits mailing list