318 lines
6.8 KiB
LLVM
318 lines
6.8 KiB
LLVM
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
|
|
; RUN: llc < %s -O2 -mtriple=riscv64 | FileCheck %s
|
|
|
|
define i32 @native_i64(i64 %a) {
|
|
; CHECK-LABEL: native_i64:
|
|
; CHECK: # %bb.0: # %entry
|
|
; CHECK-NEXT: li a1, -1
|
|
; CHECK-NEXT: beq a0, a1, .LBB0_3
|
|
; CHECK-NEXT: # %bb.1: # %entry
|
|
; CHECK-NEXT: li a1, 1
|
|
; CHECK-NEXT: bne a0, a1, .LBB0_4
|
|
; CHECK-NEXT: # %bb.2: # %sw.bb0
|
|
; CHECK-NEXT: li a0, 0
|
|
; CHECK-NEXT: ret
|
|
; CHECK-NEXT: .LBB0_3: # %sw.bb1
|
|
; CHECK-NEXT: li a0, 1
|
|
; CHECK-NEXT: ret
|
|
; CHECK-NEXT: .LBB0_4: # %sw.default
|
|
; CHECK-NEXT: li a0, -1
|
|
; CHECK-NEXT: ret
|
|
entry:
|
|
switch i64 %a, label %sw.default [
|
|
i64 1, label %sw.bb0
|
|
i64 -1, label %sw.bb1
|
|
]
|
|
|
|
sw.bb0:
|
|
br label %return
|
|
|
|
sw.bb1:
|
|
br label %return
|
|
|
|
sw.default:
|
|
br label %return
|
|
|
|
return:
|
|
%retval = phi i32 [ -1, %sw.default ], [ 0, %sw.bb0 ], [ 1, %sw.bb1 ]
|
|
ret i32 %retval
|
|
}
|
|
|
|
define i32 @native_i32(i32 %a) {
|
|
; CHECK-LABEL: native_i32:
|
|
; CHECK: # %bb.0: # %entry
|
|
; CHECK-NEXT: sext.w a0, a0
|
|
; CHECK-NEXT: li a1, -1
|
|
; CHECK-NEXT: beq a0, a1, .LBB1_3
|
|
; CHECK-NEXT: # %bb.1: # %entry
|
|
; CHECK-NEXT: li a1, 1
|
|
; CHECK-NEXT: bne a0, a1, .LBB1_4
|
|
; CHECK-NEXT: # %bb.2: # %sw.bb0
|
|
; CHECK-NEXT: li a0, 0
|
|
; CHECK-NEXT: ret
|
|
; CHECK-NEXT: .LBB1_3: # %sw.bb1
|
|
; CHECK-NEXT: li a0, 1
|
|
; CHECK-NEXT: ret
|
|
; CHECK-NEXT: .LBB1_4: # %sw.default
|
|
; CHECK-NEXT: li a0, -1
|
|
; CHECK-NEXT: ret
|
|
entry:
|
|
switch i32 %a, label %sw.default [
|
|
i32 1, label %sw.bb0
|
|
i32 -1, label %sw.bb1
|
|
]
|
|
|
|
sw.bb0:
|
|
br label %return
|
|
|
|
sw.bb1:
|
|
br label %return
|
|
|
|
sw.default:
|
|
br label %return
|
|
|
|
return:
|
|
%retval = phi i32 [ -1, %sw.default ], [ 0, %sw.bb0 ], [ 1, %sw.bb1 ]
|
|
ret i32 %retval
|
|
}
|
|
|
|
define i32 @trunc_i32(i64 %a) {
|
|
; CHECK-LABEL: trunc_i32:
|
|
; CHECK: # %bb.0: # %entry
|
|
; CHECK-NEXT: sext.w a0, a0
|
|
; CHECK-NEXT: li a1, -1
|
|
; CHECK-NEXT: beq a0, a1, .LBB2_3
|
|
; CHECK-NEXT: # %bb.1: # %entry
|
|
; CHECK-NEXT: li a1, 1
|
|
; CHECK-NEXT: bne a0, a1, .LBB2_4
|
|
; CHECK-NEXT: # %bb.2: # %sw.bb0
|
|
; CHECK-NEXT: li a0, 0
|
|
; CHECK-NEXT: ret
|
|
; CHECK-NEXT: .LBB2_3: # %sw.bb1
|
|
; CHECK-NEXT: li a0, 1
|
|
; CHECK-NEXT: ret
|
|
; CHECK-NEXT: .LBB2_4: # %sw.default
|
|
; CHECK-NEXT: li a0, -1
|
|
; CHECK-NEXT: ret
|
|
entry:
|
|
%trunc = trunc i64 %a to i32
|
|
switch i32 %trunc, label %sw.default [
|
|
i32 1, label %sw.bb0
|
|
i32 -1, label %sw.bb1
|
|
]
|
|
|
|
sw.bb0:
|
|
br label %return
|
|
|
|
sw.bb1:
|
|
br label %return
|
|
|
|
sw.default:
|
|
br label %return
|
|
|
|
return:
|
|
%retval = phi i32 [ -1, %sw.default ], [ 0, %sw.bb0 ], [ 1, %sw.bb1 ]
|
|
ret i32 %retval
|
|
}
|
|
|
|
define i32 @trunc_i17(i64 %a) {
|
|
; CHECK-LABEL: trunc_i17:
|
|
; CHECK: # %bb.0: # %entry
|
|
; CHECK-NEXT: lui a1, 32
|
|
; CHECK-NEXT: addiw a1, a1, -1
|
|
; CHECK-NEXT: and a0, a0, a1
|
|
; CHECK-NEXT: beq a0, a1, .LBB3_3
|
|
; CHECK-NEXT: # %bb.1: # %entry
|
|
; CHECK-NEXT: li a1, 1
|
|
; CHECK-NEXT: bne a0, a1, .LBB3_4
|
|
; CHECK-NEXT: # %bb.2: # %sw.bb0
|
|
; CHECK-NEXT: li a0, 0
|
|
; CHECK-NEXT: ret
|
|
; CHECK-NEXT: .LBB3_3: # %sw.bb1
|
|
; CHECK-NEXT: li a0, 1
|
|
; CHECK-NEXT: ret
|
|
; CHECK-NEXT: .LBB3_4: # %sw.default
|
|
; CHECK-NEXT: li a0, -1
|
|
; CHECK-NEXT: ret
|
|
entry:
|
|
%trunc = trunc i64 %a to i17
|
|
switch i17 %trunc, label %sw.default [
|
|
i17 1, label %sw.bb0
|
|
i17 -1, label %sw.bb1
|
|
]
|
|
|
|
sw.bb0:
|
|
br label %return
|
|
|
|
sw.bb1:
|
|
br label %return
|
|
|
|
sw.default:
|
|
br label %return
|
|
|
|
return:
|
|
%retval = phi i32 [ -1, %sw.default ], [ 0, %sw.bb0 ], [ 1, %sw.bb1 ]
|
|
ret i32 %retval
|
|
}
|
|
|
|
define i32 @trunc_i16(i64 %a) {
|
|
; CHECK-LABEL: trunc_i16:
|
|
; CHECK: # %bb.0: # %entry
|
|
; CHECK-NEXT: lui a1, 16
|
|
; CHECK-NEXT: addiw a1, a1, -1
|
|
; CHECK-NEXT: and a0, a0, a1
|
|
; CHECK-NEXT: beq a0, a1, .LBB4_3
|
|
; CHECK-NEXT: # %bb.1: # %entry
|
|
; CHECK-NEXT: li a1, 1
|
|
; CHECK-NEXT: bne a0, a1, .LBB4_4
|
|
; CHECK-NEXT: # %bb.2: # %sw.bb0
|
|
; CHECK-NEXT: li a0, 0
|
|
; CHECK-NEXT: ret
|
|
; CHECK-NEXT: .LBB4_3: # %sw.bb1
|
|
; CHECK-NEXT: li a0, 1
|
|
; CHECK-NEXT: ret
|
|
; CHECK-NEXT: .LBB4_4: # %sw.default
|
|
; CHECK-NEXT: li a0, -1
|
|
; CHECK-NEXT: ret
|
|
entry:
|
|
%trunc = trunc i64 %a to i16
|
|
switch i16 %trunc, label %sw.default [
|
|
i16 1, label %sw.bb0
|
|
i16 -1, label %sw.bb1
|
|
]
|
|
|
|
sw.bb0:
|
|
br label %return
|
|
|
|
sw.bb1:
|
|
br label %return
|
|
|
|
sw.default:
|
|
br label %return
|
|
|
|
return:
|
|
%retval = phi i32 [ -1, %sw.default ], [ 0, %sw.bb0 ], [ 1, %sw.bb1 ]
|
|
ret i32 %retval
|
|
}
|
|
|
|
|
|
define i32 @trunc_i12(i64 %a) {
|
|
; CHECK-LABEL: trunc_i12:
|
|
; CHECK: # %bb.0: # %entry
|
|
; CHECK-NEXT: lui a1, 1
|
|
; CHECK-NEXT: addiw a1, a1, -1
|
|
; CHECK-NEXT: and a0, a0, a1
|
|
; CHECK-NEXT: beq a0, a1, .LBB5_3
|
|
; CHECK-NEXT: # %bb.1: # %entry
|
|
; CHECK-NEXT: li a1, 1
|
|
; CHECK-NEXT: bne a0, a1, .LBB5_4
|
|
; CHECK-NEXT: # %bb.2: # %sw.bb0
|
|
; CHECK-NEXT: li a0, 0
|
|
; CHECK-NEXT: ret
|
|
; CHECK-NEXT: .LBB5_3: # %sw.bb1
|
|
; CHECK-NEXT: li a0, 1
|
|
; CHECK-NEXT: ret
|
|
; CHECK-NEXT: .LBB5_4: # %sw.default
|
|
; CHECK-NEXT: li a0, -1
|
|
; CHECK-NEXT: ret
|
|
entry:
|
|
%trunc = trunc i64 %a to i12
|
|
switch i12 %trunc, label %sw.default [
|
|
i12 1, label %sw.bb0
|
|
i12 -1, label %sw.bb1
|
|
]
|
|
|
|
sw.bb0:
|
|
br label %return
|
|
|
|
sw.bb1:
|
|
br label %return
|
|
|
|
sw.default:
|
|
br label %return
|
|
|
|
return:
|
|
%retval = phi i32 [ -1, %sw.default ], [ 0, %sw.bb0 ], [ 1, %sw.bb1 ]
|
|
ret i32 %retval
|
|
}
|
|
|
|
define i32 @trunc_i11(i64 %a) {
|
|
; CHECK-LABEL: trunc_i11:
|
|
; CHECK: # %bb.0: # %entry
|
|
; CHECK-NEXT: andi a0, a0, 2047
|
|
; CHECK-NEXT: li a1, 2047
|
|
; CHECK-NEXT: beq a0, a1, .LBB6_3
|
|
; CHECK-NEXT: # %bb.1: # %entry
|
|
; CHECK-NEXT: li a1, 1
|
|
; CHECK-NEXT: bne a0, a1, .LBB6_4
|
|
; CHECK-NEXT: # %bb.2: # %sw.bb0
|
|
; CHECK-NEXT: li a0, 0
|
|
; CHECK-NEXT: ret
|
|
; CHECK-NEXT: .LBB6_3: # %sw.bb1
|
|
; CHECK-NEXT: li a0, 1
|
|
; CHECK-NEXT: ret
|
|
; CHECK-NEXT: .LBB6_4: # %sw.default
|
|
; CHECK-NEXT: li a0, -1
|
|
; CHECK-NEXT: ret
|
|
entry:
|
|
%trunc = trunc i64 %a to i11
|
|
switch i11 %trunc, label %sw.default [
|
|
i11 1, label %sw.bb0
|
|
i11 -1, label %sw.bb1
|
|
]
|
|
|
|
sw.bb0:
|
|
br label %return
|
|
|
|
sw.bb1:
|
|
br label %return
|
|
|
|
sw.default:
|
|
br label %return
|
|
|
|
return:
|
|
%retval = phi i32 [ -1, %sw.default ], [ 0, %sw.bb0 ], [ 1, %sw.bb1 ]
|
|
ret i32 %retval
|
|
}
|
|
|
|
|
|
define i32 @trunc_i10(i64 %a) {
|
|
; CHECK-LABEL: trunc_i10:
|
|
; CHECK: # %bb.0: # %entry
|
|
; CHECK-NEXT: andi a0, a0, 1023
|
|
; CHECK-NEXT: li a1, 1023
|
|
; CHECK-NEXT: beq a0, a1, .LBB7_3
|
|
; CHECK-NEXT: # %bb.1: # %entry
|
|
; CHECK-NEXT: li a1, 1
|
|
; CHECK-NEXT: bne a0, a1, .LBB7_4
|
|
; CHECK-NEXT: # %bb.2: # %sw.bb0
|
|
; CHECK-NEXT: li a0, 0
|
|
; CHECK-NEXT: ret
|
|
; CHECK-NEXT: .LBB7_3: # %sw.bb1
|
|
; CHECK-NEXT: li a0, 1
|
|
; CHECK-NEXT: ret
|
|
; CHECK-NEXT: .LBB7_4: # %sw.default
|
|
; CHECK-NEXT: li a0, -1
|
|
; CHECK-NEXT: ret
|
|
entry:
|
|
%trunc = trunc i64 %a to i10
|
|
switch i10 %trunc, label %sw.default [
|
|
i10 1, label %sw.bb0
|
|
i10 -1, label %sw.bb1
|
|
]
|
|
|
|
sw.bb0:
|
|
br label %return
|
|
|
|
sw.bb1:
|
|
br label %return
|
|
|
|
sw.default:
|
|
br label %return
|
|
|
|
return:
|
|
%retval = phi i32 [ -1, %sw.default ], [ 0, %sw.bb0 ], [ 1, %sw.bb1 ]
|
|
ret i32 %retval
|
|
}
|
|
|