[PATCH] D148321: [ConstraintElimination] Add tests to check for transfering facts from sgt to ugt.
Zain Jaffal via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Fri Apr 14 03:32:22 PDT 2023
zjaffal created this revision.
zjaffal added reviewers: fhahn, spatel, nikic.
Herald added a subscriber: StephenFan.
Herald added a project: All.
zjaffal requested review of this revision.
Herald added a project: LLVM.
Herald added a subscriber: llvm-commits.
If we have a >s b and we know that b >s 0 then we also can infer that a >u b.
Repository:
rG LLVM Github Monorepo
https://reviews.llvm.org/D148321
Files:
llvm/test/Transforms/ConstraintElimination/transfer-signed-facts-to-unsigned.ll
Index: llvm/test/Transforms/ConstraintElimination/transfer-signed-facts-to-unsigned.ll
===================================================================
--- llvm/test/Transforms/ConstraintElimination/transfer-signed-facts-to-unsigned.ll
+++ llvm/test/Transforms/ConstraintElimination/transfer-signed-facts-to-unsigned.ll
@@ -596,6 +596,74 @@
ret i1 %res.2
}
+define i1 @sgt_to_ugt(i8 %a) {
+; CHECK-LABEL: @sgt_to_ugt(
+; CHECK-NEXT: entry:
+; CHECK-NEXT: [[CMP:%.*]] = icmp sgt i8 [[A:%.*]], 2
+; CHECK-NEXT: call void @llvm.assume(i1 [[CMP]])
+; CHECK-NEXT: [[T_1:%.*]] = icmp ugt i8 [[A]], 2
+; CHECK-NEXT: ret i1 [[T_1]]
+;
+entry:
+ %cmp = icmp sgt i8 %a, 2
+ call void @llvm.assume(i1 %cmp)
+ %t.1 = icmp ugt i8 %a, 2
+ ret i1 %t.1
+}
+
+define i1 @sgt_to_ugt_var(i8 %a, i8 %b) {
+; CHECK-LABEL: @sgt_to_ugt_var(
+; CHECK-NEXT: entry:
+; CHECK-NEXT: [[CMP:%.*]] = icmp sgt i8 [[A:%.*]], [[B:%.*]]
+; CHECK-NEXT: [[CMP_2:%.*]] = icmp sgt i8 [[B]], 0
+; CHECK-NEXT: call void @llvm.assume(i1 [[CMP]])
+; CHECK-NEXT: call void @llvm.assume(i1 [[CMP_2]])
+; CHECK-NEXT: [[T_1:%.*]] = icmp ugt i8 [[A]], [[B]]
+; CHECK-NEXT: ret i1 [[T_1]]
+;
+entry:
+ %cmp = icmp sgt i8 %a, %b
+ %cmp.2 = icmp sgt i8 %b, 0
+ call void @llvm.assume(i1 %cmp)
+ call void @llvm.assume(i1 %cmp.2)
+ %t.1 = icmp ugt i8 %a, %b
+ ret i1 %t.1
+}
+
+define i1 @sgt_to_ugt_not(i8 %a) {
+; CHECK-LABEL: @sgt_to_ugt_not(
+; CHECK-NEXT: entry:
+; CHECK-NEXT: [[CMP:%.*]] = icmp sgt i8 [[A:%.*]], -1
+; CHECK-NEXT: call void @llvm.assume(i1 [[CMP]])
+; CHECK-NEXT: [[T_1:%.*]] = icmp ugt i8 [[A]], -1
+; CHECK-NEXT: ret i1 [[T_1]]
+;
+entry:
+ %cmp = icmp sgt i8 %a, -1
+ call void @llvm.assume(i1 %cmp)
+ %t.1 = icmp ugt i8 %a, -1
+ ret i1 %t.1
+}
+
+define i1 @sgt_to_ugt_var_not(i8 %a, i8 %b) {
+; CHECK-LABEL: @sgt_to_ugt_var_not(
+; CHECK-NEXT: entry:
+; CHECK-NEXT: [[CMP:%.*]] = icmp sgt i8 [[A:%.*]], [[B:%.*]]
+; CHECK-NEXT: [[CMP_2:%.*]] = icmp sgt i8 [[B]], -1
+; CHECK-NEXT: call void @llvm.assume(i1 [[CMP]])
+; CHECK-NEXT: call void @llvm.assume(i1 [[CMP_2]])
+; CHECK-NEXT: [[T_1:%.*]] = icmp ugt i8 [[A]], [[B]]
+; CHECK-NEXT: ret i1 [[T_1]]
+;
+entry:
+ %cmp = icmp sgt i8 %a, %b
+ %cmp.2 = icmp sgt i8 %b, -1
+ call void @llvm.assume(i1 %cmp)
+ call void @llvm.assume(i1 %cmp.2)
+ %t.1 = icmp ugt i8 %a, %b
+ ret i1 %t.1
+}
+
define i1 @slt_first_op_known_pos(i8 %idx) {
; CHECK-LABEL: @slt_first_op_known_pos(
; CHECK-NEXT: entry:
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D148321.513520.patch
Type: text/x-patch
Size: 2518 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20230414/54875ea9/attachment.bin>
More information about the llvm-commits
mailing list