Fix LSR's OptimizeSMax to ignore max operators with more than 2 operands,
authorDan Gohman <gohman@apple.com>
Fri, 19 Jun 2009 23:03:46 +0000 (23:03 +0000)
committerDan Gohman <gohman@apple.com>
Fri, 19 Jun 2009 23:03:46 +0000 (23:03 +0000)
which it isn't prepared to handle.

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

lib/Transforms/Scalar/LoopStrengthReduce.cpp

index 03966672d623aa9b48a9e58528210ce463cdff2a..dac734029b4aa0921dc5e11d0691329808b6dde9 100644 (file)
@@ -2116,6 +2116,11 @@ ICmpInst *LoopStrengthReduce::OptimizeSMax(Loop *L, ICmpInst *Cond,
   const SCEVSMaxExpr *SMax = dyn_cast<SCEVSMaxExpr>(IterationCount);
   if (!SMax || SMax != SE->getSCEV(Sel)) return Cond;
 
+  // Two handle a max with more than two operands, this optimization would
+  // require additional checking and setup.
+  if (SMax->getNumOperands() != 2)
+    return Cond;
+
   SCEVHandle SMaxLHS = SMax->getOperand(0);
   SCEVHandle SMaxRHS = SMax->getOperand(1);
   if (!SMaxLHS || SMaxLHS != One) return Cond;