[llvm] r360445 - [CVP] Add tests for abs and nabs spf; NFC
Nikita Popov via llvm-commits
llvm-commits at lists.llvm.org
Fri May 10 10:39:51 PDT 2019
Author: nikic
Date: Fri May 10 10:39:50 2019
New Revision: 360445
URL: http://llvm.org/viewvc/llvm-project?rev=360445&view=rev
Log:
[CVP] Add tests for abs and nabs spf; NFC
One half of the bound is already computed correctly for these
tests, the other isn't.
Modified:
llvm/trunk/test/Transforms/CorrelatedValuePropagation/basic.ll
Modified: llvm/trunk/test/Transforms/CorrelatedValuePropagation/basic.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Transforms/CorrelatedValuePropagation/basic.ll?rev=360445&r1=360444&r2=360445&view=diff
==============================================================================
--- llvm/trunk/test/Transforms/CorrelatedValuePropagation/basic.ll (original)
+++ llvm/trunk/test/Transforms/CorrelatedValuePropagation/basic.ll Fri May 10 10:39:50 2019
@@ -617,6 +617,210 @@ out:
ret i1 false
}
+define void @abs1(i32 %a, i1* %p) {
+; CHECK-LABEL: @abs1(
+; CHECK-NEXT: entry:
+; CHECK-NEXT: [[CMP1:%.*]] = icmp slt i32 [[A:%.*]], 10
+; CHECK-NEXT: [[CMP2:%.*]] = icmp sgt i32 [[A]], -20
+; CHECK-NEXT: [[AND:%.*]] = and i1 [[CMP1]], [[CMP2]]
+; CHECK-NEXT: br i1 [[AND]], label [[GUARD:%.*]], label [[EXIT:%.*]]
+; CHECK: guard:
+; CHECK-NEXT: [[SUB:%.*]] = sub i32 0, [[A]]
+; CHECK-NEXT: [[CMP:%.*]] = icmp slt i32 [[A]], 0
+; CHECK-NEXT: [[ABS:%.*]] = select i1 [[CMP]], i32 [[SUB]], i32 [[A]]
+; CHECK-NEXT: br label [[SPLIT:%.*]]
+; CHECK: split:
+; CHECK-NEXT: store i1 true, i1* [[P:%.*]]
+; CHECK-NEXT: [[C2:%.*]] = icmp slt i32 [[ABS]], 19
+; CHECK-NEXT: store i1 [[C2]], i1* [[P]]
+; CHECK-NEXT: [[C3:%.*]] = icmp sge i32 [[ABS]], 0
+; CHECK-NEXT: store i1 [[C3]], i1* [[P]]
+; CHECK-NEXT: [[C4:%.*]] = icmp sge i32 [[ABS]], 1
+; CHECK-NEXT: store i1 [[C4]], i1* [[P]]
+; CHECK-NEXT: br label [[EXIT]]
+; CHECK: exit:
+; CHECK-NEXT: ret void
+;
+entry:
+ %cmp1 = icmp slt i32 %a, 10
+ %cmp2 = icmp sgt i32 %a, -20
+ %and = and i1 %cmp1, %cmp2
+ br i1 %and, label %guard, label %exit
+
+guard:
+ %sub = sub i32 0, %a
+ %cmp = icmp slt i32 %a, 0
+ %abs = select i1 %cmp, i32 %sub, i32 %a
+ br label %split
+
+split:
+ %c1 = icmp slt i32 %abs, 20
+ store i1 %c1, i1* %p
+ %c2 = icmp slt i32 %abs, 19
+ store i1 %c2, i1* %p
+ %c3 = icmp sge i32 %abs, 0
+ store i1 %c3, i1* %p
+ %c4 = icmp sge i32 %abs, 1
+ store i1 %c4, i1* %p
+ br label %exit
+
+exit:
+ ret void
+}
+
+define void @abs2(i32 %a, i1* %p) {
+; CHECK-LABEL: @abs2(
+; CHECK-NEXT: entry:
+; CHECK-NEXT: [[CMP1:%.*]] = icmp slt i32 [[A:%.*]], 10
+; CHECK-NEXT: [[CMP2:%.*]] = icmp sgt i32 [[A]], -20
+; CHECK-NEXT: [[AND:%.*]] = and i1 [[CMP1]], [[CMP2]]
+; CHECK-NEXT: br i1 [[AND]], label [[GUARD:%.*]], label [[EXIT:%.*]]
+; CHECK: guard:
+; CHECK-NEXT: [[SUB:%.*]] = sub i32 0, [[A]]
+; CHECK-NEXT: [[CMP:%.*]] = icmp sge i32 [[A]], 0
+; CHECK-NEXT: [[ABS:%.*]] = select i1 [[CMP]], i32 [[A]], i32 [[SUB]]
+; CHECK-NEXT: br label [[SPLIT:%.*]]
+; CHECK: split:
+; CHECK-NEXT: store i1 true, i1* [[P:%.*]]
+; CHECK-NEXT: [[C2:%.*]] = icmp slt i32 [[ABS]], 19
+; CHECK-NEXT: store i1 [[C2]], i1* [[P]]
+; CHECK-NEXT: [[C3:%.*]] = icmp sge i32 [[ABS]], 0
+; CHECK-NEXT: store i1 [[C3]], i1* [[P]]
+; CHECK-NEXT: [[C4:%.*]] = icmp sge i32 [[ABS]], 1
+; CHECK-NEXT: store i1 [[C4]], i1* [[P]]
+; CHECK-NEXT: br label [[EXIT]]
+; CHECK: exit:
+; CHECK-NEXT: ret void
+;
+entry:
+ %cmp1 = icmp slt i32 %a, 10
+ %cmp2 = icmp sgt i32 %a, -20
+ %and = and i1 %cmp1, %cmp2
+ br i1 %and, label %guard, label %exit
+
+guard:
+ %sub = sub i32 0, %a
+ %cmp = icmp sge i32 %a, 0
+ %abs = select i1 %cmp, i32 %a, i32 %sub
+ br label %split
+
+split:
+ %c1 = icmp slt i32 %abs, 20
+ store i1 %c1, i1* %p
+ %c2 = icmp slt i32 %abs, 19
+ store i1 %c2, i1* %p
+ %c3 = icmp sge i32 %abs, 0
+ store i1 %c3, i1* %p
+ %c4 = icmp sge i32 %abs, 1
+ store i1 %c4, i1* %p
+ br label %exit
+
+exit:
+ ret void
+}
+
+define void @nabs1(i32 %a, i1* %p) {
+; CHECK-LABEL: @nabs1(
+; CHECK-NEXT: entry:
+; CHECK-NEXT: [[CMP1:%.*]] = icmp slt i32 [[A:%.*]], 10
+; CHECK-NEXT: [[CMP2:%.*]] = icmp sgt i32 [[A]], -20
+; CHECK-NEXT: [[AND:%.*]] = and i1 [[CMP1]], [[CMP2]]
+; CHECK-NEXT: br i1 [[AND]], label [[GUARD:%.*]], label [[EXIT:%.*]]
+; CHECK: guard:
+; CHECK-NEXT: [[SUB:%.*]] = sub i32 0, [[A]]
+; CHECK-NEXT: [[CMP:%.*]] = icmp sgt i32 [[A]], 0
+; CHECK-NEXT: [[NABS:%.*]] = select i1 [[CMP]], i32 [[SUB]], i32 [[A]]
+; CHECK-NEXT: br label [[SPLIT:%.*]]
+; CHECK: split:
+; CHECK-NEXT: store i1 true, i1* [[P:%.*]]
+; CHECK-NEXT: [[C2:%.*]] = icmp sgt i32 [[NABS]], -19
+; CHECK-NEXT: store i1 [[C2]], i1* [[P]]
+; CHECK-NEXT: [[C3:%.*]] = icmp sle i32 [[NABS]], 0
+; CHECK-NEXT: store i1 [[C3]], i1* [[P]]
+; CHECK-NEXT: [[C4:%.*]] = icmp sle i32 [[NABS]], -1
+; CHECK-NEXT: store i1 [[C4]], i1* [[P]]
+; CHECK-NEXT: br label [[EXIT]]
+; CHECK: exit:
+; CHECK-NEXT: ret void
+;
+entry:
+ %cmp1 = icmp slt i32 %a, 10
+ %cmp2 = icmp sgt i32 %a, -20
+ %and = and i1 %cmp1, %cmp2
+ br i1 %and, label %guard, label %exit
+
+guard:
+ %sub = sub i32 0, %a
+ %cmp = icmp sgt i32 %a, 0
+ %nabs = select i1 %cmp, i32 %sub, i32 %a
+ br label %split
+
+split:
+ %c1 = icmp sgt i32 %nabs, -20
+ store i1 %c1, i1* %p
+ %c2 = icmp sgt i32 %nabs, -19
+ store i1 %c2, i1* %p
+ %c3 = icmp sle i32 %nabs, 0
+ store i1 %c3, i1* %p
+ %c4 = icmp sle i32 %nabs, -1
+ store i1 %c4, i1* %p
+ br label %exit
+
+exit:
+ ret void
+}
+
+define void @nabs2(i32 %a, i1* %p) {
+; CHECK-LABEL: @nabs2(
+; CHECK-NEXT: entry:
+; CHECK-NEXT: [[CMP1:%.*]] = icmp slt i32 [[A:%.*]], 10
+; CHECK-NEXT: [[CMP2:%.*]] = icmp sgt i32 [[A]], -20
+; CHECK-NEXT: [[AND:%.*]] = and i1 [[CMP1]], [[CMP2]]
+; CHECK-NEXT: br i1 [[AND]], label [[GUARD:%.*]], label [[EXIT:%.*]]
+; CHECK: guard:
+; CHECK-NEXT: [[SUB:%.*]] = sub i32 0, [[A]]
+; CHECK-NEXT: [[CMP:%.*]] = icmp slt i32 [[A]], 0
+; CHECK-NEXT: [[NABS:%.*]] = select i1 [[CMP]], i32 [[A]], i32 [[SUB]]
+; CHECK-NEXT: br label [[SPLIT:%.*]]
+; CHECK: split:
+; CHECK-NEXT: store i1 true, i1* [[P:%.*]]
+; CHECK-NEXT: [[C2:%.*]] = icmp sgt i32 [[NABS]], -19
+; CHECK-NEXT: store i1 [[C2]], i1* [[P]]
+; CHECK-NEXT: [[C3:%.*]] = icmp sle i32 [[NABS]], 0
+; CHECK-NEXT: store i1 [[C3]], i1* [[P]]
+; CHECK-NEXT: [[C4:%.*]] = icmp sle i32 [[NABS]], -1
+; CHECK-NEXT: store i1 [[C4]], i1* [[P]]
+; CHECK-NEXT: br label [[EXIT]]
+; CHECK: exit:
+; CHECK-NEXT: ret void
+;
+entry:
+ %cmp1 = icmp slt i32 %a, 10
+ %cmp2 = icmp sgt i32 %a, -20
+ %and = and i1 %cmp1, %cmp2
+ br i1 %and, label %guard, label %exit
+
+guard:
+ %sub = sub i32 0, %a
+ %cmp = icmp slt i32 %a, 0
+ %nabs = select i1 %cmp, i32 %a, i32 %sub
+ br label %split
+
+split:
+ %c1 = icmp sgt i32 %nabs, -20
+ store i1 %c1, i1* %p
+ %c2 = icmp sgt i32 %nabs, -19
+ store i1 %c2, i1* %p
+ %c3 = icmp sle i32 %nabs, 0
+ store i1 %c3, i1* %p
+ %c4 = icmp sle i32 %nabs, -1
+ store i1 %c4, i1* %p
+ br label %exit
+
+exit:
+ ret void
+}
+
define i1 @zext_unknown(i8 %a) {
; CHECK-LABEL: @zext_unknown(
; CHECK-NEXT: entry:
More information about the llvm-commits
mailing list