| ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 5 |
| ; RUN: opt -passes=constraint-elimination -S %s | FileCheck %s |
| |
| declare i64 @llvm.uadd.sat.i64(i64, i64) |
| declare i64 @llvm.usub.sat.i64(i64, i64) |
| |
| define i1 @uadd_sat_uge(i64 noundef %a, i64 noundef %b) { |
| ; CHECK-LABEL: define i1 @uadd_sat_uge( |
| ; CHECK-SAME: i64 noundef [[A:%.*]], i64 noundef [[B:%.*]]) { |
| ; CHECK-NEXT: [[ADD_SAT:%.*]] = call i64 @llvm.uadd.sat.i64(i64 [[A]], i64 [[B]]) |
| ; CHECK-NEXT: [[CMP:%.*]] = and i1 true, true |
| ; CHECK-NEXT: ret i1 [[CMP]] |
| ; |
| %add.sat = call i64 @llvm.uadd.sat.i64(i64 %a, i64 %b) |
| %cmp1 = icmp uge i64 %add.sat, %a |
| %cmp2 = icmp uge i64 %add.sat, %b |
| %cmp = and i1 %cmp1, %cmp2 |
| ret i1 %cmp |
| } |
| |
| define i1 @usub_sat_ule_lhs(i64 noundef %a, i64 noundef %b) { |
| ; CHECK-LABEL: define i1 @usub_sat_ule_lhs( |
| ; CHECK-SAME: i64 noundef [[A:%.*]], i64 noundef [[B:%.*]]) { |
| ; CHECK-NEXT: [[SUB_SAT:%.*]] = call i64 @llvm.usub.sat.i64(i64 [[A]], i64 [[B]]) |
| ; CHECK-NEXT: ret i1 true |
| ; |
| %sub.sat = call i64 @llvm.usub.sat.i64(i64 %a, i64 %b) |
| %cmp = icmp ule i64 %sub.sat, %a |
| ret i1 %cmp |
| } |
| |
| ; Negative test |
| define i1 @usub_sat_not_ule_rhs(i64 noundef %a, i64 noundef %b) { |
| ; CHECK-LABEL: define i1 @usub_sat_not_ule_rhs( |
| ; CHECK-SAME: i64 noundef [[A:%.*]], i64 noundef [[B:%.*]]) { |
| ; CHECK-NEXT: [[SUB_SAT:%.*]] = call i64 @llvm.usub.sat.i64(i64 [[A]], i64 [[B]]) |
| ; CHECK-NEXT: [[CMP:%.*]] = icmp ule i64 [[SUB_SAT]], [[B]] |
| ; CHECK-NEXT: ret i1 [[CMP]] |
| ; |
| %sub.sat = call i64 @llvm.usub.sat.i64(i64 %a, i64 %b) |
| %cmp = icmp ule i64 %sub.sat, %b |
| ret i1 %cmp |
| } |
| |
| define i1 @pr135603(i64 %conv6, i64 %str.coerce, ptr %conv) { |
| ; CHECK-LABEL: define i1 @pr135603( |
| ; CHECK-SAME: i64 [[CONV6:%.*]], i64 [[STR_COERCE:%.*]], ptr [[CONV:%.*]]) { |
| ; CHECK-NEXT: [[A:%.*]] = load i32, ptr [[CONV]], align 4 |
| ; CHECK-NEXT: [[CMP:%.*]] = icmp sgt i32 [[A]], -1 |
| ; CHECK-NEXT: [[CONV2:%.*]] = zext nneg i32 [[A]] to i64 |
| ; CHECK-NEXT: [[ADD:%.*]] = add i64 [[STR_COERCE]], [[CONV6]] |
| ; CHECK-NEXT: [[SPEC_SELECT:%.*]] = call i64 @llvm.usub.sat.i64(i64 [[CONV2]], i64 [[ADD]]) |
| ; CHECK-NEXT: ret i1 [[CMP]] |
| ; |
| %a = load i32, ptr %conv, align 4 |
| %cmp = icmp sgt i32 %a, -1 |
| %conv2 = zext nneg i32 %a to i64 |
| %add = add i64 %str.coerce, %conv6 |
| %spec.select = call i64 @llvm.usub.sat.i64(i64 %conv2, i64 %add) |
| ret i1 %cmp |
| } |
| |