=?utf-8?q?João?= Saffran <[email protected]>, =?utf-8?q?João?= Saffran <[email protected]>, =?utf-8?q?João?= Saffran <[email protected]>, =?utf-8?q?João?= Saffran <[email protected]>, =?utf-8?q?João?= Saffran <[email protected]>, =?utf-8?q?João?= Saffran <[email protected]> Message-ID: In-Reply-To: <llvm.org/llvm/llvm-project/pull/[email protected]>
llvmbot wrote: <!--LLVM PR SUMMARY COMMENT--> @llvm/pr-subscribers-hlsl Author: None (joaosaffran) <details> <summary>Changes</summary> This patch updates log10, exp2, sinh overload tests to use -O1 instead of -disable-llvm-passes; also, the checks are updated to match the change accordingly. This work is part of https://github.com/llvm/llvm-project/issues/138016. --- Patch is 30.41 KiB, truncated to 20.00 KiB below, full version: https://github.com/llvm/llvm-project/pull/177495.diff 3 Files Affected: - (modified) clang/test/CodeGenHLSL/builtins/exp2-overloads.hlsl (+82-62) - (modified) clang/test/CodeGenHLSL/builtins/log10-overloads.hlsl (+82-42) - (modified) clang/test/CodeGenHLSL/builtins/sinh-overloads.hlsl (+82-42) ``````````diff diff --git a/clang/test/CodeGenHLSL/builtins/exp2-overloads.hlsl b/clang/test/CodeGenHLSL/builtins/exp2-overloads.hlsl index a8a6f3ba76b4f..dfa928b4b1375 100644 --- a/clang/test/CodeGenHLSL/builtins/exp2-overloads.hlsl +++ b/clang/test/CodeGenHLSL/builtins/exp2-overloads.hlsl @@ -1,88 +1,108 @@ // RUN: %clang_cc1 -std=hlsl202x -finclude-default-header -triple dxil-pc-shadermodel6.3-library %s \ -// RUN: -emit-llvm -disable-llvm-passes -o - | \ -// RUN: FileCheck %s --check-prefixes=CHECK +// RUN: -emit-llvm -o - | \ +// RUN: FileCheck %s --check-prefixes=CHECK -DFNATTRS="hidden noundef nofpclass(nan inf)" -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) float {{.*}}test_exp2_double -// CHECK: [[EXP2:%.*]] = call reassoc nnan ninf nsz arcp afn float @llvm.exp2.f32( -// CHECK: ret float [[EXP2]] +// CHECK: define [[FNATTRS]] float @_Z16test_exp2_doubled( +// CHECK: [[CONVI:%.*]] = fptrunc {{.*}} double %{{.*}} to float +// CHECK: [[V2:%.*]] = call {{.*}} float @llvm.exp2.f32(float [[CONVI]]) +// CHECK: ret float [[V2]] float test_exp2_double(double p0) { return exp2(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) <2 x float> {{.*}}test_exp2_double2 -// CHECK: [[EXP2:%.*]] = call reassoc nnan ninf nsz arcp afn <2 x float> @llvm.exp2.v2f32 -// CHECK: ret <2 x float> [[EXP2]] +// CHECK: define [[FNATTRS]] <2 x float> @_Z17test_exp2_double2Dv2_d( +// CHECK: [[CONVI:%.*]] = fptrunc {{.*}} <2 x double> %{{.*}} to <2 x float> +// CHECK: [[V2:%.*]] = call {{.*}} <2 x float> @llvm.exp2.v2f32(<2 x float> [[CONVI]]) +// CHECK: ret <2 x float> [[V2]] float2 test_exp2_double2(double2 p0) { return exp2(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) <3 x float> {{.*}}test_exp2_double3 -// CHECK: [[EXP2:%.*]] = call reassoc nnan ninf nsz arcp afn <3 x float> @llvm.exp2.v3f32 -// CHECK: ret <3 x float> [[EXP2]] +// CHECK: define [[FNATTRS]] <3 x float> @_Z17test_exp2_double3Dv3_d( +// CHECK: [[CONVI:%.*]] = fptrunc {{.*}} <3 x double> %{{.*}} to <3 x float> +// CHECK: [[V2:%.*]] = call {{.*}} <3 x float> @llvm.exp2.v3f32(<3 x float> [[CONVI]]) +// CHECK: ret <3 x float> [[V2]] float3 test_exp2_double3(double3 p0) { return exp2(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) <4 x float> {{.*}}test_exp2_double4 -// CHECK: [[EXP2:%.*]] = call reassoc nnan ninf nsz arcp afn <4 x float> @llvm.exp2.v4f32 -// CHECK: ret <4 x float> [[EXP2]] +// CHECK: define [[FNATTRS]] <4 x float> @_Z17test_exp2_double4Dv4_d( +// CHECK: [[CONVI:%.*]] = fptrunc {{.*}} <4 x double> %{{.*}} to <4 x float> +// CHECK: [[V2:%.*]] = call {{.*}} <4 x float> @llvm.exp2.v4f32(<4 x float> [[CONVI]]) +// CHECK: ret <4 x float> [[V2]] float4 test_exp2_double4(double4 p0) { return exp2(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) float {{.*}}test_exp2_int -// CHECK: [[EXP2:%.*]] = call reassoc nnan ninf nsz arcp afn float @llvm.exp2.f32( -// CHECK: ret float [[EXP2]] +// CHECK: define [[FNATTRS]] float @_Z13test_exp2_inti( +// CHECK: [[CONVI:%.*]] = sitofp i32 %{{.*}} to float +// CHECK: [[V2:%.*]] = call {{.*}} float @llvm.exp2.f32(float [[CONVI]]) +// CHECK: ret float [[V2]] float test_exp2_int(int p0) { return exp2(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) <2 x float> {{.*}}test_exp2_int2 -// CHECK: [[EXP2:%.*]] = call reassoc nnan ninf nsz arcp afn <2 x float> @llvm.exp2.v2f32 -// CHECK: ret <2 x float> [[EXP2]] +// CHECK: define [[FNATTRS]] <2 x float> @_Z14test_exp2_int2Dv2_i( +// CHECK: [[CONVI:%.*]] = sitofp <2 x i32> %{{.*}} to <2 x float> +// CHECK: [[V2:%.*]] = call {{.*}} <2 x float> @llvm.exp2.v2f32(<2 x float> [[CONVI]]) +// CHECK: ret <2 x float> [[V2]] float2 test_exp2_int2(int2 p0) { return exp2(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) <3 x float> {{.*}}test_exp2_int3 -// CHECK: [[EXP2:%.*]] = call reassoc nnan ninf nsz arcp afn <3 x float> @llvm.exp2.v3f32 -// CHECK: ret <3 x float> [[EXP2]] +// CHECK: define [[FNATTRS]] <3 x float> @_Z14test_exp2_int3Dv3_i( +// CHECK: [[CONVI:%.*]] = sitofp <3 x i32> %{{.*}} to <3 x float> +// CHECK: [[V2:%.*]] = call {{.*}} <3 x float> @llvm.exp2.v3f32(<3 x float> [[CONVI]]) +// CHECK: ret <3 x float> [[V2]] float3 test_exp2_int3(int3 p0) { return exp2(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) <4 x float> {{.*}}test_exp2_int4 -// CHECK: [[EXP2:%.*]] = call reassoc nnan ninf nsz arcp afn <4 x float> @llvm.exp2.v4f32 -// CHECK: ret <4 x float> [[EXP2]] +// CHECK: define [[FNATTRS]] <4 x float> @_Z14test_exp2_int4Dv4_i( +// CHECK: [[CONVI:%.*]] = sitofp <4 x i32> %{{.*}} to <4 x float> +// CHECK: [[V2:%.*]] = call {{.*}} <4 x float> @llvm.exp2.v4f32(<4 x float> [[CONVI]]) +// CHECK: ret <4 x float> [[V2]] float4 test_exp2_int4(int4 p0) { return exp2(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) float {{.*}}test_exp2_uint -// CHECK: [[EXP2:%.*]] = call reassoc nnan ninf nsz arcp afn float @llvm.exp2.f32( -// CHECK: ret float [[EXP2]] +// CHECK: define [[FNATTRS]] float @_Z14test_exp2_uintj( +// CHECK: [[CONVI:%.*]] = uitofp i32 %{{.*}} to float +// CHECK: [[V2:%.*]] = call {{.*}} float @llvm.exp2.f32(float [[CONVI]]) +// CHECK: ret float [[V2]] float test_exp2_uint(uint p0) { return exp2(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) <2 x float> {{.*}}test_exp2_uint2 -// CHECK: [[EXP2:%.*]] = call reassoc nnan ninf nsz arcp afn <2 x float> @llvm.exp2.v2f32 -// CHECK: ret <2 x float> [[EXP2]] +// CHECK: define [[FNATTRS]] <2 x float> @_Z15test_exp2_uint2Dv2_j( +// CHECK: [[CONVI:%.*]] = uitofp <2 x i32> %{{.*}} to <2 x float> +// CHECK: [[V2:%.*]] = call {{.*}} <2 x float> @llvm.exp2.v2f32(<2 x float> [[CONVI]]) +// CHECK: ret <2 x float> [[V2]] float2 test_exp2_uint2(uint2 p0) { return exp2(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) <3 x float> {{.*}}test_exp2_uint3 -// CHECK: [[EXP2:%.*]] = call reassoc nnan ninf nsz arcp afn <3 x float> @llvm.exp2.v3f32 -// CHECK: ret <3 x float> [[EXP2]] +// CHECK: define [[FNATTRS]] <3 x float> @_Z15test_exp2_uint3Dv3_j( +// CHECK: [[CONVI:%.*]] = uitofp <3 x i32> %{{.*}} to <3 x float> +// CHECK: [[V2:%.*]] = call {{.*}} <3 x float> @llvm.exp2.v3f32(<3 x float> [[CONVI]]) +// CHECK: ret <3 x float> [[V2]] float3 test_exp2_uint3(uint3 p0) { return exp2(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) <4 x float> {{.*}}test_exp2_uint4 -// CHECK: [[EXP2:%.*]] = call reassoc nnan ninf nsz arcp afn <4 x float> @llvm.exp2.v4f32 -// CHECK: ret <4 x float> [[EXP2]] +// CHECK: define [[FNATTRS]] <4 x float> @_Z15test_exp2_uint4Dv4_j( +// CHECK: [[CONVI:%.*]] = uitofp <4 x i32> %{{.*}} to <4 x float> +// CHECK: [[V2:%.*]] = call {{.*}} <4 x float> @llvm.exp2.v4f32(<4 x float> [[CONVI]]) +// CHECK: ret <4 x float> [[V2]] float4 test_exp2_uint4(uint4 p0) { return exp2(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) float {{.*}}test_exp2_int64_t -// CHECK: [[EXP2:%.*]] = call reassoc nnan ninf nsz arcp afn float @llvm.exp2.f32( -// CHECK: ret float [[EXP2]] +// CHECK: define [[FNATTRS]] float @_Z17test_exp2_int64_tl( +// CHECK: [[CONVI:%.*]] = sitofp i64 %{{.*}} to float +// CHECK: [[V2:%.*]] = call {{.*}} float @llvm.exp2.f32(float [[CONVI]]) +// CHECK: ret float [[V2]] float test_exp2_int64_t(int64_t p0) { return exp2(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) <2 x float> {{.*}}test_exp2_int64_t2 -// CHECK: [[EXP2:%.*]] = call reassoc nnan ninf nsz arcp afn <2 x float> @llvm.exp2.v2f32 -// CHECK: ret <2 x float> [[EXP2]] +// CHECK: define [[FNATTRS]] <2 x float> @_Z18test_exp2_int64_t2Dv2_l( +// CHECK: [[CONVI:%.*]] = sitofp <2 x i64> %{{.*}} to <2 x float> +// CHECK: [[V2:%.*]] = call {{.*}} <2 x float> @llvm.exp2.v2f32(<2 x float> [[CONVI]]) +// CHECK: ret <2 x float> [[V2]] float2 test_exp2_int64_t2(int64_t2 p0) { return exp2(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) <3 x float> {{.*}}test_exp2_int64_t3 -// CHECK: [[EXP2:%.*]] = call reassoc nnan ninf nsz arcp afn <3 x float> @llvm.exp2.v3f32 -// CHECK: ret <3 x float> [[EXP2]] +// CHECK: define [[FNATTRS]] <3 x float> @_Z18test_exp2_int64_t3Dv3_l( +// CHECK: [[CONVI:%.*]] = sitofp <3 x i64> %{{.*}} to <3 x float> +// CHECK: [[V2:%.*]] = call {{.*}} <3 x float> @llvm.exp2.v3f32(<3 x float> [[CONVI]]) +// CHECK: ret <3 x float> [[V2]] float3 test_exp2_int64_t3(int64_t3 p0) { return exp2(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) <4 x float> {{.*}}test_exp2_int64_t4 -// CHECK: [[EXP2:%.*]] = call reassoc nnan ninf nsz arcp afn <4 x float> @llvm.exp2.v4f32 -// CHECK: ret <4 x float> [[EXP2]] +// CHECK: define [[FNATTRS]] <4 x float> @_Z18test_exp2_int64_t4Dv4_l( +// CHECK: [[CONVI:%.*]] = sitofp <4 x i64> %{{.*}} to <4 x float> +// CHECK: [[V2:%.*]] = call {{.*}} <4 x float> @llvm.exp2.v4f32(<4 x float> [[CONVI]]) +// CHECK: ret <4 x float> [[V2]] float4 test_exp2_int64_t4(int64_t4 p0) { return exp2(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) float {{.*}}test_exp2_uint64_t -// CHECK: [[EXP2:%.*]] = call reassoc nnan ninf nsz arcp afn float @llvm.exp2.f32( -// CHECK: ret float [[EXP2]] +// CHECK: define [[FNATTRS]] float @_Z18test_exp2_uint64_tm( +// CHECK: [[CONVI:%.*]] = uitofp i64 %{{.*}} to float +// CHECK: [[V2:%.*]] = call {{.*}} float @llvm.exp2.f32(float [[CONVI]]) +// CHECK: ret float [[V2]] float test_exp2_uint64_t(uint64_t p0) { return exp2(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) <2 x float> {{.*}}test_exp2_uint64_t2 -// CHECK: [[EXP2:%.*]] = call reassoc nnan ninf nsz arcp afn <2 x float> @llvm.exp2.v2f32 -// CHECK: ret <2 x float> [[EXP2]] +// CHECK: define [[FNATTRS]] <2 x float> @_Z19test_exp2_uint64_t2Dv2_m( +// CHECK: [[CONVI:%.*]] = uitofp <2 x i64> %{{.*}} to <2 x float> +// CHECK: [[V2:%.*]] = call {{.*}} <2 x float> @llvm.exp2.v2f32(<2 x float> [[CONVI]]) +// CHECK: ret <2 x float> [[V2]] float2 test_exp2_uint64_t2(uint64_t2 p0) { return exp2(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) <3 x float> {{.*}}test_exp2_uint64_t3 -// CHECK: [[EXP2:%.*]] = call reassoc nnan ninf nsz arcp afn <3 x float> @llvm.exp2.v3f32 -// CHECK: ret <3 x float> [[EXP2]] +// CHECK: define [[FNATTRS]] <3 x float> @_Z19test_exp2_uint64_t3Dv3_m( +// CHECK: [[CONVI:%.*]] = uitofp <3 x i64> %{{.*}} to <3 x float> +// CHECK: [[V2:%.*]] = call {{.*}} <3 x float> @llvm.exp2.v3f32(<3 x float> [[CONVI]]) +// CHECK: ret <3 x float> [[V2]] float3 test_exp2_uint64_t3(uint64_t3 p0) { return exp2(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) <4 x float> {{.*}}test_exp2_uint64_t4 -// CHECK: [[EXP2:%.*]] = call reassoc nnan ninf nsz arcp afn <4 x float> @llvm.exp2.v4f32 -// CHECK: ret <4 x float> [[EXP2]] +// CHECK: define [[FNATTRS]] <4 x float> @_Z19test_exp2_uint64_t4Dv4_m( +// CHECK: [[CONVI:%.*]] = uitofp <4 x i64> %{{.*}} to <4 x float> +// CHECK: [[V2:%.*]] = call {{.*}} <4 x float> @llvm.exp2.v4f32(<4 x float> [[CONVI]]) +// CHECK: ret <4 x float> [[V2]] float4 test_exp2_uint64_t4(uint64_t4 p0) { return exp2(p0); } diff --git a/clang/test/CodeGenHLSL/builtins/log10-overloads.hlsl b/clang/test/CodeGenHLSL/builtins/log10-overloads.hlsl index e408f4a5d45ce..37e351a69e1b6 100644 --- a/clang/test/CodeGenHLSL/builtins/log10-overloads.hlsl +++ b/clang/test/CodeGenHLSL/builtins/log10-overloads.hlsl @@ -1,68 +1,108 @@ // RUN: %clang_cc1 -std=hlsl202x -finclude-default-header -triple dxil-pc-shadermodel6.3-library %s \ -// RUN: -emit-llvm -disable-llvm-passes -o - | \ -// RUN: FileCheck %s --check-prefixes=CHECK +// RUN: -emit-llvm -o - | \ +// RUN: FileCheck %s --check-prefixes=CHECK -DFNATTRS="hidden noundef nofpclass(nan inf)" -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) float {{.*}}test_log10_double -// CHECK: call reassoc nnan ninf nsz arcp afn float @llvm.log10.f32( +// CHECK: define [[FNATTRS]] float @_Z17test_log10_doubled( +// CHECK: [[CONVI:%.*]] = fptrunc {{.*}} double %{{.*}} to float +// CHECK: [[V2:%.*]] = call {{.*}} float @llvm.log10.f32(float [[CONVI]]) +// CHECK: ret float [[V2]] float test_log10_double(double p0) { return log10(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) <2 x float> {{.*}}test_log10_double2 -// CHECK: call reassoc nnan ninf nsz arcp afn <2 x float> @llvm.log10.v2f32 +// CHECK: define [[FNATTRS]] <2 x float> @_Z18test_log10_double2Dv2_d( +// CHECK: [[CONVI:%.*]] = fptrunc {{.*}} <2 x double> %{{.*}} to <2 x float> +// CHECK: [[V2:%.*]] = call {{.*}} <2 x float> @llvm.log10.v2f32(<2 x float> [[CONVI]]) +// CHECK: ret <2 x float> [[V2]] float2 test_log10_double2(double2 p0) { return log10(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) <3 x float> {{.*}}test_log10_double3 -// CHECK: call reassoc nnan ninf nsz arcp afn <3 x float> @llvm.log10.v3f32 +// CHECK: define [[FNATTRS]] <3 x float> @_Z18test_log10_double3Dv3_d( +// CHECK: [[CONVI:%.*]] = fptrunc {{.*}} <3 x double> %{{.*}} to <3 x float> +// CHECK: [[V2:%.*]] = call {{.*}} <3 x float> @llvm.log10.v3f32(<3 x float> [[CONVI]]) +// CHECK: ret <3 x float> [[V2]] float3 test_log10_double3(double3 p0) { return log10(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) <4 x float> {{.*}}test_log10_double4 -// CHECK: call reassoc nnan ninf nsz arcp afn <4 x float> @llvm.log10.v4f32 +// CHECK: define [[FNATTRS]] <4 x float> @_Z18test_log10_double4Dv4_d( +// CHECK: [[CONVI:%.*]] = fptrunc {{.*}} <4 x double> %{{.*}} to <4 x float> +// CHECK: [[V2:%.*]] = call {{.*}} <4 x float> @llvm.log10.v4f32(<4 x float> [[CONVI]]) +// CHECK: ret <4 x float> [[V2]] float4 test_log10_double4(double4 p0) { return log10(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) float {{.*}}test_log10_int -// CHECK: call reassoc nnan ninf nsz arcp afn float @llvm.log10.f32( +// CHECK: define [[FNATTRS]] float @_Z14test_log10_inti( +// CHECK: [[CONVI:%.*]] = sitofp i32 %{{.*}} to float +// CHECK: [[V2:%.*]] = call {{.*}} float @llvm.log10.f32(float [[CONVI]]) +// CHECK: ret float [[V2]] float test_log10_int(int p0) { return log10(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) <2 x float> {{.*}}test_log10_int2 -// CHECK: call reassoc nnan ninf nsz arcp afn <2 x float> @llvm.log10.v2f32 +// CHECK: define [[FNATTRS]] <2 x float> @_Z15test_log10_int2Dv2_i( +// CHECK: [[CONVI:%.*]] = sitofp <2 x i32> %{{.*}} to <2 x float> +// CHECK: [[V2:%.*]] = call {{.*}} <2 x float> @llvm.log10.v2f32(<2 x float> [[CONVI]]) +// CHECK: ret <2 x float> [[V2]] float2 test_log10_int2(int2 p0) { return log10(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) <3 x float> {{.*}}test_log10_int3 -// CHECK: call reassoc nnan ninf nsz arcp afn <3 x float> @llvm.log10.v3f32 +// CHECK: define [[FNATTRS]] <3 x float> @_Z15test_log10_int3Dv3_i( +// CHECK: [[CONVI:%.*]] = sitofp <3 x i32> %{{.*}} to <3 x float> +// CHECK: [[V2:%.*]] = call {{.*}} <3 x float> @llvm.log10.v3f32(<3 x float> [[CONVI]]) +// CHECK: ret <3 x float> [[V2]] float3 test_log10_int3(int3 p0) { return log10(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) <4 x float> {{.*}}test_log10_int4 -// CHECK: call reassoc nnan ninf nsz arcp afn <4 x float> @llvm.log10.v4f32 +// CHECK: define [[FNATTRS]] <4 x float> @_Z15test_log10_int4Dv4_i( +// CHECK: [[CONVI:%.*]] = sitofp <4 x i32> %{{.*}} to <4 x float> +// CHECK: [[V2:%.*]] = call {{.*}} <4 x float> @llvm.log10.v4f32(<4 x float> [[CONVI]]) +// CHECK: ret <4 x float> [[V2]] float4 test_log10_int4(int4 p0) { return log10(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) float {{.*}}test_log10_uint -// CHECK: call reassoc nnan ninf nsz arcp afn float @llvm.log10.f32( +// CHECK: define [[FNATTRS]] float @_Z15test_log10_uintj( +// CHECK: [[CONVI:%.*]] = uitofp i32 %{{.*}} to float +// CHECK: [[V2:%.*]] = call {{.*}} float @llvm.log10.f32(float [[CONVI]]) +// CHECK: ret float [[V2]] float test_log10_uint(uint p0) { return log10(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) <2 x float> {{.*}}test_log10_uint2 -// CHECK: call reassoc nnan ninf nsz arcp afn <2 x float> @llvm.log10.v2f32 +// CHECK: define [[FNATTRS]] <2 x float> @_Z16test_log10_uint2Dv2_j( +// CHECK: [[CONVI:%.*]] = uitofp <2 x i32> %{{.*}} to <2 x float> +// CHECK: [[V2:%.*]] = call {{.*}} <2 x float> @llvm.log10.v2f32(<2 x float> [[CONVI]]) +// CHECK: ret <2 x float> [[V2]] float2 test_log10_uint2(uint2 p0) { return log10(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) <3 x float> {{.*}}test_log10_uint3 -// CHECK: call reassoc nnan ninf nsz arcp afn <3 x float> @llvm.log10.v3f32 +// CHECK: define [[FNATTRS]] <3 x float> @_Z16test_log10_uint3Dv3_j( +// CHECK: [[CONVI:%.*]] = uitofp <3 x i32> %{{.*}} to <3 x float> +// CHECK: [[V2:%.*]] = call {{.*}} <3 x float> @llvm.log10.v3f32(<3 x float> [[CONVI]]) +// CHECK: ret <3 x float> [[V2]] float3 test_log10_uint3(uint3 p0) { return log10(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) <4 x float> {{.*}}test_log10_uint4 -// CHECK: call reassoc nnan ninf nsz arcp afn <4 x float> @llvm.log10.v4f32 +// CHECK: define [[FNATTRS]] <4 x float> @_Z16test_log10_uint4Dv4_j( +// CHECK: [[CONVI:%.*]] = uitofp <4 x i32> %{{.*}} to <4 x float> +// CHECK: [[V2:%.*]] = call {{.*}} <4 x float> @llvm.log10.v4f32(<4 x float> [[CONVI]]) +// CHECK: ret <4 x float> [[V2]] float4 test_log10_uint4(uint4 p0) { return log10(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) float {{.*}}test_log10_int64_t -// CHECK: call reassoc nnan ninf nsz arcp afn float @llvm.log10.f32( +// CHECK: define [[FNATTRS]] float @_Z18test_log10_int64_tl( +// CHECK: [[CONVI:%.*]] = sitofp i64 %{{.*}} to float +// CHECK: [[V2:%.*]] = call {{.*}} float @llvm.log10.f32(float [[CONVI]]) +// CHECK: ret float [[V2]] float test_log10_int64_t(int64_t p0) { return log10(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) <2 x float> {{.*}}test_log10_int64_t2 -// CHECK: call reassoc nnan ninf nsz arcp afn <2 x float> @llvm.log10.v2f32 +// CHECK: define [[FNATTRS]] <2 x float> @_Z19test_log10_int64_t2Dv2_l( +// CHECK: [[CONVI:%.*]] = sitofp <2 x i64> %{{.*}} to <2 x float> +// CHECK: [[V2:%.*]] = call {{.*}} <2 x float> @llvm.log10.v2f32(<2 x float> [[CONVI]]) +// CHECK: ret <2 x float> [[V2]] float2 test_log10_int64_t2(int64_t2 p0) { return log10(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) <3 x float> {{.*}}test_log10_int64_t3 -// CHECK: call reassoc nnan ninf nsz arcp afn <3 x float> @llvm.log10.v3f32 +// CHECK: define [[FNATTRS]] <3 x float> @_Z19test_log10_int64_t3Dv3_l( +// CHECK: [[CONVI:%.*]] = sitofp <3 x i64> %{{.*}} to <3 x float> +// CHECK: [[V2:%.*]] = call {{.*}} <3 x float> @llvm.log10.v3f32(<3 x float> [[CONVI]]) +// CHECK: ret <3 x float> [[V2]] float3 test_log10_int64_t3(int64_t3 p0) { return log10(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) <4 x float> {{.*}}test_log10_int64_t4 -// CHECK: call reassoc nnan ninf nsz arcp afn <4 x float> @llvm.log10.v4f32 +// CHECK: define [[FNATTRS]] <4 x float> @_Z19test_log10_int64_t4Dv4_l( +// CHECK: [[CONVI:%.*]] = sitofp <4 x i64> %{{.*}} to <4 x float> +// CHECK: [[V2:%.*]] = call {{.*}} <4 x float> @llvm.log10.v4f32(<4 x float> [[CONVI]]) +// CHECK: ret <4 x float> [[V2]] float4 test_log10_int64_t4(int64_t4 p0) { return log10(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) float {{.*}}test_log10_uint64_t -// CHECK: call reassoc nnan ninf nsz arcp afn float @llvm.log10.f32( +// CHECK: define [[FNATTRS]] float @_Z19test_log10_uint64_tm( +// CHECK: [[CONVI:%.*]] = uitofp i64 %{{.*}} to float +// CHECK: [[V2:%.*]] = call {{.*}} float @llvm.log10.f32(float [[CONVI]]) +// CHECK: ret float [[V2]] float test_log10_uint64_t(uint64_t p0) { return log10(p0); } -// CHECK-LABEL: define hidden noundef nofpclass(nan inf) <2 x float> {{.*}}test_log10_uint64_t2 -// CHECK: call reassoc nnan ninf nsz arcp afn <2 x float> @llvm.log10.v2f32 +// CHECK: define [[FNATTRS]] <2 x float> @_Z20test_log10_uint64_t2Dv2_m( +// CHECK: [[CONVI:%.*]] = uitofp <2 x i64> %{{.*}... [truncated] `````````` </details> https://github.com/llvm/llvm-project/pull/177495 _______________________________________________ cfe-commits mailing list [email protected] https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits
