|
| 1 | +; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5 |
| 2 | +; RUN: llc -O1 -mtriple=riscv64 -mattr=+v < %s | FileCheck %s |
| 3 | + |
| 4 | +define i32 @pr134424(i64 %input_value, i32 %base_value, i1 %cond_flag1, i1 %cond_flag2, i1 %cond_flag3) { |
| 5 | +; CHECK-LABEL: pr134424: |
| 6 | +; CHECK: # %bb.0: # %for.body.us.preheader.i |
| 7 | +; CHECK-NEXT: andi a3, a3, 1 |
| 8 | +; CHECK-NEXT: andi a5, a2, 1 |
| 9 | +; CHECK-NEXT: vsetivli zero, 4, e64, m2, ta, ma |
| 10 | +; CHECK-NEXT: vmv.v.x v8, a0 |
| 11 | +; CHECK-NEXT: vsetvli zero, zero, e64, m2, tu, ma |
| 12 | +; CHECK-NEXT: vmv.s.x v8, zero |
| 13 | +; CHECK-NEXT: vsetivli zero, 1, e8, mf8, ta, ma |
| 14 | +; CHECK-NEXT: vmv.v.i v0, 14 |
| 15 | +; CHECK-NEXT: mv a2, a1 |
| 16 | +; CHECK-NEXT: bnez a5, .LBB0_2 |
| 17 | +; CHECK-NEXT: # %bb.1: # %for.body.us.preheader.i |
| 18 | +; CHECK-NEXT: li a2, 1 |
| 19 | +; CHECK-NEXT: .LBB0_2: # %for.body.us.preheader.i |
| 20 | +; CHECK-NEXT: vsetivli zero, 4, e64, m2, ta, ma |
| 21 | +; CHECK-NEXT: vmerge.vxm v8, v8, a0, v0 |
| 22 | +; CHECK-NEXT: andi a4, a4, 1 |
| 23 | +; CHECK-NEXT: mv a0, a1 |
| 24 | +; CHECK-NEXT: bnez a3, .LBB0_4 |
| 25 | +; CHECK-NEXT: # %bb.3: # %for.body.us.preheader.i |
| 26 | +; CHECK-NEXT: li a0, 1 |
| 27 | +; CHECK-NEXT: .LBB0_4: # %for.body.us.preheader.i |
| 28 | +; CHECK-NEXT: vmsle.vi v0, v8, 0 |
| 29 | +; CHECK-NEXT: sext.w a2, a2 |
| 30 | +; CHECK-NEXT: bnez a4, .LBB0_6 |
| 31 | +; CHECK-NEXT: # %bb.5: # %for.body.us.preheader.i |
| 32 | +; CHECK-NEXT: li a1, 1 |
| 33 | +; CHECK-NEXT: .LBB0_6: # %for.body.us.preheader.i |
| 34 | +; CHECK-NEXT: sext.w a0, a0 |
| 35 | +; CHECK-NEXT: vsetvli zero, zero, e32, m1, ta, ma |
| 36 | +; CHECK-NEXT: vmv.v.i v8, 0 |
| 37 | +; CHECK-NEXT: vmerge.vim v8, v8, 1, v0 |
| 38 | +; CHECK-NEXT: vsetivli zero, 8, e32, m2, ta, ma |
| 39 | +; CHECK-NEXT: vredmin.vs v8, v8, v8 |
| 40 | +; CHECK-NEXT: vmv.x.s a3, v8 |
| 41 | +; CHECK-NEXT: sext.w a1, a1 |
| 42 | +; CHECK-NEXT: bge a3, a2, .LBB0_11 |
| 43 | +; CHECK-NEXT: # %bb.7: # %for.body.us.preheader.i |
| 44 | +; CHECK-NEXT: bge a0, a1, .LBB0_12 |
| 45 | +; CHECK-NEXT: .LBB0_8: # %for.body.us.preheader.i |
| 46 | +; CHECK-NEXT: blt a3, a0, .LBB0_10 |
| 47 | +; CHECK-NEXT: .LBB0_9: # %for.body.us.preheader.i |
| 48 | +; CHECK-NEXT: mv a3, a0 |
| 49 | +; CHECK-NEXT: .LBB0_10: # %for.body.us.preheader.i |
| 50 | +; CHECK-NEXT: sw a3, 0(zero) |
| 51 | +; CHECK-NEXT: li a0, 0 |
| 52 | +; CHECK-NEXT: ret |
| 53 | +; CHECK-NEXT: .LBB0_11: # %for.body.us.preheader.i |
| 54 | +; CHECK-NEXT: mv a3, a2 |
| 55 | +; CHECK-NEXT: blt a0, a1, .LBB0_8 |
| 56 | +; CHECK-NEXT: .LBB0_12: # %for.body.us.preheader.i |
| 57 | +; CHECK-NEXT: mv a0, a1 |
| 58 | +; CHECK-NEXT: bge a3, a0, .LBB0_9 |
| 59 | +; CHECK-NEXT: j .LBB0_10 |
| 60 | +for.body.us.preheader.i: |
| 61 | + %partial_vector = insertelement <4 x i64> zeroinitializer, i64 %input_value, i64 1 |
| 62 | + %comparison_vector = shufflevector <4 x i64> %partial_vector, <4 x i64> zeroinitializer, <4 x i32> <i32 0, i32 1, i32 1, i32 1> |
| 63 | + %comparison_result = icmp sle <4 x i64> %comparison_vector, zeroinitializer |
| 64 | + %selected_value1 = select i1 %cond_flag1, i32 %base_value, i32 1 |
| 65 | + %selected_value2 = select i1 %cond_flag2, i32 %base_value, i32 1 |
| 66 | + %selected_value3 = select i1 %cond_flag3, i32 %base_value, i32 1 |
| 67 | + %bool_to_int = zext <4 x i1> %comparison_result to <4 x i32> |
| 68 | + %extended_vector = shufflevector <4 x i32> %bool_to_int, <4 x i32> zeroinitializer, <8 x i32> <i32 0, i32 1, i32 2, i32 3, i32 poison, i32 poison, i32 poison, i32 poison> |
| 69 | + %vector_min = call i32 @llvm.vector.reduce.smin.v8i32(<8 x i32> %extended_vector) |
| 70 | + %min1 = call i32 @llvm.smin.i32(i32 %vector_min, i32 %selected_value1) |
| 71 | + %min2 = call i32 @llvm.smin.i32(i32 %selected_value2, i32 %selected_value3) |
| 72 | + %final_min = call i32 @llvm.smin.i32(i32 %min1, i32 %min2) |
| 73 | + store i32 %final_min, ptr null, align 4 |
| 74 | + ret i32 0 |
| 75 | +} |
| 76 | + |
0 commit comments