This change add the elementwise fmod builtin to support HLSL function 'fmod' in clang for #99118 Builtins.td - add the fmod builtin CGBuiltin.cpp - lower the builtin to llvm FRem instruction hlsl_intrinsics.h - add the fmod api SemaChecking.cpp - add type checks for builtin SemaHLSL.cpp - add HLSL type checks for builtin clang/docs/LanguageExtensions.rst - add the builtin in *Elementwise Builtins* clang/docs/ReleaseNotes.rst - announce the builtin
78 lines
2.6 KiB
HLSL
78 lines
2.6 KiB
HLSL
// DirectX target:
|
|
//
|
|
// ---------- Native Half support test -----------
|
|
//
|
|
// RUN: %clang_cc1 -finclude-default-header -x hlsl -triple \
|
|
// RUN: dxil-pc-shadermodel6.3-library %s -fnative-half-type \
|
|
// RUN: -emit-llvm -disable-llvm-passes -o - | FileCheck %s \
|
|
// RUN: -DFNATTRS=noundef -DTYPE=half
|
|
|
|
//
|
|
// ---------- No Native Half support test -----------
|
|
//
|
|
// RUN: %clang_cc1 -finclude-default-header -x hlsl -triple \
|
|
// RUN: dxil-pc-shadermodel6.3-library %s -emit-llvm -disable-llvm-passes \
|
|
// RUN: -o - | FileCheck %s \
|
|
// RUN: -DFNATTRS=noundef -DTYPE=float
|
|
|
|
|
|
// Spirv target:
|
|
//
|
|
// ---------- Native Half support test -----------
|
|
//
|
|
// RUN: %clang_cc1 -finclude-default-header -x hlsl -triple \
|
|
// RUN: spirv-unknown-vulkan-compute %s -fnative-half-type \
|
|
// RUN: -emit-llvm -disable-llvm-passes -o - | FileCheck %s \
|
|
// RUN: -DFNATTRS="spir_func noundef" -DTYPE=half
|
|
|
|
//
|
|
// ---------- No Native Half support test -----------
|
|
//
|
|
// RUN: %clang_cc1 -finclude-default-header -x hlsl -triple \
|
|
// RUN: spirv-unknown-vulkan-compute %s -emit-llvm -disable-llvm-passes \
|
|
// RUN: -o - | FileCheck %s \
|
|
// RUN: -DFNATTRS="spir_func noundef" -DTYPE=float
|
|
|
|
|
|
|
|
// CHECK: define [[FNATTRS]] [[TYPE]] @
|
|
// CHECK: %fmod = frem [[TYPE]]
|
|
// CHECK: ret [[TYPE]] %fmod
|
|
half test_fmod_half(half p0, half p1) { return fmod(p0, p1); }
|
|
|
|
// CHECK: define [[FNATTRS]] <2 x [[TYPE]]> @
|
|
// CHECK: %fmod = frem <2 x [[TYPE]]>
|
|
// CHECK: ret <2 x [[TYPE]]> %fmod
|
|
half2 test_fmod_half2(half2 p0, half2 p1) { return fmod(p0, p1); }
|
|
|
|
// CHECK: define [[FNATTRS]] <3 x [[TYPE]]> @
|
|
// CHECK: %fmod = frem <3 x [[TYPE]]>
|
|
// CHECK: ret <3 x [[TYPE]]> %fmod
|
|
half3 test_fmod_half3(half3 p0, half3 p1) { return fmod(p0, p1); }
|
|
|
|
// CHECK: define [[FNATTRS]] <4 x [[TYPE]]> @
|
|
// CHECK: %fmod = frem <4 x [[TYPE]]>
|
|
// CHECK: ret <4 x [[TYPE]]> %fmod
|
|
half4 test_fmod_half4(half4 p0, half4 p1) { return fmod(p0, p1); }
|
|
|
|
// CHECK: define [[FNATTRS]] float @
|
|
// CHECK: %fmod = frem float
|
|
// CHECK: ret float %fmod
|
|
float test_fmod_float(float p0, float p1) { return fmod(p0, p1); }
|
|
|
|
// CHECK: define [[FNATTRS]] <2 x float> @
|
|
// CHECK: %fmod = frem <2 x float>
|
|
// CHECK: ret <2 x float> %fmod
|
|
float2 test_fmod_float2(float2 p0, float2 p1) { return fmod(p0, p1); }
|
|
|
|
// CHECK: define [[FNATTRS]] <3 x float> @
|
|
// CHECK: %fmod = frem <3 x float>
|
|
// CHECK: ret <3 x float> %fmod
|
|
float3 test_fmod_float3(float3 p0, float3 p1) { return fmod(p0, p1); }
|
|
|
|
// CHECK: define [[FNATTRS]] <4 x float> @
|
|
// CHECK: %fmod = frem <4 x float>
|
|
// CHECK: ret <4 x float> %fmod
|
|
float4 test_fmod_float4(float4 p0, float4 p1) { return fmod(p0, p1); }
|
|
|