Revert "[lldb][test] Remove compiler version check and use regex" (#124101)
[llvm-project.git] / clang / test / CodeGenHLSL / builtins / frac.hlsl
blob7b105ce84359f1d66676515ed9b0de348765c815
1 // RUN: %clang_cc1 -finclude-default-header -x hlsl -triple \
2 // RUN:   dxil-pc-shadermodel6.3-library %s -fnative-half-type \
3 // RUN:   -emit-llvm -disable-llvm-passes -o - | FileCheck %s \
4 // RUN:   --check-prefixes=CHECK,NATIVE_HALF \
5 // RUN:   -DFNATTRS="noundef nofpclass(nan inf)" -DTARGET=dx
6 // RUN: %clang_cc1 -finclude-default-header -x hlsl -triple \
7 // RUN:   dxil-pc-shadermodel6.3-library %s -emit-llvm -disable-llvm-passes \
8 // RUN:   -o - | FileCheck %s --check-prefixes=CHECK,NO_HALF \
9 // RUN:   -DFNATTRS="noundef nofpclass(nan inf)" -DTARGET=dx
10 // RUN: %clang_cc1 -finclude-default-header -x hlsl -triple \
11 // RUN:   spirv-unknown-vulkan-compute %s -fnative-half-type \
12 // RUN:   -emit-llvm -disable-llvm-passes -o - | FileCheck %s \
13 // RUN:   --check-prefixes=CHECK,NATIVE_HALF \
14 // RUN:   -DFNATTRS="spir_func noundef nofpclass(nan inf)" -DTARGET=spv
15 // RUN: %clang_cc1 -finclude-default-header -x hlsl -triple \
16 // RUN:   spirv-unknown-vulkan-compute %s -emit-llvm -disable-llvm-passes \
17 // RUN:   -o - | FileCheck %s --check-prefixes=CHECK,NO_HALF \
18 // RUN:   -DFNATTRS="spir_func noundef nofpclass(nan inf)" -DTARGET=spv
20 // NATIVE_HALF: define [[FNATTRS]] half @
21 // NATIVE_HALF: %hlsl.frac = call reassoc nnan ninf nsz arcp afn half @llvm.[[TARGET]].frac.f16(
22 // NATIVE_HALF: ret half %hlsl.frac
23 // NO_HALF: define [[FNATTRS]] float @
24 // NO_HALF: %hlsl.frac = call reassoc nnan ninf nsz arcp afn float @llvm.[[TARGET]].frac.f32(
25 // NO_HALF: ret float %hlsl.frac
26 half test_frac_half(half p0) { return frac(p0); }
27 // NATIVE_HALF: define [[FNATTRS]] <2 x half> @
28 // NATIVE_HALF: %hlsl.frac = call reassoc nnan ninf nsz arcp afn <2 x half> @llvm.[[TARGET]].frac.v2f16
29 // NATIVE_HALF: ret <2 x half> %hlsl.frac
30 // NO_HALF: define [[FNATTRS]] <2 x float> @
31 // NO_HALF: %hlsl.frac = call reassoc nnan ninf nsz arcp afn <2 x float> @llvm.[[TARGET]].frac.v2f32(
32 // NO_HALF: ret <2 x float> %hlsl.frac
33 half2 test_frac_half2(half2 p0) { return frac(p0); }
34 // NATIVE_HALF: define [[FNATTRS]] <3 x half> @
35 // NATIVE_HALF: %hlsl.frac = call reassoc nnan ninf nsz arcp afn <3 x half> @llvm.[[TARGET]].frac.v3f16
36 // NATIVE_HALF: ret <3 x half> %hlsl.frac
37 // NO_HALF: define [[FNATTRS]] <3 x float> @
38 // NO_HALF: %hlsl.frac = call reassoc nnan ninf nsz arcp afn <3 x float> @llvm.[[TARGET]].frac.v3f32(
39 // NO_HALF: ret <3 x float> %hlsl.frac
40 half3 test_frac_half3(half3 p0) { return frac(p0); }
41 // NATIVE_HALF: define [[FNATTRS]] <4 x half> @
42 // NATIVE_HALF: %hlsl.frac = call reassoc nnan ninf nsz arcp afn <4 x half> @llvm.[[TARGET]].frac.v4f16
43 // NATIVE_HALF: ret <4 x half> %hlsl.frac
44 // NO_HALF: define [[FNATTRS]] <4 x float> @
45 // NO_HALF: %hlsl.frac = call reassoc nnan ninf nsz arcp afn <4 x float> @llvm.[[TARGET]].frac.v4f32(
46 // NO_HALF: ret <4 x float> %hlsl.frac
47 half4 test_frac_half4(half4 p0) { return frac(p0); }
49 // CHECK: define [[FNATTRS]] float @
50 // CHECK: %hlsl.frac = call reassoc nnan ninf nsz arcp afn float @llvm.[[TARGET]].frac.f32(
51 // CHECK: ret float %hlsl.frac
52 float test_frac_float(float p0) { return frac(p0); }
53 // CHECK: define [[FNATTRS]] <2 x float> @
54 // CHECK: %hlsl.frac = call reassoc nnan ninf nsz arcp afn <2 x float> @llvm.[[TARGET]].frac.v2f32
55 // CHECK: ret <2 x float> %hlsl.frac
56 float2 test_frac_float2(float2 p0) { return frac(p0); }
57 // CHECK: define [[FNATTRS]] <3 x float> @
58 // CHECK: %hlsl.frac = call reassoc nnan ninf nsz arcp afn <3 x float> @llvm.[[TARGET]].frac.v3f32
59 // CHECK: ret <3 x float> %hlsl.frac
60 float3 test_frac_float3(float3 p0) { return frac(p0); }
61 // CHECK: define [[FNATTRS]] <4 x float> @
62 // CHECK: %hlsl.frac = call reassoc nnan ninf nsz arcp afn <4 x float> @llvm.[[TARGET]].frac.v4f32
63 // CHECK: ret <4 x float> %hlsl.frac
64 float4 test_frac_float4(float4 p0) { return frac(p0); }