mirror of
https://github.com/RPCSX/llvm.git
synced 2025-01-03 02:08:35 +00:00
5332ea03d1
The patch extends the optimization to cases where the constant's magnitude is so small or large that the rounding of the conversion is irrelevant. The "so small" case includes negative zero. Differential review: http://reviews.llvm.org/D11210 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@247708 91177308-0d34-0410-b5e6-96231b3b80d8
491 lines
12 KiB
LLVM
491 lines
12 KiB
LLVM
; RUN: opt -S -instcombine < %s | FileCheck %s
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_oeq_int_0_uitofp(
|
|
; CHECK-NEXT: icmp eq i32 %i, 0
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_oeq_int_0_uitofp(i32 %i) {
|
|
%f = uitofp i32 %i to float
|
|
%cmp = fcmp oeq float %f, 0.0
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_oeq_int_n0_uitofp(
|
|
; CHECK-NEXT: icmp eq i32 %i, 0
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_oeq_int_n0_uitofp(i32 %i) {
|
|
%f = uitofp i32 %i to float
|
|
%cmp = fcmp oeq float %f, -0.0
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_oeq_int_0_sitofp(
|
|
; CHECK-NEXT: icmp eq i32 %i, 0
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_oeq_int_0_sitofp(i32 %i) {
|
|
%f = sitofp i32 %i to float
|
|
%cmp = fcmp oeq float %f, 0.0
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_oeq_int_n0_sitofp(
|
|
; CHECK-NEXT: icmp eq i32 %i, 0
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_oeq_int_n0_sitofp(i32 %i) {
|
|
%f = sitofp i32 %i to float
|
|
%cmp = fcmp oeq float %f, -0.0
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_one_int_0_uitofp(
|
|
; CHECK-NEXT: icmp ne i32 %i, 0
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_one_int_0_uitofp(i32 %i) {
|
|
%f = uitofp i32 %i to float
|
|
%cmp = fcmp one float %f, 0.0
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_one_int_n0_uitofp(
|
|
; CHECK-NEXT: icmp ne i32 %i, 0
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_one_int_n0_uitofp(i32 %i) {
|
|
%f = uitofp i32 %i to float
|
|
%cmp = fcmp one float %f, -0.0
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_one_int_0_sitofp(
|
|
; CHECK-NEXT: icmp ne i32 %i, 0
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_one_int_0_sitofp(i32 %i) {
|
|
%f = sitofp i32 %i to float
|
|
%cmp = fcmp one float %f, 0.0
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_one_int_n0_sitofp(
|
|
; CHECK-NEXT: icmp ne i32 %i, 0
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_one_int_n0_sitofp(i32 %i) {
|
|
%f = sitofp i32 %i to float
|
|
%cmp = fcmp one float %f, -0.0
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_ueq_int_0_uitofp(
|
|
; CHECK-NEXT: icmp eq i32 %i, 0
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_ueq_int_0_uitofp(i32 %i) {
|
|
%f = uitofp i32 %i to float
|
|
%cmp = fcmp ueq float %f, 0.0
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_ueq_int_n0_uitofp(
|
|
; CHECK-NEXT: icmp eq i32 %i, 0
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_ueq_int_n0_uitofp(i32 %i) {
|
|
%f = uitofp i32 %i to float
|
|
%cmp = fcmp ueq float %f, -0.0
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_ueq_int_0_sitofp(
|
|
; CHECK-NEXT: icmp eq i32 %i, 0
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_ueq_int_0_sitofp(i32 %i) {
|
|
%f = sitofp i32 %i to float
|
|
%cmp = fcmp ueq float %f, 0.0
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_ueq_int_n0_sitofp(
|
|
; CHECK-NEXT: icmp eq i32 %i, 0
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_ueq_int_n0_sitofp(i32 %i) {
|
|
%f = sitofp i32 %i to float
|
|
%cmp = fcmp ueq float %f, -0.0
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_une_int_0_uitofp(
|
|
; CHECK-NEXT: icmp ne i32 %i, 0
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_une_int_0_uitofp(i32 %i) {
|
|
%f = uitofp i32 %i to float
|
|
%cmp = fcmp une float %f, 0.0
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_une_int_n0_uitofp(
|
|
; CHECK-NEXT: icmp ne i32 %i, 0
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_une_int_n0_uitofp(i32 %i) {
|
|
%f = uitofp i32 %i to float
|
|
%cmp = fcmp une float %f, -0.0
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_une_int_0_sitofp(
|
|
; CHECK-NEXT: icmp ne i32 %i, 0
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_une_int_0_sitofp(i32 %i) {
|
|
%f = sitofp i32 %i to float
|
|
%cmp = fcmp une float %f, 0.0
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_une_int_n0_sitofp(
|
|
; CHECK-NEXT: icmp ne i32 %i, 0
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_une_int_n0_sitofp(i32 %i) {
|
|
%f = sitofp i32 %i to float
|
|
%cmp = fcmp une float %f, -0.0
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_ogt_int_0_uitofp(
|
|
; CHECK: icmp ne i32 %i, 0
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_ogt_int_0_uitofp(i32 %i) {
|
|
%f = uitofp i32 %i to float
|
|
%cmp = fcmp ogt float %f, 0.0
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_ogt_int_n0_uitofp(
|
|
; CHECK: icmp ne i32 %i, 0
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_ogt_int_n0_uitofp(i32 %i) {
|
|
%f = uitofp i32 %i to float
|
|
%cmp = fcmp ogt float %f, -0.0
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_ogt_int_0_sitofp(
|
|
; CHECK: icmp sgt i32 %i, 0
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_ogt_int_0_sitofp(i32 %i) {
|
|
%f = sitofp i32 %i to float
|
|
%cmp = fcmp ogt float %f, 0.0
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_ogt_int_n0_sitofp(
|
|
; CHECK: icmp sgt i32 %i, 0
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_ogt_int_n0_sitofp(i32 %i) {
|
|
%f = sitofp i32 %i to float
|
|
%cmp = fcmp ogt float %f, -0.0
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_ole_int_0_uitofp(
|
|
; CHECK: icmp eq i32 %i, 0
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_ole_int_0_uitofp(i32 %i) {
|
|
%f = uitofp i32 %i to float
|
|
%cmp = fcmp ole float %f, 0.0
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_ole_int_0_sitofp(
|
|
; CHECK: icmp slt i32 %i, 1
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_ole_int_0_sitofp(i32 %i) {
|
|
%f = sitofp i32 %i to float
|
|
%cmp = fcmp ole float %f, 0.0
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_olt_int_0_uitofp(
|
|
; CHECK: ret i1 false
|
|
define i1 @i32_cast_cmp_olt_int_0_uitofp(i32 %i) {
|
|
%f = uitofp i32 %i to float
|
|
%cmp = fcmp olt float %f, 0.0
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_olt_int_0_sitofp(
|
|
; CHECK: icmp slt i32 %i, 0
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_olt_int_0_sitofp(i32 %i) {
|
|
%f = sitofp i32 %i to float
|
|
%cmp = fcmp olt float %f, 0.0
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i64_cast_cmp_oeq_int_0_uitofp(
|
|
; CHECK-NEXT: icmp eq i64 %i, 0
|
|
; CHECK-NEXT: ret
|
|
define i1 @i64_cast_cmp_oeq_int_0_uitofp(i64 %i) {
|
|
%f = uitofp i64 %i to float
|
|
%cmp = fcmp oeq float %f, 0.0
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i64_cast_cmp_oeq_int_0_sitofp(
|
|
; CHECK-NEXT: icmp eq i64 %i, 0
|
|
; CHECK-NEXT: ret
|
|
define i1 @i64_cast_cmp_oeq_int_0_sitofp(i64 %i) {
|
|
%f = sitofp i64 %i to float
|
|
%cmp = fcmp oeq float %f, 0.0
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i64_cast_cmp_oeq_int_0_uitofp_half(
|
|
; CHECK-NEXT: icmp eq i64 %i, 0
|
|
; CHECK-NEXT: ret
|
|
define i1 @i64_cast_cmp_oeq_int_0_uitofp_half(i64 %i) {
|
|
%f = uitofp i64 %i to half
|
|
%cmp = fcmp oeq half %f, 0.0
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i64_cast_cmp_oeq_int_0_sitofp_half(
|
|
; CHECK-NEXT: icmp eq i64 %i, 0
|
|
; CHECK-NEXT: ret
|
|
define i1 @i64_cast_cmp_oeq_int_0_sitofp_half(i64 %i) {
|
|
%f = sitofp i64 %i to half
|
|
%cmp = fcmp oeq half %f, 0.0
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_oeq_int_0_uitofp_ppcf128(
|
|
; CHECK: uitofp
|
|
; CHECK: fcmp oeq
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_oeq_int_0_uitofp_ppcf128(i32 %i) {
|
|
%f = uitofp i32 %i to ppc_fp128
|
|
%cmp = fcmp oeq ppc_fp128 %f, 0xM00000000000000000000000000000000
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; Since 0xFFFFFF fits in a float, and one less and
|
|
; one more than it also fits without rounding, the
|
|
; test can be optimized to an integer compare.
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_oeq_int_i24max_uitofp(
|
|
; CHECK: icmp eq i32 %i, 16777215
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_oeq_int_i24max_uitofp(i32 %i) {
|
|
%f = uitofp i32 %i to float
|
|
%cmp = fcmp oeq float %f, 0x416FFFFFE0000000
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_oeq_int_i24max_sitofp(
|
|
; CHECK: icmp eq i32 %i, 16777215
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_oeq_int_i24max_sitofp(i32 %i) {
|
|
%f = sitofp i32 %i to float
|
|
%cmp = fcmp oeq float %f, 0x416FFFFFE0000000
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; Though 0x1000000 fits in a float, one more than it
|
|
; would round to it too, hence a single integer comparison
|
|
; does not suffice.
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_oeq_int_i24maxp1_uitofp(
|
|
; CHECK: uitofp
|
|
; CHECK: fcmp oeq
|
|
|
|
; XCHECK: icmp eq i32 %i, 16777216
|
|
; XCHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_oeq_int_i24maxp1_uitofp(i32 %i) {
|
|
%f = uitofp i32 %i to float
|
|
%cmp = fcmp oeq float %f, 0x4170000000000000
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_oeq_int_i24maxp1_sitofp(
|
|
; CHECK: sitofp
|
|
; CHECK: fcmp oeq
|
|
|
|
; XCHECK: icmp eq i32 %i, 16777216
|
|
; XCHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_oeq_int_i24maxp1_sitofp(i32 %i) {
|
|
%f = sitofp i32 %i to float
|
|
%cmp = fcmp oeq float %f, 0x4170000000000000
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_oeq_int_i32umax_uitofp(
|
|
; CHECK: uitofp
|
|
; CHECK: fcmp oeq
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_oeq_int_i32umax_uitofp(i32 %i) {
|
|
%f = uitofp i32 %i to float
|
|
%cmp = fcmp oeq float %f, 0x41F0000000000000
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; 32-bit unsigned integer cannot possibly round up to 1<<33
|
|
; CHECK-LABEL: @i32_cast_cmp_oeq_int_big_uitofp(
|
|
; CHECK-NEXT: ret i1 false
|
|
define i1 @i32_cast_cmp_oeq_int_big_uitofp(i32 %i) {
|
|
%f = uitofp i32 %i to float
|
|
%cmp = fcmp oeq float %f, 0x4200000000000000
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; 32-bit signed integer cannot possibly round up to 1<<32
|
|
; CHECK-LABEL: @i32_cast_cmp_oeq_int_i32umax_sitofp(
|
|
; CHECK-NEXT: ret i1 false
|
|
define i1 @i32_cast_cmp_oeq_int_i32umax_sitofp(i32 %i) {
|
|
%f = sitofp i32 %i to float
|
|
%cmp = fcmp oeq float %f, 0x41F0000000000000
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_oeq_int_i32imin_uitofp(
|
|
; CHECK: uitofp
|
|
; CHECK: fcmp oeq
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_oeq_int_i32imin_uitofp(i32 %i) {
|
|
%f = uitofp i32 %i to float
|
|
%cmp = fcmp oeq float %f, 0xC1E0000000000000
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_oeq_int_i32imin_sitofp(
|
|
; CHECK: sitofp
|
|
; CHECK: fcmp oeq
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_oeq_int_i32imin_sitofp(i32 %i) {
|
|
%f = sitofp i32 %i to float
|
|
%cmp = fcmp oeq float %f, 0xC1E0000000000000
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_oeq_int_i32imax_uitofp(
|
|
; CHECK: uitofp
|
|
; CHECK: fcmp oeq
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_oeq_int_i32imax_uitofp(i32 %i) {
|
|
%f = uitofp i32 %i to float
|
|
%cmp = fcmp oeq float %f, 0x41E0000000000000
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_oeq_int_i32imax_sitofp(
|
|
; CHECK: sitofp
|
|
; CHECK: fcmp oeq
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_oeq_int_i32imax_sitofp(i32 %i) {
|
|
%f = sitofp i32 %i to float
|
|
%cmp = fcmp oeq float %f, 0x41E0000000000000
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_oeq_int_negi32umax_uitofp(
|
|
; CHECK: uitofp
|
|
; CHECK: fcmp oeq
|
|
; CHECK-NEXT: ret
|
|
define i1 @i32_cast_cmp_oeq_int_negi32umax_uitofp(i32 %i) {
|
|
%f = uitofp i32 %i to float
|
|
%cmp = fcmp oeq float %f, 0xC1F0000000000000
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; 32-bit signed integer cannot possibly round to -1<<32
|
|
; CHECK-LABEL: @i32_cast_cmp_oeq_int_negi32umax_sitofp(
|
|
; CHECK-NEXT: ret i1 false
|
|
define i1 @i32_cast_cmp_oeq_int_negi32umax_sitofp(i32 %i) {
|
|
%f = sitofp i32 %i to float
|
|
%cmp = fcmp oeq float %f, 0xC1F0000000000000
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_oeq_half_uitofp(
|
|
; CHECK: ret i1 false
|
|
define i1 @i32_cast_cmp_oeq_half_uitofp(i32 %i) {
|
|
%f = uitofp i32 %i to float
|
|
%cmp = fcmp oeq float %f, 0.5
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_oeq_half_sitofp(
|
|
; CHECK: ret i1 false
|
|
define i1 @i32_cast_cmp_oeq_half_sitofp(i32 %i) {
|
|
%f = sitofp i32 %i to float
|
|
%cmp = fcmp oeq float %f, 0.5
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_one_half_uitofp(
|
|
; CHECK: ret i1 true
|
|
define i1 @i32_cast_cmp_one_half_uitofp(i32 %i) {
|
|
%f = uitofp i32 %i to float
|
|
%cmp = fcmp one float %f, 0.5
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_one_half_sitofp(
|
|
; CHECK: ret i1 true
|
|
define i1 @i32_cast_cmp_one_half_sitofp(i32 %i) {
|
|
%f = sitofp i32 %i to float
|
|
%cmp = fcmp one float %f, 0.5
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_ueq_half_uitofp(
|
|
; CHECK: ret i1 false
|
|
define i1 @i32_cast_cmp_ueq_half_uitofp(i32 %i) {
|
|
%f = uitofp i32 %i to float
|
|
%cmp = fcmp ueq float %f, 0.5
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_ueq_half_sitofp(
|
|
; CHECK: ret i1 false
|
|
define i1 @i32_cast_cmp_ueq_half_sitofp(i32 %i) {
|
|
%f = sitofp i32 %i to float
|
|
%cmp = fcmp ueq float %f, 0.5
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_une_half_uitofp(
|
|
; CHECK: ret i1 true
|
|
define i1 @i32_cast_cmp_une_half_uitofp(i32 %i) {
|
|
%f = uitofp i32 %i to float
|
|
%cmp = fcmp une float %f, 0.5
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_une_half_sitofp(
|
|
; CHECK: ret i1 true
|
|
define i1 @i32_cast_cmp_une_half_sitofp(i32 %i) {
|
|
%f = sitofp i32 %i to float
|
|
%cmp = fcmp une float %f, 0.5
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_oeq_int_inf_uitofp(
|
|
; CHECK-NEXT: ret i1 false
|
|
define i1 @i32_cast_cmp_oeq_int_inf_uitofp(i32 %i) {
|
|
%f = uitofp i32 %i to float
|
|
%cmp = fcmp oeq float %f, 0x7FF0000000000000
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; CHECK-LABEL: @i32_cast_cmp_oeq_int_inf_sitofp(
|
|
; CHECK-NEXT: ret i1 false
|
|
define i1 @i32_cast_cmp_oeq_int_inf_sitofp(i32 %i) {
|
|
%f = sitofp i32 %i to float
|
|
%cmp = fcmp oeq float %f, 0x7FF0000000000000
|
|
ret i1 %cmp
|
|
}
|
|
|
|
; An i128 could round to an IEEE single-precision infinity.
|
|
; CHECK-LABEL: @i128_cast_cmp_oeq_int_inf_uitofp(
|
|
; CHECK: uitofp
|
|
; CHECK: fcmp oeq
|
|
; CHECK-NEXT: ret
|
|
define i1 @i128_cast_cmp_oeq_int_inf_uitofp(i128 %i) {
|
|
%f = uitofp i128 %i to float
|
|
%cmp = fcmp oeq float %f, 0x7FF0000000000000
|
|
ret i1 %cmp
|
|
}
|