[PATCH] D68022: [InstCombine] Don't assume CmpInst has been visited in getFlippedStrictnessPredicateAndConstant
Bjorn Pettersson via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Wed Sep 25 07:15:14 PDT 2019
bjope created this revision.
bjope added a reviewer: spatel.
Herald added a subscriber: hiraditya.
Herald added a project: LLVM.
Removing an assumption (assert) that the CmpInst already has been
simplified in getFlippedStrictnessPredicateAndConstant. Solution is
to simply bail out instead of hitting the assertion. Instead we
assume that any profitable rewrite will happen in the next iteration
of InstCombine.
The reason why we can't assume that the CmpInst already has been
simplified is that the worklist does not guarantee such an ordering.
Solves https://bugs.llvm.org/show_bug.cgi?id=43376
Repository:
rG LLVM Github Monorepo
https://reviews.llvm.org/D68022
Files:
llvm/lib/Transforms/InstCombine/InstCombineCompares.cpp
llvm/test/Transforms/InstCombine/pr43376-getFlippedStrictnessPredicateAndConstant-assert.ll
Index: llvm/test/Transforms/InstCombine/pr43376-getFlippedStrictnessPredicateAndConstant-assert.ll
===================================================================
--- /dev/null
+++ llvm/test/Transforms/InstCombine/pr43376-getFlippedStrictnessPredicateAndConstant-assert.ll
@@ -0,0 +1,36 @@
+; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
+; RUN: opt < %s -instcombine -S | FileCheck %s
+
+; We used to hit an assertion in getFlippedStrictnessPredicateAndConstant due
+; to assuming that edge cases such as %cmp (ult x, 0) already has been
+; simplified. But that depends on the worklist order, so that is not always
+; guaranteed.
+
+define i16 @d(i16* %d.a, i16* %d.b) {
+; CHECK-LABEL: @d(
+; CHECK-NEXT: entry:
+; CHECK-NEXT: [[T0:%.*]] = load i16, i16* [[D_A:%.*]], align 1
+; CHECK-NEXT: [[TOBOOL:%.*]] = icmp eq i16 [[T0]], 0
+; CHECK-NEXT: br i1 [[TOBOOL]], label [[LAND_END:%.*]], label [[LAND_RHS:%.*]]
+; CHECK: land.rhs:
+; CHECK-NEXT: br label [[LAND_END]]
+; CHECK: land.end:
+; CHECK-NEXT: ret i16 -1
+;
+entry:
+ %t0 = load i16, i16* %d.a, align 1
+ %tobool = icmp ne i16 %t0, 0
+ br i1 %tobool, label %land.rhs, label %land.end
+
+land.rhs:
+ %t1 = load i16, i16* %d.b, align 1
+ %cmp = icmp ult i16 %t1, 0
+ br label %land.end
+
+land.end:
+ %t2 = phi i1 [ false, %entry ], [ %cmp, %land.rhs ]
+ %land.ext = zext i1 %t2 to i16
+ %mul = mul nsw i16 %land.ext, 3
+ %neg = xor i16 %mul, -1
+ ret i16 %neg
+}
Index: llvm/lib/Transforms/InstCombine/InstCombineCompares.cpp
===================================================================
--- llvm/lib/Transforms/InstCombine/InstCombineCompares.cpp
+++ llvm/lib/Transforms/InstCombine/InstCombineCompares.cpp
@@ -5132,12 +5132,14 @@
return WillIncrement ? !C->isMaxValue(IsSigned) : !C->isMinValue(IsSigned);
};
- // For scalars, SimplifyICmpInst should have already handled
- // the edge cases for us, so we just assert on them.
+ // For scalars, SimplifyICmpInst should have already handled the edge cases
+ // for us, although that depends on if we already have visited the ICmp
+ // instruction or not (we might have to wait for the next iteration).
// For vectors, we must handle the edge cases.
if (isa<ConstantInt>(C)) {
+ if (!ConstantIsOk(cast<ConstantInt>(C)))
+ return llvm::None;
// A <= MAX -> TRUE ; A >= MIN -> TRUE
- assert(ConstantIsOk(cast<ConstantInt>(C)));
} else if (Type->isVectorTy()) {
// TODO? If the edge cases for vectors were guaranteed to be handled as they
// are for scalar, we could remove the min/max checks. However, to do that,
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D68022.221762.patch
Type: text/x-patch
Size: 2647 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20190925/92f071f8/attachment.bin>
More information about the llvm-commits
mailing list