Files
clang-p2996/clang/test/SemaHLSL/BuiltIns/mad-errors.hlsl
Farzon Lotfi 8386a388bd [HLSL] implement clamp intrinsic (#85424)
closes #70071
- `CGBuiltin.cpp` - Add the unsigned\generic clamp intrinsic emitter.
- `IntrinsicsDirectX.td` - add the `dx.clamp` & `dx.uclamp` intrinsics
- `DXILIntrinsicExpansion.cpp` - add the `clamp` instruction expansion
while maintaining vector form.
- `SemaChecking.cpp` -  Add `clamp`  builtin Sema Checks.
- `Builtins.td` - add a `clamp` builtin
- `hlsl_intrinsics.h` - add the `clamp` api

Why `clamp` as instruction expansion  for DXIL?
1. SPIR-V has a GLSL `clamp` extension via:
-
[FClamp](https://registry.khronos.org/SPIR-V/specs/1.0/GLSL.std.450.html#FClamp)
-
[UClamp](https://registry.khronos.org/SPIR-V/specs/1.0/GLSL.std.450.html#UClamp)
-
[SClamp](https://registry.khronos.org/SPIR-V/specs/1.0/GLSL.std.450.html#SClamp)
2. Further Clamp lowers to `min(max( x, min_range ), max_range)` which
we have float, signed, & unsigned dixilOps.
2024-03-15 20:57:08 -04:00

87 lines
3.2 KiB
HLSL

// RUN: %clang_cc1 -finclude-default-header -triple dxil-pc-shadermodel6.6-library %s -fnative-half-type -emit-llvm -disable-llvm-passes -verify -verify-ignore-unexpected
float2 test_no_second_arg(float2 p0) {
return __builtin_hlsl_mad(p0);
// expected-error@-1 {{too few arguments to function call, expected 3, have 1}}
}
float2 test_no_third_arg(float2 p0) {
return __builtin_hlsl_mad(p0, p0);
// expected-error@-1 {{too few arguments to function call, expected 3, have 2}}
}
float2 test_too_many_arg(float2 p0) {
return __builtin_hlsl_mad(p0, p0, p0, p0);
// expected-error@-1 {{too many arguments to function call, expected 3, have 4}}
}
float2 test_mad_no_second_arg(float2 p0) {
return mad(p0);
// expected-error@-1 {{no matching function for call to 'mad'}}
}
float2 test_mad_vector_size_mismatch(float3 p0, float2 p1) {
return mad(p0, p0, p1);
// expected-warning@-1 {{implicit conversion truncates vector: 'float3' (aka 'vector<float, 3>') to 'float __attribute__((ext_vector_type(2)))' (vector of 2 'float' values)}}
}
float2 test_mad_builtin_vector_size_mismatch(float3 p0, float2 p1) {
return __builtin_hlsl_mad(p0, p1, p1);
// expected-error@-1 {{all arguments to '__builtin_hlsl_mad' must have the same type}}
}
float test_mad_scalar_mismatch(float p0, half p1) {
return mad(p1, p0, p1);
// expected-error@-1 {{call to 'mad' is ambiguous}}
}
float2 test_mad_element_type_mismatch(half2 p0, float2 p1) {
return mad(p1, p0, p1);
// expected-error@-1 {{call to 'mad' is ambiguous}}
}
float2 test_builtin_mad_float2_splat(float p0, float2 p1) {
return __builtin_hlsl_mad(p0, p1, p1);
// expected-error@-1 {{all arguments to '__builtin_hlsl_mad' must be vectors}}
}
float3 test_builtin_mad_float3_splat(float p0, float3 p1) {
return __builtin_hlsl_mad(p0, p1, p1);
// expected-error@-1 {{all arguments to '__builtin_hlsl_mad' must be vectors}}
}
float4 test_builtin_mad_float4_splat(float p0, float4 p1) {
return __builtin_hlsl_mad(p0, p1, p1);
// expected-error@-1 {{all arguments to '__builtin_hlsl_mad' must be vectors}}
}
float2 test_mad_float2_int_splat(float2 p0, int p1) {
return __builtin_hlsl_mad(p0, p1, p1);
// expected-error@-1 {{all arguments to '__builtin_hlsl_mad' must be vectors}}
}
float3 test_mad_float3_int_splat(float3 p0, int p1) {
return __builtin_hlsl_mad(p0, p1, p1);
// expected-error@-1 {{all arguments to '__builtin_hlsl_mad' must be vectors}}
}
float2 test_builtin_mad_int_vect_to_float_vec_promotion(int2 p0, float p1) {
return __builtin_hlsl_mad(p0, p1, p1);
// expected-error@-1 {{all arguments to '__builtin_hlsl_mad' must be vectors}}
}
float builtin_bool_to_float_type_promotion(float p0, bool p1) {
return __builtin_hlsl_mad(p0, p0, p1);
// expected-error@-1 {{3rd argument must be a floating point type (was 'bool')}}
}
float builtin_bool_to_float_type_promotion2(bool p0, float p1) {
return __builtin_hlsl_mad(p1, p0, p1);
// expected-error@-1 {{2nd argument must be a floating point type (was 'bool')}}
}
float builtin_mad_int_to_float_promotion(float p0, int p1) {
return __builtin_hlsl_mad(p0, p0, p1);
// expected-error@-1 {{3rd argument must be a floating point type (was 'int')}}
}