llvm/llvm/test/CodeGen/RISCV/switch-width.ll

; 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
}