|
1 | | -// RUN: %dxc -T ps_6_9 %s | FileCheck %s |
| 1 | +// RUN: %dxc -T lib_6_9 %s | FileCheck %s |
2 | 2 |
|
3 | 3 | // Long vector tests for vec ops that scalarize to something more complex |
4 | 4 | // than a simple repetition of the same dx.op calls. |
5 | 5 |
|
6 | | -StructuredBuffer< vector<float, 8> > buf; |
7 | | -ByteAddressBuffer rbuf; |
8 | | - |
9 | | -float4 main(uint i : SV_PrimitiveID, bool b : B) : SV_Target { |
10 | | - vector<float, 8> vec1 = rbuf.Load< vector<float, 8> >(i++*32); |
11 | | - vector<float, 8> vec2 = rbuf.Load< vector<float, 8> >(i++*32); |
12 | | - vector<float, 8> vec3 = rbuf.Load< vector<float, 8> >(i++*32); |
13 | | - |
14 | | - // CHECK: fdiv fast <8 x float> |
15 | | - // CHECK: call float @dx.op.unary.f32(i32 17, float %{{.*}}) ; Atan(value) |
16 | | - // CHECK: call float @dx.op.unary.f32(i32 17, float %{{.*}}) ; Atan(value) |
17 | | - // CHECK: call float @dx.op.unary.f32(i32 17, float %{{.*}}) ; Atan(value) |
18 | | - // CHECK: call float @dx.op.unary.f32(i32 17, float %{{.*}}) ; Atan(value) |
19 | | - // CHECK: call float @dx.op.unary.f32(i32 17, float %{{.*}}) ; Atan(value) |
20 | | - // CHECK: call float @dx.op.unary.f32(i32 17, float %{{.*}}) ; Atan(value) |
21 | | - // CHECK: call float @dx.op.unary.f32(i32 17, float %{{.*}}) ; Atan(value) |
22 | | - // CHECK: call float @dx.op.unary.f32(i32 17, float %{{.*}}) ; Atan(value) |
23 | | - // CHECK: fadd fast <8 x float> %{{.*}}, <float 0x |
24 | | - // CHECK: fadd fast <8 x float> %{{.*}}, <float 0x |
25 | | - // CHECK: fcmp fast olt <8 x float> |
26 | | - // CHECK: fcmp fast oeq <8 x float> |
27 | | - // CHECK: fcmp fast oge <8 x float> |
28 | | - // CHECK: fcmp fast olt <8 x float> |
29 | | - // CHECK: and <8 x i1> |
30 | | - // CHECK: select <8 x i1> %{{.*}}, <8 x float> %{{.*}}, <8 x float> |
31 | | - // CHECK: and <8 x i1> |
32 | | - // CHECK: select <8 x i1> %{{.*}}, <8 x float> %{{.*}}, <8 x float> |
33 | | - // CHECK: and <8 x i1> |
34 | | - // CHECK: select <8 x i1> %{{.*}}, <8 x float> <float 0x |
35 | | - // CHECK: and <8 x i1> |
36 | | - // CHECK: select <8 x i1> %{{.*}}, <8 x float> <float 0x |
| 6 | +// CHECK-LABEL: test_atan2 |
| 7 | +// CHECK: fdiv fast <8 x float> |
| 8 | +// CHECK: call <8 x float> @dx.op.unary.v8f32(i32 17, <8 x float> %{{.*}}) ; Atan(value) |
| 9 | +// CHECK: fadd fast <8 x float> %{{.*}}, <float 0x |
| 10 | +// CHECK: fadd fast <8 x float> %{{.*}}, <float 0x |
| 11 | +// CHECK: fcmp fast olt <8 x float> |
| 12 | +// CHECK: fcmp fast oeq <8 x float> |
| 13 | +// CHECK: fcmp fast oge <8 x float> |
| 14 | +// CHECK: fcmp fast olt <8 x float> |
| 15 | +// CHECK: and <8 x i1> |
| 16 | +// CHECK: select <8 x i1> %{{.*}}, <8 x float> %{{.*}}, <8 x float> |
| 17 | +// CHECK: and <8 x i1> |
| 18 | +// CHECK: select <8 x i1> %{{.*}}, <8 x float> %{{.*}}, <8 x float> |
| 19 | +// CHECK: and <8 x i1> |
| 20 | +// CHECK: select <8 x i1> %{{.*}}, <8 x float> <float 0x |
| 21 | +// CHECK: and <8 x i1> |
| 22 | +// CHECK: select <8 x i1> %{{.*}}, <8 x float> <float 0x |
| 23 | +export void test_atan2(inout vector<float, 8> vec1, vector<float, 8> vec2) { |
37 | 24 | vec1 = atan2(vec1, vec2); |
| 25 | +} |
38 | 26 |
|
| 27 | +// CHECK-LABEL: test_fmod |
| 28 | +// CHECK: fdiv fast <8 x float> |
| 29 | +// CHECK: fsub fast <8 x float> <float |
| 30 | +// CHECK: fcmp fast oge <8 x float> |
| 31 | +// CHECK: call <8 x float> @dx.op.unary.v8f32(i32 6, <8 x float> %{{.*}}) ; FAbs(value) |
| 32 | +// CHECK: call <8 x float> @dx.op.unary.v8f32(i32 22, <8 x float> %{{.*}}) ; Frc(value) |
39 | 33 |
|
40 | | - // CHECK: fdiv fast <8 x float> |
41 | | - // CHECK: fsub fast <8 x float> <float |
42 | | - // CHECK: fcmp fast oge <8 x float> |
43 | | - // CHECK: call float @dx.op.unary.f32(i32 6, float %{{.*}}) ; FAbs(value) |
44 | | - // CHECK: call float @dx.op.unary.f32(i32 6, float %{{.*}}) ; FAbs(value) |
45 | | - // CHECK: call float @dx.op.unary.f32(i32 6, float %{{.*}}) ; FAbs(value) |
46 | | - // CHECK: call float @dx.op.unary.f32(i32 6, float %{{.*}}) ; FAbs(value) |
47 | | - // CHECK: call float @dx.op.unary.f32(i32 6, float %{{.*}}) ; FAbs(value) |
48 | | - // CHECK: call float @dx.op.unary.f32(i32 6, float %{{.*}}) ; FAbs(value) |
49 | | - // CHECK: call float @dx.op.unary.f32(i32 6, float %{{.*}}) ; FAbs(value) |
50 | | - // CHECK: call float @dx.op.unary.f32(i32 6, float %{{.*}}) ; FAbs(value) |
51 | | - |
52 | | - // CHECK: call float @dx.op.unary.f32(i32 22, float %{{.*}}) ; Frc(value) |
53 | | - // CHECK: call float @dx.op.unary.f32(i32 22, float %{{.*}}) ; Frc(value) |
54 | | - // CHECK: call float @dx.op.unary.f32(i32 22, float %{{.*}}) ; Frc(value) |
55 | | - // CHECK: call float @dx.op.unary.f32(i32 22, float %{{.*}}) ; Frc(value) |
56 | | - // CHECK: call float @dx.op.unary.f32(i32 22, float %{{.*}}) ; Frc(value) |
57 | | - // CHECK: call float @dx.op.unary.f32(i32 22, float %{{.*}}) ; Frc(value) |
58 | | - // CHECK: call float @dx.op.unary.f32(i32 22, float %{{.*}}) ; Frc(value) |
59 | | - // CHECK: call float @dx.op.unary.f32(i32 22, float %{{.*}}) ; Frc(value) |
60 | | - |
61 | | - // CHECK: fsub fast <8 x float> <float |
62 | | - // CHECK: select <8 x i1> %{{.*}}, <8 x float> %{{.*}}, <8 x float> |
63 | | - // CHECK: fmul fast <8 x float> |
| 34 | +// CHECK: fsub fast <8 x float> <float |
| 35 | +// CHECK: select <8 x i1> %{{.*}}, <8 x float> %{{.*}}, <8 x float> |
| 36 | +// CHECK: fmul fast <8 x float> |
| 37 | +export void test_fmod(inout vector<float, 8> vec1, vector<float, 8> vec2) { |
64 | 38 | vec1 = fmod(vec1, vec2); |
| 39 | +} |
| 40 | + |
| 41 | +// CHECK-LABEL: test_ldexp |
| 42 | +// CHECK: call <8 x float> @dx.op.unary.v8f32(i32 21, <8 x float> %{{.*}}) ; Exp(value) |
| 43 | +// CHECK: fmul fast <8 x float> |
65 | 44 |
|
66 | | - // CHECK: call float @dx.op.unary.f32(i32 21, float %{{.*}}) ; Exp(value) |
67 | | - // CHECK: call float @dx.op.unary.f32(i32 21, float %{{.*}}) ; Exp(value) |
68 | | - // CHECK: call float @dx.op.unary.f32(i32 21, float %{{.*}}) ; Exp(value) |
69 | | - // CHECK: call float @dx.op.unary.f32(i32 21, float %{{.*}}) ; Exp(value) |
70 | | - // CHECK: call float @dx.op.unary.f32(i32 21, float %{{.*}}) ; Exp(value) |
71 | | - // CHECK: call float @dx.op.unary.f32(i32 21, float %{{.*}}) ; Exp(value) |
72 | | - // CHECK: call float @dx.op.unary.f32(i32 21, float %{{.*}}) ; Exp(value) |
73 | | - // CHECK: call float @dx.op.unary.f32(i32 21, float %{{.*}}) ; Exp(value) |
74 | | - // CHECK: fmul fast <8 x float> |
| 45 | +export void test_ldexp(inout vector<float, 8> vec1, vector<float, 8> vec2) { |
75 | 46 | vec1 = ldexp(vec1, vec2); |
| 47 | +} |
| 48 | + |
76 | 49 |
|
77 | | - // CHECK: call float @dx.op.unary.f32(i32 23, float %{{.*}}) ; Log(value) |
78 | | - // CHECK: call float @dx.op.unary.f32(i32 23, float %{{.*}}) ; Log(value) |
79 | | - // CHECK: call float @dx.op.unary.f32(i32 23, float %{{.*}}) ; Log(value) |
80 | | - // CHECK: call float @dx.op.unary.f32(i32 23, float %{{.*}}) ; Log(value) |
81 | | - // CHECK: call float @dx.op.unary.f32(i32 23, float %{{.*}}) ; Log(value) |
82 | | - // CHECK: call float @dx.op.unary.f32(i32 23, float %{{.*}}) ; Log(value) |
83 | | - // CHECK: call float @dx.op.unary.f32(i32 23, float %{{.*}}) ; Log(value) |
84 | | - // CHECK: call float @dx.op.unary.f32(i32 23, float %{{.*}}) ; Log(value) |
85 | | - // CHECK: fmul fast <8 x float> |
86 | | - // CHECK: call float @dx.op.unary.f32(i32 21, float %{{.*}}) ; Exp(value) |
87 | | - // CHECK: call float @dx.op.unary.f32(i32 21, float %{{.*}}) ; Exp(value) |
88 | | - // CHECK: call float @dx.op.unary.f32(i32 21, float %{{.*}}) ; Exp(value) |
89 | | - // CHECK: call float @dx.op.unary.f32(i32 21, float %{{.*}}) ; Exp(value) |
90 | | - // CHECK: call float @dx.op.unary.f32(i32 21, float %{{.*}}) ; Exp(value) |
91 | | - // CHECK: call float @dx.op.unary.f32(i32 21, float %{{.*}}) ; Exp(value) |
92 | | - // CHECK: call float @dx.op.unary.f32(i32 21, float %{{.*}}) ; Exp(value) |
93 | | - // CHECK: call float @dx.op.unary.f32(i32 21, float %{{.*}}) ; Exp(value) |
| 50 | +// CHECK-LABEL: test_pow |
| 51 | +// CHECK: call <8 x float> @dx.op.unary.v8f32(i32 23, <8 x float> %{{.*}}) ; Log(value) |
| 52 | +// CHECK: fmul fast <8 x float> |
| 53 | +// CHECK: call <8 x float> @dx.op.unary.v8f32(i32 21, <8 x float> %{{.*}}) ; Exp(value) |
| 54 | +export void test_pow(inout vector<float, 8> vec1, vector<float, 8> vec2) { |
94 | 55 | vec1 = pow(vec1, vec2); |
| 56 | +} |
95 | 57 |
|
96 | | - // CHECK: call float @dx.op.unary.f32(i32 29, float %{{.*}}) ; Round_z(value) |
97 | | - // CHECK: call float @dx.op.unary.f32(i32 29, float %{{.*}}) ; Round_z(value) |
98 | | - // CHECK: call float @dx.op.unary.f32(i32 29, float %{{.*}}) ; Round_z(value) |
99 | | - // CHECK: call float @dx.op.unary.f32(i32 29, float %{{.*}}) ; Round_z(value) |
100 | | - // CHECK: call float @dx.op.unary.f32(i32 29, float %{{.*}}) ; Round_z(value) |
101 | | - // CHECK: call float @dx.op.unary.f32(i32 29, float %{{.*}}) ; Round_z(value) |
102 | | - // CHECK: call float @dx.op.unary.f32(i32 29, float %{{.*}}) ; Round_z(value) |
103 | | - // CHECK: call float @dx.op.unary.f32(i32 29, float %{{.*}}) ; Round_z(value) |
104 | | - // CHECK: fsub fast <8 x float> |
| 58 | +// CHECK-LABEL: test_modf |
| 59 | +// CHECK: call <8 x float> @dx.op.unary.v8f32(i32 29, <8 x float> %{{.*}}) ; Round_z(value) |
| 60 | +// CHECK: fsub fast <8 x float> |
| 61 | +export void test_modf(inout vector<float, 8> vec1, vector<float, 8> vec2) { |
105 | 62 | vec1 = modf(vec1, vec2); |
| 63 | +} |
106 | 64 |
|
107 | | - // CHECK: [[el:%.*]] = extractelement <8 x float> |
108 | | - // CHECK: [[mul:%.*]] = fmul fast float [[el]] |
109 | | - // CHECK: [[ping:%.*]] = call float @dx.op.tertiary.f32(i32 46, float %{{.*}}, float %{{.*}}, float [[mul]]) ; FMad(a,b,c) |
110 | | - // CHECK: [[pong:%.*]] = call float @dx.op.tertiary.f32(i32 46, float %{{.*}}, float %{{.*}}, float [[ping]]) ; FMad(a,b,c) |
111 | | - // CHECK: [[ping:%.*]] = call float @dx.op.tertiary.f32(i32 46, float %{{.*}}, float %{{.*}}, float [[pong]]) ; FMad(a,b,c) |
112 | | - // CHECK: [[pong:%.*]] = call float @dx.op.tertiary.f32(i32 46, float %{{.*}}, float %{{.*}}, float [[ping]]) ; FMad(a,b,c) |
113 | | - // CHECK: [[ping:%.*]] = call float @dx.op.tertiary.f32(i32 46, float %{{.*}}, float %{{.*}}, float [[pong]]) ; FMad(a,b,c) |
114 | | - // CHECK: [[pong:%.*]] = call float @dx.op.tertiary.f32(i32 46, float %{{.*}}, float %{{.*}}, float [[ping]]) ; FMad(a,b,c) |
115 | | - // CHECK: [[ping:%.*]] = call float @dx.op.tertiary.f32(i32 46, float %{{.*}}, float %{{.*}}, float [[pong]]) ; FMad(a,b,c) |
| 65 | +// CHECK-LABEL: test_dot |
| 66 | +// CHECK: [[el:%.*]] = extractelement <8 x float> |
| 67 | +// CHECK: [[mul:%.*]] = fmul fast float [[el]] |
| 68 | +// CHECK: [[ping:%.*]] = call float @dx.op.tertiary.f32(i32 46, float %{{.*}}, float %{{.*}}, float [[mul]]) ; FMad(a,b,c) |
| 69 | +// CHECK: [[pong:%.*]] = call float @dx.op.tertiary.f32(i32 46, float %{{.*}}, float %{{.*}}, float [[ping]]) ; FMad(a,b,c) |
| 70 | +// CHECK: [[ping:%.*]] = call float @dx.op.tertiary.f32(i32 46, float %{{.*}}, float %{{.*}}, float [[pong]]) ; FMad(a,b,c) |
| 71 | +// CHECK: [[pong:%.*]] = call float @dx.op.tertiary.f32(i32 46, float %{{.*}}, float %{{.*}}, float [[ping]]) ; FMad(a,b,c) |
| 72 | +// CHECK: [[ping:%.*]] = call float @dx.op.tertiary.f32(i32 46, float %{{.*}}, float %{{.*}}, float [[pong]]) ; FMad(a,b,c) |
| 73 | +// CHECK: [[pong:%.*]] = call float @dx.op.tertiary.f32(i32 46, float %{{.*}}, float %{{.*}}, float [[ping]]) ; FMad(a,b,c) |
| 74 | +// CHECK: [[ping:%.*]] = call float @dx.op.tertiary.f32(i32 46, float %{{.*}}, float %{{.*}}, float [[pong]]) ; FMad(a,b,c) |
| 75 | +export void test_dot(inout vector<float, 8> vec1, vector<float, 8> vec2) { |
116 | 76 | vec1 = dot(vec1, vec2); |
| 77 | +} |
117 | 78 |
|
118 | | - vector<bool, 8> bvec = b; |
119 | | - // CHECK: or i1 |
120 | | - // CHECK: or i1 |
121 | | - // CHECK: or i1 |
122 | | - // CHECK: or i1 |
123 | | - // CHECK: or i1 |
124 | | - // CHECK: or i1 |
125 | | - // CHECK: or i1 |
| 79 | +// CHECK-LABEL: test_any |
| 80 | +// CHECK: or i1 |
| 81 | +// CHECK: or i1 |
| 82 | +// CHECK: or i1 |
| 83 | +// CHECK: or i1 |
| 84 | +// CHECK: or i1 |
| 85 | +// CHECK: or i1 |
| 86 | +// CHECK: or i1 |
| 87 | +export void test_any(vector<float, 8> vec1, inout vector<bool, 8> bvec) { |
126 | 88 | bvec &= any(vec1); |
| 89 | +} |
127 | 90 |
|
128 | | - // CHECK: and i1 |
129 | | - // CHECK: and i1 |
130 | | - // CHECK: and i1 |
131 | | - // CHECK: and i1 |
132 | | - // CHECK: and i1 |
133 | | - // CHECK: and i1 |
134 | | - // CHECK: and i1 |
135 | | - bvec &= all(vec2); |
| 91 | +// CHECK-LABEL: test_all |
| 92 | +// CHECK: and i1 |
| 93 | +// CHECK: and i1 |
| 94 | +// CHECK: and i1 |
| 95 | +// CHECK: and i1 |
| 96 | +// CHECK: and i1 |
| 97 | +// CHECK: and i1 |
| 98 | +// CHECK: and i1 |
| 99 | +export void test_all(vector<float, 8> vec1, inout vector<bool, 8> bvec) { |
| 100 | + bvec &= all(vec1); |
| 101 | +} |
136 | 102 |
|
137 | | - // call {{.*}} @dx.op.wave |
138 | | - // call {{.*}} @dx.op.wave |
139 | | - // call {{.*}} @dx.op.wave |
140 | | - // call {{.*}} @dx.op.wave |
141 | | - // call {{.*}} @dx.op.wave |
142 | | - // call {{.*}} @dx.op.wave |
143 | | - // call {{.*}} @dx.op.wave |
144 | | - // call {{.*}} @dx.op.wave |
145 | | - // call {{.*}} @dx.op.wave |
| 103 | +// CHECK-LABEL: test_WaveMatch |
| 104 | +// call {{.*}} @dx.op.wave |
| 105 | +// call {{.*}} @dx.op.wave |
| 106 | +// call {{.*}} @dx.op.wave |
| 107 | +// call {{.*}} @dx.op.wave |
| 108 | +// call {{.*}} @dx.op.wave |
| 109 | +// call {{.*}} @dx.op.wave |
| 110 | +// call {{.*}} @dx.op.wave |
| 111 | +// call {{.*}} @dx.op.wave |
| 112 | +// call {{.*}} @dx.op.wave |
| 113 | +export uint4 test_WaveMatch(vector<bool, 8> bvec) { |
146 | 114 | return WaveMatch(bvec); |
147 | 115 | } |
0 commit comments