Do not try to optimize PHI nodes with incredibly high degree. This reduces SCCP
authorChris Lattner <sabre@nondot.org>
Tue, 16 Mar 2004 19:49:59 +0000 (19:49 +0000)
committerChris Lattner <sabre@nondot.org>
Tue, 16 Mar 2004 19:49:59 +0000 (19:49 +0000)
time from 615s to 1.49s on a large testcase that has a gigantic switch statement
that all of the blocks in the function go to (an intepreter).

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

lib/Transforms/Scalar/SCCP.cpp

index 26c246df0007896313eb65455d40e7484afe1860..75be39704e1112294fe24ee61dce606c889edac8 100644 (file)
@@ -500,6 +500,13 @@ void SCCP::visitPHINode(PHINode &PN) {
     return;  // Quick exit
   }
 
+  // Super-extra-high-degree PHI nodes are unlikely to ever be marked constant,
+  // and slow us down a lot.  Just mark them overdefined.
+  if (PN.getNumIncomingValues() > 64) {
+    markOverdefined(PNIV, &PN);
+    return;
+  }
+
   // Look at all of the executable operands of the PHI node.  If any of them
   // are overdefined, the PHI becomes overdefined as well.  If they are all
   // constant, and they agree with each other, the PHI becomes the identical