blob: ed6c2e52e09673592761e7f47cba1182e112d37a [file] [log] [blame] [edit]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc -mtriple=riscv32 -mattr=+experimental-zibi -verify-machineinstrs < %s \
; RUN: | FileCheck -check-prefixes=ZIBI,ZIBI-RV32 %s
; RUN: llc -mtriple=riscv64 -mattr=+experimental-zibi -verify-machineinstrs < %s \
; RUN: | FileCheck -check-prefixes=ZIBI,ZIBI-RV64 %s
define void @test_bne_neg(ptr %b) nounwind {
; ZIBI-LABEL: test_bne_neg:
; ZIBI: # %bb.0:
; ZIBI-NEXT: lw a1, 0(a0)
; ZIBI-NEXT: bnei a1, -1, .LBB0_2
; ZIBI-NEXT: # %bb.1: # %test2
; ZIBI-NEXT: lw zero, 0(a0)
; ZIBI-NEXT: .LBB0_2: # %end
; ZIBI-NEXT: ret
%val1 = load volatile i32, ptr %b
%tst1 = icmp ne i32 %val1, -1
br i1 %tst1, label %end, label %test2, !prof !0
test2:
%val2 = load volatile i32, ptr %b
br label %end
end:
ret void
}
define void @test_beq_neg(ptr %b) nounwind {
; ZIBI-LABEL: test_beq_neg:
; ZIBI: # %bb.0:
; ZIBI-NEXT: lw a1, 0(a0)
; ZIBI-NEXT: beqi a1, -1, .LBB1_2
; ZIBI-NEXT: # %bb.1: # %test2
; ZIBI-NEXT: lw zero, 0(a0)
; ZIBI-NEXT: .LBB1_2: # %end
; ZIBI-NEXT: ret
%val1 = load volatile i32, ptr %b
%tst1 = icmp eq i32 %val1, -1
br i1 %tst1, label %end, label %test2, !prof !0
test2:
%val2 = load volatile i32, ptr %b
br label %end
end:
ret void
}
define void @test_bne_zero(ptr %b) nounwind {
; ZIBI-LABEL: test_bne_zero:
; ZIBI: # %bb.0:
; ZIBI-NEXT: lw a1, 0(a0)
; ZIBI-NEXT: bnez a1, .LBB2_2
; ZIBI-NEXT: # %bb.1: # %test2
; ZIBI-NEXT: lw zero, 0(a0)
; ZIBI-NEXT: .LBB2_2: # %end
; ZIBI-NEXT: ret
%val1 = load volatile i32, ptr %b
%tst1 = icmp ne i32 %val1, 0
br i1 %tst1, label %end, label %test2, !prof !0
test2:
%val2 = load volatile i32, ptr %b
br label %end
end:
ret void
}
define void @test_beq_zero(ptr %b) nounwind {
; ZIBI-LABEL: test_beq_zero:
; ZIBI: # %bb.0:
; ZIBI-NEXT: lw a1, 0(a0)
; ZIBI-NEXT: beqz a1, .LBB3_2
; ZIBI-NEXT: # %bb.1: # %test2
; ZIBI-NEXT: lw zero, 0(a0)
; ZIBI-NEXT: .LBB3_2: # %end
; ZIBI-NEXT: ret
%val1 = load volatile i32, ptr %b
%tst1 = icmp eq i32 %val1, 0
br i1 %tst1, label %end, label %test2, !prof !0
test2:
%val2 = load volatile i32, ptr %b
br label %end
end:
ret void
}
define void @test_bne_1(ptr %b) nounwind {
; ZIBI-LABEL: test_bne_1:
; ZIBI: # %bb.0:
; ZIBI-NEXT: lw a1, 0(a0)
; ZIBI-NEXT: bnei a1, 1, .LBB4_2
; ZIBI-NEXT: # %bb.1: # %test2
; ZIBI-NEXT: lw zero, 0(a0)
; ZIBI-NEXT: .LBB4_2: # %end
; ZIBI-NEXT: ret
%val1 = load volatile i32, ptr %b
%tst1 = icmp ne i32 %val1, 1
br i1 %tst1, label %end, label %test2, !prof !0
test2:
%val2 = load volatile i32, ptr %b
br label %end
end:
ret void
}
define void @test_beq_1(ptr %b) nounwind {
; ZIBI-LABEL: test_beq_1:
; ZIBI: # %bb.0:
; ZIBI-NEXT: lw a1, 0(a0)
; ZIBI-NEXT: beqi a1, 1, .LBB5_2
; ZIBI-NEXT: # %bb.1: # %test2
; ZIBI-NEXT: lw zero, 0(a0)
; ZIBI-NEXT: .LBB5_2: # %end
; ZIBI-NEXT: ret
%val1 = load volatile i32, ptr %b
%tst1 = icmp eq i32 %val1, 1
br i1 %tst1, label %end, label %test2, !prof !0
test2:
%val2 = load volatile i32, ptr %b
br label %end
end:
ret void
}
define void @test_bne_31(ptr %b) nounwind {
; ZIBI-LABEL: test_bne_31:
; ZIBI: # %bb.0:
; ZIBI-NEXT: lw a1, 0(a0)
; ZIBI-NEXT: bnei a1, 31, .LBB6_2
; ZIBI-NEXT: # %bb.1: # %test2
; ZIBI-NEXT: lw zero, 0(a0)
; ZIBI-NEXT: .LBB6_2: # %end
; ZIBI-NEXT: ret
%val1 = load volatile i32, ptr %b
%tst1 = icmp ne i32 %val1, 31
br i1 %tst1, label %end, label %test2, !prof !0
test2:
%val2 = load volatile i32, ptr %b
br label %end
end:
ret void
}
define void @test_beq_31(ptr %b) nounwind {
; ZIBI-LABEL: test_beq_31:
; ZIBI: # %bb.0:
; ZIBI-NEXT: lw a1, 0(a0)
; ZIBI-NEXT: beqi a1, 31, .LBB7_2
; ZIBI-NEXT: # %bb.1: # %test2
; ZIBI-NEXT: lw zero, 0(a0)
; ZIBI-NEXT: .LBB7_2: # %end
; ZIBI-NEXT: ret
%val1 = load volatile i32, ptr %b
%tst1 = icmp eq i32 %val1, 31
br i1 %tst1, label %end, label %test2, !prof !0
test2:
%val2 = load volatile i32, ptr %b
br label %end
end:
ret void
}
define void @test_bne_32(ptr %b) nounwind {
; ZIBI-LABEL: test_bne_32:
; ZIBI: # %bb.0:
; ZIBI-NEXT: lw a1, 0(a0)
; ZIBI-NEXT: li a2, 32
; ZIBI-NEXT: bne a1, a2, .LBB8_2
; ZIBI-NEXT: # %bb.1: # %test2
; ZIBI-NEXT: lw zero, 0(a0)
; ZIBI-NEXT: .LBB8_2: # %end
; ZIBI-NEXT: ret
%val1 = load volatile i32, ptr %b
%tst1 = icmp ne i32 %val1, 32
br i1 %tst1, label %end, label %test2, !prof !0
test2:
%val2 = load volatile i32, ptr %b
br label %end
end:
ret void
}
define void @test_beq_32(ptr %b) nounwind {
; ZIBI-LABEL: test_beq_32:
; ZIBI: # %bb.0:
; ZIBI-NEXT: lw a1, 0(a0)
; ZIBI-NEXT: li a2, 32
; ZIBI-NEXT: beq a1, a2, .LBB9_2
; ZIBI-NEXT: # %bb.1: # %test2
; ZIBI-NEXT: lw zero, 0(a0)
; ZIBI-NEXT: .LBB9_2: # %end
; ZIBI-NEXT: ret
%val1 = load volatile i32, ptr %b
%tst1 = icmp eq i32 %val1, 32
br i1 %tst1, label %end, label %test2, !prof !0
test2:
%val2 = load volatile i32, ptr %b
br label %end
end:
ret void
}
!0 = !{!"branch_weights", i32 1, i32 99}
define i32 @test_select_beq_neg(i32 %a, i32 %b, i32 %c) nounwind {
; ZIBI-RV32-LABEL: test_select_beq_neg:
; ZIBI-RV32: # %bb.0:
; ZIBI-RV32-NEXT: beqi a0, -1, .LBB10_2
; ZIBI-RV32-NEXT: # %bb.1:
; ZIBI-RV32-NEXT: mv a1, a2
; ZIBI-RV32-NEXT: .LBB10_2:
; ZIBI-RV32-NEXT: mv a0, a1
; ZIBI-RV32-NEXT: ret
;
; ZIBI-RV64-LABEL: test_select_beq_neg:
; ZIBI-RV64: # %bb.0:
; ZIBI-RV64-NEXT: sext.w a3, a0
; ZIBI-RV64-NEXT: mv a0, a1
; ZIBI-RV64-NEXT: beqi a3, -1, .LBB10_2
; ZIBI-RV64-NEXT: # %bb.1:
; ZIBI-RV64-NEXT: mv a0, a2
; ZIBI-RV64-NEXT: .LBB10_2:
; ZIBI-RV64-NEXT: ret
%tst = icmp eq i32 %a, -1
%ret = select i1 %tst, i32 %b, i32 %c
ret i32 %ret
}
define i32 @test_select_bne_neg(i32 %a, i32 %b, i32 %c) nounwind {
; ZIBI-RV32-LABEL: test_select_bne_neg:
; ZIBI-RV32: # %bb.0:
; ZIBI-RV32-NEXT: bnei a0, -1, .LBB11_2
; ZIBI-RV32-NEXT: # %bb.1:
; ZIBI-RV32-NEXT: mv a1, a2
; ZIBI-RV32-NEXT: .LBB11_2:
; ZIBI-RV32-NEXT: mv a0, a1
; ZIBI-RV32-NEXT: ret
;
; ZIBI-RV64-LABEL: test_select_bne_neg:
; ZIBI-RV64: # %bb.0:
; ZIBI-RV64-NEXT: sext.w a3, a0
; ZIBI-RV64-NEXT: mv a0, a1
; ZIBI-RV64-NEXT: bnei a3, -1, .LBB11_2
; ZIBI-RV64-NEXT: # %bb.1:
; ZIBI-RV64-NEXT: mv a0, a2
; ZIBI-RV64-NEXT: .LBB11_2:
; ZIBI-RV64-NEXT: ret
%tst = icmp ne i32 %a, -1
%ret = select i1 %tst, i32 %b, i32 %c
ret i32 %ret
}
define i32 @test_select_beq_zero(i32 %a, i32 %b, i32 %c) nounwind {
; ZIBI-RV32-LABEL: test_select_beq_zero:
; ZIBI-RV32: # %bb.0:
; ZIBI-RV32-NEXT: beqz a0, .LBB12_2
; ZIBI-RV32-NEXT: # %bb.1:
; ZIBI-RV32-NEXT: mv a1, a2
; ZIBI-RV32-NEXT: .LBB12_2:
; ZIBI-RV32-NEXT: mv a0, a1
; ZIBI-RV32-NEXT: ret
;
; ZIBI-RV64-LABEL: test_select_beq_zero:
; ZIBI-RV64: # %bb.0:
; ZIBI-RV64-NEXT: sext.w a3, a0
; ZIBI-RV64-NEXT: mv a0, a1
; ZIBI-RV64-NEXT: beqz a3, .LBB12_2
; ZIBI-RV64-NEXT: # %bb.1:
; ZIBI-RV64-NEXT: mv a0, a2
; ZIBI-RV64-NEXT: .LBB12_2:
; ZIBI-RV64-NEXT: ret
%tst = icmp eq i32 %a, 0
%ret = select i1 %tst, i32 %b, i32 %c
ret i32 %ret
}
define i32 @test_select_bne_zero(i32 %a, i32 %b, i32 %c) nounwind {
; ZIBI-RV32-LABEL: test_select_bne_zero:
; ZIBI-RV32: # %bb.0:
; ZIBI-RV32-NEXT: bnez a0, .LBB13_2
; ZIBI-RV32-NEXT: # %bb.1:
; ZIBI-RV32-NEXT: mv a1, a2
; ZIBI-RV32-NEXT: .LBB13_2:
; ZIBI-RV32-NEXT: mv a0, a1
; ZIBI-RV32-NEXT: ret
;
; ZIBI-RV64-LABEL: test_select_bne_zero:
; ZIBI-RV64: # %bb.0:
; ZIBI-RV64-NEXT: sext.w a3, a0
; ZIBI-RV64-NEXT: mv a0, a1
; ZIBI-RV64-NEXT: bnez a3, .LBB13_2
; ZIBI-RV64-NEXT: # %bb.1:
; ZIBI-RV64-NEXT: mv a0, a2
; ZIBI-RV64-NEXT: .LBB13_2:
; ZIBI-RV64-NEXT: ret
%tst = icmp ne i32 %a, 0
%ret = select i1 %tst, i32 %b, i32 %c
ret i32 %ret
}
define i32 @test_select_beq_1(i32 %a, i32 %b, i32 %c) nounwind {
; ZIBI-RV32-LABEL: test_select_beq_1:
; ZIBI-RV32: # %bb.0:
; ZIBI-RV32-NEXT: beqi a0, 1, .LBB14_2
; ZIBI-RV32-NEXT: # %bb.1:
; ZIBI-RV32-NEXT: mv a1, a2
; ZIBI-RV32-NEXT: .LBB14_2:
; ZIBI-RV32-NEXT: mv a0, a1
; ZIBI-RV32-NEXT: ret
;
; ZIBI-RV64-LABEL: test_select_beq_1:
; ZIBI-RV64: # %bb.0:
; ZIBI-RV64-NEXT: sext.w a3, a0
; ZIBI-RV64-NEXT: mv a0, a1
; ZIBI-RV64-NEXT: beqi a3, 1, .LBB14_2
; ZIBI-RV64-NEXT: # %bb.1:
; ZIBI-RV64-NEXT: mv a0, a2
; ZIBI-RV64-NEXT: .LBB14_2:
; ZIBI-RV64-NEXT: ret
%tst = icmp eq i32 %a, 1
%ret = select i1 %tst, i32 %b, i32 %c
ret i32 %ret
}
define i32 @test_select_bne_1(i32 %a, i32 %b, i32 %c) nounwind {
; ZIBI-RV32-LABEL: test_select_bne_1:
; ZIBI-RV32: # %bb.0:
; ZIBI-RV32-NEXT: bnei a0, 1, .LBB15_2
; ZIBI-RV32-NEXT: # %bb.1:
; ZIBI-RV32-NEXT: mv a1, a2
; ZIBI-RV32-NEXT: .LBB15_2:
; ZIBI-RV32-NEXT: mv a0, a1
; ZIBI-RV32-NEXT: ret
;
; ZIBI-RV64-LABEL: test_select_bne_1:
; ZIBI-RV64: # %bb.0:
; ZIBI-RV64-NEXT: sext.w a3, a0
; ZIBI-RV64-NEXT: mv a0, a1
; ZIBI-RV64-NEXT: bnei a3, 1, .LBB15_2
; ZIBI-RV64-NEXT: # %bb.1:
; ZIBI-RV64-NEXT: mv a0, a2
; ZIBI-RV64-NEXT: .LBB15_2:
; ZIBI-RV64-NEXT: ret
%tst = icmp ne i32 %a, 1
%ret = select i1 %tst, i32 %b, i32 %c
ret i32 %ret
}
define i32 @test_select_beq_31(i32 %a, i32 %b, i32 %c) nounwind {
; ZIBI-RV32-LABEL: test_select_beq_31:
; ZIBI-RV32: # %bb.0:
; ZIBI-RV32-NEXT: beqi a0, 31, .LBB16_2
; ZIBI-RV32-NEXT: # %bb.1:
; ZIBI-RV32-NEXT: mv a1, a2
; ZIBI-RV32-NEXT: .LBB16_2:
; ZIBI-RV32-NEXT: mv a0, a1
; ZIBI-RV32-NEXT: ret
;
; ZIBI-RV64-LABEL: test_select_beq_31:
; ZIBI-RV64: # %bb.0:
; ZIBI-RV64-NEXT: sext.w a3, a0
; ZIBI-RV64-NEXT: mv a0, a1
; ZIBI-RV64-NEXT: beqi a3, 31, .LBB16_2
; ZIBI-RV64-NEXT: # %bb.1:
; ZIBI-RV64-NEXT: mv a0, a2
; ZIBI-RV64-NEXT: .LBB16_2:
; ZIBI-RV64-NEXT: ret
%tst = icmp eq i32 %a, 31
%ret = select i1 %tst, i32 %b, i32 %c
ret i32 %ret
}
define i32 @test_select_bne_31(i32 %a, i32 %b, i32 %c) nounwind {
; ZIBI-RV32-LABEL: test_select_bne_31:
; ZIBI-RV32: # %bb.0:
; ZIBI-RV32-NEXT: bnei a0, 31, .LBB17_2
; ZIBI-RV32-NEXT: # %bb.1:
; ZIBI-RV32-NEXT: mv a1, a2
; ZIBI-RV32-NEXT: .LBB17_2:
; ZIBI-RV32-NEXT: mv a0, a1
; ZIBI-RV32-NEXT: ret
;
; ZIBI-RV64-LABEL: test_select_bne_31:
; ZIBI-RV64: # %bb.0:
; ZIBI-RV64-NEXT: sext.w a3, a0
; ZIBI-RV64-NEXT: mv a0, a1
; ZIBI-RV64-NEXT: bnei a3, 31, .LBB17_2
; ZIBI-RV64-NEXT: # %bb.1:
; ZIBI-RV64-NEXT: mv a0, a2
; ZIBI-RV64-NEXT: .LBB17_2:
; ZIBI-RV64-NEXT: ret
%tst = icmp ne i32 %a, 31
%ret = select i1 %tst, i32 %b, i32 %c
ret i32 %ret
}
define i32 @test_select_beq_32(i32 %a, i32 %b, i32 %c) nounwind {
; ZIBI-RV32-LABEL: test_select_beq_32:
; ZIBI-RV32: # %bb.0:
; ZIBI-RV32-NEXT: li a3, 32
; ZIBI-RV32-NEXT: beq a0, a3, .LBB18_2
; ZIBI-RV32-NEXT: # %bb.1:
; ZIBI-RV32-NEXT: mv a1, a2
; ZIBI-RV32-NEXT: .LBB18_2:
; ZIBI-RV32-NEXT: mv a0, a1
; ZIBI-RV32-NEXT: ret
;
; ZIBI-RV64-LABEL: test_select_beq_32:
; ZIBI-RV64: # %bb.0:
; ZIBI-RV64-NEXT: sext.w a3, a0
; ZIBI-RV64-NEXT: li a4, 32
; ZIBI-RV64-NEXT: mv a0, a1
; ZIBI-RV64-NEXT: beq a3, a4, .LBB18_2
; ZIBI-RV64-NEXT: # %bb.1:
; ZIBI-RV64-NEXT: mv a0, a2
; ZIBI-RV64-NEXT: .LBB18_2:
; ZIBI-RV64-NEXT: ret
%tst = icmp eq i32 %a, 32
%ret = select i1 %tst, i32 %b, i32 %c
ret i32 %ret
}
define i32 @test_select_bne_32(i32 %a, i32 %b, i32 %c) nounwind {
; ZIBI-RV32-LABEL: test_select_bne_32:
; ZIBI-RV32: # %bb.0:
; ZIBI-RV32-NEXT: li a3, 32
; ZIBI-RV32-NEXT: bne a0, a3, .LBB19_2
; ZIBI-RV32-NEXT: # %bb.1:
; ZIBI-RV32-NEXT: mv a1, a2
; ZIBI-RV32-NEXT: .LBB19_2:
; ZIBI-RV32-NEXT: mv a0, a1
; ZIBI-RV32-NEXT: ret
;
; ZIBI-RV64-LABEL: test_select_bne_32:
; ZIBI-RV64: # %bb.0:
; ZIBI-RV64-NEXT: sext.w a3, a0
; ZIBI-RV64-NEXT: li a4, 32
; ZIBI-RV64-NEXT: mv a0, a1
; ZIBI-RV64-NEXT: bne a3, a4, .LBB19_2
; ZIBI-RV64-NEXT: # %bb.1:
; ZIBI-RV64-NEXT: mv a0, a2
; ZIBI-RV64-NEXT: .LBB19_2:
; ZIBI-RV64-NEXT: ret
%tst = icmp ne i32 %a, 32
%ret = select i1 %tst, i32 %b, i32 %c
ret i32 %ret
}