Revert "[lldb][test] Remove compiler version check and use regex" (#124101)
[llvm-project.git] / clang / test / CodeGenHLSL / builtins / step.hlsl
blob49d09e5c6fe6f70cb08ed011ba781c7496966dfd
1 // RUN: %clang_cc1 -finclude-default-header -x hlsl -triple \\r
2 // RUN:   dxil-pc-shadermodel6.3-library %s -fnative-half-type \\r
3 // RUN:   -emit-llvm -disable-llvm-passes -o - | FileCheck %s \\r
4 // RUN:   --check-prefixes=CHECK,NATIVE_HALF \\r
5 // RUN:   -DFNATTRS="noundef nofpclass(nan inf)" -DTARGET=dx\r
6 // RUN: %clang_cc1 -finclude-default-header -x hlsl -triple \\r
7 // RUN:   dxil-pc-shadermodel6.3-library %s -emit-llvm -disable-llvm-passes \\r
8 // RUN:   -o - | FileCheck %s --check-prefixes=CHECK,NO_HALF \\r
9 // RUN:   -DFNATTRS="noundef nofpclass(nan inf)" -DTARGET=dx\r
10 // RUN: %clang_cc1 -finclude-default-header -x hlsl -triple \\r
11 // RUN:   spirv-unknown-vulkan-compute %s -fnative-half-type \\r
12 // RUN:   -emit-llvm -disable-llvm-passes -o - | FileCheck %s \\r
13 // RUN:   --check-prefixes=CHECK,NATIVE_HALF \\r
14 // RUN:   -DFNATTRS="spir_func noundef nofpclass(nan inf)" -DTARGET=spv\r
15 // RUN: %clang_cc1 -finclude-default-header -x hlsl -triple \\r
16 // RUN:   spirv-unknown-vulkan-compute %s -emit-llvm -disable-llvm-passes \\r
17 // RUN:   -o - | FileCheck %s --check-prefixes=CHECK,NO_HALF \\r
18 // RUN:   -DFNATTRS="spir_func noundef nofpclass(nan inf)" -DTARGET=spv\r
20 // NATIVE_HALF: define [[FNATTRS]] half @\r
21 // NATIVE_HALF: call reassoc nnan ninf nsz arcp afn half @llvm.[[TARGET]].step.f16(half\r
22 // NO_HALF: call reassoc nnan ninf nsz arcp afn float @llvm.[[TARGET]].step.f32(float\r
23 // NATIVE_HALF: ret half\r
24 // NO_HALF: ret float\r
25 half test_step_half(half p0, half p1)\r
26 {\r
27     return step(p0, p1);\r
28 }\r
29 // NATIVE_HALF: define [[FNATTRS]] <2 x half> @\r
30 // NATIVE_HALF: call reassoc nnan ninf nsz arcp afn <2 x half> @llvm.[[TARGET]].step.v2f16(<2 x half>\r
31 // NO_HALF: call reassoc nnan ninf nsz arcp afn <2 x float> @llvm.[[TARGET]].step.v2f32(<2 x float>\r
32 // NATIVE_HALF: ret <2 x half> %hlsl.step\r
33 // NO_HALF: ret <2 x float> %hlsl.step\r
34 half2 test_step_half2(half2 p0, half2 p1)\r
35 {\r
36     return step(p0, p1);\r
37 }\r
38 // NATIVE_HALF: define [[FNATTRS]] <3 x half> @\r
39 // NATIVE_HALF: call reassoc nnan ninf nsz arcp afn <3 x half> @llvm.[[TARGET]].step.v3f16(<3 x half>\r
40 // NO_HALF: call reassoc nnan ninf nsz arcp afn <3 x float> @llvm.[[TARGET]].step.v3f32(<3 x float>\r
41 // NATIVE_HALF: ret <3 x half> %hlsl.step\r
42 // NO_HALF: ret <3 x float> %hlsl.step\r
43 half3 test_step_half3(half3 p0, half3 p1)\r
44 {\r
45     return step(p0, p1);\r
46 }\r
47 // NATIVE_HALF: define [[FNATTRS]] <4 x half> @\r
48 // NATIVE_HALF: call reassoc nnan ninf nsz arcp afn <4 x half> @llvm.[[TARGET]].step.v4f16(<4 x half>\r
49 // NO_HALF: call reassoc nnan ninf nsz arcp afn <4 x float> @llvm.[[TARGET]].step.v4f32(<4 x float>\r
50 // NATIVE_HALF: ret <4 x half> %hlsl.step\r
51 // NO_HALF: ret <4 x float> %hlsl.step\r
52 half4 test_step_half4(half4 p0, half4 p1)\r
53 {\r
54     return step(p0, p1);\r
55 }\r
57 // CHECK: define [[FNATTRS]] float @\r
58 // CHECK: call reassoc nnan ninf nsz arcp afn float @llvm.[[TARGET]].step.f32(float\r
59 // CHECK: ret float\r
60 float test_step_float(float p0, float p1)\r
61 {\r
62     return step(p0, p1);\r
63 }\r
64 // CHECK: define [[FNATTRS]] <2 x float> @\r
65 // CHECK: %hlsl.step = call reassoc nnan ninf nsz arcp afn <2 x float> @llvm.[[TARGET]].step.v2f32(\r
66 // CHECK: ret <2 x float> %hlsl.step\r
67 float2 test_step_float2(float2 p0, float2 p1)\r
68 {\r
69     return step(p0, p1);\r
70 }\r
71 // CHECK: define [[FNATTRS]] <3 x float> @\r
72 // CHECK: %hlsl.step = call reassoc nnan ninf nsz arcp afn <3 x float> @llvm.[[TARGET]].step.v3f32(\r
73 // CHECK: ret <3 x float> %hlsl.step\r
74 float3 test_step_float3(float3 p0, float3 p1)\r
75 {\r
76     return step(p0, p1);\r
77 }\r
78 // CHECK: define [[FNATTRS]] <4 x float> @\r
79 // CHECK: %hlsl.step = call reassoc nnan ninf nsz arcp afn <4 x float> @llvm.[[TARGET]].step.v4f32(\r
80 // CHECK: ret <4 x float> %hlsl.step\r
81 float4 test_step_float4(float4 p0, float4 p1)\r
82 {\r
83     return step(p0, p1);\r
84 }\r