1; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py 2; RUN: llc -mtriple=riscv32 -verify-machineinstrs < %s \ 3; RUN: | FileCheck -check-prefix=RV32I %s 4 5define void @foo(i32 %a, i32 *%b, i1 %c) nounwind { 6; RV32I-LABEL: foo: 7; RV32I: # %bb.0: 8; RV32I-NEXT: lw a3, 0(a1) 9; RV32I-NEXT: beq a3, a0, .LBB0_12 10; RV32I-NEXT: # %bb.1: # %test2 11; RV32I-NEXT: lw a3, 0(a1) 12; RV32I-NEXT: bne a3, a0, .LBB0_12 13; RV32I-NEXT: # %bb.2: # %test3 14; RV32I-NEXT: lw a3, 0(a1) 15; RV32I-NEXT: blt a3, a0, .LBB0_12 16; RV32I-NEXT: # %bb.3: # %test4 17; RV32I-NEXT: lw a3, 0(a1) 18; RV32I-NEXT: bge a3, a0, .LBB0_12 19; RV32I-NEXT: # %bb.4: # %test5 20; RV32I-NEXT: lw a3, 0(a1) 21; RV32I-NEXT: bltu a3, a0, .LBB0_12 22; RV32I-NEXT: # %bb.5: # %test6 23; RV32I-NEXT: lw a3, 0(a1) 24; RV32I-NEXT: bgeu a3, a0, .LBB0_12 25; RV32I-NEXT: # %bb.6: # %test7 26; RV32I-NEXT: lw a3, 0(a1) 27; RV32I-NEXT: blt a0, a3, .LBB0_12 28; RV32I-NEXT: # %bb.7: # %test8 29; RV32I-NEXT: lw a3, 0(a1) 30; RV32I-NEXT: bge a0, a3, .LBB0_12 31; RV32I-NEXT: # %bb.8: # %test9 32; RV32I-NEXT: lw a3, 0(a1) 33; RV32I-NEXT: bltu a0, a3, .LBB0_12 34; RV32I-NEXT: # %bb.9: # %test10 35; RV32I-NEXT: lw a3, 0(a1) 36; RV32I-NEXT: bgeu a0, a3, .LBB0_12 37; RV32I-NEXT: # %bb.10: # %test11 38; RV32I-NEXT: lw a0, 0(a1) 39; RV32I-NEXT: andi a0, a2, 1 40; RV32I-NEXT: bnez a0, .LBB0_12 41; RV32I-NEXT: # %bb.11: # %test12 42; RV32I-NEXT: lw a0, 0(a1) 43; RV32I-NEXT: .LBB0_12: # %end 44; RV32I-NEXT: ret 45 %val1 = load volatile i32, i32* %b 46 %tst1 = icmp eq i32 %val1, %a 47 br i1 %tst1, label %end, label %test2 48 49test2: 50 %val2 = load volatile i32, i32* %b 51 %tst2 = icmp ne i32 %val2, %a 52 br i1 %tst2, label %end, label %test3 53 54test3: 55 %val3 = load volatile i32, i32* %b 56 %tst3 = icmp slt i32 %val3, %a 57 br i1 %tst3, label %end, label %test4 58 59test4: 60 %val4 = load volatile i32, i32* %b 61 %tst4 = icmp sge i32 %val4, %a 62 br i1 %tst4, label %end, label %test5 63 64test5: 65 %val5 = load volatile i32, i32* %b 66 %tst5 = icmp ult i32 %val5, %a 67 br i1 %tst5, label %end, label %test6 68 69test6: 70 %val6 = load volatile i32, i32* %b 71 %tst6 = icmp uge i32 %val6, %a 72 br i1 %tst6, label %end, label %test7 73 74; Check for condition codes that don't have a matching instruction 75 76test7: 77 %val7 = load volatile i32, i32* %b 78 %tst7 = icmp sgt i32 %val7, %a 79 br i1 %tst7, label %end, label %test8 80 81test8: 82 %val8 = load volatile i32, i32* %b 83 %tst8 = icmp sle i32 %val8, %a 84 br i1 %tst8, label %end, label %test9 85 86test9: 87 %val9 = load volatile i32, i32* %b 88 %tst9 = icmp ugt i32 %val9, %a 89 br i1 %tst9, label %end, label %test10 90 91test10: 92 %val10 = load volatile i32, i32* %b 93 %tst10 = icmp ule i32 %val10, %a 94 br i1 %tst10, label %end, label %test11 95 96; Check the case of a branch where the condition was generated in another 97; function 98 99test11: 100 %val11 = load volatile i32, i32* %b 101 br i1 %c, label %end, label %test12 102 103test12: 104 %val12 = load volatile i32, i32* %b 105 br label %end 106 107end: 108 ret void 109} 110