305 lines
11 KiB
LLVM
305 lines
11 KiB
LLVM
; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 3
|
|
; RUN: opt -S -passes=instsimplify %s | FileCheck %s
|
|
|
|
declare float @llvm.exp10.f32(float)
|
|
declare <2 x float> @llvm.exp10.v2f32(<2 x float>)
|
|
declare <4 x float> @llvm.exp10.v4f32(<4 x float>)
|
|
declare ppc_fp128 @llvm.exp10.ppcf128(ppc_fp128)
|
|
declare <vscale x 2 x float> @llvm.exp10.nxv2f32(<vscale x 2 x float>)
|
|
|
|
|
|
define float @exp10_exp10(float %x) {
|
|
; CHECK-LABEL: define float @exp10_exp10
|
|
; CHECK-SAME: (float [[X:%.*]]) {
|
|
; CHECK-NEXT: [[EXP100:%.*]] = call float @llvm.exp10.f32(float [[X]])
|
|
; CHECK-NEXT: [[EXP101:%.*]] = call float @llvm.exp10.f32(float [[EXP100]])
|
|
; CHECK-NEXT: ret float [[EXP101]]
|
|
;
|
|
%exp100 = call float @llvm.exp10.f32(float %x)
|
|
%exp101 = call float @llvm.exp10.f32(float %exp100)
|
|
ret float %exp101
|
|
}
|
|
|
|
define <2 x float> @exp10_exp10_vector(<2 x float> %x) {
|
|
; CHECK-LABEL: define <2 x float> @exp10_exp10_vector
|
|
; CHECK-SAME: (<2 x float> [[X:%.*]]) {
|
|
; CHECK-NEXT: [[EXP100:%.*]] = call <2 x float> @llvm.exp10.v2f32(<2 x float> [[X]])
|
|
; CHECK-NEXT: [[EXP101:%.*]] = call <2 x float> @llvm.exp10.v2f32(<2 x float> [[EXP100]])
|
|
; CHECK-NEXT: ret <2 x float> [[EXP101]]
|
|
;
|
|
%exp100 = call <2 x float> @llvm.exp10.v2f32(<2 x float> %x)
|
|
%exp101 = call <2 x float> @llvm.exp10.v2f32(<2 x float> %exp100)
|
|
ret <2 x float> %exp101
|
|
}
|
|
|
|
define float @exp10_exp10_const(float %x) {
|
|
; CHECK-LABEL: define float @exp10_exp10_const
|
|
; CHECK-SAME: (float [[X:%.*]]) {
|
|
; CHECK-NEXT: [[EXP101:%.*]] = call float @llvm.exp10.f32(float 0x7FF0000000000000)
|
|
; CHECK-NEXT: ret float [[EXP101]]
|
|
;
|
|
%exp100 = call float @llvm.exp10.f32(float 42.0)
|
|
%exp101 = call float @llvm.exp10.f32(float %exp100)
|
|
ret float %exp101
|
|
}
|
|
|
|
define <vscale x 2 x float> @exp10_exp10_scalable_vector(<vscale x 2 x float> %x) {
|
|
; CHECK-LABEL: define <vscale x 2 x float> @exp10_exp10_scalable_vector
|
|
; CHECK-SAME: (<vscale x 2 x float> [[X:%.*]]) {
|
|
; CHECK-NEXT: [[EXP100:%.*]] = call <vscale x 2 x float> @llvm.exp10.nxv2f32(<vscale x 2 x float> [[X]])
|
|
; CHECK-NEXT: [[EXP101:%.*]] = call <vscale x 2 x float> @llvm.exp10.nxv2f32(<vscale x 2 x float> [[EXP100]])
|
|
; CHECK-NEXT: ret <vscale x 2 x float> [[EXP101]]
|
|
;
|
|
%exp100 = call <vscale x 2 x float> @llvm.exp10.nxv2f32(<vscale x 2 x float> %x)
|
|
%exp101 = call <vscale x 2 x float> @llvm.exp10.nxv2f32(<vscale x 2 x float> %exp100)
|
|
ret <vscale x 2 x float> %exp101
|
|
}
|
|
|
|
define float @exp10_poison() {
|
|
; CHECK-LABEL: define float @exp10_poison() {
|
|
; CHECK-NEXT: [[RET:%.*]] = call float @llvm.exp10.f32(float poison)
|
|
; CHECK-NEXT: ret float [[RET]]
|
|
;
|
|
%ret = call float @llvm.exp10.f32(float poison)
|
|
ret float %ret
|
|
}
|
|
|
|
define <2 x float> @exp10_poison_vector() {
|
|
; CHECK-LABEL: define <2 x float> @exp10_poison_vector() {
|
|
; CHECK-NEXT: [[RET:%.*]] = call <2 x float> @llvm.exp10.v2f32(<2 x float> poison)
|
|
; CHECK-NEXT: ret <2 x float> [[RET]]
|
|
;
|
|
%ret = call <2 x float> @llvm.exp10.v2f32(<2 x float> poison)
|
|
ret <2 x float> %ret
|
|
}
|
|
|
|
define <vscale x 2 x float> @exp10_poison_scaleable_vector() {
|
|
; CHECK-LABEL: define <vscale x 2 x float> @exp10_poison_scaleable_vector() {
|
|
; CHECK-NEXT: [[RET:%.*]] = call <vscale x 2 x float> @llvm.exp10.nxv2f32(<vscale x 2 x float> poison)
|
|
; CHECK-NEXT: ret <vscale x 2 x float> [[RET]]
|
|
;
|
|
%ret = call <vscale x 2 x float> @llvm.exp10.nxv2f32(<vscale x 2 x float> poison)
|
|
ret <vscale x 2 x float> %ret
|
|
}
|
|
|
|
define float @exp10_undef() {
|
|
; CHECK-LABEL: define float @exp10_undef() {
|
|
; CHECK-NEXT: [[RET:%.*]] = call float @llvm.exp10.f32(float undef)
|
|
; CHECK-NEXT: ret float [[RET]]
|
|
;
|
|
%ret = call float @llvm.exp10.f32(float undef)
|
|
ret float %ret
|
|
}
|
|
define <2 x float> @exp10_undef_vector() {
|
|
; CHECK-LABEL: define <2 x float> @exp10_undef_vector() {
|
|
; CHECK-NEXT: [[RET:%.*]] = call <2 x float> @llvm.exp10.v2f32(<2 x float> undef)
|
|
; CHECK-NEXT: ret <2 x float> [[RET]]
|
|
;
|
|
%ret = call <2 x float> @llvm.exp10.v2f32(<2 x float> undef)
|
|
ret <2 x float> %ret
|
|
}
|
|
|
|
define <2 x float> @exp10_zero_vector() {
|
|
; CHECK-LABEL: define <2 x float> @exp10_zero_vector() {
|
|
; CHECK-NEXT: ret <2 x float> <float 1.000000e+00, float 1.000000e+00>
|
|
;
|
|
%ret = call <2 x float> @llvm.exp10.v2f32(<2 x float> zeroinitializer)
|
|
ret <2 x float> %ret
|
|
}
|
|
|
|
define <vscale x 2 x float> @exp10_zero_scalable_vector() {
|
|
; CHECK-LABEL: define <vscale x 2 x float> @exp10_zero_scalable_vector() {
|
|
; CHECK-NEXT: [[RET:%.*]] = call <vscale x 2 x float> @llvm.exp10.nxv2f32(<vscale x 2 x float> zeroinitializer)
|
|
; CHECK-NEXT: ret <vscale x 2 x float> [[RET]]
|
|
;
|
|
%ret = call <vscale x 2 x float> @llvm.exp10.nxv2f32(<vscale x 2 x float> zeroinitializer)
|
|
ret <vscale x 2 x float> %ret
|
|
}
|
|
|
|
define <2 x float> @exp10_zero_negzero_vector() {
|
|
; CHECK-LABEL: define <2 x float> @exp10_zero_negzero_vector() {
|
|
; CHECK-NEXT: ret <2 x float> <float 1.000000e+00, float 1.000000e+00>
|
|
;
|
|
%ret = call <2 x float> @llvm.exp10.v2f32(<2 x float> <float 0.0, float -0.0>)
|
|
ret <2 x float> %ret
|
|
}
|
|
|
|
define <4 x float> @exp10_nonsplat_vector() {
|
|
; CHECK-LABEL: define <4 x float> @exp10_nonsplat_vector() {
|
|
; CHECK-NEXT: [[RET:%.*]] = call <4 x float> @llvm.exp10.v4f32(<4 x float> <float 1.600000e+01, float -3.200000e+01, float undef, float 9.999000e+03>)
|
|
; CHECK-NEXT: ret <4 x float> [[RET]]
|
|
;
|
|
%ret = call <4 x float> @llvm.exp10.v4f32(<4 x float> <float 16.0, float -32.0, float undef, float 9999.0>)
|
|
ret <4 x float> %ret
|
|
}
|
|
|
|
define float @exp10_zero() {
|
|
; CHECK-LABEL: define float @exp10_zero() {
|
|
; CHECK-NEXT: ret float 1.000000e+00
|
|
;
|
|
%ret = call float @llvm.exp10.f32(float 0.0)
|
|
ret float %ret
|
|
}
|
|
|
|
define float @exp10_negzero() {
|
|
; CHECK-LABEL: define float @exp10_negzero() {
|
|
; CHECK-NEXT: ret float 1.000000e+00
|
|
;
|
|
%ret = call float @llvm.exp10.f32(float -0.0)
|
|
ret float %ret
|
|
}
|
|
|
|
define float @exp10_one() {
|
|
; CHECK-LABEL: define float @exp10_one() {
|
|
; CHECK-NEXT: ret float 1.000000e+01
|
|
;
|
|
%ret = call float @llvm.exp10.f32(float 1.0)
|
|
ret float %ret
|
|
}
|
|
|
|
define float @exp10_negone() {
|
|
; CHECK-LABEL: define float @exp10_negone() {
|
|
; CHECK-NEXT: ret float 0x3FB99999A0000000
|
|
;
|
|
%ret = call float @llvm.exp10.f32(float -1.0)
|
|
ret float %ret
|
|
}
|
|
|
|
define float @exp10_two() {
|
|
; CHECK-LABEL: define float @exp10_two() {
|
|
; CHECK-NEXT: ret float 1.000000e+02
|
|
;
|
|
%ret = call float @llvm.exp10.f32(float 2.0)
|
|
ret float %ret
|
|
}
|
|
|
|
define float @exp10_negtwo() {
|
|
; CHECK-LABEL: define float @exp10_negtwo() {
|
|
; CHECK-NEXT: ret float 0x3F847AE140000000
|
|
;
|
|
%ret = call float @llvm.exp10.f32(float -2.0)
|
|
ret float %ret
|
|
}
|
|
|
|
define float @exp10_inf() {
|
|
; CHECK-LABEL: define float @exp10_inf() {
|
|
; CHECK-NEXT: [[RET:%.*]] = call float @llvm.exp10.f32(float 0x7FF0000000000000)
|
|
; CHECK-NEXT: ret float [[RET]]
|
|
;
|
|
%ret = call float @llvm.exp10.f32(float 0x7FF0000000000000)
|
|
ret float %ret
|
|
}
|
|
|
|
define float @exp10_neginf() {
|
|
; CHECK-LABEL: define float @exp10_neginf() {
|
|
; CHECK-NEXT: [[RET:%.*]] = call float @llvm.exp10.f32(float 0xFFF0000000000000)
|
|
; CHECK-NEXT: ret float [[RET]]
|
|
;
|
|
%ret = call float @llvm.exp10.f32(float 0xFFF0000000000000)
|
|
ret float %ret
|
|
}
|
|
|
|
define float @exp10_qnan() {
|
|
; CHECK-LABEL: define float @exp10_qnan() {
|
|
; CHECK-NEXT: [[RET:%.*]] = call float @llvm.exp10.f32(float 0x7FF8000000000000)
|
|
; CHECK-NEXT: ret float [[RET]]
|
|
;
|
|
%ret = call float @llvm.exp10.f32(float 0x7FF8000000000000)
|
|
ret float %ret
|
|
}
|
|
|
|
define float @exp10_snan() {
|
|
; CHECK-LABEL: define float @exp10_snan() {
|
|
; CHECK-NEXT: [[RET:%.*]] = call float @llvm.exp10.f32(float 0x7FF0000020000000)
|
|
; CHECK-NEXT: ret float [[RET]]
|
|
;
|
|
%ret = call float @llvm.exp10.f32(float bitcast (i32 2139095041 to float))
|
|
ret float %ret
|
|
}
|
|
|
|
define float @exp10_pos_denorm() {
|
|
; CHECK-LABEL: define float @exp10_pos_denorm() {
|
|
; CHECK-NEXT: ret float 1.000000e+00
|
|
;
|
|
%ret = call float @llvm.exp10.f32(float bitcast (i32 8388607 to float))
|
|
ret float %ret
|
|
}
|
|
|
|
define float @exp10_neg_denorm() {
|
|
; CHECK-LABEL: define float @exp10_neg_denorm() {
|
|
; CHECK-NEXT: ret float 1.000000e+00
|
|
;
|
|
%ret = call float @llvm.exp10.f32(float bitcast (i32 -2139095041 to float))
|
|
ret float %ret
|
|
}
|
|
|
|
define ppc_fp128 @exp10_one_ppcf128() {
|
|
; CHECK-LABEL: define ppc_fp128 @exp10_one_ppcf128() {
|
|
; CHECK-NEXT: [[RET:%.*]] = call ppc_fp128 @llvm.exp10.ppcf128(ppc_fp128 0xM3FF00000000000000000000000000000)
|
|
; CHECK-NEXT: ret ppc_fp128 [[RET]]
|
|
;
|
|
%ret = call ppc_fp128 @llvm.exp10.ppcf128(ppc_fp128 0xM3FF00000000000000000000000000000)
|
|
ret ppc_fp128 %ret
|
|
}
|
|
|
|
define ppc_fp128 @exp10_negone_ppcf128() {
|
|
; CHECK-LABEL: define ppc_fp128 @exp10_negone_ppcf128() {
|
|
; CHECK-NEXT: [[RET:%.*]] = call ppc_fp128 @llvm.exp10.ppcf128(ppc_fp128 0xMBFF00000000000000000000000000000)
|
|
; CHECK-NEXT: ret ppc_fp128 [[RET]]
|
|
;
|
|
%ret = call ppc_fp128 @llvm.exp10.ppcf128(ppc_fp128 0xMBFF00000000000000000000000000000)
|
|
ret ppc_fp128 %ret
|
|
}
|
|
|
|
define ppc_fp128 @canonicalize_noncanonical_zero_1_ppcf128() {
|
|
; CHECK-LABEL: define ppc_fp128 @canonicalize_noncanonical_zero_1_ppcf128() {
|
|
; CHECK-NEXT: [[RET:%.*]] = call ppc_fp128 @llvm.exp10.ppcf128(ppc_fp128 0xM00000000000000000000000000000001)
|
|
; CHECK-NEXT: ret ppc_fp128 [[RET]]
|
|
;
|
|
%ret = call ppc_fp128 @llvm.exp10.ppcf128(ppc_fp128 0xM00000000000000000000000000000001)
|
|
ret ppc_fp128 %ret
|
|
}
|
|
|
|
define <2 x float> @exp10_splat_4() {
|
|
; CHECK-LABEL: define <2 x float> @exp10_splat_4() {
|
|
; CHECK-NEXT: ret <2 x float> <float 1.000000e+04, float 1.000000e+04>
|
|
;
|
|
%ret = call <2 x float> @llvm.exp10.v2f32(<2 x float> <float 4.0, float 4.0>)
|
|
ret <2 x float> %ret
|
|
}
|
|
|
|
define <2 x float> @exp10_splat_qnan() {
|
|
; CHECK-LABEL: define <2 x float> @exp10_splat_qnan() {
|
|
; CHECK-NEXT: [[RET:%.*]] = call <2 x float> @llvm.exp10.v2f32(<2 x float> <float 0x7FF8000000000000, float 0x7FF8000000000000>)
|
|
; CHECK-NEXT: ret <2 x float> [[RET]]
|
|
;
|
|
%ret = call <2 x float> @llvm.exp10.v2f32(<2 x float> <float 0x7FF8000000000000, float 0x7FF8000000000000>)
|
|
ret <2 x float> %ret
|
|
}
|
|
|
|
define <2 x float> @exp10_splat_inf() {
|
|
; CHECK-LABEL: define <2 x float> @exp10_splat_inf() {
|
|
; CHECK-NEXT: [[RET:%.*]] = call <2 x float> @llvm.exp10.v2f32(<2 x float> <float 0x7FF0000000000000, float 0x7FF0000000000000>)
|
|
; CHECK-NEXT: ret <2 x float> [[RET]]
|
|
;
|
|
%ret = call <2 x float> @llvm.exp10.v2f32(<2 x float> <float 0x7FF0000000000000, float 0x7FF0000000000000>)
|
|
ret <2 x float> %ret
|
|
}
|
|
|
|
define <2 x float> @exp10_splat_neginf() {
|
|
; CHECK-LABEL: define <2 x float> @exp10_splat_neginf() {
|
|
; CHECK-NEXT: [[RET:%.*]] = call <2 x float> @llvm.exp10.v2f32(<2 x float> <float 0xFFF0000000000000, float 0xFFF0000000000000>)
|
|
; CHECK-NEXT: ret <2 x float> [[RET]]
|
|
;
|
|
%ret = call <2 x float> @llvm.exp10.v2f32(<2 x float> <float 0xFFF0000000000000, float 0xFFF0000000000000>)
|
|
ret <2 x float> %ret
|
|
}
|
|
|
|
define <2 x float> @exp10_splat_undef_inf() {
|
|
; CHECK-LABEL: define <2 x float> @exp10_splat_undef_inf() {
|
|
; CHECK-NEXT: [[RET:%.*]] = call <2 x float> @llvm.exp10.v2f32(<2 x float> <float undef, float 0x7FF0000000000000>)
|
|
; CHECK-NEXT: ret <2 x float> [[RET]]
|
|
;
|
|
%ret = call <2 x float> @llvm.exp10.v2f32(<2 x float> <float undef, float 0x7FF0000000000000>)
|
|
ret <2 x float> %ret
|
|
}
|