|
1 | 1 | // RUN: %clang_cc1 -finclude-default-header -x hlsl -triple \
|
2 | 2 | // RUN: dxil-pc-shadermodel6.3-library %s -fnative-half-type \
|
3 | 3 | // RUN: -emit-llvm -disable-llvm-passes -o - | FileCheck %s \
|
4 |
| -// RUN: --check-prefixes=CHECK,NATIVE_HALF |
| 4 | +// RUN: --check-prefixes=CHECK,DXIL_CHECK,DXIL_NATIVE_HALF,NATIVE_HALF |
5 | 5 | // RUN: %clang_cc1 -finclude-default-header -x hlsl -triple \
|
6 | 6 | // RUN: dxil-pc-shadermodel6.3-library %s -emit-llvm -disable-llvm-passes \
|
7 |
| -// RUN: -o - | FileCheck %s --check-prefixes=CHECK,NO_HALF |
| 7 | +// RUN: -o - | FileCheck %s --check-prefixes=CHECK,DXIL_CHECK,NO_HALF,DXIL_NO_HALF |
| 8 | +// RUN: %clang_cc1 -finclude-default-header -x hlsl -triple \ |
| 9 | +// RUN: spirv-unknown-vulkan-compute %s -fnative-half-type \ |
| 10 | +// RUN: -emit-llvm -disable-llvm-passes -o - | FileCheck %s \ |
| 11 | +// RUN: --check-prefixes=CHECK,NATIVE_HALF,SPIR_NATIVE_HALF,SPIR_CHECK |
| 12 | +// RUN: %clang_cc1 -finclude-default-header -x hlsl -triple \ |
| 13 | +// RUN: spirv-unknown-vulkan-compute %s -emit-llvm -disable-llvm-passes \ |
| 14 | +// RUN: -o - | FileCheck %s --check-prefixes=CHECK,NO_HALF,SPIR_NO_HALF,SPIR_CHECK |
8 | 15 |
|
9 | 16 |
|
10 |
| -// NATIVE_HALF: %dx.lerp = call half @llvm.dx.lerp.f16(half %0, half %1, half %2) |
11 |
| -// NATIVE_HALF: ret half %dx.lerp |
12 |
| -// NO_HALF: %dx.lerp = call float @llvm.dx.lerp.f32(float %0, float %1, float %2) |
13 |
| -// NO_HALF: ret float %dx.lerp |
| 17 | +// DXIL_NATIVE_HALF: %hlsl.lerp = call half @llvm.dx.lerp.f16(half %0, half %1, half %2) |
| 18 | +// SPIR_NATIVE_HALF: %hlsl.lerp = call half @llvm.spv.lerp.f16(half %0, half %1, half %2) |
| 19 | +// NATIVE_HALF: ret half %hlsl.lerp |
| 20 | +// DXIL_NO_HALF: %hlsl.lerp = call float @llvm.dx.lerp.f32(float %0, float %1, float %2) |
| 21 | +// SPIR_NO_HALF: %hlsl.lerp = call float @llvm.spv.lerp.f32(float %0, float %1, float %2) |
| 22 | +// NO_HALF: ret float %hlsl.lerp |
14 | 23 | half test_lerp_half(half p0) { return lerp(p0, p0, p0); }
|
15 | 24 |
|
16 |
| -// NATIVE_HALF: %dx.lerp = call <2 x half> @llvm.dx.lerp.v2f16(<2 x half> %0, <2 x half> %1, <2 x half> %2) |
17 |
| -// NATIVE_HALF: ret <2 x half> %dx.lerp |
18 |
| -// NO_HALF: %dx.lerp = call <2 x float> @llvm.dx.lerp.v2f32(<2 x float> %0, <2 x float> %1, <2 x float> %2) |
19 |
| -// NO_HALF: ret <2 x float> %dx.lerp |
| 25 | +// DXIL_NATIVE_HALF: %hlsl.lerp = call <2 x half> @llvm.dx.lerp.v2f16(<2 x half> %0, <2 x half> %1, <2 x half> %2) |
| 26 | +// SPIR_NATIVE_HALF: %hlsl.lerp = call <2 x half> @llvm.spv.lerp.v2f16(<2 x half> %0, <2 x half> %1, <2 x half> %2) |
| 27 | +// NATIVE_HALF: ret <2 x half> %hlsl.lerp |
| 28 | +// DXIL_NO_HALF: %hlsl.lerp = call <2 x float> @llvm.dx.lerp.v2f32(<2 x float> %0, <2 x float> %1, <2 x float> %2) |
| 29 | +// SPIR_NO_HALF: %hlsl.lerp = call <2 x float> @llvm.spv.lerp.v2f32(<2 x float> %0, <2 x float> %1, <2 x float> %2) |
| 30 | +// NO_HALF: ret <2 x float> %hlsl.lerp |
20 | 31 | half2 test_lerp_half2(half2 p0) { return lerp(p0, p0, p0); }
|
21 | 32 |
|
22 |
| -// NATIVE_HALF: %dx.lerp = call <3 x half> @llvm.dx.lerp.v3f16(<3 x half> %0, <3 x half> %1, <3 x half> %2) |
23 |
| -// NATIVE_HALF: ret <3 x half> %dx.lerp |
24 |
| -// NO_HALF: %dx.lerp = call <3 x float> @llvm.dx.lerp.v3f32(<3 x float> %0, <3 x float> %1, <3 x float> %2) |
25 |
| -// NO_HALF: ret <3 x float> %dx.lerp |
| 33 | +// DXIL_NATIVE_HALF: %hlsl.lerp = call <3 x half> @llvm.dx.lerp.v3f16(<3 x half> %0, <3 x half> %1, <3 x half> %2) |
| 34 | +// SPIR_NATIVE_HALF: %hlsl.lerp = call <3 x half> @llvm.spv.lerp.v3f16(<3 x half> %0, <3 x half> %1, <3 x half> %2) |
| 35 | +// NATIVE_HALF: ret <3 x half> %hlsl.lerp |
| 36 | +// DXIL_NO_HALF: %hlsl.lerp = call <3 x float> @llvm.dx.lerp.v3f32(<3 x float> %0, <3 x float> %1, <3 x float> %2) |
| 37 | +// SPIR_NO_HALF: %hlsl.lerp = call <3 x float> @llvm.spv.lerp.v3f32(<3 x float> %0, <3 x float> %1, <3 x float> %2) |
| 38 | +// NO_HALF: ret <3 x float> %hlsl.lerp |
26 | 39 | half3 test_lerp_half3(half3 p0) { return lerp(p0, p0, p0); }
|
27 | 40 |
|
28 |
| -// NATIVE_HALF: %dx.lerp = call <4 x half> @llvm.dx.lerp.v4f16(<4 x half> %0, <4 x half> %1, <4 x half> %2) |
29 |
| -// NATIVE_HALF: ret <4 x half> %dx.lerp |
30 |
| -// NO_HALF: %dx.lerp = call <4 x float> @llvm.dx.lerp.v4f32(<4 x float> %0, <4 x float> %1, <4 x float> %2) |
31 |
| -// NO_HALF: ret <4 x float> %dx.lerp |
| 41 | +// DXIL_NATIVE_HALF: %hlsl.lerp = call <4 x half> @llvm.dx.lerp.v4f16(<4 x half> %0, <4 x half> %1, <4 x half> %2) |
| 42 | +// SPIR_NATIVE_HALF: %hlsl.lerp = call <4 x half> @llvm.spv.lerp.v4f16(<4 x half> %0, <4 x half> %1, <4 x half> %2) |
| 43 | +// NATIVE_HALF: ret <4 x half> %hlsl.lerp |
| 44 | +// DXIL_NO_HALF: %hlsl.lerp = call <4 x float> @llvm.dx.lerp.v4f32(<4 x float> %0, <4 x float> %1, <4 x float> %2) |
| 45 | +// SPIR_NO_HALF: %hlsl.lerp = call <4 x float> @llvm.spv.lerp.v4f32(<4 x float> %0, <4 x float> %1, <4 x float> %2) |
| 46 | +// NO_HALF: ret <4 x float> %hlsl.lerp |
32 | 47 | half4 test_lerp_half4(half4 p0) { return lerp(p0, p0, p0); }
|
33 | 48 |
|
34 |
| -// CHECK: %dx.lerp = call float @llvm.dx.lerp.f32(float %0, float %1, float %2) |
35 |
| -// CHECK: ret float %dx.lerp |
| 49 | +// DXIL_CHECK: %hlsl.lerp = call float @llvm.dx.lerp.f32(float %0, float %1, float %2) |
| 50 | +// SPIR_CHECK: %hlsl.lerp = call float @llvm.spv.lerp.f32(float %0, float %1, float %2) |
| 51 | +// CHECK: ret float %hlsl.lerp |
36 | 52 | float test_lerp_float(float p0) { return lerp(p0, p0, p0); }
|
37 | 53 |
|
38 |
| -// CHECK: %dx.lerp = call <2 x float> @llvm.dx.lerp.v2f32(<2 x float> %0, <2 x float> %1, <2 x float> %2) |
39 |
| -// CHECK: ret <2 x float> %dx.lerp |
| 54 | +// DXIL_CHECK: %hlsl.lerp = call <2 x float> @llvm.dx.lerp.v2f32(<2 x float> %0, <2 x float> %1, <2 x float> %2) |
| 55 | +// SPIR_CHECK: %hlsl.lerp = call <2 x float> @llvm.spv.lerp.v2f32(<2 x float> %0, <2 x float> %1, <2 x float> %2) |
| 56 | +// CHECK: ret <2 x float> %hlsl.lerp |
40 | 57 | float2 test_lerp_float2(float2 p0) { return lerp(p0, p0, p0); }
|
41 | 58 |
|
42 |
| -// CHECK: %dx.lerp = call <3 x float> @llvm.dx.lerp.v3f32(<3 x float> %0, <3 x float> %1, <3 x float> %2) |
43 |
| -// CHECK: ret <3 x float> %dx.lerp |
| 59 | +// DXIL_CHECK: %hlsl.lerp = call <3 x float> @llvm.dx.lerp.v3f32(<3 x float> %0, <3 x float> %1, <3 x float> %2) |
| 60 | +// SPIR_CHECK: %hlsl.lerp = call <3 x float> @llvm.spv.lerp.v3f32(<3 x float> %0, <3 x float> %1, <3 x float> %2) |
| 61 | +// CHECK: ret <3 x float> %hlsl.lerp |
44 | 62 | float3 test_lerp_float3(float3 p0) { return lerp(p0, p0, p0); }
|
45 | 63 |
|
46 |
| -// CHECK: %dx.lerp = call <4 x float> @llvm.dx.lerp.v4f32(<4 x float> %0, <4 x float> %1, <4 x float> %2) |
47 |
| -// CHECK: ret <4 x float> %dx.lerp |
| 64 | +// DXIL_CHECK: %hlsl.lerp = call <4 x float> @llvm.dx.lerp.v4f32(<4 x float> %0, <4 x float> %1, <4 x float> %2) |
| 65 | +// SPIR_CHECK: %hlsl.lerp = call <4 x float> @llvm.spv.lerp.v4f32(<4 x float> %0, <4 x float> %1, <4 x float> %2) |
| 66 | +// CHECK: ret <4 x float> %hlsl.lerp |
48 | 67 | float4 test_lerp_float4(float4 p0) { return lerp(p0, p0, p0); }
|
49 | 68 |
|
50 |
| -// CHECK: %dx.lerp = call <2 x float> @llvm.dx.lerp.v2f32(<2 x float> %splat.splat, <2 x float> %1, <2 x float> %2) |
51 |
| -// CHECK: ret <2 x float> %dx.lerp |
| 69 | +// DXIL_CHECK: %hlsl.lerp = call <2 x float> @llvm.dx.lerp.v2f32(<2 x float> %splat.splat, <2 x float> %1, <2 x float> %2) |
| 70 | +// SPIR_CHECK: %hlsl.lerp = call <2 x float> @llvm.spv.lerp.v2f32(<2 x float> %splat.splat, <2 x float> %1, <2 x float> %2) |
| 71 | +// CHECK: ret <2 x float> %hlsl.lerp |
52 | 72 | float2 test_lerp_float2_splat(float p0, float2 p1) { return lerp(p0, p1, p1); }
|
53 | 73 |
|
54 |
| -// CHECK: %dx.lerp = call <3 x float> @llvm.dx.lerp.v3f32(<3 x float> %splat.splat, <3 x float> %1, <3 x float> %2) |
55 |
| -// CHECK: ret <3 x float> %dx.lerp |
| 74 | +// DXIL_CHECK: %hlsl.lerp = call <3 x float> @llvm.dx.lerp.v3f32(<3 x float> %splat.splat, <3 x float> %1, <3 x float> %2) |
| 75 | +// SPIR_CHECK: %hlsl.lerp = call <3 x float> @llvm.spv.lerp.v3f32(<3 x float> %splat.splat, <3 x float> %1, <3 x float> %2) |
| 76 | +// CHECK: ret <3 x float> %hlsl.lerp |
56 | 77 | float3 test_lerp_float3_splat(float p0, float3 p1) { return lerp(p0, p1, p1); }
|
57 | 78 |
|
58 |
| -// CHECK: %dx.lerp = call <4 x float> @llvm.dx.lerp.v4f32(<4 x float> %splat.splat, <4 x float> %1, <4 x float> %2) |
59 |
| -// CHECK: ret <4 x float> %dx.lerp |
| 79 | +// DXIL_CHECK: %hlsl.lerp = call <4 x float> @llvm.dx.lerp.v4f32(<4 x float> %splat.splat, <4 x float> %1, <4 x float> %2) |
| 80 | +// SPIR_CHECK: %hlsl.lerp = call <4 x float> @llvm.spv.lerp.v4f32(<4 x float> %splat.splat, <4 x float> %1, <4 x float> %2) |
| 81 | +// CHECK: ret <4 x float> %hlsl.lerp |
60 | 82 | float4 test_lerp_float4_splat(float p0, float4 p1) { return lerp(p0, p1, p1); }
|
61 | 83 |
|
62 | 84 | // CHECK: %conv = sitofp i32 %2 to float
|
63 | 85 | // CHECK: %splat.splatinsert = insertelement <2 x float> poison, float %conv, i64 0
|
64 | 86 | // CHECK: %splat.splat = shufflevector <2 x float> %splat.splatinsert, <2 x float> poison, <2 x i32> zeroinitializer
|
65 |
| -// CHECK: %dx.lerp = call <2 x float> @llvm.dx.lerp.v2f32(<2 x float> %0, <2 x float> %1, <2 x float> %splat.splat) |
66 |
| -// CHECK: ret <2 x float> %dx.lerp |
| 87 | +// DXIL_CHECK: %hlsl.lerp = call <2 x float> @llvm.dx.lerp.v2f32(<2 x float> %0, <2 x float> %1, <2 x float> %splat.splat) |
| 88 | +// SPIR_CHECK: %hlsl.lerp = call <2 x float> @llvm.spv.lerp.v2f32(<2 x float> %0, <2 x float> %1, <2 x float> %splat.splat) |
| 89 | +// CHECK: ret <2 x float> %hlsl.lerp |
67 | 90 | float2 test_lerp_float2_int_splat(float2 p0, int p1) {
|
68 | 91 | return lerp(p0, p0, p1);
|
69 | 92 | }
|
70 | 93 |
|
71 | 94 | // CHECK: %conv = sitofp i32 %2 to float
|
72 | 95 | // CHECK: %splat.splatinsert = insertelement <3 x float> poison, float %conv, i64 0
|
73 | 96 | // CHECK: %splat.splat = shufflevector <3 x float> %splat.splatinsert, <3 x float> poison, <3 x i32> zeroinitializer
|
74 |
| -// CHECK: %dx.lerp = call <3 x float> @llvm.dx.lerp.v3f32(<3 x float> %0, <3 x float> %1, <3 x float> %splat.splat) |
75 |
| -// CHECK: ret <3 x float> %dx.lerp |
| 97 | +// DXIL_CHECK: %hlsl.lerp = call <3 x float> @llvm.dx.lerp.v3f32(<3 x float> %0, <3 x float> %1, <3 x float> %splat.splat) |
| 98 | +// SPIR_CHECK: %hlsl.lerp = call <3 x float> @llvm.spv.lerp.v3f32(<3 x float> %0, <3 x float> %1, <3 x float> %splat.splat) |
| 99 | +// CHECK: ret <3 x float> %hlsl.lerp |
76 | 100 | float3 test_lerp_float3_int_splat(float3 p0, int p1) {
|
77 | 101 | return lerp(p0, p0, p1);
|
78 | 102 | }
|
0 commit comments