llvmbot wrote:
<!--LLVM PR SUMMARY COMMENT--> @llvm/pr-subscribers-hlsl @llvm/pr-subscribers-clang Author: Farzon Lotfi (farzonl) <details> <summary>Changes</summary> This PR brings best practices mentioned to me on other prs and adds them to the existing builtin tests. Note to reviewers: I put this up in two commits because the clang-format changes is making it hard to tell what actually changed. use the first commit to check for correctness. --- Patch is 66.50 KiB, truncated to 20.00 KiB below, full version: https://github.com/llvm/llvm-project/pull/83340.diff 13 Files Affected: - (modified) clang/test/CodeGenHLSL/builtins/abs.hlsl (+43-91) - (modified) clang/test/CodeGenHLSL/builtins/ceil.hlsl (+23-46) - (modified) clang/test/CodeGenHLSL/builtins/cos.hlsl (+27-42) - (modified) clang/test/CodeGenHLSL/builtins/floor.hlsl (+23-46) - (modified) clang/test/CodeGenHLSL/builtins/log.hlsl (+26-41) - (modified) clang/test/CodeGenHLSL/builtins/log10.hlsl (+27-42) - (modified) clang/test/CodeGenHLSL/builtins/log2.hlsl (+27-42) - (modified) clang/test/CodeGenHLSL/builtins/max.hlsl (+71-143) - (modified) clang/test/CodeGenHLSL/builtins/min.hlsl (+67-140) - (modified) clang/test/CodeGenHLSL/builtins/pow.hlsl (+31-66) - (modified) clang/test/CodeGenHLSL/builtins/sin.hlsl (+22-37) - (modified) clang/test/CodeGenHLSL/builtins/trunc.hlsl (+33-42) - (modified) clang/test/SemaHLSL/VectorOverloadResolution.hlsl (+1-1) ``````````diff diff --git a/clang/test/CodeGenHLSL/builtins/abs.hlsl b/clang/test/CodeGenHLSL/builtins/abs.hlsl index 54c9d1a9dded45..ad65cab2721a2b 100644 --- a/clang/test/CodeGenHLSL/builtins/abs.hlsl +++ b/clang/test/CodeGenHLSL/builtins/abs.hlsl @@ -1,141 +1,93 @@ // RUN: %clang_cc1 -std=hlsl2021 -finclude-default-header -x hlsl -triple \ // RUN: dxil-pc-shadermodel6.3-library %s -fnative-half-type \ -// RUN: -emit-llvm -disable-llvm-passes -O3 -o - | FileCheck %s +// RUN: -emit-llvm -disable-llvm-passes -o - | FileCheck %s \ +// RUN: --check-prefixes=CHECK,NATIVE_HALF // RUN: %clang_cc1 -std=hlsl2021 -finclude-default-header -x hlsl -triple \ // RUN: dxil-pc-shadermodel6.3-library %s -emit-llvm -disable-llvm-passes \ -// RUN: -o - | FileCheck %s --check-prefix=NO_HALF +// RUN: -o - | FileCheck %s --check-prefixes=CHECK,NO_HALF using hlsl::abs; #ifdef __HLSL_ENABLE_16_BIT -// CHECK: define noundef i16 @ -// CHECK: call i16 @llvm.abs.i16( -int16_t test_abs_int16_t ( int16_t p0 ) { - return abs ( p0 ); -} -// CHECK: define noundef <2 x i16> @ -// CHECK: call <2 x i16> @llvm.abs.v2i16( -int16_t2 test_abs_int16_t2 ( int16_t2 p0 ) { - return abs ( p0 ); -} -// CHECK: define noundef <3 x i16> @ -// CHECK: call <3 x i16> @llvm.abs.v3i16( -int16_t3 test_abs_int16_t3 ( int16_t3 p0 ) { - return abs ( p0 ); -} -// CHECK: define noundef <4 x i16> @ -// CHECK: call <4 x i16> @llvm.abs.v4i16( -int16_t4 test_abs_int16_t4 ( int16_t4 p0 ) { - return abs ( p0 ); -} +// NATIVE_HALF: define noundef i16 @ +// NATIVE_HALF: call i16 @llvm.abs.i16( +int16_t test_abs_int16_t(int16_t p0) { return abs(p0); } +// NATIVE_HALF: define noundef <2 x i16> @ +// NATIVE_HALF: call <2 x i16> @llvm.abs.v2i16( +int16_t2 test_abs_int16_t2(int16_t2 p0) { return abs(p0); } +// NATIVE_HALF: define noundef <3 x i16> @ +// NATIVE_HALF: call <3 x i16> @llvm.abs.v3i16( +int16_t3 test_abs_int16_t3(int16_t3 p0) { return abs(p0); } +// NATIVE_HALF: define noundef <4 x i16> @ +// NATIVE_HALF: call <4 x i16> @llvm.abs.v4i16( +int16_t4 test_abs_int16_t4(int16_t4 p0) { return abs(p0); } #endif // __HLSL_ENABLE_16_BIT -// CHECK: define noundef half @ -// CHECK: call half @llvm.fabs.f16( +// NATIVE_HALF: define noundef half @ +// NATIVE_HALF: call half @llvm.fabs.f16( // NO_HALF: define noundef float @"?test_abs_half@@YA$halff@$halff@@Z"( // NO_HALF: call float @llvm.fabs.f32(float %0) -half test_abs_half ( half p0 ) { - return abs ( p0 ); -} -// CHECK: define noundef <2 x half> @ -// CHECK: call <2 x half> @llvm.fabs.v2f16( +half test_abs_half(half p0) { return abs(p0); } +// NATIVE_HALF: define noundef <2 x half> @ +// NATIVE_HALF: call <2 x half> @llvm.fabs.v2f16( // NO_HALF: define noundef <2 x float> @"?test_abs_half2@@YAT?$__vector@$halff@$01@__clang@@T12@@Z"( // NO_HALF: call <2 x float> @llvm.fabs.v2f32( -half2 test_abs_half2 ( half2 p0 ) { - return abs ( p0 ); -} -// CHECK: define noundef <3 x half> @ -// CHECK: call <3 x half> @llvm.fabs.v3f16( +half2 test_abs_half2(half2 p0) { return abs(p0); } +// NATIVE_HALF: define noundef <3 x half> @ +// NATIVE_HALF: call <3 x half> @llvm.fabs.v3f16( // NO_HALF: define noundef <3 x float> @"?test_abs_half3@@YAT?$__vector@$halff@$02@__clang@@T12@@Z"( // NO_HALF: call <3 x float> @llvm.fabs.v3f32( -half3 test_abs_half3 ( half3 p0 ) { - return abs ( p0 ); -} -// CHECK: define noundef <4 x half> @ -// CHECK: call <4 x half> @llvm.fabs.v4f16( +half3 test_abs_half3(half3 p0) { return abs(p0); } +// NATIVE_HALF: define noundef <4 x half> @ +// NATIVE_HALF: call <4 x half> @llvm.fabs.v4f16( // NO_HALF: define noundef <4 x float> @"?test_abs_half4@@YAT?$__vector@$halff@$03@__clang@@T12@@Z"( // NO_HALF: call <4 x float> @llvm.fabs.v4f32( -half4 test_abs_half4 ( half4 p0 ) { - return abs ( p0 ); -} +half4 test_abs_half4(half4 p0) { return abs(p0); } // CHECK: define noundef i32 @ // CHECK: call i32 @llvm.abs.i32( -// NO_HALF: define noundef i32 @"?test_abs_int@@YAHH@Z" -int test_abs_int ( int p0 ) { - return abs ( p0 ); -} +int test_abs_int(int p0) { return abs(p0); } // CHECK: define noundef <2 x i32> @ // CHECK: call <2 x i32> @llvm.abs.v2i32( -int2 test_abs_int2 ( int2 p0 ) { - return abs ( p0 ); -} +int2 test_abs_int2(int2 p0) { return abs(p0); } // CHECK: define noundef <3 x i32> @ // CHECK: call <3 x i32> @llvm.abs.v3i32( -int3 test_abs_int3 ( int3 p0 ) { - return abs ( p0 ); -} +int3 test_abs_int3(int3 p0) { return abs(p0); } // CHECK: define noundef <4 x i32> @ // CHECK: call <4 x i32> @llvm.abs.v4i32( -int4 test_abs_int4 ( int4 p0 ) { - return abs ( p0 ); -} +int4 test_abs_int4(int4 p0) { return abs(p0); } // CHECK: define noundef float @ // CHECK: call float @llvm.fabs.f32( -float test_abs_float ( float p0 ) { - return abs ( p0 ); -} +float test_abs_float(float p0) { return abs(p0); } // CHECK: define noundef <2 x float> @ // CHECK: call <2 x float> @llvm.fabs.v2f32( -float2 test_abs_float2 ( float2 p0 ) { - return abs ( p0 ); -} +float2 test_abs_float2(float2 p0) { return abs(p0); } // CHECK: define noundef <3 x float> @ // CHECK: call <3 x float> @llvm.fabs.v3f32( -float3 test_abs_float3 ( float3 p0 ) { - return abs ( p0 ); -} +float3 test_abs_float3(float3 p0) { return abs(p0); } // CHECK: define noundef <4 x float> @ // CHECK: call <4 x float> @llvm.fabs.v4f32( -float4 test_abs_float4 ( float4 p0 ) { - return abs ( p0 ); -} +float4 test_abs_float4(float4 p0) { return abs(p0); } // CHECK: define noundef i64 @ // CHECK: call i64 @llvm.abs.i64( -int64_t test_abs_int64_t ( int64_t p0 ) { - return abs ( p0 ); -} +int64_t test_abs_int64_t(int64_t p0) { return abs(p0); } // CHECK: define noundef <2 x i64> @ // CHECK: call <2 x i64> @llvm.abs.v2i64( -int64_t2 test_abs_int64_t2 ( int64_t2 p0 ) { - return abs ( p0 ); -} +int64_t2 test_abs_int64_t2(int64_t2 p0) { return abs(p0); } // CHECK: define noundef <3 x i64> @ // CHECK: call <3 x i64> @llvm.abs.v3i64( -int64_t3 test_abs_int64_t3 ( int64_t3 p0 ) { - return abs ( p0 ); -} +int64_t3 test_abs_int64_t3(int64_t3 p0) { return abs(p0); } // CHECK: define noundef <4 x i64> @ // CHECK: call <4 x i64> @llvm.abs.v4i64( -int64_t4 test_abs_int64_t4 ( int64_t4 p0 ) { - return abs ( p0 ); -} +int64_t4 test_abs_int64_t4(int64_t4 p0) { return abs(p0); } // CHECK: define noundef double @ // CHECK: call double @llvm.fabs.f64( -double test_abs_double ( double p0 ) { - return abs ( p0 ); -} +double test_abs_double(double p0) { return abs(p0); } // CHECK: define noundef <2 x double> @ // CHECK: call <2 x double> @llvm.fabs.v2f64( -double2 test_abs_double2 ( double2 p0 ) { - return abs ( p0 ); -} +double2 test_abs_double2(double2 p0) { return abs(p0); } // CHECK: define noundef <3 x double> @ // CHECK: call <3 x double> @llvm.fabs.v3f64( -double3 test_abs_double3 ( double3 p0 ) { - return abs ( p0 ); -} +double3 test_abs_double3(double3 p0) { return abs(p0); } // CHECK: define noundef <4 x double> @ // CHECK: call <4 x double> @llvm.fabs.v4f64( -double4 test_abs_double4 ( double4 p0 ) { - return abs ( p0 ); -} +double4 test_abs_double4(double4 p0) { return abs(p0); } diff --git a/clang/test/CodeGenHLSL/builtins/ceil.hlsl b/clang/test/CodeGenHLSL/builtins/ceil.hlsl index f1672816e72bc2..06d0d4c2cf546d 100644 --- a/clang/test/CodeGenHLSL/builtins/ceil.hlsl +++ b/clang/test/CodeGenHLSL/builtins/ceil.hlsl @@ -1,79 +1,56 @@ // RUN: %clang_cc1 -std=hlsl2021 -finclude-default-header -x hlsl -triple \ // RUN: dxil-pc-shadermodel6.3-library %s -fnative-half-type \ -// RUN: -emit-llvm -disable-llvm-passes -O3 -o - | FileCheck %s +// RUN: -emit-llvm -disable-llvm-passes -o - | FileCheck %s \ +// RUN: --check-prefixes=CHECK,NATIVE_HALF // RUN: %clang_cc1 -std=hlsl2021 -finclude-default-header -x hlsl -triple \ // RUN: dxil-pc-shadermodel6.3-library %s -emit-llvm -disable-llvm-passes \ -// RUN: -o - | FileCheck %s --check-prefix=NO_HALF +// RUN: -o - | FileCheck %s --check-prefixes=CHECK,NO_HALF using hlsl::ceil; -// CHECK: define noundef half @ -// CHECK: call half @llvm.ceil.f16( +// NATIVE_HALF: define noundef half @ +// NATIVE_HALF: call half @llvm.ceil.f16( // NO_HALF: define noundef float @"?test_ceil_half@@YA$halff@$halff@@Z"( // NO_HALF: call float @llvm.ceil.f32(float %0) -half test_ceil_half ( half p0 ) { - return ceil ( p0 ); -} -// CHECK: define noundef <2 x half> @ -// CHECK: call <2 x half> @llvm.ceil.v2f16( +half test_ceil_half(half p0) { return ceil(p0); } +// NATIVE_HALF: define noundef <2 x half> @ +// NATIVE_HALF: call <2 x half> @llvm.ceil.v2f16( // NO_HALF: define noundef <2 x float> @"?test_ceil_half2@@YAT?$__vector@$halff@$01@__clang@@T12@@Z"( // NO_HALF: call <2 x float> @llvm.ceil.v2f32( -half2 test_ceil_half2 ( half2 p0 ) { - return ceil ( p0 ); -} -// CHECK: define noundef <3 x half> @ -// CHECK: call <3 x half> @llvm.ceil.v3f16( +half2 test_ceil_half2(half2 p0) { return ceil(p0); } +// NATIVE_HALF: define noundef <3 x half> @ +// NATIVE_HALF: call <3 x half> @llvm.ceil.v3f16( // NO_HALF: define noundef <3 x float> @"?test_ceil_half3@@YAT?$__vector@$halff@$02@__clang@@T12@@Z"( // NO_HALF: call <3 x float> @llvm.ceil.v3f32( -half3 test_ceil_half3 ( half3 p0 ) { - return ceil ( p0 ); -} -// CHECK: define noundef <4 x half> @ -// CHECK: call <4 x half> @llvm.ceil.v4f16( +half3 test_ceil_half3(half3 p0) { return ceil(p0); } +// NATIVE_HALF: define noundef <4 x half> @ +// NATIVE_HALF: call <4 x half> @llvm.ceil.v4f16( // NO_HALF: define noundef <4 x float> @"?test_ceil_half4@@YAT?$__vector@$halff@$03@__clang@@T12@@Z"( // NO_HALF: call <4 x float> @llvm.ceil.v4f32( -half4 test_ceil_half4 ( half4 p0 ) { - return ceil ( p0 ); -} +half4 test_ceil_half4(half4 p0) { return ceil(p0); } // CHECK: define noundef float @ // CHECK: call float @llvm.ceil.f32( -float test_ceil_float ( float p0 ) { - return ceil ( p0 ); -} +float test_ceil_float(float p0) { return ceil(p0); } // CHECK: define noundef <2 x float> @ // CHECK: call <2 x float> @llvm.ceil.v2f32( -float2 test_ceil_float2 ( float2 p0 ) { - return ceil ( p0 ); -} +float2 test_ceil_float2(float2 p0) { return ceil(p0); } // CHECK: define noundef <3 x float> @ // CHECK: call <3 x float> @llvm.ceil.v3f32( -float3 test_ceil_float3 ( float3 p0 ) { - return ceil ( p0 ); -} +float3 test_ceil_float3(float3 p0) { return ceil(p0); } // CHECK: define noundef <4 x float> @ // CHECK: call <4 x float> @llvm.ceil.v4f32( -float4 test_ceil_float4 ( float4 p0 ) { - return ceil ( p0 ); -} +float4 test_ceil_float4(float4 p0) { return ceil(p0); } // CHECK: define noundef double @ // CHECK: call double @llvm.ceil.f64( -double test_ceil_double ( double p0 ) { - return ceil ( p0 ); -} +double test_ceil_double(double p0) { return ceil(p0); } // CHECK: define noundef <2 x double> @ // CHECK: call <2 x double> @llvm.ceil.v2f64( -double2 test_ceil_double2 ( double2 p0 ) { - return ceil ( p0 ); -} +double2 test_ceil_double2(double2 p0) { return ceil(p0); } // CHECK: define noundef <3 x double> @ // CHECK: call <3 x double> @llvm.ceil.v3f64( -double3 test_ceil_double3 ( double3 p0 ) { - return ceil ( p0 ); -} +double3 test_ceil_double3(double3 p0) { return ceil(p0); } // CHECK: define noundef <4 x double> @ // CHECK: call <4 x double> @llvm.ceil.v4f64( -double4 test_ceil_double4 ( double4 p0 ) { - return ceil ( p0 ); -} +double4 test_ceil_double4(double4 p0) { return ceil(p0); } diff --git a/clang/test/CodeGenHLSL/builtins/cos.hlsl b/clang/test/CodeGenHLSL/builtins/cos.hlsl index 2fc1571949b2c5..fb416fcaa49d76 100644 --- a/clang/test/CodeGenHLSL/builtins/cos.hlsl +++ b/clang/test/CodeGenHLSL/builtins/cos.hlsl @@ -1,56 +1,41 @@ // RUN: %clang_cc1 -std=hlsl2021 -finclude-default-header -x hlsl -triple \ // RUN: dxil-pc-shadermodel6.3-library %s -fnative-half-type \ -// RUN: -emit-llvm -disable-llvm-passes -O3 -o - | FileCheck %s +// RUN: -emit-llvm -disable-llvm-passes -o - | FileCheck %s \ +// RUN: --check-prefixes=CHECK,NATIVE_HALF // RUN: %clang_cc1 -std=hlsl2021 -finclude-default-header -x hlsl -triple \ // RUN: dxil-pc-shadermodel6.3-library %s -emit-llvm -disable-llvm-passes \ -// RUN: -o - | FileCheck %s --check-prefix=NO_HALF +// RUN: -o - | FileCheck %s --check-prefixes=CHECK,NO_HALF -// CHECK: define noundef half @ -// CHECK: call half @llvm.cos.f16( -// NO_HALF: define noundef float @"?test_cos_half@@YA$halff@$halff@@Z"( +// NATIVE_HALF: define noundef half @ +// NATIVE_HALF: call half @llvm.cos.f16( +// NO_HALF: define noundef float @"?test_cos_half // NO_HALF: call float @llvm.cos.f32( -half test_cos_half ( half p0 ) { - return cos ( p0 ); -} -// CHECK: define noundef <2 x half> @ -// CHECK: call <2 x half> @llvm.cos.v2f16 -// NO_HALF: define noundef <2 x float> @"?test_cos_float2@@YAT?$__vector@M$01@__clang@@T12@@Z"( +half test_cos_half(half p0) { return cos(p0); } +// NATIVE_HALF: define noundef <2 x half> @ +// NATIVE_HALF: call <2 x half> @llvm.cos.v2f16 +// NO_HALF: define noundef <2 x float> @"?test_cos_half2 // NO_HALF: call <2 x float> @llvm.cos.v2f32( -half2 test_cos_half2 ( half2 p0 ) { - return cos ( p0 ); -} -// CHECK: define noundef <3 x half> @ -// CHECK: call <3 x half> @llvm.cos.v3f16 -// NO_HALF: define noundef <3 x float> @"?test_cos_float3@@YAT?$__vector@M$02@__clang@@T12@@Z"( +half2 test_cos_half2(half2 p0) { return cos(p0); } +// NATIVE_HALF: define noundef <3 x half> @ +// NATIVE_HALF: call <3 x half> @llvm.cos.v3f16 +// NO_HALF: define noundef <3 x float> @"?test_cos_half3 // NO_HALF: call <3 x float> @llvm.cos.v3f32( -half3 test_cos_half3 ( half3 p0 ) { - return cos ( p0 ); -} -// CHECK: define noundef <4 x half> @ -// CHECK: call <4 x half> @llvm.cos.v4f16 -// NO_HALF: define noundef <4 x float> @"?test_cos_float4@@YAT?$__vector@M$03@__clang@@T12@@Z"( +half3 test_cos_half3(half3 p0) { return cos(p0); } +// NATIVE_HALF: define noundef <4 x half> @ +// NATIVE_HALF: call <4 x half> @llvm.cos.v4f16 +// NO_HALF: define noundef <4 x float> @"?test_cos_half4 // NO_HALF: call <4 x float> @llvm.cos.v4f32( -half4 test_cos_half4 ( half4 p0 ) { - return cos ( p0 ); -} +half4 test_cos_half4(half4 p0) { return cos(p0); } -// CHECK: define noundef float @ +// CHECK: define noundef float @"?test_cos_float // CHECK: call float @llvm.cos.f32( -float test_cos_float ( float p0 ) { - return cos ( p0 ); -} -// CHECK: define noundef <2 x float> @ +float test_cos_float(float p0) { return cos(p0); } +// CHECK: define noundef <2 x float> @"?test_cos_float2 // CHECK: call <2 x float> @llvm.cos.v2f32 -float2 test_cos_float2 ( float2 p0 ) { - return cos ( p0 ); -} -// CHECK: define noundef <3 x float> @ +float2 test_cos_float2(float2 p0) { return cos(p0); } +// CHECK: define noundef <3 x float> @"?test_cos_float3 // CHECK: call <3 x float> @llvm.cos.v3f32 -float3 test_cos_float3 ( float3 p0 ) { - return cos ( p0 ); -} -// CHECK: define noundef <4 x float> @ +float3 test_cos_float3(float3 p0) { return cos(p0); } +// CHECK: define noundef <4 x float> @"?test_cos_float4 // CHECK: call <4 x float> @llvm.cos.v4f32 -float4 test_cos_float4 ( float4 p0 ) { - return cos ( p0 ); -} +float4 test_cos_float4(float4 p0) { return cos(p0); } diff --git a/clang/test/CodeGenHLSL/builtins/floor.hlsl b/clang/test/CodeGenHLSL/builtins/floor.hlsl index 357661761b762a..d2a2f6e52f1ec3 100644 --- a/clang/test/CodeGenHLSL/builtins/floor.hlsl +++ b/clang/test/CodeGenHLSL/builtins/floor.hlsl @@ -1,79 +1,56 @@ // RUN: %clang_cc1 -std=hlsl2021 -finclude-default-header -x hlsl -triple \ // RUN: dxil-pc-shadermodel6.3-library %s -fnative-half-type \ -// RUN: -emit-llvm -disable-llvm-passes -O3 -o - | FileCheck %s +// RUN: -emit-llvm -disable-llvm-passes -o - | FileCheck %s \ +// RUN: --check-prefixes=CHECK,NATIVE_HALF // RUN: %clang_cc1 -std=hlsl2021 -finclude-default-header -x hlsl -triple \ // RUN: dxil-pc-shadermodel6.3-library %s -emit-llvm -disable-llvm-passes \ -// RUN: -o - | FileCheck %s --check-prefix=NO_HALF +// RUN: -o - | FileCheck %s --check-prefixes=CHECK,NO_HALF using hlsl::floor; -// CHECK: define noundef half @ -// CHECK: call half @llvm.floor.f16( +// NATIVE_HALF: define noundef half @ +// NATIVE_HALF: call half @llvm.floor.f16( // NO_HALF: define noundef float @"?test_floor_half@@YA$halff@$halff@@Z"( // NO_HALF: call float @llvm.floor.f32(float %0) -half test_floor_half ( half p0 ) { - return floor ( p0 ); -} -// CHECK: define noundef <2 x half> @ -// CHECK: call <2 x half> @llvm.floor.v2f16( +half test_floor_half(half p0) { return floor(p0); } +// NATIVE_HALF: define noundef <2 x half> @ +// NATIVE_HALF: call <2 x half> @llvm.floor.v2f16( // NO_HALF: define noundef <2 x float> @"?test_floor_half2@@YAT?$__vector@$halff@$01@__clang@@T12@@Z"( // NO_HALF: call <2 x float> @llvm.floor.v2f32( -half2 test_floor_half2 ( half2 p0 ) { - return floor ( p0 ); -} -// CHECK: define noundef <3 x half> @ -// CHECK: call <3 x half> @llvm.floor.v3f16( +half2 test_floor_half2(half2 p0) { return floor(p0); } +// NATIVE_HALF: define noundef <3 x half> @ +// NATIVE_HALF: call <3 x half> @llvm.floor.v3f16( // NO_HALF: define noundef <3 x float> @"?test_floor_half3@@YAT?$__vector@$halff@$02@__clang@@T12@@Z"( // NO_HALF: call <3 x float> @llvm.floor.v3f32( -half3 test_floor_half3 ( half3 p0 ) { - return floor ( p0 ); -} -// CHECK: define noundef <4 x half> @ -// CHECK: call <4 x half> @llvm.floor.v4f16( +half3 test_floor_half3(half3 p0) { return floor(p0); } +// NATIVE_HALF: define noundef <4 x half> @ +// NATIVE_HALF: call <4 x half> @llvm.floor.v4f16( // NO_HALF: define noundef <4 x float> @"?test_floor_half4@@YAT?$__vector@$halff@$03@__clang@@T12@@Z"( // NO_HALF: call <4 x float> @llvm.floor.v4f32( -half4 test_floor_half4 ( half4 p0 ) { - return floor ( p0 ); -} +half4 test_floor_half4(half4 p0) { return floor(p0); } // CHECK: define noundef float @ // CHECK: call float @llvm.floor.f32( -float test_floor_float ( float p0 ) { - return floor ( p0 ); -} +float test_floor_float(float p0) { return floor(p0); } // CHECK: define noundef <2 x float> @ // CHECK: call <2 x float> @llvm.floor.v2f32( -float2 test_floor_float2 ( float2 p0 ) { - return floor ( p0 ); -} +float2 test_floor_float2(float2 p0) { return floor(p0); } // CHECK: define noundef <3 x float> @ // CHECK: call <3 x float> @llvm.floor.v3f32( -float3 test_floor_float3 ( float3 p0 ) { - return floor ( p0 ); -} +float3 test_floor_float3(float3 p0) { return floor(p0); } // CHECK: define noundef <4 x float> @ // CHECK: call <4 x float> @llvm.floor.v4f32( -float4 test_floor_float4 ( float4 p0 ) { - return floor ( p0 ); -} +float4 test_floor_float4(float4 p0) { return floor(p0); } // CHECK: define noundef double @ // CHECK: call double @llvm.floor.f64( -double test_floor_double ( double p0 ) { - return floor ( p0 ); -} +double test_floor_double(double p0) { return floor(p0); } // CHECK: define noundef <2 x double> @ // CHECK: call <2 x double> @llvm.floor.v2f64( -double2 test_floor_double2 ( double2 p0 ) { - return floor ( p0 ); -} +double2 test_floor_double2(double2 p0) { return floor(p0); } // CHECK: define noundef <3 x double> @ // CHECK: call <3 x double> @llvm.floor.v3f64( -double3 test_floor_double3 ( double3 p0 ) { - return floor ( p0 ); -} +double3 test_floor_double3(double3 p0) { return floor(p0); } // CHECK: define noundef <4 x double> @ // CHECK: call <4 x double> @llvm.floor.v4f64( -double4 test_floor_double4 ( double4 p0 ) { - return floor ( p0 ); -} +double4 test_floor_double4(double4 p0) { return floor(p0); } diff --git a/clang/test/CodeGenHLSL/builtins/log.hlsl b/clang/test/CodeGenHLSL/builtins/log.hlsl index 6a8e4ac2e5f294..ecbdf1e98ac346 100644 --- a/clang/test/CodeGenHLSL/builtins/log.hlsl +++ b/clang/test/CodeGenHLSL/builtins/log.hlsl @@ -1,56 +1,41 @@ // RUN: %clang_cc1 -std=hlsl2021 -finclude-default-header -x hlsl -triple \ // RUN: dxil-pc-shadermodel6.3-library %s -fnative-half-type \ -// RUN: -emit-llvm -disable-llvm-passes -O3 -o - | FileCheck %s +// RUN: -emit-llvm -disable-llvm-passes -o - | FileCheck %s \ +// RUN: --check-prefixes=CHECK,NATIVE_HALF // RUN: %clang_cc1 -std=hlsl2021 -finclude-default-header -x hlsl -triple \ // RUN: dxil-pc-shadermodel6.3-library %s -emit-llvm -disable-llvm-passes \ -// RUN: -o - | FileCheck %s --check-prefi... [truncated] `````````` </details> https://github.com/llvm/llvm-project/pull/83340 _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits