[llvm-commits] [llvm] r113136 - /llvm/trunk/utils/TableGen/IntrinsicEmitter.cpp

Chris Lattner sabre at nondot.org
Sun Sep 5 18:44:44 PDT 2010


Author: lattner
Date: Sun Sep  5 20:44:44 2010
New Revision: 113136

URL: http://llvm.org/viewvc/llvm-project?rev=113136&view=rev
Log:
slightly improve the runtime and code size of the Intrinsics info table by not
comparing the "llvm." prefix in the memcmp, and not storing it in the string literal.

Modified:
    llvm/trunk/utils/TableGen/IntrinsicEmitter.cpp

Modified: llvm/trunk/utils/TableGen/IntrinsicEmitter.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/utils/TableGen/IntrinsicEmitter.cpp?rev=113136&r1=113135&r2=113136&view=diff
==============================================================================
--- llvm/trunk/utils/TableGen/IntrinsicEmitter.cpp (original)
+++ llvm/trunk/utils/TableGen/IntrinsicEmitter.cpp Sun Sep  5 20:44:44 2010
@@ -99,33 +99,35 @@
   // Build a function name -> intrinsic name mapping.
   std::map<std::string, unsigned> IntMapping;
   for (unsigned i = 0, e = Ints.size(); i != e; ++i)
-    IntMapping[Ints[i].Name] = i;
+    IntMapping[Ints[i].Name.substr(5)] = i;
     
   OS << "// Function name -> enum value recognizer code.\n";
   OS << "#ifdef GET_FUNCTION_RECOGNIZER\n";
-  OS << "  switch (Name[5]) {\n";
+  OS << "  Name += 5; Len -= 5;  // Skip over 'llvm.'\n";
+  OS << "  switch (*Name) {      // Dispatch on first letter.\n";
   OS << "  default:\n";
   // Emit the intrinsics in sorted order.
   char LastChar = 0;
   for (std::map<std::string, unsigned>::iterator I = IntMapping.begin(),
        E = IntMapping.end(); I != E; ++I) {
-    if (I->first[5] != LastChar) {
-      LastChar = I->first[5];
+    if (I->first[0] != LastChar) {
+      LastChar = I->first[0];
       OS << "    break;\n";
       OS << "  case '" << LastChar << "':\n";
     }
     
     // For overloaded intrinsics, only the prefix needs to match
-    if (Ints[I->second].isOverloaded)
-      OS << "    if (Len > " << I->first.size()
-       << " && !memcmp(Name, \"" << I->first << ".\", "
-       << (I->first.size() + 1) << ")) return " << TargetPrefix << "Intrinsic::"
+    std::string TheStr = I->first;
+    if (Ints[I->second].isOverloaded) {
+      TheStr += '.';  // Require "bswap." instead of bswap.
+      OS << "    if (Len > " << I->first.size();
+    } else {
+      OS << "    if (Len == " << I->first.size();
+    }
+      
+    OS << " && !memcmp(Name, \"" << TheStr << "\", "
+       << TheStr.size() << ")) return " << TargetPrefix << "Intrinsic::"
        << Ints[I->second].EnumName << ";\n";
-    else 
-      OS << "    if (Len == " << I->first.size()
-         << " && !memcmp(Name, \"" << I->first << "\", "
-         << I->first.size() << ")) return " << TargetPrefix << "Intrinsic::"
-         << Ints[I->second].EnumName << ";\n";
   }
   OS << "  }\n";
   OS << "#endif\n\n";





More information about the llvm-commits mailing list