]> granicus.if.org Git - llvm/commitdiff
[NFC][IRCE] Filter out empty ranges early
authorMax Kazantsev <max.kazantsev@azul.com>
Thu, 19 Oct 2017 05:33:28 +0000 (05:33 +0000)
committerMax Kazantsev <max.kazantsev@azul.com>
Thu, 19 Oct 2017 05:33:28 +0000 (05:33 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@316146 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Transforms/Scalar/InductiveRangeCheckElimination.cpp

index 9cdc1d18963e535e8693565b5b1c9c28cc87e916..111713b541c90440feaced7e6fbb2e33b70c7743 100644 (file)
@@ -1655,12 +1655,14 @@ static Optional<InductiveRangeCheck::Range>
 IntersectRange(ScalarEvolution &SE,
                const Optional<InductiveRangeCheck::Range> &R1,
                const InductiveRangeCheck::Range &R2) {
-  if (!R1.hasValue()) {
-    if (!R2.isEmpty())
-      return R2;
+  if (R2.isEmpty())
     return None;
-  }
+  if (!R1.hasValue())
+    return R2;
   auto &R1Value = R1.getValue();
+  // We never return empty ranges from this function, and R1 is supposed to be
+  // a result of intersection. Thus, R1 is never empty.
+  assert(!R1Value.isEmpty() && "We should never have empty R1!");
 
   // TODO: we could widen the smaller range and have this work; but for now we
   // bail out to keep things simple.