| ; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 6 |
| ; RUN: opt -S -mtriple=amdgcn-amd-amdhsa -passes=amdgpu-simplifylib,instcombine -amdgpu-prelink %s | FileCheck %s |
| |
| define float @test_pow_afn_f32(float %x, float %y) #0 { |
| ; CHECK-LABEL: define float @test_pow_afn_f32( |
| ; CHECK-SAME: float [[X:%.*]], float [[Y:%.*]]) #[[ATTR0:[0-9]+]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call afn float @_Z10__pow_fastff(float [[X]], float [[Y]]) |
| ; CHECK-NEXT: ret float [[CALL]] |
| ; |
| entry: |
| %call = tail call afn float @_Z3powff(float %x, float %y) |
| ret float %call |
| } |
| |
| declare float @_Z3powff(float, float) #1 |
| |
| define <2 x float> @test_pow_afn_v2f32(<2 x float> %x, <2 x float> %y) #0 { |
| ; CHECK-LABEL: define <2 x float> @test_pow_afn_v2f32( |
| ; CHECK-SAME: <2 x float> [[X:%.*]], <2 x float> [[Y:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call afn <2 x float> @_Z10__pow_fastDv2_fS_(<2 x float> [[X]], <2 x float> [[Y]]) |
| ; CHECK-NEXT: ret <2 x float> [[CALL]] |
| ; |
| entry: |
| %call = tail call afn <2 x float> @_Z3powDv2_fS_(<2 x float> %x, <2 x float> %y) |
| ret <2 x float> %call |
| } |
| |
| declare <2 x float> @_Z3powDv2_fS_(<2 x float>, <2 x float>) #1 |
| |
| define <3 x float> @test_pow_afn_v3f32(<3 x float> %x, <3 x float> %y) #0 { |
| ; CHECK-LABEL: define <3 x float> @test_pow_afn_v3f32( |
| ; CHECK-SAME: <3 x float> [[X:%.*]], <3 x float> [[Y:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call afn <3 x float> @_Z10__pow_fastDv3_fS_(<3 x float> [[X]], <3 x float> [[Y]]) |
| ; CHECK-NEXT: ret <3 x float> [[CALL]] |
| ; |
| entry: |
| %call = tail call afn <3 x float> @_Z3powDv3_fS_(<3 x float> %x, <3 x float> %y) |
| ret <3 x float> %call |
| } |
| |
| declare <3 x float> @_Z3powDv3_fS_(<3 x float>, <3 x float>) #1 |
| |
| define <4 x float> @test_pow_afn_v4f32(<4 x float> %x, <4 x float> %y) #0 { |
| ; CHECK-LABEL: define <4 x float> @test_pow_afn_v4f32( |
| ; CHECK-SAME: <4 x float> [[X:%.*]], <4 x float> [[Y:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call afn <4 x float> @_Z10__pow_fastDv4_fS_(<4 x float> [[X]], <4 x float> [[Y]]) |
| ; CHECK-NEXT: ret <4 x float> [[CALL]] |
| ; |
| entry: |
| %call = tail call afn <4 x float> @_Z3powDv4_fS_(<4 x float> %x, <4 x float> %y) |
| ret <4 x float> %call |
| } |
| |
| declare <4 x float> @_Z3powDv4_fS_(<4 x float>, <4 x float>) #1 |
| |
| define <8 x float> @test_pow_afn_v8f32(<8 x float> %x, <8 x float> %y) #0 { |
| ; CHECK-LABEL: define <8 x float> @test_pow_afn_v8f32( |
| ; CHECK-SAME: <8 x float> [[X:%.*]], <8 x float> [[Y:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call afn <8 x float> @_Z10__pow_fastDv8_fS_(<8 x float> [[X]], <8 x float> [[Y]]) |
| ; CHECK-NEXT: ret <8 x float> [[CALL]] |
| ; |
| entry: |
| %call = tail call afn <8 x float> @_Z3powDv8_fS_(<8 x float> %x, <8 x float> %y) |
| ret <8 x float> %call |
| } |
| |
| declare <8 x float> @_Z3powDv8_fS_(<8 x float>, <8 x float>) #1 |
| |
| define <16 x float> @test_pow_afn_v16f32(<16 x float> %x, <16 x float> %y) #0 { |
| ; CHECK-LABEL: define <16 x float> @test_pow_afn_v16f32( |
| ; CHECK-SAME: <16 x float> [[X:%.*]], <16 x float> [[Y:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call afn <16 x float> @_Z10__pow_fastDv16_fS_(<16 x float> [[X]], <16 x float> [[Y]]) |
| ; CHECK-NEXT: ret <16 x float> [[CALL]] |
| ; |
| entry: |
| %call = tail call afn <16 x float> @_Z3powDv16_fS_(<16 x float> %x, <16 x float> %y) |
| ret <16 x float> %call |
| } |
| |
| declare <16 x float> @_Z3powDv16_fS_(<16 x float>, <16 x float>) #1 |
| |
| |
| define float @test_pow_afn_f32__known_positive_x(float nofpclass(ninf nnorm nsub nzero) %x, float %y) #0 { |
| ; CHECK-LABEL: define float @test_pow_afn_f32__known_positive_x( |
| ; CHECK-SAME: float nofpclass(ninf nzero nsub nnorm) [[X:%.*]], float [[Y:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call afn float @_Z11__powr_fastff(float [[X]], float [[Y]]) |
| ; CHECK-NEXT: ret float [[CALL]] |
| ; |
| entry: |
| %call = tail call afn float @_Z3powff(float %x, float %y) |
| ret float %call |
| } |
| |
| define float @test_pow_afn_f32__known_positive_x__known_integral_y(float nofpclass(ninf nnorm nsub nzero) %x, i32 %y.int) #0 { |
| ; CHECK-LABEL: define float @test_pow_afn_f32__known_positive_x__known_integral_y( |
| ; CHECK-SAME: float nofpclass(ninf nzero nsub nnorm) [[X:%.*]], i32 [[Y_INT:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[Y:%.*]] = sitofp i32 [[Y_INT]] to float |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call afn float @_Z11__powr_fastff(float [[X]], float [[Y]]) |
| ; CHECK-NEXT: ret float [[CALL]] |
| ; |
| entry: |
| %y = sitofp i32 %y.int to float |
| %call = tail call afn float @_Z3powff(float %x, float %y) |
| ret float %call |
| } |
| |
| define <2 x float> @test_pow_afn_v2f32__known_positive_x(<2 x float> nofpclass(ninf nnorm nsub nzero) %x, <2 x float> %y) #0 { |
| ; CHECK-LABEL: define <2 x float> @test_pow_afn_v2f32__known_positive_x( |
| ; CHECK-SAME: <2 x float> nofpclass(ninf nzero nsub nnorm) [[X:%.*]], <2 x float> [[Y:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call afn <2 x float> @_Z11__powr_fastDv2_fS_(<2 x float> [[X]], <2 x float> [[Y]]) |
| ; CHECK-NEXT: ret <2 x float> [[CALL]] |
| ; |
| entry: |
| %call = tail call afn <2 x float> @_Z3powDv2_fS_(<2 x float> %x, <2 x float> %y) |
| ret <2 x float> %call |
| } |
| |
| define float @test_pow_afn_f32__known_integral_y(float %x, i32 %y.int) #0 { |
| ; CHECK-LABEL: define float @test_pow_afn_f32__known_integral_y( |
| ; CHECK-SAME: float [[X:%.*]], i32 [[Y_INT:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[Y:%.*]] = sitofp i32 [[Y_INT]] to float |
| ; CHECK-NEXT: [[TMP0:%.*]] = fptosi float [[Y]] to i32 |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call afn float @_Z11__pown_fastfi(float [[X]], i32 [[TMP0]]) |
| ; CHECK-NEXT: ret float [[CALL]] |
| ; |
| entry: |
| %y = sitofp i32 %y.int to float |
| %call = tail call afn float @_Z3powff(float %x, float %y) |
| ret float %call |
| } |
| |
| define <2 x float> @test_pow_afn_v2f32__known_integral_y(<2 x float> %x, <2 x i32> %y.int) #0 { |
| ; CHECK-LABEL: define <2 x float> @test_pow_afn_v2f32__known_integral_y( |
| ; CHECK-SAME: <2 x float> [[X:%.*]], <2 x i32> [[Y_INT:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[Y:%.*]] = sitofp <2 x i32> [[Y_INT]] to <2 x float> |
| ; CHECK-NEXT: [[TMP0:%.*]] = fptosi <2 x float> [[Y]] to <2 x i32> |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call afn <2 x float> @_Z11__pown_fastDv2_fDv2_i(<2 x float> [[X]], <2 x i32> [[TMP0]]) |
| ; CHECK-NEXT: ret <2 x float> [[CALL]] |
| ; |
| entry: |
| %y = sitofp <2 x i32> %y.int to <2 x float> |
| %call = tail call afn <2 x float> @_Z3powDv2_fS_(<2 x float> %x, <2 x float> %y) |
| ret <2 x float> %call |
| } |
| |
| define float @test_pow_afn_f32__0(float %x) #0 { |
| ; CHECK-LABEL: define float @test_pow_afn_f32__0( |
| ; CHECK-SAME: float [[X:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: ret float 1.000000e+00 |
| ; |
| entry: |
| %call = tail call afn float @_Z3powff(float %x, float 0.0) |
| ret float %call |
| } |
| |
| define float @test_pow_afn_f32__1(float %x) #0 { |
| ; CHECK-LABEL: define float @test_pow_afn_f32__1( |
| ; CHECK-SAME: float [[X:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: ret float [[X]] |
| ; |
| entry: |
| %call = tail call afn float @_Z3powff(float %x, float 1.0) |
| ret float %call |
| } |
| |
| define float @test_pow_afn_f32__2(float %x) #0 { |
| ; CHECK-LABEL: define float @test_pow_afn_f32__2( |
| ; CHECK-SAME: float [[X:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[__POW2:%.*]] = fmul afn float [[X]], [[X]] |
| ; CHECK-NEXT: ret float [[__POW2]] |
| ; |
| entry: |
| %call = tail call afn float @_Z3powff(float %x, float 2.0) |
| ret float %call |
| } |
| |
| define float @test_pow_afn_f32__3(float %x) #0 { |
| ; CHECK-LABEL: define float @test_pow_afn_f32__3( |
| ; CHECK-SAME: float [[X:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call afn float @_Z11__pown_fastfi(float [[X]], i32 3) |
| ; CHECK-NEXT: ret float [[CALL]] |
| ; |
| entry: |
| %call = tail call afn float @_Z3powff(float %x, float 3.0) |
| ret float %call |
| } |
| |
| define float @test_pow_afn_f32__8(float %x) #0 { |
| ; CHECK-LABEL: define float @test_pow_afn_f32__8( |
| ; CHECK-SAME: float [[X:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call afn float @_Z11__pown_fastfi(float [[X]], i32 8) |
| ; CHECK-NEXT: ret float [[CALL]] |
| ; |
| entry: |
| %call = tail call afn float @_Z3powff(float %x, float 8.0) |
| ret float %call |
| } |
| |
| define float @test_pow_afn_f32__neg1(float %x) #0 { |
| ; CHECK-LABEL: define float @test_pow_afn_f32__neg1( |
| ; CHECK-SAME: float [[X:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[__POWRECIP:%.*]] = fdiv afn float 1.000000e+00, [[X]] |
| ; CHECK-NEXT: ret float [[__POWRECIP]] |
| ; |
| entry: |
| %call = tail call afn float @_Z3powff(float %x, float -1.0) |
| ret float %call |
| } |
| |
| define float @test_pow_afn_f32__half(float %x) #0 { |
| ; CHECK-LABEL: define float @test_pow_afn_f32__half( |
| ; CHECK-SAME: float [[X:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[__POW2SQRT:%.*]] = call afn float @_Z4sqrtf(float [[X]]) |
| ; CHECK-NEXT: ret float [[__POW2SQRT]] |
| ; |
| entry: |
| %call = tail call afn float @_Z3powff(float %x, float 0.5) |
| ret float %call |
| } |
| |
| define float @test_pow_afn_f32__neghalf(float %x) #0 { |
| ; CHECK-LABEL: define float @test_pow_afn_f32__neghalf( |
| ; CHECK-SAME: float [[X:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[__POW2RSQRT:%.*]] = call afn float @_Z5rsqrtf(float [[X]]) |
| ; CHECK-NEXT: ret float [[__POW2RSQRT]] |
| ; |
| entry: |
| %call = tail call afn float @_Z3powff(float %x, float -0.5) |
| ret float %call |
| } |
| |
| define <2 x float> @test_pow_afn_v2f32__0(<2 x float> %x) #0 { |
| ; CHECK-LABEL: define <2 x float> @test_pow_afn_v2f32__0( |
| ; CHECK-SAME: <2 x float> [[X:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: ret <2 x float> splat (float 1.000000e+00) |
| ; |
| entry: |
| %call = tail call afn <2 x float> @_Z3powDv2_fS_(<2 x float> %x, <2 x float> zeroinitializer) |
| ret <2 x float> %call |
| } |
| |
| define <2 x float> @test_pow_afn_v2f32__1(<2 x float> %x) #0 { |
| ; CHECK-LABEL: define <2 x float> @test_pow_afn_v2f32__1( |
| ; CHECK-SAME: <2 x float> [[X:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: ret <2 x float> [[X]] |
| ; |
| entry: |
| %call = tail call afn <2 x float> @_Z3powDv2_fS_(<2 x float> %x, <2 x float> splat (float 1.0)) |
| ret <2 x float> %call |
| } |
| |
| define <2 x float> @test_pow_afn_v2f32__2(<2 x float> %x) #0 { |
| ; CHECK-LABEL: define <2 x float> @test_pow_afn_v2f32__2( |
| ; CHECK-SAME: <2 x float> [[X:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[__POW2:%.*]] = fmul afn <2 x float> [[X]], [[X]] |
| ; CHECK-NEXT: ret <2 x float> [[__POW2]] |
| ; |
| entry: |
| %call = tail call afn <2 x float> @_Z3powDv2_fS_(<2 x float> %x, <2 x float> splat (float 2.0)) |
| ret <2 x float> %call |
| } |
| |
| define <2 x float> @test_pow_afn_v2f32__3(<2 x float> %x) #0 { |
| ; CHECK-LABEL: define <2 x float> @test_pow_afn_v2f32__3( |
| ; CHECK-SAME: <2 x float> [[X:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call afn <2 x float> @_Z11__pown_fastDv2_fDv2_i(<2 x float> [[X]], <2 x i32> splat (i32 3)) |
| ; CHECK-NEXT: ret <2 x float> [[CALL]] |
| ; |
| entry: |
| %call = tail call afn <2 x float> @_Z3powDv2_fS_(<2 x float> %x, <2 x float> splat (float 3.0)) |
| ret <2 x float> %call |
| } |
| |
| define <2 x float> @test_pow_afn_v2f32__8(<2 x float> %x) #0 { |
| ; CHECK-LABEL: define <2 x float> @test_pow_afn_v2f32__8( |
| ; CHECK-SAME: <2 x float> [[X:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call afn <2 x float> @_Z11__pown_fastDv2_fDv2_i(<2 x float> [[X]], <2 x i32> splat (i32 8)) |
| ; CHECK-NEXT: ret <2 x float> [[CALL]] |
| ; |
| entry: |
| %call = tail call afn <2 x float> @_Z3powDv2_fS_(<2 x float> %x, <2 x float> splat (float 8.0)) |
| ret <2 x float> %call |
| } |
| |
| define <2 x float> @test_pow_afn_v2f32__neg1(<2 x float> %x) #0 { |
| ; CHECK-LABEL: define <2 x float> @test_pow_afn_v2f32__neg1( |
| ; CHECK-SAME: <2 x float> [[X:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[__POWRECIP:%.*]] = fdiv afn <2 x float> splat (float 1.000000e+00), [[X]] |
| ; CHECK-NEXT: ret <2 x float> [[__POWRECIP]] |
| ; |
| entry: |
| %call = tail call afn <2 x float> @_Z3powDv2_fS_(<2 x float> %x, <2 x float> splat (float -1.0)) |
| ret <2 x float> %call |
| } |
| |
| define <2 x float> @test_pow_afn_v2f32__half(<2 x float> %x) #0 { |
| ; CHECK-LABEL: define <2 x float> @test_pow_afn_v2f32__half( |
| ; CHECK-SAME: <2 x float> [[X:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[__POW2SQRT:%.*]] = call afn <2 x float> @_Z4sqrtDv2_f(<2 x float> [[X]]) |
| ; CHECK-NEXT: ret <2 x float> [[__POW2SQRT]] |
| ; |
| entry: |
| %call = tail call afn <2 x float> @_Z3powDv2_fS_(<2 x float> %x, <2 x float> splat (float 0.5)) |
| ret <2 x float> %call |
| } |
| |
| define <2 x float> @test_pow_afn_v2f32__neghalf(<2 x float> %x) #0 { |
| ; CHECK-LABEL: define <2 x float> @test_pow_afn_v2f32__neghalf( |
| ; CHECK-SAME: <2 x float> [[X:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[__POW2RSQRT:%.*]] = call afn <2 x float> @_Z5rsqrtDv2_f(<2 x float> [[X]]) |
| ; CHECK-NEXT: ret <2 x float> [[__POW2RSQRT]] |
| ; |
| entry: |
| %call = tail call afn <2 x float> @_Z3powDv2_fS_(<2 x float> %x, <2 x float> splat (float -0.5)) |
| ret <2 x float> %call |
| } |
| |
| define float @test__pow_fast_f32(float %x, float %y) #0 { |
| ; CHECK-LABEL: define float @test__pow_fast_f32( |
| ; CHECK-SAME: float [[X:%.*]], float [[Y:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call float @_Z10__pow_fastff(float [[X]], float [[Y]]) |
| ; CHECK-NEXT: ret float [[CALL]] |
| ; |
| entry: |
| %call = tail call float @_Z10__pow_fastff(float %x, float %y) |
| ret float %call |
| } |
| |
| declare float @_Z10__pow_fastff(float, float) #1 |
| |
| define <2 x float> @test__pow_fast_v2f32(<2 x float> %x, <2 x float> %y) #0 { |
| ; CHECK-LABEL: define <2 x float> @test__pow_fast_v2f32( |
| ; CHECK-SAME: <2 x float> [[X:%.*]], <2 x float> [[Y:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call <2 x float> @_Z10__pow_fastDv2_fS_(<2 x float> [[X]], <2 x float> [[Y]]) |
| ; CHECK-NEXT: ret <2 x float> [[CALL]] |
| ; |
| entry: |
| %call = tail call <2 x float> @_Z10__pow_fastDv2_fS_(<2 x float> %x, <2 x float> %y) |
| ret <2 x float> %call |
| } |
| |
| declare <2 x float> @_Z10__pow_fastDv2_fS_(<2 x float>, <2 x float>) #1 |
| |
| define <3 x float> @test__pow_fast_v3f32(<3 x float> %x, <3 x float> %y) #0 { |
| ; CHECK-LABEL: define <3 x float> @test__pow_fast_v3f32( |
| ; CHECK-SAME: <3 x float> [[X:%.*]], <3 x float> [[Y:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call <3 x float> @_Z10__pow_fastDv3_fS_(<3 x float> [[X]], <3 x float> [[Y]]) |
| ; CHECK-NEXT: ret <3 x float> [[CALL]] |
| ; |
| entry: |
| %call = tail call <3 x float> @_Z10__pow_fastDv3_fS_(<3 x float> %x, <3 x float> %y) |
| ret <3 x float> %call |
| } |
| |
| declare <3 x float> @_Z10__pow_fastDv3_fS_(<3 x float>, <3 x float>) #1 |
| |
| define <4 x float> @test__pow_fast_v4f32(<4 x float> %x, <4 x float> %y) #0 { |
| ; CHECK-LABEL: define <4 x float> @test__pow_fast_v4f32( |
| ; CHECK-SAME: <4 x float> [[X:%.*]], <4 x float> [[Y:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call <4 x float> @_Z10__pow_fastDv4_fS_(<4 x float> [[X]], <4 x float> [[Y]]) |
| ; CHECK-NEXT: ret <4 x float> [[CALL]] |
| ; |
| entry: |
| %call = tail call <4 x float> @_Z10__pow_fastDv4_fS_(<4 x float> %x, <4 x float> %y) |
| ret <4 x float> %call |
| } |
| |
| declare <4 x float> @_Z10__pow_fastDv4_fS_(<4 x float>, <4 x float>) #1 |
| |
| define <8 x float> @test__pow_fast_v8f32(<8 x float> %x, <8 x float> %y) #0 { |
| ; CHECK-LABEL: define <8 x float> @test__pow_fast_v8f32( |
| ; CHECK-SAME: <8 x float> [[X:%.*]], <8 x float> [[Y:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call <8 x float> @_Z10__pow_fastDv8_fS_(<8 x float> [[X]], <8 x float> [[Y]]) |
| ; CHECK-NEXT: ret <8 x float> [[CALL]] |
| ; |
| entry: |
| %call = tail call <8 x float> @_Z10__pow_fastDv8_fS_(<8 x float> %x, <8 x float> %y) |
| ret <8 x float> %call |
| } |
| |
| declare <8 x float> @_Z10__pow_fastDv8_fS_(<8 x float>, <8 x float>) #1 |
| |
| define <16 x float> @test__pow_fast_v16f32(<16 x float> %x, <16 x float> %y) #0 { |
| ; CHECK-LABEL: define <16 x float> @test__pow_fast_v16f32( |
| ; CHECK-SAME: <16 x float> [[X:%.*]], <16 x float> [[Y:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call <16 x float> @_Z10__pow_fastDv16_fS_(<16 x float> [[X]], <16 x float> [[Y]]) |
| ; CHECK-NEXT: ret <16 x float> [[CALL]] |
| ; |
| entry: |
| %call = tail call <16 x float> @_Z10__pow_fastDv16_fS_(<16 x float> %x, <16 x float> %y) |
| ret <16 x float> %call |
| } |
| |
| declare <16 x float> @_Z10__pow_fastDv16_fS_(<16 x float>, <16 x float>) #1 |
| |
| define float @test__pow_fast_f32__known_positive_x(float nofpclass(ninf nnorm nsub nzero) %x, float %y) #0 { |
| ; CHECK-LABEL: define float @test__pow_fast_f32__known_positive_x( |
| ; CHECK-SAME: float nofpclass(ninf nzero nsub nnorm) [[X:%.*]], float [[Y:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call float @_Z11__powr_fastff(float [[X]], float [[Y]]) |
| ; CHECK-NEXT: ret float [[CALL]] |
| ; |
| entry: |
| %call = tail call float @_Z10__pow_fastff(float %x, float %y) |
| ret float %call |
| } |
| |
| define float @test__pow_fast_f32__known_positive_x_preserve_flags(float nofpclass(ninf nnorm nsub nzero) %x, float %y) #0 { |
| ; CHECK-LABEL: define float @test__pow_fast_f32__known_positive_x_preserve_flags( |
| ; CHECK-SAME: float nofpclass(ninf nzero nsub nnorm) [[X:%.*]], float [[Y:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call nsz contract nofpclass(snan) float @_Z11__powr_fastff(float [[X]], float [[Y]]), !keep.md [[META0:![0-9]+]] |
| ; CHECK-NEXT: ret float [[CALL]] |
| ; |
| entry: |
| %call = tail call contract nsz nofpclass(snan) float @_Z10__pow_fastff(float %x, float %y), !keep.md !{} |
| ret float %call |
| } |
| |
| define <2 x float> @test__pow_fast_v2f32__known_positive_x(<2 x float> nofpclass(ninf nnorm nsub nzero) %x, <2 x float> %y) #0 { |
| ; CHECK-LABEL: define <2 x float> @test__pow_fast_v2f32__known_positive_x( |
| ; CHECK-SAME: <2 x float> nofpclass(ninf nzero nsub nnorm) [[X:%.*]], <2 x float> [[Y:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call <2 x float> @_Z11__powr_fastDv2_fS_(<2 x float> [[X]], <2 x float> [[Y]]) |
| ; CHECK-NEXT: ret <2 x float> [[CALL]] |
| ; |
| entry: |
| %call = tail call <2 x float> @_Z10__pow_fastDv2_fS_(<2 x float> %x, <2 x float> %y) |
| ret <2 x float> %call |
| } |
| |
| define float @test___pow_fast_f32__known_integral_y(float %x, i32 %y.int) #0 { |
| ; CHECK-LABEL: define float @test___pow_fast_f32__known_integral_y( |
| ; CHECK-SAME: float [[X:%.*]], i32 [[Y_INT:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[Y:%.*]] = sitofp i32 [[Y_INT]] to float |
| ; CHECK-NEXT: [[TMP0:%.*]] = fptosi float [[Y]] to i32 |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call float @_Z11__pown_fastfi(float [[X]], i32 [[TMP0]]) |
| ; CHECK-NEXT: ret float [[CALL]] |
| ; |
| entry: |
| %y = sitofp i32 %y.int to float |
| %call = tail call float @_Z10__pow_fastff(float %x, float %y) |
| ret float %call |
| } |
| |
| define float @test__pow_fast_f32__0(float %x) #0 { |
| ; CHECK-LABEL: define float @test__pow_fast_f32__0( |
| ; CHECK-SAME: float [[X:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: ret float 1.000000e+00 |
| ; |
| entry: |
| %call = tail call float @_Z10__pow_fastff(float %x, float 0.0) |
| ret float %call |
| } |
| |
| define float @test__pow_fast_afn_f32__0(float %x) #0 { |
| ; CHECK-LABEL: define float @test__pow_fast_afn_f32__0( |
| ; CHECK-SAME: float [[X:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: ret float 1.000000e+00 |
| ; |
| entry: |
| %call = tail call afn float @_Z10__pow_fastff(float %x, float 0.0) |
| ret float %call |
| } |
| |
| define float @test__pow_fast_f32__2(float %x) #0 { |
| ; CHECK-LABEL: define float @test__pow_fast_f32__2( |
| ; CHECK-SAME: float [[X:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[__POW2:%.*]] = fmul float [[X]], [[X]] |
| ; CHECK-NEXT: ret float [[__POW2]] |
| ; |
| entry: |
| %call = tail call float @_Z10__pow_fastff(float %x, float 2.0) |
| ret float %call |
| } |
| |
| define float @test__pow_fast_afn_f32__2(float %x) #0 { |
| ; CHECK-LABEL: define float @test__pow_fast_afn_f32__2( |
| ; CHECK-SAME: float [[X:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[__POW2:%.*]] = fmul afn float [[X]], [[X]] |
| ; CHECK-NEXT: ret float [[__POW2]] |
| ; |
| entry: |
| %call = tail call afn float @_Z10__pow_fastff(float %x, float 2.0) |
| ret float %call |
| } |
| |
| define float @test__pow_fast_f32__half(float %x) #0 { |
| ; CHECK-LABEL: define float @test__pow_fast_f32__half( |
| ; CHECK-SAME: float [[X:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[__POW2SQRT:%.*]] = call float @_Z4sqrtf(float [[X]]) |
| ; CHECK-NEXT: ret float [[__POW2SQRT]] |
| ; |
| entry: |
| %call = tail call float @_Z10__pow_fastff(float %x, float 0.5) |
| ret float %call |
| } |
| |
| define float @test__pow_fast_afn_f32__half(float %x) #0 { |
| ; CHECK-LABEL: define float @test__pow_fast_afn_f32__half( |
| ; CHECK-SAME: float [[X:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[__POW2SQRT:%.*]] = call afn float @_Z4sqrtf(float [[X]]) |
| ; CHECK-NEXT: ret float [[__POW2SQRT]] |
| ; |
| entry: |
| %call = tail call afn float @_Z10__pow_fastff(float %x, float 0.5) |
| ret float %call |
| } |
| |
| define float @test__pow_fast_f32__neghalf(float %x) #0 { |
| ; CHECK-LABEL: define float @test__pow_fast_f32__neghalf( |
| ; CHECK-SAME: float [[X:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[__POW2RSQRT:%.*]] = call float @_Z5rsqrtf(float [[X]]) |
| ; CHECK-NEXT: ret float [[__POW2RSQRT]] |
| ; |
| entry: |
| %call = tail call float @_Z10__pow_fastff(float %x, float -0.5) |
| ret float %call |
| } |
| |
| define float @test__pow_fast_afn_f32__neghalf(float %x) #0 { |
| ; CHECK-LABEL: define float @test__pow_fast_afn_f32__neghalf( |
| ; CHECK-SAME: float [[X:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[__POW2RSQRT:%.*]] = call afn float @_Z5rsqrtf(float [[X]]) |
| ; CHECK-NEXT: ret float [[__POW2RSQRT]] |
| ; |
| entry: |
| %call = tail call afn float @_Z10__pow_fastff(float %x, float -0.5) |
| ret float %call |
| } |
| |
| define <2 x float> @test__pow_fast_v2f32__neghalf(<2 x float> %x) #0 { |
| ; CHECK-LABEL: define <2 x float> @test__pow_fast_v2f32__neghalf( |
| ; CHECK-SAME: <2 x float> [[X:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[__POW2RSQRT:%.*]] = call <2 x float> @_Z5rsqrtDv2_f(<2 x float> [[X]]) |
| ; CHECK-NEXT: ret <2 x float> [[__POW2RSQRT]] |
| ; |
| entry: |
| %call = tail call <2 x float> @_Z10__pow_fastDv2_fS_(<2 x float> %x, <2 x float> splat (float -0.5)) |
| ret <2 x float> %call |
| } |
| |
| define <2 x float> @test__pow_fast_afn_v2f32__neghalf(<2 x float> %x) #0 { |
| ; CHECK-LABEL: define <2 x float> @test__pow_fast_afn_v2f32__neghalf( |
| ; CHECK-SAME: <2 x float> [[X:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[__POW2RSQRT:%.*]] = call afn <2 x float> @_Z5rsqrtDv2_f(<2 x float> [[X]]) |
| ; CHECK-NEXT: ret <2 x float> [[__POW2RSQRT]] |
| ; |
| entry: |
| %call = tail call afn <2 x float> @_Z10__pow_fastDv2_fS_(<2 x float> %x, <2 x float> splat (float -0.5)) |
| ret <2 x float> %call |
| } |
| |
| define double @test_pow_afn_f64(double %x, double %y) #0 { |
| ; CHECK-LABEL: define double @test_pow_afn_f64( |
| ; CHECK-SAME: double [[X:%.*]], double [[Y:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call afn double @_Z3powdd(double [[X]], double [[Y]]) |
| ; CHECK-NEXT: ret double [[CALL]] |
| ; |
| entry: |
| %call = tail call afn double @_Z3powdd(double %x, double %y) |
| ret double %call |
| } |
| |
| declare double @_Z3powdd(double, double) #0 |
| |
| define <2 x double> @test_pow_afn_v2f64(<2 x double> %x, <2 x double> %y) #0 { |
| ; CHECK-LABEL: define <2 x double> @test_pow_afn_v2f64( |
| ; CHECK-SAME: <2 x double> [[X:%.*]], <2 x double> [[Y:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call afn <2 x double> @_Z3powDv2_dS_(<2 x double> [[X]], <2 x double> [[Y]]) |
| ; CHECK-NEXT: ret <2 x double> [[CALL]] |
| ; |
| entry: |
| %call = tail call afn <2 x double> @_Z3powDv2_dS_(<2 x double> %x, <2 x double> %y) |
| ret <2 x double> %call |
| } |
| |
| declare <2 x double> @_Z3powDv2_dS_(<2 x double>, <2 x double>) #0 |
| |
| define half @test_pow_afn_f16(half %x, half %y) #0 { |
| ; CHECK-LABEL: define half @test_pow_afn_f16( |
| ; CHECK-SAME: half [[X:%.*]], half [[Y:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call afn half @_Z3powDhDh(half [[X]], half [[Y]]) |
| ; CHECK-NEXT: ret half [[CALL]] |
| ; |
| entry: |
| %call = tail call afn half @_Z3powDhDh(half %x, half %y) |
| ret half %call |
| } |
| |
| declare half @_Z3powDhDh(half, half) #0 |
| |
| define <2 x half> @test_pow_afn_v2f16(<2 x half> %x, <2 x half> %y) #0 { |
| ; CHECK-LABEL: define <2 x half> @test_pow_afn_v2f16( |
| ; CHECK-SAME: <2 x half> [[X:%.*]], <2 x half> [[Y:%.*]]) #[[ATTR0]] { |
| ; CHECK-NEXT: [[ENTRY:.*:]] |
| ; CHECK-NEXT: [[CALL:%.*]] = tail call afn <2 x half> @_Z3powDv2_DhS_(<2 x half> [[X]], <2 x half> [[Y]]) #[[ATTR3:[0-9]+]] |
| ; CHECK-NEXT: ret <2 x half> [[CALL]] |
| ; |
| entry: |
| %call = tail call afn <2 x half> @_Z3powDv2_DhS_(<2 x half> %x, <2 x half> %y) |
| ret <2 x half> %call |
| } |
| |
| declare <2 x half> @_Z3powDv2_DhS_(<2 x half>, <2 x half>) #3 |
| |
| attributes #0 = { mustprogress nofree norecurse nounwind willreturn memory(none) } |
| attributes #1 = { mustprogress nofree nounwind willreturn memory(none) } |
| ;. |
| ; CHECK: [[META0]] = !{} |
| ;. |