Minor speedup for legalize by avoiding some malloc traffic
authorChris Lattner <sabre@nondot.org>
Tue, 19 Sep 2006 04:51:23 +0000 (04:51 +0000)
committerChris Lattner <sabre@nondot.org>
Tue, 19 Sep 2006 04:51:23 +0000 (04:51 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@30477 91177308-0d34-0410-b5e6-96231b3b80d8

lib/CodeGen/SelectionDAG/SelectionDAG.cpp

index df6d604bd18e01eaca5f6642275b24f0021b32e5..55b128f515d4dc6cad6876ef844a889d421a78ca 100644 (file)
@@ -1329,6 +1329,15 @@ SDOperand SelectionDAG::getNode(unsigned Opcode, MVT::ValueType VT,
     if (EVT == VT) return N1;  // Not actually extending
     break;
   }
+  case ISD::EXTRACT_ELEMENT:
+    // EXTRACT_ELEMENT of BUILD_PAIR is often formed while legalize is expanding
+    // 64-bit integers into 32-bit parts.  Instead of building the extract of
+    // the BUILD_PAIR, only to have legalize rip it apart, just do it now. 
+    if (N2C && N1.getOpcode() == ISD::BUILD_PAIR) {
+      assert((unsigned)N2C->getValue() < 2 && "Bad EXTRACT_ELEMENT!");
+      return N1.getOperand(N2C->getValue());
+    }
+    break;
 
   // FIXME: figure out how to safely handle things like
   // int foo(int x) { return 1 << (x & 255); }