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 ; RUN: llc -mtriple=riscv64 -verify-machineinstrs < %s \
5 ; RUN: | FileCheck -check-prefix=RV64I %s
7 ;; There are a few different ways to lower (select (and A, B), X, Y). This test
8 ;; ensures that we do so with as few branches as possible.
10 define signext i32 @select_of_and(i1 zeroext %a, i1 zeroext %b, i32 signext %c, i32 signext %d) nounwind {
11 ; RV32I-LABEL: select_of_and:
13 ; RV32I-NEXT: and a1, a0, a1
14 ; RV32I-NEXT: mv a0, a2
15 ; RV32I-NEXT: bnez a1, .LBB0_2
16 ; RV32I-NEXT: # %bb.1:
17 ; RV32I-NEXT: mv a0, a3
18 ; RV32I-NEXT: .LBB0_2:
21 ; RV64I-LABEL: select_of_and:
23 ; RV64I-NEXT: and a1, a0, a1
24 ; RV64I-NEXT: mv a0, a2
25 ; RV64I-NEXT: bnez a1, .LBB0_2
26 ; RV64I-NEXT: # %bb.1:
27 ; RV64I-NEXT: mv a0, a3
28 ; RV64I-NEXT: .LBB0_2:
31 %2 = select i1 %1, i32 %c, i32 %d
35 declare signext i32 @both() nounwind
36 declare signext i32 @neither() nounwind
38 define signext i32 @if_of_and(i1 zeroext %a, i1 zeroext %b) nounwind {
39 ; RV32I-LABEL: if_of_and:
41 ; RV32I-NEXT: addi sp, sp, -16
42 ; RV32I-NEXT: sw ra, 12(sp) # 4-byte Folded Spill
43 ; RV32I-NEXT: and a0, a0, a1
44 ; RV32I-NEXT: beqz a0, .LBB1_2
45 ; RV32I-NEXT: # %bb.1: # %if.then
46 ; RV32I-NEXT: call both@plt
47 ; RV32I-NEXT: j .LBB1_3
48 ; RV32I-NEXT: .LBB1_2: # %if.else
49 ; RV32I-NEXT: call neither@plt
50 ; RV32I-NEXT: .LBB1_3: # %if.end
51 ; RV32I-NEXT: lw ra, 12(sp) # 4-byte Folded Reload
52 ; RV32I-NEXT: addi sp, sp, 16
55 ; RV64I-LABEL: if_of_and:
57 ; RV64I-NEXT: addi sp, sp, -16
58 ; RV64I-NEXT: sd ra, 8(sp) # 8-byte Folded Spill
59 ; RV64I-NEXT: and a0, a0, a1
60 ; RV64I-NEXT: beqz a0, .LBB1_2
61 ; RV64I-NEXT: # %bb.1: # %if.then
62 ; RV64I-NEXT: call both@plt
63 ; RV64I-NEXT: j .LBB1_3
64 ; RV64I-NEXT: .LBB1_2: # %if.else
65 ; RV64I-NEXT: call neither@plt
66 ; RV64I-NEXT: .LBB1_3: # %if.end
67 ; RV64I-NEXT: ld ra, 8(sp) # 8-byte Folded Reload
68 ; RV64I-NEXT: addi sp, sp, 16
71 br i1 %1, label %if.then, label %if.else
74 %2 = tail call i32 @both()
78 %3 = tail call i32 @neither()
82 %4 = phi i32 [%2, %if.then], [%3, %if.else]