blob: 79b36fc8826f995eccbbf4497a7ba2973fcc32a4 [file] [edit]
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 6
; RUN: opt -S -mtriple=x86_64-- -passes='require<libcall-lowering-info>,expand-ir-insts' -expand-fp-convert-bits=0 < %s | FileCheck %s
; Test small bit widths that can be verified by alive2.
define half @uitofp_i32_f16(i32 %x) {
; CHECK-LABEL: define half @uitofp_i32_f16(
; CHECK-SAME: i32 [[X:%.*]]) {
; CHECK-NEXT: [[ITOFP_ENTRY:.*]]:
; CHECK-NEXT: [[TMP8:%.*]] = freeze i32 [[X]]
; CHECK-NEXT: [[TMP0:%.*]] = icmp eq i32 [[TMP8]], 0
; CHECK-NEXT: br i1 [[TMP0]], label %[[ITOFP_RETURN:.*]], label %[[ITOFP_IF_END:.*]]
; CHECK: [[ITOFP_IF_END]]:
; CHECK-NEXT: [[TMP1:%.*]] = ashr i32 [[TMP8]], 31
; CHECK-NEXT: [[TMP2:%.*]] = xor i32 [[TMP1]], [[TMP8]]
; CHECK-NEXT: [[TMP3:%.*]] = sub i32 [[TMP2]], [[TMP1]]
; CHECK-NEXT: [[TMP4:%.*]] = call i32 @llvm.ctlz.i32(i32 [[TMP8]], i1 true)
; CHECK-NEXT: [[TMP5:%.*]] = sub i32 32, [[TMP4]]
; CHECK-NEXT: [[TMP6:%.*]] = sub i32 31, [[TMP4]]
; CHECK-NEXT: [[TMP7:%.*]] = icmp sgt i32 [[TMP5]], 24
; CHECK-NEXT: br i1 [[TMP7]], label %[[ITOFP_IF_THEN4:.*]], label %[[ITOFP_IF_ELSE:.*]]
; CHECK: [[ITOFP_IF_THEN4]]:
; CHECK-NEXT: switch i32 [[TMP5]], label %[[ITOFP_SW_DEFAULT:.*]] [
; CHECK-NEXT: i32 25, label %[[ITOFP_SW_BB:.*]]
; CHECK-NEXT: i32 26, label %[[ITOFP_SW_EPILOG:.*]]
; CHECK-NEXT: ]
; CHECK: [[ITOFP_SW_BB]]:
; CHECK-NEXT: [[TMP41:%.*]] = shl i32 [[TMP8]], 1
; CHECK-NEXT: br label %[[ITOFP_SW_EPILOG]]
; CHECK: [[ITOFP_SW_DEFAULT]]:
; CHECK-NEXT: [[TMP9:%.*]] = sub i32 6, [[TMP4]]
; CHECK-NEXT: [[TMP10:%.*]] = lshr i32 [[TMP8]], [[TMP9]]
; CHECK-NEXT: [[TMP11:%.*]] = add i32 [[TMP4]], 26
; CHECK-NEXT: [[TMP12:%.*]] = lshr i32 -1, [[TMP11]]
; CHECK-NEXT: [[TMP13:%.*]] = and i32 [[TMP12]], [[TMP8]]
; CHECK-NEXT: [[TMP14:%.*]] = icmp ne i32 [[TMP13]], 0
; CHECK-NEXT: [[TMP15:%.*]] = zext i1 [[TMP14]] to i32
; CHECK-NEXT: [[TMP16:%.*]] = or i32 [[TMP10]], [[TMP15]]
; CHECK-NEXT: br label %[[ITOFP_SW_EPILOG]]
; CHECK: [[ITOFP_SW_EPILOG]]:
; CHECK-NEXT: [[TMP17:%.*]] = phi i32 [ [[TMP16]], %[[ITOFP_SW_DEFAULT]] ], [ [[TMP8]], %[[ITOFP_IF_THEN4]] ], [ [[TMP41]], %[[ITOFP_SW_BB]] ]
; CHECK-NEXT: [[TMP18:%.*]] = lshr i32 [[TMP17]], 2
; CHECK-NEXT: [[TMP19:%.*]] = and i32 [[TMP18]], 1
; CHECK-NEXT: [[TMP20:%.*]] = or i32 [[TMP17]], [[TMP19]]
; CHECK-NEXT: [[TMP21:%.*]] = add i32 [[TMP20]], 1
; CHECK-NEXT: [[TMP22:%.*]] = lshr i32 [[TMP21]], 2
; CHECK-NEXT: [[A3:%.*]] = and i32 [[TMP21]], 67108864
; CHECK-NEXT: [[TMP23:%.*]] = icmp eq i32 [[A3]], 0
; CHECK-NEXT: [[TMP24:%.*]] = lshr i32 [[TMP22]], 32
; CHECK-NEXT: br i1 [[TMP23]], label %[[ITOFP_IF_END26:.*]], label %[[ITOFP_IF_THEN20:.*]]
; CHECK: [[ITOFP_IF_THEN20]]:
; CHECK-NEXT: [[TMP25:%.*]] = lshr i32 [[TMP21]], 3
; CHECK-NEXT: [[TMP26:%.*]] = lshr i32 [[TMP25]], 32
; CHECK-NEXT: br label %[[ITOFP_IF_END26]]
; CHECK: [[ITOFP_IF_ELSE]]:
; CHECK-NEXT: [[TMP27:%.*]] = add i32 [[TMP4]], -8
; CHECK-NEXT: [[TMP28:%.*]] = shl i32 [[TMP8]], [[TMP27]]
; CHECK-NEXT: [[TMP29:%.*]] = lshr i32 [[TMP28]], 32
; CHECK-NEXT: br label %[[ITOFP_IF_END26]]
; CHECK: [[ITOFP_IF_END26]]:
; CHECK-NEXT: [[TMP30:%.*]] = phi i32 [ [[TMP25]], %[[ITOFP_IF_THEN20]] ], [ [[TMP22]], %[[ITOFP_SW_EPILOG]] ], [ [[TMP28]], %[[ITOFP_IF_ELSE]] ]
; CHECK-NEXT: [[TMP31:%.*]] = phi i32 [ [[TMP5]], %[[ITOFP_IF_THEN20]] ], [ [[TMP6]], %[[ITOFP_SW_EPILOG]] ], [ [[TMP6]], %[[ITOFP_IF_ELSE]] ]
; CHECK-NEXT: [[TMP32:%.*]] = and i32 [[TMP1]], -2147483648
; CHECK-NEXT: [[TMP33:%.*]] = shl i32 [[TMP31]], 23
; CHECK-NEXT: [[TMP34:%.*]] = add i32 [[TMP33]], 1065353216
; CHECK-NEXT: [[TMP35:%.*]] = and i32 [[TMP30]], 8388607
; CHECK-NEXT: [[TMP36:%.*]] = or i32 [[TMP35]], [[TMP32]]
; CHECK-NEXT: [[TMP37:%.*]] = or i32 [[TMP35]], [[TMP34]]
; CHECK-NEXT: [[TMP38:%.*]] = bitcast i32 [[TMP37]] to float
; CHECK-NEXT: [[TMP39:%.*]] = fptrunc float [[TMP38]] to half
; CHECK-NEXT: br label %[[ITOFP_RETURN]]
; CHECK: [[ITOFP_RETURN]]:
; CHECK-NEXT: [[TMP40:%.*]] = phi half [ [[TMP39]], %[[ITOFP_IF_END26]] ], [ 0.000000e+00, %[[ITOFP_ENTRY]] ]
; CHECK-NEXT: ret half [[TMP40]]
;
%res = uitofp i32 %x to half
ret half %res
}
define half @uitofp_i32_f16_noundef(i32 noundef %x) {
; CHECK-LABEL: define half @uitofp_i32_f16_noundef(
; CHECK-SAME: i32 noundef [[X:%.*]]) {
; CHECK-NEXT: [[ITOFP_ENTRY:.*]]:
; CHECK-NEXT: [[TMP0:%.*]] = icmp eq i32 [[X]], 0
; CHECK-NEXT: br i1 [[TMP0]], label %[[ITOFP_RETURN:.*]], label %[[ITOFP_IF_END:.*]]
; CHECK: [[ITOFP_IF_END]]:
; CHECK-NEXT: [[TMP1:%.*]] = ashr i32 [[X]], 31
; CHECK-NEXT: [[TMP2:%.*]] = xor i32 [[TMP1]], [[X]]
; CHECK-NEXT: [[TMP3:%.*]] = sub i32 [[TMP2]], [[TMP1]]
; CHECK-NEXT: [[TMP4:%.*]] = call i32 @llvm.ctlz.i32(i32 [[X]], i1 true)
; CHECK-NEXT: [[TMP5:%.*]] = sub i32 32, [[TMP4]]
; CHECK-NEXT: [[TMP6:%.*]] = sub i32 31, [[TMP4]]
; CHECK-NEXT: [[TMP7:%.*]] = icmp sgt i32 [[TMP5]], 24
; CHECK-NEXT: br i1 [[TMP7]], label %[[ITOFP_IF_THEN4:.*]], label %[[ITOFP_IF_ELSE:.*]]
; CHECK: [[ITOFP_IF_THEN4]]:
; CHECK-NEXT: switch i32 [[TMP5]], label %[[ITOFP_SW_DEFAULT:.*]] [
; CHECK-NEXT: i32 25, label %[[ITOFP_SW_BB:.*]]
; CHECK-NEXT: i32 26, label %[[ITOFP_SW_EPILOG:.*]]
; CHECK-NEXT: ]
; CHECK: [[ITOFP_SW_BB]]:
; CHECK-NEXT: [[TMP8:%.*]] = shl i32 [[X]], 1
; CHECK-NEXT: br label %[[ITOFP_SW_EPILOG]]
; CHECK: [[ITOFP_SW_DEFAULT]]:
; CHECK-NEXT: [[TMP9:%.*]] = sub i32 6, [[TMP4]]
; CHECK-NEXT: [[TMP10:%.*]] = lshr i32 [[X]], [[TMP9]]
; CHECK-NEXT: [[TMP11:%.*]] = add i32 [[TMP4]], 26
; CHECK-NEXT: [[TMP12:%.*]] = lshr i32 -1, [[TMP11]]
; CHECK-NEXT: [[TMP13:%.*]] = and i32 [[TMP12]], [[X]]
; CHECK-NEXT: [[TMP14:%.*]] = icmp ne i32 [[TMP13]], 0
; CHECK-NEXT: [[TMP15:%.*]] = zext i1 [[TMP14]] to i32
; CHECK-NEXT: [[TMP16:%.*]] = or i32 [[TMP10]], [[TMP15]]
; CHECK-NEXT: br label %[[ITOFP_SW_EPILOG]]
; CHECK: [[ITOFP_SW_EPILOG]]:
; CHECK-NEXT: [[TMP17:%.*]] = phi i32 [ [[TMP16]], %[[ITOFP_SW_DEFAULT]] ], [ [[X]], %[[ITOFP_IF_THEN4]] ], [ [[TMP8]], %[[ITOFP_SW_BB]] ]
; CHECK-NEXT: [[TMP18:%.*]] = lshr i32 [[TMP17]], 2
; CHECK-NEXT: [[TMP19:%.*]] = and i32 [[TMP18]], 1
; CHECK-NEXT: [[TMP20:%.*]] = or i32 [[TMP17]], [[TMP19]]
; CHECK-NEXT: [[TMP21:%.*]] = add i32 [[TMP20]], 1
; CHECK-NEXT: [[TMP22:%.*]] = lshr i32 [[TMP21]], 2
; CHECK-NEXT: [[A3:%.*]] = and i32 [[TMP21]], 67108864
; CHECK-NEXT: [[TMP23:%.*]] = icmp eq i32 [[A3]], 0
; CHECK-NEXT: [[TMP24:%.*]] = lshr i32 [[TMP22]], 32
; CHECK-NEXT: br i1 [[TMP23]], label %[[ITOFP_IF_END26:.*]], label %[[ITOFP_IF_THEN20:.*]]
; CHECK: [[ITOFP_IF_THEN20]]:
; CHECK-NEXT: [[TMP25:%.*]] = lshr i32 [[TMP21]], 3
; CHECK-NEXT: [[TMP26:%.*]] = lshr i32 [[TMP25]], 32
; CHECK-NEXT: br label %[[ITOFP_IF_END26]]
; CHECK: [[ITOFP_IF_ELSE]]:
; CHECK-NEXT: [[TMP27:%.*]] = add i32 [[TMP4]], -8
; CHECK-NEXT: [[TMP28:%.*]] = shl i32 [[X]], [[TMP27]]
; CHECK-NEXT: [[TMP29:%.*]] = lshr i32 [[TMP28]], 32
; CHECK-NEXT: br label %[[ITOFP_IF_END26]]
; CHECK: [[ITOFP_IF_END26]]:
; CHECK-NEXT: [[TMP30:%.*]] = phi i32 [ [[TMP25]], %[[ITOFP_IF_THEN20]] ], [ [[TMP22]], %[[ITOFP_SW_EPILOG]] ], [ [[TMP28]], %[[ITOFP_IF_ELSE]] ]
; CHECK-NEXT: [[TMP31:%.*]] = phi i32 [ [[TMP5]], %[[ITOFP_IF_THEN20]] ], [ [[TMP6]], %[[ITOFP_SW_EPILOG]] ], [ [[TMP6]], %[[ITOFP_IF_ELSE]] ]
; CHECK-NEXT: [[TMP32:%.*]] = and i32 [[TMP1]], -2147483648
; CHECK-NEXT: [[TMP33:%.*]] = shl i32 [[TMP31]], 23
; CHECK-NEXT: [[TMP34:%.*]] = add i32 [[TMP33]], 1065353216
; CHECK-NEXT: [[TMP35:%.*]] = and i32 [[TMP30]], 8388607
; CHECK-NEXT: [[TMP36:%.*]] = or i32 [[TMP35]], [[TMP32]]
; CHECK-NEXT: [[TMP37:%.*]] = or i32 [[TMP35]], [[TMP34]]
; CHECK-NEXT: [[TMP38:%.*]] = bitcast i32 [[TMP37]] to float
; CHECK-NEXT: [[TMP39:%.*]] = fptrunc float [[TMP38]] to half
; CHECK-NEXT: br label %[[ITOFP_RETURN]]
; CHECK: [[ITOFP_RETURN]]:
; CHECK-NEXT: [[TMP40:%.*]] = phi half [ [[TMP39]], %[[ITOFP_IF_END26]] ], [ 0.000000e+00, %[[ITOFP_ENTRY]] ]
; CHECK-NEXT: ret half [[TMP40]]
;
%res = uitofp i32 %x to half
ret half %res
}
define half @uitofp_i16_f16(i16 %x) {
; CHECK-LABEL: define half @uitofp_i16_f16(
; CHECK-SAME: i16 [[X:%.*]]) {
; CHECK-NEXT: [[ITOFP_ENTRY:.*]]:
; CHECK-NEXT: [[TMP42:%.*]] = freeze i16 [[X]]
; CHECK-NEXT: [[TMP0:%.*]] = zext i16 [[TMP42]] to i32
; CHECK-NEXT: [[TMP1:%.*]] = icmp eq i32 [[TMP0]], 0
; CHECK-NEXT: br i1 [[TMP1]], label %[[ITOFP_RETURN:.*]], label %[[ITOFP_IF_END:.*]]
; CHECK: [[ITOFP_IF_END]]:
; CHECK-NEXT: [[TMP2:%.*]] = ashr i32 [[TMP0]], 31
; CHECK-NEXT: [[TMP3:%.*]] = xor i32 [[TMP2]], [[TMP0]]
; CHECK-NEXT: [[TMP4:%.*]] = sub i32 [[TMP3]], [[TMP2]]
; CHECK-NEXT: [[TMP5:%.*]] = call i32 @llvm.ctlz.i32(i32 [[TMP0]], i1 true)
; CHECK-NEXT: [[TMP6:%.*]] = sub i32 32, [[TMP5]]
; CHECK-NEXT: [[TMP7:%.*]] = sub i32 31, [[TMP5]]
; CHECK-NEXT: [[TMP8:%.*]] = icmp sgt i32 [[TMP6]], 24
; CHECK-NEXT: br i1 [[TMP8]], label %[[ITOFP_IF_THEN4:.*]], label %[[ITOFP_IF_ELSE:.*]]
; CHECK: [[ITOFP_IF_THEN4]]:
; CHECK-NEXT: switch i32 [[TMP6]], label %[[ITOFP_SW_DEFAULT:.*]] [
; CHECK-NEXT: i32 25, label %[[ITOFP_SW_BB:.*]]
; CHECK-NEXT: i32 26, label %[[ITOFP_SW_EPILOG:.*]]
; CHECK-NEXT: ]
; CHECK: [[ITOFP_SW_BB]]:
; CHECK-NEXT: [[TMP9:%.*]] = shl i32 [[TMP0]], 1
; CHECK-NEXT: br label %[[ITOFP_SW_EPILOG]]
; CHECK: [[ITOFP_SW_DEFAULT]]:
; CHECK-NEXT: [[TMP10:%.*]] = sub i32 6, [[TMP5]]
; CHECK-NEXT: [[TMP11:%.*]] = lshr i32 [[TMP0]], [[TMP10]]
; CHECK-NEXT: [[TMP12:%.*]] = add i32 [[TMP5]], 26
; CHECK-NEXT: [[TMP13:%.*]] = lshr i32 -1, [[TMP12]]
; CHECK-NEXT: [[TMP14:%.*]] = and i32 [[TMP13]], [[TMP0]]
; CHECK-NEXT: [[TMP15:%.*]] = icmp ne i32 [[TMP14]], 0
; CHECK-NEXT: [[TMP16:%.*]] = zext i1 [[TMP15]] to i32
; CHECK-NEXT: [[TMP17:%.*]] = or i32 [[TMP11]], [[TMP16]]
; CHECK-NEXT: br label %[[ITOFP_SW_EPILOG]]
; CHECK: [[ITOFP_SW_EPILOG]]:
; CHECK-NEXT: [[TMP18:%.*]] = phi i32 [ [[TMP17]], %[[ITOFP_SW_DEFAULT]] ], [ [[TMP0]], %[[ITOFP_IF_THEN4]] ], [ [[TMP9]], %[[ITOFP_SW_BB]] ]
; CHECK-NEXT: [[TMP19:%.*]] = lshr i32 [[TMP18]], 2
; CHECK-NEXT: [[TMP20:%.*]] = and i32 [[TMP19]], 1
; CHECK-NEXT: [[TMP21:%.*]] = or i32 [[TMP18]], [[TMP20]]
; CHECK-NEXT: [[TMP22:%.*]] = add i32 [[TMP21]], 1
; CHECK-NEXT: [[TMP23:%.*]] = lshr i32 [[TMP22]], 2
; CHECK-NEXT: [[A3:%.*]] = and i32 [[TMP22]], 67108864
; CHECK-NEXT: [[TMP24:%.*]] = icmp eq i32 [[A3]], 0
; CHECK-NEXT: [[TMP25:%.*]] = lshr i32 [[TMP23]], 32
; CHECK-NEXT: br i1 [[TMP24]], label %[[ITOFP_IF_END26:.*]], label %[[ITOFP_IF_THEN20:.*]]
; CHECK: [[ITOFP_IF_THEN20]]:
; CHECK-NEXT: [[TMP26:%.*]] = lshr i32 [[TMP22]], 3
; CHECK-NEXT: [[TMP27:%.*]] = lshr i32 [[TMP26]], 32
; CHECK-NEXT: br label %[[ITOFP_IF_END26]]
; CHECK: [[ITOFP_IF_ELSE]]:
; CHECK-NEXT: [[TMP28:%.*]] = add i32 [[TMP5]], -8
; CHECK-NEXT: [[TMP29:%.*]] = shl i32 [[TMP0]], [[TMP28]]
; CHECK-NEXT: [[TMP30:%.*]] = lshr i32 [[TMP29]], 32
; CHECK-NEXT: br label %[[ITOFP_IF_END26]]
; CHECK: [[ITOFP_IF_END26]]:
; CHECK-NEXT: [[TMP31:%.*]] = phi i32 [ [[TMP26]], %[[ITOFP_IF_THEN20]] ], [ [[TMP23]], %[[ITOFP_SW_EPILOG]] ], [ [[TMP29]], %[[ITOFP_IF_ELSE]] ]
; CHECK-NEXT: [[TMP32:%.*]] = phi i32 [ [[TMP6]], %[[ITOFP_IF_THEN20]] ], [ [[TMP7]], %[[ITOFP_SW_EPILOG]] ], [ [[TMP7]], %[[ITOFP_IF_ELSE]] ]
; CHECK-NEXT: [[TMP33:%.*]] = and i32 [[TMP2]], -2147483648
; CHECK-NEXT: [[TMP34:%.*]] = shl i32 [[TMP32]], 23
; CHECK-NEXT: [[TMP35:%.*]] = add i32 [[TMP34]], 1065353216
; CHECK-NEXT: [[TMP36:%.*]] = and i32 [[TMP31]], 8388607
; CHECK-NEXT: [[TMP37:%.*]] = or i32 [[TMP36]], [[TMP33]]
; CHECK-NEXT: [[TMP38:%.*]] = or i32 [[TMP36]], [[TMP35]]
; CHECK-NEXT: [[TMP39:%.*]] = bitcast i32 [[TMP38]] to float
; CHECK-NEXT: [[TMP40:%.*]] = fptrunc float [[TMP39]] to half
; CHECK-NEXT: br label %[[ITOFP_RETURN]]
; CHECK: [[ITOFP_RETURN]]:
; CHECK-NEXT: [[TMP41:%.*]] = phi half [ [[TMP40]], %[[ITOFP_IF_END26]] ], [ 0.000000e+00, %[[ITOFP_ENTRY]] ]
; CHECK-NEXT: ret half [[TMP41]]
;
%res = uitofp i16 %x to half
ret half %res
}
define half @sitofp_i32_f16(i32 %x) {
; CHECK-LABEL: define half @sitofp_i32_f16(
; CHECK-SAME: i32 [[X:%.*]]) {
; CHECK-NEXT: [[ITOFP_ENTRY:.*]]:
; CHECK-NEXT: [[TMP41:%.*]] = freeze i32 [[X]]
; CHECK-NEXT: [[TMP0:%.*]] = icmp eq i32 [[TMP41]], 0
; CHECK-NEXT: br i1 [[TMP0]], label %[[ITOFP_RETURN:.*]], label %[[ITOFP_IF_END:.*]]
; CHECK: [[ITOFP_IF_END]]:
; CHECK-NEXT: [[TMP1:%.*]] = ashr i32 [[TMP41]], 31
; CHECK-NEXT: [[TMP2:%.*]] = xor i32 [[TMP1]], [[TMP41]]
; CHECK-NEXT: [[TMP3:%.*]] = sub i32 [[TMP2]], [[TMP1]]
; CHECK-NEXT: [[TMP4:%.*]] = call i32 @llvm.ctlz.i32(i32 [[TMP3]], i1 true)
; CHECK-NEXT: [[TMP5:%.*]] = sub i32 32, [[TMP4]]
; CHECK-NEXT: [[TMP6:%.*]] = sub i32 31, [[TMP4]]
; CHECK-NEXT: [[TMP7:%.*]] = icmp sgt i32 [[TMP5]], 24
; CHECK-NEXT: br i1 [[TMP7]], label %[[ITOFP_IF_THEN4:.*]], label %[[ITOFP_IF_ELSE:.*]]
; CHECK: [[ITOFP_IF_THEN4]]:
; CHECK-NEXT: switch i32 [[TMP5]], label %[[ITOFP_SW_DEFAULT:.*]] [
; CHECK-NEXT: i32 25, label %[[ITOFP_SW_BB:.*]]
; CHECK-NEXT: i32 26, label %[[ITOFP_SW_EPILOG:.*]]
; CHECK-NEXT: ]
; CHECK: [[ITOFP_SW_BB]]:
; CHECK-NEXT: [[TMP8:%.*]] = shl i32 [[TMP3]], 1
; CHECK-NEXT: br label %[[ITOFP_SW_EPILOG]]
; CHECK: [[ITOFP_SW_DEFAULT]]:
; CHECK-NEXT: [[TMP9:%.*]] = sub i32 6, [[TMP4]]
; CHECK-NEXT: [[TMP10:%.*]] = lshr i32 [[TMP3]], [[TMP9]]
; CHECK-NEXT: [[TMP11:%.*]] = add i32 [[TMP4]], 26
; CHECK-NEXT: [[TMP12:%.*]] = lshr i32 -1, [[TMP11]]
; CHECK-NEXT: [[TMP13:%.*]] = and i32 [[TMP12]], [[TMP3]]
; CHECK-NEXT: [[TMP14:%.*]] = icmp ne i32 [[TMP13]], 0
; CHECK-NEXT: [[TMP15:%.*]] = zext i1 [[TMP14]] to i32
; CHECK-NEXT: [[TMP16:%.*]] = or i32 [[TMP10]], [[TMP15]]
; CHECK-NEXT: br label %[[ITOFP_SW_EPILOG]]
; CHECK: [[ITOFP_SW_EPILOG]]:
; CHECK-NEXT: [[TMP17:%.*]] = phi i32 [ [[TMP16]], %[[ITOFP_SW_DEFAULT]] ], [ [[TMP3]], %[[ITOFP_IF_THEN4]] ], [ [[TMP8]], %[[ITOFP_SW_BB]] ]
; CHECK-NEXT: [[TMP18:%.*]] = lshr i32 [[TMP17]], 2
; CHECK-NEXT: [[TMP19:%.*]] = and i32 [[TMP18]], 1
; CHECK-NEXT: [[TMP20:%.*]] = or i32 [[TMP17]], [[TMP19]]
; CHECK-NEXT: [[TMP21:%.*]] = add i32 [[TMP20]], 1
; CHECK-NEXT: [[TMP22:%.*]] = ashr i32 [[TMP21]], 2
; CHECK-NEXT: [[A3:%.*]] = and i32 [[TMP21]], 67108864
; CHECK-NEXT: [[TMP23:%.*]] = icmp eq i32 [[A3]], 0
; CHECK-NEXT: [[TMP24:%.*]] = lshr i32 [[TMP22]], 32
; CHECK-NEXT: br i1 [[TMP23]], label %[[ITOFP_IF_END26:.*]], label %[[ITOFP_IF_THEN20:.*]]
; CHECK: [[ITOFP_IF_THEN20]]:
; CHECK-NEXT: [[TMP25:%.*]] = ashr i32 [[TMP21]], 3
; CHECK-NEXT: [[TMP26:%.*]] = lshr i32 [[TMP25]], 32
; CHECK-NEXT: br label %[[ITOFP_IF_END26]]
; CHECK: [[ITOFP_IF_ELSE]]:
; CHECK-NEXT: [[TMP27:%.*]] = add i32 [[TMP4]], -8
; CHECK-NEXT: [[TMP28:%.*]] = shl i32 [[TMP3]], [[TMP27]]
; CHECK-NEXT: [[TMP29:%.*]] = lshr i32 [[TMP28]], 32
; CHECK-NEXT: br label %[[ITOFP_IF_END26]]
; CHECK: [[ITOFP_IF_END26]]:
; CHECK-NEXT: [[TMP30:%.*]] = phi i32 [ [[TMP25]], %[[ITOFP_IF_THEN20]] ], [ [[TMP22]], %[[ITOFP_SW_EPILOG]] ], [ [[TMP28]], %[[ITOFP_IF_ELSE]] ]
; CHECK-NEXT: [[TMP31:%.*]] = phi i32 [ [[TMP5]], %[[ITOFP_IF_THEN20]] ], [ [[TMP6]], %[[ITOFP_SW_EPILOG]] ], [ [[TMP6]], %[[ITOFP_IF_ELSE]] ]
; CHECK-NEXT: [[TMP32:%.*]] = and i32 [[TMP1]], -2147483648
; CHECK-NEXT: [[TMP33:%.*]] = shl i32 [[TMP31]], 23
; CHECK-NEXT: [[TMP34:%.*]] = add i32 [[TMP33]], 1065353216
; CHECK-NEXT: [[TMP35:%.*]] = and i32 [[TMP30]], 8388607
; CHECK-NEXT: [[TMP36:%.*]] = or i32 [[TMP35]], [[TMP32]]
; CHECK-NEXT: [[TMP37:%.*]] = or i32 [[TMP36]], [[TMP34]]
; CHECK-NEXT: [[TMP38:%.*]] = bitcast i32 [[TMP37]] to float
; CHECK-NEXT: [[TMP39:%.*]] = fptrunc float [[TMP38]] to half
; CHECK-NEXT: br label %[[ITOFP_RETURN]]
; CHECK: [[ITOFP_RETURN]]:
; CHECK-NEXT: [[TMP40:%.*]] = phi half [ [[TMP39]], %[[ITOFP_IF_END26]] ], [ 0.000000e+00, %[[ITOFP_ENTRY]] ]
; CHECK-NEXT: ret half [[TMP40]]
;
%res = sitofp i32 %x to half
ret half %res
}
define half @sitofp_i16_f16(i16 %x) {
; CHECK-LABEL: define half @sitofp_i16_f16(
; CHECK-SAME: i16 [[X:%.*]]) {
; CHECK-NEXT: [[ITOFP_ENTRY:.*]]:
; CHECK-NEXT: [[TMP42:%.*]] = freeze i16 [[X]]
; CHECK-NEXT: [[TMP1:%.*]] = sext i16 [[TMP42]] to i32
; CHECK-NEXT: [[TMP0:%.*]] = icmp eq i32 [[TMP1]], 0
; CHECK-NEXT: br i1 [[TMP0]], label %[[ITOFP_RETURN:.*]], label %[[ITOFP_IF_END:.*]]
; CHECK: [[ITOFP_IF_END]]:
; CHECK-NEXT: [[TMP2:%.*]] = ashr i32 [[TMP1]], 31
; CHECK-NEXT: [[TMP3:%.*]] = xor i32 [[TMP2]], [[TMP1]]
; CHECK-NEXT: [[TMP4:%.*]] = sub i32 [[TMP3]], [[TMP2]]
; CHECK-NEXT: [[TMP5:%.*]] = call i32 @llvm.ctlz.i32(i32 [[TMP4]], i1 true)
; CHECK-NEXT: [[TMP6:%.*]] = sub i32 32, [[TMP5]]
; CHECK-NEXT: [[TMP8:%.*]] = sub i32 31, [[TMP5]]
; CHECK-NEXT: [[TMP7:%.*]] = icmp sgt i32 [[TMP6]], 24
; CHECK-NEXT: br i1 [[TMP7]], label %[[ITOFP_IF_THEN4:.*]], label %[[ITOFP_IF_ELSE:.*]]
; CHECK: [[ITOFP_IF_THEN4]]:
; CHECK-NEXT: switch i32 [[TMP6]], label %[[ITOFP_SW_DEFAULT:.*]] [
; CHECK-NEXT: i32 25, label %[[ITOFP_SW_BB:.*]]
; CHECK-NEXT: i32 26, label %[[ITOFP_SW_EPILOG:.*]]
; CHECK-NEXT: ]
; CHECK: [[ITOFP_SW_BB]]:
; CHECK-NEXT: [[TMP9:%.*]] = shl i32 [[TMP4]], 1
; CHECK-NEXT: br label %[[ITOFP_SW_EPILOG]]
; CHECK: [[ITOFP_SW_DEFAULT]]:
; CHECK-NEXT: [[TMP10:%.*]] = sub i32 6, [[TMP5]]
; CHECK-NEXT: [[TMP11:%.*]] = lshr i32 [[TMP4]], [[TMP10]]
; CHECK-NEXT: [[TMP12:%.*]] = add i32 [[TMP5]], 26
; CHECK-NEXT: [[TMP13:%.*]] = lshr i32 -1, [[TMP12]]
; CHECK-NEXT: [[TMP14:%.*]] = and i32 [[TMP13]], [[TMP4]]
; CHECK-NEXT: [[TMP15:%.*]] = icmp ne i32 [[TMP14]], 0
; CHECK-NEXT: [[TMP16:%.*]] = zext i1 [[TMP15]] to i32
; CHECK-NEXT: [[TMP17:%.*]] = or i32 [[TMP11]], [[TMP16]]
; CHECK-NEXT: br label %[[ITOFP_SW_EPILOG]]
; CHECK: [[ITOFP_SW_EPILOG]]:
; CHECK-NEXT: [[TMP18:%.*]] = phi i32 [ [[TMP17]], %[[ITOFP_SW_DEFAULT]] ], [ [[TMP4]], %[[ITOFP_IF_THEN4]] ], [ [[TMP9]], %[[ITOFP_SW_BB]] ]
; CHECK-NEXT: [[TMP19:%.*]] = lshr i32 [[TMP18]], 2
; CHECK-NEXT: [[TMP20:%.*]] = and i32 [[TMP19]], 1
; CHECK-NEXT: [[TMP21:%.*]] = or i32 [[TMP18]], [[TMP20]]
; CHECK-NEXT: [[TMP22:%.*]] = add i32 [[TMP21]], 1
; CHECK-NEXT: [[TMP24:%.*]] = ashr i32 [[TMP22]], 2
; CHECK-NEXT: [[A3:%.*]] = and i32 [[TMP22]], 67108864
; CHECK-NEXT: [[TMP23:%.*]] = icmp eq i32 [[A3]], 0
; CHECK-NEXT: [[TMP25:%.*]] = lshr i32 [[TMP24]], 32
; CHECK-NEXT: br i1 [[TMP23]], label %[[ITOFP_IF_END26:.*]], label %[[ITOFP_IF_THEN20:.*]]
; CHECK: [[ITOFP_IF_THEN20]]:
; CHECK-NEXT: [[TMP26:%.*]] = ashr i32 [[TMP22]], 3
; CHECK-NEXT: [[TMP27:%.*]] = lshr i32 [[TMP26]], 32
; CHECK-NEXT: br label %[[ITOFP_IF_END26]]
; CHECK: [[ITOFP_IF_ELSE]]:
; CHECK-NEXT: [[TMP28:%.*]] = add i32 [[TMP5]], -8
; CHECK-NEXT: [[TMP29:%.*]] = shl i32 [[TMP4]], [[TMP28]]
; CHECK-NEXT: [[TMP30:%.*]] = lshr i32 [[TMP29]], 32
; CHECK-NEXT: br label %[[ITOFP_IF_END26]]
; CHECK: [[ITOFP_IF_END26]]:
; CHECK-NEXT: [[TMP31:%.*]] = phi i32 [ [[TMP26]], %[[ITOFP_IF_THEN20]] ], [ [[TMP24]], %[[ITOFP_SW_EPILOG]] ], [ [[TMP29]], %[[ITOFP_IF_ELSE]] ]
; CHECK-NEXT: [[TMP32:%.*]] = phi i32 [ [[TMP6]], %[[ITOFP_IF_THEN20]] ], [ [[TMP8]], %[[ITOFP_SW_EPILOG]] ], [ [[TMP8]], %[[ITOFP_IF_ELSE]] ]
; CHECK-NEXT: [[TMP33:%.*]] = and i32 [[TMP2]], -2147483648
; CHECK-NEXT: [[TMP34:%.*]] = shl i32 [[TMP32]], 23
; CHECK-NEXT: [[TMP35:%.*]] = add i32 [[TMP34]], 1065353216
; CHECK-NEXT: [[TMP36:%.*]] = and i32 [[TMP31]], 8388607
; CHECK-NEXT: [[TMP37:%.*]] = or i32 [[TMP36]], [[TMP33]]
; CHECK-NEXT: [[TMP41:%.*]] = or i32 [[TMP37]], [[TMP35]]
; CHECK-NEXT: [[TMP38:%.*]] = bitcast i32 [[TMP41]] to float
; CHECK-NEXT: [[TMP39:%.*]] = fptrunc float [[TMP38]] to half
; CHECK-NEXT: br label %[[ITOFP_RETURN]]
; CHECK: [[ITOFP_RETURN]]:
; CHECK-NEXT: [[TMP40:%.*]] = phi half [ [[TMP39]], %[[ITOFP_IF_END26]] ], [ 0.000000e+00, %[[ITOFP_ENTRY]] ]
; CHECK-NEXT: ret half [[TMP40]]
;
%res = sitofp i16 %x to half
ret half %res
}