forked from llvm/llvm-project
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[clang][hlsl] Add atan2 intrinsic part 1
Issue: llvm#70096 Changes: - Doc updates: - `clang/docs/LanguageExtensions.rst` - Document the new elementwise atan2 builtin. - `llvm/docs/LangRef.rst` - Document the atan2 intrinsic - TableGen: - `clang/include/clang/Basic/Builtins.td` - Implement the atan2 builtin. - `llvm/include/llvm/IR/Intrinsics.td` - Create the atan2 intrinsic - Sema checking: - `clang/lib/Sema/SemaChecking.cpp` - Add generic sema checks to the atan2 builtin - `clang/lib/Sema/SemaHLSL` Add HLSL specifc sema checks to the atan2 builtin - `clang/lib/CodeGen/CGBuiltin.cpp` - invoke the atan2 intrinsic on uses of the builtin - `clang/lib/Headers/hlsl/hlsl_intrinsics.h` - Associate the atan2 builtin with the equivalent hlsl apis
- Loading branch information
Showing
16 changed files
with
219 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,59 @@ | ||
// 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: --check-prefixes=CHECK,NATIVE_HALF | ||
// RUN: %clang_cc1 -finclude-default-header -x hlsl -triple \ | ||
// RUN: spirv-unknown-vulkan-compute %s -emit-llvm -disable-llvm-passes \ | ||
// RUN: -o - | FileCheck %s --check-prefixes=CHECK,NO_HALF | ||
|
||
// CHECK-LABEL: test_atan2_half | ||
// NATIVE_HALF: call half @llvm.atan2.f16 | ||
// NO_HALF: call float @llvm.atan2.f32 | ||
half test_atan2_half (half p0, half p1) { | ||
return atan2(p0, p1); | ||
} | ||
|
||
// CHECK-LABEL: test_atan2_half2 | ||
// NATIVE_HALF: call <2 x half> @llvm.atan2.v2f16 | ||
// NO_HALF: call <2 x float> @llvm.atan2.v2f32 | ||
half2 test_atan2_half2 (half2 p0, half2 p1) { | ||
return atan2(p0, p1); | ||
} | ||
|
||
// CHECK-LABEL: test_atan2_half3 | ||
// NATIVE_HALF: call <3 x half> @llvm.atan2.v3f16 | ||
// NO_HALF: call <3 x float> @llvm.atan2.v3f32 | ||
half3 test_atan2_half3 (half3 p0, half3 p1) { | ||
return atan2(p0, p1); | ||
} | ||
|
||
// CHECK-LABEL: test_atan2_half4 | ||
// NATIVE_HALF: call <4 x half> @llvm.atan2.v4f16 | ||
// NO_HALF: call <4 x float> @llvm.atan2.v4f32 | ||
half4 test_atan2_half4 (half4 p0, half4 p1) { | ||
return atan2(p0, p1); | ||
} | ||
|
||
// CHECK-LABEL: test_atan2_float | ||
// CHECK: call float @llvm.atan2.f32 | ||
float test_atan2_float (float p0, float p1) { | ||
return atan2(p0, p1); | ||
} | ||
|
||
// CHECK-LABEL: test_atan2_float2 | ||
// CHECK: call <2 x float> @llvm.atan2.v2f32 | ||
float2 test_atan2_float2 (float2 p0, float2 p1) { | ||
return atan2(p0, p1); | ||
} | ||
|
||
// CHECK-LABEL: test_atan2_float3 | ||
// CHECK: call <3 x float> @llvm.atan2.v3f32 | ||
float3 test_atan2_float3 (float3 p0, float3 p1) { | ||
return atan2(p0, p1); | ||
} | ||
|
||
// CHECK-LABEL: test_atan2_float4 | ||
// CHECK: call <4 x float> @llvm.atan2.v4f32 | ||
float4 test_atan2_float4 (float4 p0, float4 p1) { | ||
return atan2(p0, p1); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
// RUN: %clang_cc1 -finclude-default-header -triple dxil-pc-shadermodel6.6-library %s -fnative-half-type -emit-llvm-only -disable-llvm-passes -verify -DTEST_FUNC=__builtin_elementwise_atan2 | ||
// RUN: %clang_cc1 -finclude-default-header -triple dxil-pc-shadermodel6.6-library %s -fnative-half-type -emit-llvm-only -disable-llvm-passes -verify -DTEST_FUNC=__builtin_elementwise_pow | ||
|
||
double2 test_double_builtin(double2 p0, double2 p1) { | ||
return TEST_FUNC(p0, p1); | ||
// expected-error@-1 {{passing 'double2' (aka 'vector<double, 2>') to parameter of incompatible type '__attribute__((__vector_size__(2 * sizeof(float)))) float' (vector of 2 'float' values)}} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters