summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSanjay Patel <spatel@rotateright.com>2019-04-15 20:25:31 +0000
committerSanjay Patel <spatel@rotateright.com>2019-04-15 20:25:31 +0000
commit5ae05d810c8db486989a799306f65e8e16cfeff1 (patch)
tree064a9d1a1280823712abfbb5ae2aaf7c11bb06d7
parent16256123d006069edacf7ee4b65e5b82d723a3cd (diff)
downloadbcm5719-llvm-5ae05d810c8db486989a799306f65e8e16cfeff1.tar.gz
bcm5719-llvm-5ae05d810c8db486989a799306f65e8e16cfeff1.zip
[EarlyCSE] add test for select condition double-negation; NFC
llvm-svn: 358444
-rw-r--r--llvm/test/Transforms/EarlyCSE/commute.ll21
1 files changed, 21 insertions, 0 deletions
diff --git a/llvm/test/Transforms/EarlyCSE/commute.ll b/llvm/test/Transforms/EarlyCSE/commute.ll
index e7a1cfcf103..df092fcc29a 100644
--- a/llvm/test/Transforms/EarlyCSE/commute.ll
+++ b/llvm/test/Transforms/EarlyCSE/commute.ll
@@ -451,3 +451,24 @@ define i32 @select_invert_pred_wrong_cmp_ops(float %x, i32 %t, i32 %f) {
%r = xor i32 %m2, %m1
ret i32 %r
}
+
+; TODO: If we have both an inverted predicate and a 'not' op, recognize the double-negation.
+
+define i32 @select_not_invert_pred_cond(i8 %x, i32 %t, i32 %f) {
+; CHECK-LABEL: @select_not_invert_pred_cond(
+; CHECK-NEXT: [[COND:%.*]] = icmp ugt i8 [[X:%.*]], 42
+; CHECK-NEXT: [[INVCOND:%.*]] = icmp ule i8 [[X]], 42
+; CHECK-NEXT: [[NOT:%.*]] = xor i1 [[INVCOND]], true
+; CHECK-NEXT: [[M1:%.*]] = select i1 [[COND]], i32 [[T:%.*]], i32 [[F:%.*]]
+; CHECK-NEXT: [[M2:%.*]] = select i1 [[NOT]], i32 [[T]], i32 [[F]]
+; CHECK-NEXT: [[R:%.*]] = xor i32 [[M1]], [[M2]]
+; CHECK-NEXT: ret i32 [[R]]
+;
+ %cond = icmp ugt i8 %x, 42
+ %invcond = icmp ule i8 %x, 42
+ %not = xor i1 %invcond, -1
+ %m1 = select i1 %cond, i32 %t, i32 %f
+ %m2 = select i1 %not, i32 %t, i32 %f
+ %r = xor i32 %m1, %m2
+ ret i32 %r
+}
OpenPOWER on IntegriCloud