1*61046927SAndroid Build Coastguard Worker /*
2*61046927SAndroid Build Coastguard Worker * Copyright © 2020 Valve Corporation
3*61046927SAndroid Build Coastguard Worker *
4*61046927SAndroid Build Coastguard Worker * Permission is hereby granted, free of charge, to any person obtaining a
5*61046927SAndroid Build Coastguard Worker * copy of this software and associated documentation files (the "Software"),
6*61046927SAndroid Build Coastguard Worker * to deal in the Software without restriction, including without limitation
7*61046927SAndroid Build Coastguard Worker * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8*61046927SAndroid Build Coastguard Worker * and/or sell copies of the Software, and to permit persons to whom the
9*61046927SAndroid Build Coastguard Worker * Software is furnished to do so, subject to the following conditions:
10*61046927SAndroid Build Coastguard Worker *
11*61046927SAndroid Build Coastguard Worker * The above copyright notice and this permission notice (including the next
12*61046927SAndroid Build Coastguard Worker * paragraph) shall be included in all copies or substantial portions of the
13*61046927SAndroid Build Coastguard Worker * Software.
14*61046927SAndroid Build Coastguard Worker *
15*61046927SAndroid Build Coastguard Worker * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16*61046927SAndroid Build Coastguard Worker * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17*61046927SAndroid Build Coastguard Worker * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
18*61046927SAndroid Build Coastguard Worker * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19*61046927SAndroid Build Coastguard Worker * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20*61046927SAndroid Build Coastguard Worker * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
21*61046927SAndroid Build Coastguard Worker * IN THE SOFTWARE.
22*61046927SAndroid Build Coastguard Worker */
23*61046927SAndroid Build Coastguard Worker #include "helpers.h"
24*61046927SAndroid Build Coastguard Worker
25*61046927SAndroid Build Coastguard Worker class Volatile : public spirv_test {};
26*61046927SAndroid Build Coastguard Worker
TEST_F(Volatile,opload_volatile)27*61046927SAndroid Build Coastguard Worker TEST_F(Volatile, opload_volatile)
28*61046927SAndroid Build Coastguard Worker {
29*61046927SAndroid Build Coastguard Worker /*
30*61046927SAndroid Build Coastguard Worker OpCapability Shader
31*61046927SAndroid Build Coastguard Worker %1 = OpExtInstImport "GLSL.std.450"
32*61046927SAndroid Build Coastguard Worker OpMemoryModel Logical GLSL450
33*61046927SAndroid Build Coastguard Worker OpEntryPoint GLCompute %4 "main"
34*61046927SAndroid Build Coastguard Worker OpExecutionMode %4 LocalSize 1 1 1
35*61046927SAndroid Build Coastguard Worker OpMemberDecorate %_struct_7 0 Offset 0
36*61046927SAndroid Build Coastguard Worker OpDecorate %_struct_7 BufferBlock
37*61046927SAndroid Build Coastguard Worker OpDecorate %9 DescriptorSet 0
38*61046927SAndroid Build Coastguard Worker OpDecorate %9 Binding 0
39*61046927SAndroid Build Coastguard Worker %void = OpTypeVoid
40*61046927SAndroid Build Coastguard Worker %3 = OpTypeFunction %void
41*61046927SAndroid Build Coastguard Worker %uint = OpTypeInt 32 0
42*61046927SAndroid Build Coastguard Worker %_struct_7 = OpTypeStruct %uint
43*61046927SAndroid Build Coastguard Worker %_ptr_Uniform__struct_7 = OpTypePointer Uniform %_struct_7
44*61046927SAndroid Build Coastguard Worker %9 = OpVariable %_ptr_Uniform__struct_7 Uniform
45*61046927SAndroid Build Coastguard Worker %int = OpTypeInt 32 1
46*61046927SAndroid Build Coastguard Worker %int_0 = OpConstant %int 0
47*61046927SAndroid Build Coastguard Worker %_ptr_Uniform_uint = OpTypePointer Uniform %uint
48*61046927SAndroid Build Coastguard Worker %4 = OpFunction %void None %3
49*61046927SAndroid Build Coastguard Worker %5 = OpLabel
50*61046927SAndroid Build Coastguard Worker %13 = OpAccessChain %_ptr_Uniform_uint %9 %int_0
51*61046927SAndroid Build Coastguard Worker %14 = OpLoad %uint %13 Volatile
52*61046927SAndroid Build Coastguard Worker OpStore %13 %14
53*61046927SAndroid Build Coastguard Worker OpReturn
54*61046927SAndroid Build Coastguard Worker OpFunctionEnd
55*61046927SAndroid Build Coastguard Worker */
56*61046927SAndroid Build Coastguard Worker static const uint32_t words[] = {
57*61046927SAndroid Build Coastguard Worker 0x07230203, 0x00010300, 0x00070000, 0x0000000f, 0x00000000, 0x00020011,
58*61046927SAndroid Build Coastguard Worker 0x00000001, 0x0006000b, 0x00000001, 0x4c534c47, 0x6474732e, 0x3035342e,
59*61046927SAndroid Build Coastguard Worker 0x00000000, 0x0003000e, 0x00000000, 0x00000001, 0x0005000f, 0x00000005,
60*61046927SAndroid Build Coastguard Worker 0x00000002, 0x6e69616d, 0x00000000, 0x00060010, 0x00000002, 0x00000011,
61*61046927SAndroid Build Coastguard Worker 0x00000001, 0x00000001, 0x00000001, 0x00050048, 0x00000003, 0x00000000,
62*61046927SAndroid Build Coastguard Worker 0x00000023, 0x00000000, 0x00030047, 0x00000003, 0x00000003, 0x00040047,
63*61046927SAndroid Build Coastguard Worker 0x00000004, 0x00000022, 0x00000000, 0x00040047, 0x00000004, 0x00000021,
64*61046927SAndroid Build Coastguard Worker 0x00000000, 0x00020013, 0x00000005, 0x00030021, 0x00000006, 0x00000005,
65*61046927SAndroid Build Coastguard Worker 0x00040015, 0x00000007, 0x00000020, 0x00000000, 0x0003001e, 0x00000003,
66*61046927SAndroid Build Coastguard Worker 0x00000007, 0x00040020, 0x00000008, 0x00000002, 0x00000003, 0x0004003b,
67*61046927SAndroid Build Coastguard Worker 0x00000008, 0x00000004, 0x00000002, 0x00040015, 0x00000009, 0x00000020,
68*61046927SAndroid Build Coastguard Worker 0x00000001, 0x0004002b, 0x00000009, 0x0000000a, 0x00000000, 0x00040020,
69*61046927SAndroid Build Coastguard Worker 0x0000000b, 0x00000002, 0x00000007, 0x00050036, 0x00000005, 0x00000002,
70*61046927SAndroid Build Coastguard Worker 0x00000000, 0x00000006, 0x000200f8, 0x0000000c, 0x00050041, 0x0000000b,
71*61046927SAndroid Build Coastguard Worker 0x0000000d, 0x00000004, 0x0000000a, 0x0005003d, 0x00000007, 0x0000000e,
72*61046927SAndroid Build Coastguard Worker 0x0000000d, 0x00000001, 0x0003003e, 0x0000000d, 0x0000000e, 0x000100fd,
73*61046927SAndroid Build Coastguard Worker 0x00010038,
74*61046927SAndroid Build Coastguard Worker };
75*61046927SAndroid Build Coastguard Worker
76*61046927SAndroid Build Coastguard Worker get_nir(sizeof(words) / sizeof(words[0]), words);
77*61046927SAndroid Build Coastguard Worker
78*61046927SAndroid Build Coastguard Worker nir_intrinsic_instr *intrinsic = find_intrinsic(nir_intrinsic_load_deref);
79*61046927SAndroid Build Coastguard Worker ASSERT_NE(intrinsic, nullptr);
80*61046927SAndroid Build Coastguard Worker EXPECT_NE(nir_intrinsic_access(intrinsic) & ACCESS_VOLATILE, 0);
81*61046927SAndroid Build Coastguard Worker }
82*61046927SAndroid Build Coastguard Worker
TEST_F(Volatile,opstore_volatile)83*61046927SAndroid Build Coastguard Worker TEST_F(Volatile, opstore_volatile)
84*61046927SAndroid Build Coastguard Worker {
85*61046927SAndroid Build Coastguard Worker /*
86*61046927SAndroid Build Coastguard Worker OpCapability Shader
87*61046927SAndroid Build Coastguard Worker %1 = OpExtInstImport "GLSL.std.450"
88*61046927SAndroid Build Coastguard Worker OpMemoryModel Logical GLSL450
89*61046927SAndroid Build Coastguard Worker OpEntryPoint GLCompute %4 "main"
90*61046927SAndroid Build Coastguard Worker OpExecutionMode %4 LocalSize 1 1 1
91*61046927SAndroid Build Coastguard Worker OpMemberDecorate %_struct_7 0 Offset 0
92*61046927SAndroid Build Coastguard Worker OpDecorate %_struct_7 BufferBlock
93*61046927SAndroid Build Coastguard Worker OpDecorate %9 DescriptorSet 0
94*61046927SAndroid Build Coastguard Worker OpDecorate %9 Binding 0
95*61046927SAndroid Build Coastguard Worker %void = OpTypeVoid
96*61046927SAndroid Build Coastguard Worker %3 = OpTypeFunction %void
97*61046927SAndroid Build Coastguard Worker %uint = OpTypeInt 32 0
98*61046927SAndroid Build Coastguard Worker %_struct_7 = OpTypeStruct %uint
99*61046927SAndroid Build Coastguard Worker %_ptr_Uniform__struct_7 = OpTypePointer Uniform %_struct_7
100*61046927SAndroid Build Coastguard Worker %9 = OpVariable %_ptr_Uniform__struct_7 Uniform
101*61046927SAndroid Build Coastguard Worker %int = OpTypeInt 32 1
102*61046927SAndroid Build Coastguard Worker %int_0 = OpConstant %int 0
103*61046927SAndroid Build Coastguard Worker %_ptr_Uniform_uint = OpTypePointer Uniform %uint
104*61046927SAndroid Build Coastguard Worker %4 = OpFunction %void None %3
105*61046927SAndroid Build Coastguard Worker %5 = OpLabel
106*61046927SAndroid Build Coastguard Worker %13 = OpAccessChain %_ptr_Uniform_uint %9 %int_0
107*61046927SAndroid Build Coastguard Worker %14 = OpLoad %uint %13
108*61046927SAndroid Build Coastguard Worker OpStore %13 %14 Volatile
109*61046927SAndroid Build Coastguard Worker OpReturn
110*61046927SAndroid Build Coastguard Worker OpFunctionEnd
111*61046927SAndroid Build Coastguard Worker */
112*61046927SAndroid Build Coastguard Worker static const uint32_t words[] = {
113*61046927SAndroid Build Coastguard Worker 0x07230203, 0x00010300, 0x00070000, 0x0000000f, 0x00000000, 0x00020011,
114*61046927SAndroid Build Coastguard Worker 0x00000001, 0x0006000b, 0x00000001, 0x4c534c47, 0x6474732e, 0x3035342e,
115*61046927SAndroid Build Coastguard Worker 0x00000000, 0x0003000e, 0x00000000, 0x00000001, 0x0005000f, 0x00000005,
116*61046927SAndroid Build Coastguard Worker 0x00000002, 0x6e69616d, 0x00000000, 0x00060010, 0x00000002, 0x00000011,
117*61046927SAndroid Build Coastguard Worker 0x00000001, 0x00000001, 0x00000001, 0x00050048, 0x00000003, 0x00000000,
118*61046927SAndroid Build Coastguard Worker 0x00000023, 0x00000000, 0x00030047, 0x00000003, 0x00000003, 0x00040047,
119*61046927SAndroid Build Coastguard Worker 0x00000004, 0x00000022, 0x00000000, 0x00040047, 0x00000004, 0x00000021,
120*61046927SAndroid Build Coastguard Worker 0x00000000, 0x00020013, 0x00000005, 0x00030021, 0x00000006, 0x00000005,
121*61046927SAndroid Build Coastguard Worker 0x00040015, 0x00000007, 0x00000020, 0x00000000, 0x0003001e, 0x00000003,
122*61046927SAndroid Build Coastguard Worker 0x00000007, 0x00040020, 0x00000008, 0x00000002, 0x00000003, 0x0004003b,
123*61046927SAndroid Build Coastguard Worker 0x00000008, 0x00000004, 0x00000002, 0x00040015, 0x00000009, 0x00000020,
124*61046927SAndroid Build Coastguard Worker 0x00000001, 0x0004002b, 0x00000009, 0x0000000a, 0x00000000, 0x00040020,
125*61046927SAndroid Build Coastguard Worker 0x0000000b, 0x00000002, 0x00000007, 0x00050036, 0x00000005, 0x00000002,
126*61046927SAndroid Build Coastguard Worker 0x00000000, 0x00000006, 0x000200f8, 0x0000000c, 0x00050041, 0x0000000b,
127*61046927SAndroid Build Coastguard Worker 0x0000000d, 0x00000004, 0x0000000a, 0x0004003d, 0x00000007, 0x0000000e,
128*61046927SAndroid Build Coastguard Worker 0x0000000d, 0x0004003e, 0x0000000d, 0x0000000e, 0x00000001, 0x000100fd,
129*61046927SAndroid Build Coastguard Worker 0x00010038,
130*61046927SAndroid Build Coastguard Worker };
131*61046927SAndroid Build Coastguard Worker
132*61046927SAndroid Build Coastguard Worker get_nir(sizeof(words) / sizeof(words[0]), words);
133*61046927SAndroid Build Coastguard Worker
134*61046927SAndroid Build Coastguard Worker nir_intrinsic_instr *intrinsic = find_intrinsic(nir_intrinsic_store_deref);
135*61046927SAndroid Build Coastguard Worker ASSERT_NE(intrinsic, nullptr);
136*61046927SAndroid Build Coastguard Worker EXPECT_NE(nir_intrinsic_access(intrinsic) & ACCESS_VOLATILE, 0);
137*61046927SAndroid Build Coastguard Worker }
138*61046927SAndroid Build Coastguard Worker
TEST_F(Volatile,opcopymemory_volatile_both)139*61046927SAndroid Build Coastguard Worker TEST_F(Volatile, opcopymemory_volatile_both)
140*61046927SAndroid Build Coastguard Worker {
141*61046927SAndroid Build Coastguard Worker /*
142*61046927SAndroid Build Coastguard Worker OpCapability Shader
143*61046927SAndroid Build Coastguard Worker %1 = OpExtInstImport "GLSL.std.450"
144*61046927SAndroid Build Coastguard Worker OpMemoryModel Logical GLSL450
145*61046927SAndroid Build Coastguard Worker OpEntryPoint GLCompute %4 "main"
146*61046927SAndroid Build Coastguard Worker OpExecutionMode %4 LocalSize 1 1 1
147*61046927SAndroid Build Coastguard Worker OpMemberDecorate %_struct_7 0 Offset 0
148*61046927SAndroid Build Coastguard Worker OpDecorate %_struct_7 BufferBlock
149*61046927SAndroid Build Coastguard Worker OpDecorate %9 DescriptorSet 0
150*61046927SAndroid Build Coastguard Worker OpDecorate %9 Binding 0
151*61046927SAndroid Build Coastguard Worker %void = OpTypeVoid
152*61046927SAndroid Build Coastguard Worker %3 = OpTypeFunction %void
153*61046927SAndroid Build Coastguard Worker %uint = OpTypeInt 32 0
154*61046927SAndroid Build Coastguard Worker %_struct_7 = OpTypeStruct %uint
155*61046927SAndroid Build Coastguard Worker %_ptr_Uniform__struct_7 = OpTypePointer Uniform %_struct_7
156*61046927SAndroid Build Coastguard Worker %9 = OpVariable %_ptr_Uniform__struct_7 Uniform
157*61046927SAndroid Build Coastguard Worker %int = OpTypeInt 32 1
158*61046927SAndroid Build Coastguard Worker %int_0 = OpConstant %int 0
159*61046927SAndroid Build Coastguard Worker %_ptr_Uniform_uint = OpTypePointer Uniform %uint
160*61046927SAndroid Build Coastguard Worker %4 = OpFunction %void None %3
161*61046927SAndroid Build Coastguard Worker %5 = OpLabel
162*61046927SAndroid Build Coastguard Worker %13 = OpAccessChain %_ptr_Uniform_uint %9 %int_0
163*61046927SAndroid Build Coastguard Worker OpCopyMemory %13 %13 Volatile
164*61046927SAndroid Build Coastguard Worker OpReturn
165*61046927SAndroid Build Coastguard Worker OpFunctionEnd
166*61046927SAndroid Build Coastguard Worker */
167*61046927SAndroid Build Coastguard Worker static const uint32_t words[] = {
168*61046927SAndroid Build Coastguard Worker 0x07230203, 0x00010300, 0x00070000, 0x0000000e, 0x00000000, 0x00020011,
169*61046927SAndroid Build Coastguard Worker 0x00000001, 0x0006000b, 0x00000001, 0x4c534c47, 0x6474732e, 0x3035342e,
170*61046927SAndroid Build Coastguard Worker 0x00000000, 0x0003000e, 0x00000000, 0x00000001, 0x0005000f, 0x00000005,
171*61046927SAndroid Build Coastguard Worker 0x00000002, 0x6e69616d, 0x00000000, 0x00060010, 0x00000002, 0x00000011,
172*61046927SAndroid Build Coastguard Worker 0x00000001, 0x00000001, 0x00000001, 0x00050048, 0x00000003, 0x00000000,
173*61046927SAndroid Build Coastguard Worker 0x00000023, 0x00000000, 0x00030047, 0x00000003, 0x00000003, 0x00040047,
174*61046927SAndroid Build Coastguard Worker 0x00000004, 0x00000022, 0x00000000, 0x00040047, 0x00000004, 0x00000021,
175*61046927SAndroid Build Coastguard Worker 0x00000000, 0x00020013, 0x00000005, 0x00030021, 0x00000006, 0x00000005,
176*61046927SAndroid Build Coastguard Worker 0x00040015, 0x00000007, 0x00000020, 0x00000000, 0x0003001e, 0x00000003,
177*61046927SAndroid Build Coastguard Worker 0x00000007, 0x00040020, 0x00000008, 0x00000002, 0x00000003, 0x0004003b,
178*61046927SAndroid Build Coastguard Worker 0x00000008, 0x00000004, 0x00000002, 0x00040015, 0x00000009, 0x00000020,
179*61046927SAndroid Build Coastguard Worker 0x00000001, 0x0004002b, 0x00000009, 0x0000000a, 0x00000000, 0x00040020,
180*61046927SAndroid Build Coastguard Worker 0x0000000b, 0x00000002, 0x00000007, 0x00050036, 0x00000005, 0x00000002,
181*61046927SAndroid Build Coastguard Worker 0x00000000, 0x00000006, 0x000200f8, 0x0000000c, 0x00050041, 0x0000000b,
182*61046927SAndroid Build Coastguard Worker 0x0000000d, 0x00000004, 0x0000000a, 0x0004003f, 0x0000000d, 0x0000000d,
183*61046927SAndroid Build Coastguard Worker 0x00000001, 0x000100fd, 0x00010038,
184*61046927SAndroid Build Coastguard Worker };
185*61046927SAndroid Build Coastguard Worker
186*61046927SAndroid Build Coastguard Worker get_nir(sizeof(words) / sizeof(words[0]), words);
187*61046927SAndroid Build Coastguard Worker
188*61046927SAndroid Build Coastguard Worker nir_intrinsic_instr *intrinsic = find_intrinsic(nir_intrinsic_load_deref);
189*61046927SAndroid Build Coastguard Worker ASSERT_NE(intrinsic, nullptr);
190*61046927SAndroid Build Coastguard Worker EXPECT_NE(nir_intrinsic_access(intrinsic) & ACCESS_VOLATILE, 0);
191*61046927SAndroid Build Coastguard Worker
192*61046927SAndroid Build Coastguard Worker intrinsic = find_intrinsic(nir_intrinsic_store_deref);
193*61046927SAndroid Build Coastguard Worker ASSERT_NE(intrinsic, nullptr);
194*61046927SAndroid Build Coastguard Worker EXPECT_NE(nir_intrinsic_access(intrinsic) & ACCESS_VOLATILE, 0);
195*61046927SAndroid Build Coastguard Worker }
196*61046927SAndroid Build Coastguard Worker
TEST_F(Volatile,opcopymemory_volatile_target)197*61046927SAndroid Build Coastguard Worker TEST_F(Volatile, opcopymemory_volatile_target)
198*61046927SAndroid Build Coastguard Worker {
199*61046927SAndroid Build Coastguard Worker /*
200*61046927SAndroid Build Coastguard Worker OpCapability Shader
201*61046927SAndroid Build Coastguard Worker %1 = OpExtInstImport "GLSL.std.450"
202*61046927SAndroid Build Coastguard Worker OpMemoryModel Logical GLSL450
203*61046927SAndroid Build Coastguard Worker OpEntryPoint GLCompute %4 "main" %9
204*61046927SAndroid Build Coastguard Worker OpExecutionMode %4 LocalSize 1 1 1
205*61046927SAndroid Build Coastguard Worker OpMemberDecorate %_struct_7 0 Offset 0
206*61046927SAndroid Build Coastguard Worker OpDecorate %_struct_7 Block
207*61046927SAndroid Build Coastguard Worker OpDecorate %9 DescriptorSet 0
208*61046927SAndroid Build Coastguard Worker OpDecorate %9 Binding 0
209*61046927SAndroid Build Coastguard Worker %void = OpTypeVoid
210*61046927SAndroid Build Coastguard Worker %3 = OpTypeFunction %void
211*61046927SAndroid Build Coastguard Worker %uint = OpTypeInt 32 0
212*61046927SAndroid Build Coastguard Worker %_struct_7 = OpTypeStruct %uint
213*61046927SAndroid Build Coastguard Worker %_ptr_StorageBuffer__struct_7 = OpTypePointer StorageBuffer %_struct_7
214*61046927SAndroid Build Coastguard Worker %9 = OpVariable %_ptr_StorageBuffer__struct_7 StorageBuffer
215*61046927SAndroid Build Coastguard Worker %int = OpTypeInt 32 1
216*61046927SAndroid Build Coastguard Worker %int_0 = OpConstant %int 0
217*61046927SAndroid Build Coastguard Worker %_ptr_StorageBuffer_uint = OpTypePointer StorageBuffer %uint
218*61046927SAndroid Build Coastguard Worker %4 = OpFunction %void None %3
219*61046927SAndroid Build Coastguard Worker %5 = OpLabel
220*61046927SAndroid Build Coastguard Worker %13 = OpAccessChain %_ptr_StorageBuffer_uint %9 %int_0
221*61046927SAndroid Build Coastguard Worker OpCopyMemory %13 %13 Volatile None
222*61046927SAndroid Build Coastguard Worker OpReturn
223*61046927SAndroid Build Coastguard Worker OpFunctionEnd
224*61046927SAndroid Build Coastguard Worker */
225*61046927SAndroid Build Coastguard Worker static const uint32_t words[] = {
226*61046927SAndroid Build Coastguard Worker 0x07230203, 0x00010500, 0x00070000, 0x0000000e, 0x00000000, 0x00020011,
227*61046927SAndroid Build Coastguard Worker 0x00000001, 0x0006000b, 0x00000001, 0x4c534c47, 0x6474732e, 0x3035342e,
228*61046927SAndroid Build Coastguard Worker 0x00000000, 0x0003000e, 0x00000000, 0x00000001, 0x0006000f, 0x00000005,
229*61046927SAndroid Build Coastguard Worker 0x00000002, 0x6e69616d, 0x00000000, 0x00000003, 0x00060010, 0x00000002,
230*61046927SAndroid Build Coastguard Worker 0x00000011, 0x00000001, 0x00000001, 0x00000001, 0x00050048, 0x00000004,
231*61046927SAndroid Build Coastguard Worker 0x00000000, 0x00000023, 0x00000000, 0x00030047, 0x00000004, 0x00000002,
232*61046927SAndroid Build Coastguard Worker 0x00040047, 0x00000003, 0x00000022, 0x00000000, 0x00040047, 0x00000003,
233*61046927SAndroid Build Coastguard Worker 0x00000021, 0x00000000, 0x00020013, 0x00000005, 0x00030021, 0x00000006,
234*61046927SAndroid Build Coastguard Worker 0x00000005, 0x00040015, 0x00000007, 0x00000020, 0x00000000, 0x0003001e,
235*61046927SAndroid Build Coastguard Worker 0x00000004, 0x00000007, 0x00040020, 0x00000008, 0x0000000c, 0x00000004,
236*61046927SAndroid Build Coastguard Worker 0x0004003b, 0x00000008, 0x00000003, 0x0000000c, 0x00040015, 0x00000009,
237*61046927SAndroid Build Coastguard Worker 0x00000020, 0x00000001, 0x0004002b, 0x00000009, 0x0000000a, 0x00000000,
238*61046927SAndroid Build Coastguard Worker 0x00040020, 0x0000000b, 0x0000000c, 0x00000007, 0x00050036, 0x00000005,
239*61046927SAndroid Build Coastguard Worker 0x00000002, 0x00000000, 0x00000006, 0x000200f8, 0x0000000c, 0x00050041,
240*61046927SAndroid Build Coastguard Worker 0x0000000b, 0x0000000d, 0x00000003, 0x0000000a, 0x0005003f, 0x0000000d,
241*61046927SAndroid Build Coastguard Worker 0x0000000d, 0x00000001, 0x00000000, 0x000100fd, 0x00010038,
242*61046927SAndroid Build Coastguard Worker };
243*61046927SAndroid Build Coastguard Worker
244*61046927SAndroid Build Coastguard Worker get_nir(sizeof(words) / sizeof(words[0]), words);
245*61046927SAndroid Build Coastguard Worker
246*61046927SAndroid Build Coastguard Worker nir_intrinsic_instr *intrinsic = find_intrinsic(nir_intrinsic_load_deref);
247*61046927SAndroid Build Coastguard Worker ASSERT_NE(intrinsic, nullptr);
248*61046927SAndroid Build Coastguard Worker EXPECT_EQ(nir_intrinsic_access(intrinsic) & ACCESS_VOLATILE, 0);
249*61046927SAndroid Build Coastguard Worker
250*61046927SAndroid Build Coastguard Worker intrinsic = find_intrinsic(nir_intrinsic_store_deref);
251*61046927SAndroid Build Coastguard Worker ASSERT_NE(intrinsic, nullptr);
252*61046927SAndroid Build Coastguard Worker EXPECT_NE(nir_intrinsic_access(intrinsic) & ACCESS_VOLATILE, 0);
253*61046927SAndroid Build Coastguard Worker }
254*61046927SAndroid Build Coastguard Worker
TEST_F(Volatile,opcopymemory_volatile_source)255*61046927SAndroid Build Coastguard Worker TEST_F(Volatile, opcopymemory_volatile_source)
256*61046927SAndroid Build Coastguard Worker {
257*61046927SAndroid Build Coastguard Worker /*
258*61046927SAndroid Build Coastguard Worker OpCapability Shader
259*61046927SAndroid Build Coastguard Worker %1 = OpExtInstImport "GLSL.std.450"
260*61046927SAndroid Build Coastguard Worker OpMemoryModel Logical GLSL450
261*61046927SAndroid Build Coastguard Worker OpEntryPoint GLCompute %4 "main" %9
262*61046927SAndroid Build Coastguard Worker OpExecutionMode %4 LocalSize 1 1 1
263*61046927SAndroid Build Coastguard Worker OpMemberDecorate %_struct_7 0 Offset 0
264*61046927SAndroid Build Coastguard Worker OpDecorate %_struct_7 Block
265*61046927SAndroid Build Coastguard Worker OpDecorate %9 DescriptorSet 0
266*61046927SAndroid Build Coastguard Worker OpDecorate %9 Binding 0
267*61046927SAndroid Build Coastguard Worker %void = OpTypeVoid
268*61046927SAndroid Build Coastguard Worker %3 = OpTypeFunction %void
269*61046927SAndroid Build Coastguard Worker %uint = OpTypeInt 32 0
270*61046927SAndroid Build Coastguard Worker %_struct_7 = OpTypeStruct %uint
271*61046927SAndroid Build Coastguard Worker %_ptr_StorageBuffer__struct_7 = OpTypePointer StorageBuffer %_struct_7
272*61046927SAndroid Build Coastguard Worker %9 = OpVariable %_ptr_StorageBuffer__struct_7 StorageBuffer
273*61046927SAndroid Build Coastguard Worker %int = OpTypeInt 32 1
274*61046927SAndroid Build Coastguard Worker %int_0 = OpConstant %int 0
275*61046927SAndroid Build Coastguard Worker %_ptr_StorageBuffer_uint = OpTypePointer StorageBuffer %uint
276*61046927SAndroid Build Coastguard Worker %4 = OpFunction %void None %3
277*61046927SAndroid Build Coastguard Worker %5 = OpLabel
278*61046927SAndroid Build Coastguard Worker %13 = OpAccessChain %_ptr_StorageBuffer_uint %9 %int_0
279*61046927SAndroid Build Coastguard Worker OpCopyMemory %13 %13 None Volatile
280*61046927SAndroid Build Coastguard Worker OpReturn
281*61046927SAndroid Build Coastguard Worker OpFunctionEnd
282*61046927SAndroid Build Coastguard Worker */
283*61046927SAndroid Build Coastguard Worker static const uint32_t words[] = {
284*61046927SAndroid Build Coastguard Worker 0x07230203, 0x00010500, 0x00070000, 0x0000000e, 0x00000000, 0x00020011,
285*61046927SAndroid Build Coastguard Worker 0x00000001, 0x0006000b, 0x00000001, 0x4c534c47, 0x6474732e, 0x3035342e,
286*61046927SAndroid Build Coastguard Worker 0x00000000, 0x0003000e, 0x00000000, 0x00000001, 0x0006000f, 0x00000005,
287*61046927SAndroid Build Coastguard Worker 0x00000002, 0x6e69616d, 0x00000000, 0x00000003, 0x00060010, 0x00000002,
288*61046927SAndroid Build Coastguard Worker 0x00000011, 0x00000001, 0x00000001, 0x00000001, 0x00050048, 0x00000004,
289*61046927SAndroid Build Coastguard Worker 0x00000000, 0x00000023, 0x00000000, 0x00030047, 0x00000004, 0x00000002,
290*61046927SAndroid Build Coastguard Worker 0x00040047, 0x00000003, 0x00000022, 0x00000000, 0x00040047, 0x00000003,
291*61046927SAndroid Build Coastguard Worker 0x00000021, 0x00000000, 0x00020013, 0x00000005, 0x00030021, 0x00000006,
292*61046927SAndroid Build Coastguard Worker 0x00000005, 0x00040015, 0x00000007, 0x00000020, 0x00000000, 0x0003001e,
293*61046927SAndroid Build Coastguard Worker 0x00000004, 0x00000007, 0x00040020, 0x00000008, 0x0000000c, 0x00000004,
294*61046927SAndroid Build Coastguard Worker 0x0004003b, 0x00000008, 0x00000003, 0x0000000c, 0x00040015, 0x00000009,
295*61046927SAndroid Build Coastguard Worker 0x00000020, 0x00000001, 0x0004002b, 0x00000009, 0x0000000a, 0x00000000,
296*61046927SAndroid Build Coastguard Worker 0x00040020, 0x0000000b, 0x0000000c, 0x00000007, 0x00050036, 0x00000005,
297*61046927SAndroid Build Coastguard Worker 0x00000002, 0x00000000, 0x00000006, 0x000200f8, 0x0000000c, 0x00050041,
298*61046927SAndroid Build Coastguard Worker 0x0000000b, 0x0000000d, 0x00000003, 0x0000000a, 0x0005003f, 0x0000000d,
299*61046927SAndroid Build Coastguard Worker 0x0000000d, 0x00000000, 0x00000001, 0x000100fd, 0x00010038,
300*61046927SAndroid Build Coastguard Worker };
301*61046927SAndroid Build Coastguard Worker
302*61046927SAndroid Build Coastguard Worker get_nir(sizeof(words) / sizeof(words[0]), words);
303*61046927SAndroid Build Coastguard Worker
304*61046927SAndroid Build Coastguard Worker nir_intrinsic_instr *intrinsic = find_intrinsic(nir_intrinsic_load_deref);
305*61046927SAndroid Build Coastguard Worker ASSERT_NE(intrinsic, nullptr);
306*61046927SAndroid Build Coastguard Worker EXPECT_NE(nir_intrinsic_access(intrinsic) & ACCESS_VOLATILE, 0);
307*61046927SAndroid Build Coastguard Worker
308*61046927SAndroid Build Coastguard Worker intrinsic = find_intrinsic(nir_intrinsic_store_deref);
309*61046927SAndroid Build Coastguard Worker ASSERT_NE(intrinsic, nullptr);
310*61046927SAndroid Build Coastguard Worker EXPECT_EQ(nir_intrinsic_access(intrinsic) & ACCESS_VOLATILE, 0);
311*61046927SAndroid Build Coastguard Worker }
312*61046927SAndroid Build Coastguard Worker
TEST_F(Volatile,opimageread_volatile)313*61046927SAndroid Build Coastguard Worker TEST_F(Volatile, opimageread_volatile)
314*61046927SAndroid Build Coastguard Worker {
315*61046927SAndroid Build Coastguard Worker /*
316*61046927SAndroid Build Coastguard Worker OpCapability Shader
317*61046927SAndroid Build Coastguard Worker OpCapability VulkanMemoryModel
318*61046927SAndroid Build Coastguard Worker %1 = OpExtInstImport "GLSL.std.450"
319*61046927SAndroid Build Coastguard Worker OpMemoryModel Logical Vulkan
320*61046927SAndroid Build Coastguard Worker OpEntryPoint GLCompute %4 "main" %9
321*61046927SAndroid Build Coastguard Worker OpExecutionMode %4 LocalSize 1 1 1
322*61046927SAndroid Build Coastguard Worker OpDecorate %9 DescriptorSet 0
323*61046927SAndroid Build Coastguard Worker OpDecorate %9 Binding 1
324*61046927SAndroid Build Coastguard Worker %void = OpTypeVoid
325*61046927SAndroid Build Coastguard Worker %3 = OpTypeFunction %void
326*61046927SAndroid Build Coastguard Worker %uint = OpTypeInt 32 0
327*61046927SAndroid Build Coastguard Worker %7 = OpTypeImage %uint 2D 0 0 0 2 R32ui
328*61046927SAndroid Build Coastguard Worker %_ptr_UniformConstant_7 = OpTypePointer UniformConstant %7
329*61046927SAndroid Build Coastguard Worker %9 = OpVariable %_ptr_UniformConstant_7 UniformConstant
330*61046927SAndroid Build Coastguard Worker %int = OpTypeInt 32 1
331*61046927SAndroid Build Coastguard Worker %v2int = OpTypeVector %int 2
332*61046927SAndroid Build Coastguard Worker %int_0 = OpConstant %int 0
333*61046927SAndroid Build Coastguard Worker %14 = OpConstantComposite %v2int %int_0 %int_0
334*61046927SAndroid Build Coastguard Worker %v4uint = OpTypeVector %uint 4
335*61046927SAndroid Build Coastguard Worker %v3uint = OpTypeVector %uint 3
336*61046927SAndroid Build Coastguard Worker %uint_1 = OpConstant %uint 1
337*61046927SAndroid Build Coastguard Worker %4 = OpFunction %void None %3
338*61046927SAndroid Build Coastguard Worker %5 = OpLabel
339*61046927SAndroid Build Coastguard Worker %10 = OpLoad %7 %9
340*61046927SAndroid Build Coastguard Worker %15 = OpLoad %7 %9
341*61046927SAndroid Build Coastguard Worker %17 = OpImageRead %v4uint %15 %14 VolatileTexel
342*61046927SAndroid Build Coastguard Worker OpImageWrite %10 %14 %17
343*61046927SAndroid Build Coastguard Worker OpReturn
344*61046927SAndroid Build Coastguard Worker OpFunctionEnd
345*61046927SAndroid Build Coastguard Worker */
346*61046927SAndroid Build Coastguard Worker static const uint32_t words[] = {
347*61046927SAndroid Build Coastguard Worker 0x07230203, 0x00010500, 0x00070000, 0x00000014, 0x00000000, 0x00020011,
348*61046927SAndroid Build Coastguard Worker 0x00000001, 0x00020011, 0x000014e1, 0x0006000b, 0x00000001, 0x4c534c47,
349*61046927SAndroid Build Coastguard Worker 0x6474732e, 0x3035342e, 0x00000000, 0x0003000e, 0x00000000, 0x00000003,
350*61046927SAndroid Build Coastguard Worker 0x0006000f, 0x00000005, 0x00000002, 0x6e69616d, 0x00000000, 0x00000003,
351*61046927SAndroid Build Coastguard Worker 0x00060010, 0x00000002, 0x00000011, 0x00000001, 0x00000001, 0x00000001,
352*61046927SAndroid Build Coastguard Worker 0x00040047, 0x00000003, 0x00000022, 0x00000000, 0x00040047, 0x00000003,
353*61046927SAndroid Build Coastguard Worker 0x00000021, 0x00000001, 0x00020013, 0x00000004, 0x00030021, 0x00000005,
354*61046927SAndroid Build Coastguard Worker 0x00000004, 0x00040015, 0x00000006, 0x00000020, 0x00000000, 0x00090019,
355*61046927SAndroid Build Coastguard Worker 0x00000007, 0x00000006, 0x00000001, 0x00000000, 0x00000000, 0x00000000,
356*61046927SAndroid Build Coastguard Worker 0x00000002, 0x00000021, 0x00040020, 0x00000008, 0x00000000, 0x00000007,
357*61046927SAndroid Build Coastguard Worker 0x0004003b, 0x00000008, 0x00000003, 0x00000000, 0x00040015, 0x00000009,
358*61046927SAndroid Build Coastguard Worker 0x00000020, 0x00000001, 0x00040017, 0x0000000a, 0x00000009, 0x00000002,
359*61046927SAndroid Build Coastguard Worker 0x0004002b, 0x00000009, 0x0000000b, 0x00000000, 0x0005002c, 0x0000000a,
360*61046927SAndroid Build Coastguard Worker 0x0000000c, 0x0000000b, 0x0000000b, 0x00040017, 0x0000000d, 0x00000006,
361*61046927SAndroid Build Coastguard Worker 0x00000004, 0x00040017, 0x0000000e, 0x00000006, 0x00000003, 0x0004002b,
362*61046927SAndroid Build Coastguard Worker 0x00000006, 0x0000000f, 0x00000001, 0x00050036, 0x00000004, 0x00000002,
363*61046927SAndroid Build Coastguard Worker 0x00000000, 0x00000005, 0x000200f8, 0x00000010, 0x0004003d, 0x00000007,
364*61046927SAndroid Build Coastguard Worker 0x00000011, 0x00000003, 0x0004003d, 0x00000007, 0x00000012, 0x00000003,
365*61046927SAndroid Build Coastguard Worker 0x00060062, 0x0000000d, 0x00000013, 0x00000012, 0x0000000c, 0x00000800,
366*61046927SAndroid Build Coastguard Worker 0x00040063, 0x00000011, 0x0000000c, 0x00000013, 0x000100fd, 0x00010038,
367*61046927SAndroid Build Coastguard Worker };
368*61046927SAndroid Build Coastguard Worker
369*61046927SAndroid Build Coastguard Worker get_nir(sizeof(words) / sizeof(words[0]), words);
370*61046927SAndroid Build Coastguard Worker
371*61046927SAndroid Build Coastguard Worker nir_intrinsic_instr *intrinsic = find_intrinsic(nir_intrinsic_image_deref_load, 0);
372*61046927SAndroid Build Coastguard Worker ASSERT_NE(intrinsic, nullptr);
373*61046927SAndroid Build Coastguard Worker EXPECT_NE(nir_intrinsic_access(intrinsic) & ACCESS_VOLATILE, 0);
374*61046927SAndroid Build Coastguard Worker }
375*61046927SAndroid Build Coastguard Worker
TEST_F(Volatile,opimagewrite_volatile)376*61046927SAndroid Build Coastguard Worker TEST_F(Volatile, opimagewrite_volatile)
377*61046927SAndroid Build Coastguard Worker {
378*61046927SAndroid Build Coastguard Worker /*
379*61046927SAndroid Build Coastguard Worker OpCapability Shader
380*61046927SAndroid Build Coastguard Worker OpCapability VulkanMemoryModel
381*61046927SAndroid Build Coastguard Worker %1 = OpExtInstImport "GLSL.std.450"
382*61046927SAndroid Build Coastguard Worker OpMemoryModel Logical Vulkan
383*61046927SAndroid Build Coastguard Worker OpEntryPoint GLCompute %4 "main" %9
384*61046927SAndroid Build Coastguard Worker OpExecutionMode %4 LocalSize 1 1 1
385*61046927SAndroid Build Coastguard Worker OpDecorate %9 DescriptorSet 0
386*61046927SAndroid Build Coastguard Worker OpDecorate %9 Binding 1
387*61046927SAndroid Build Coastguard Worker %void = OpTypeVoid
388*61046927SAndroid Build Coastguard Worker %3 = OpTypeFunction %void
389*61046927SAndroid Build Coastguard Worker %uint = OpTypeInt 32 0
390*61046927SAndroid Build Coastguard Worker %7 = OpTypeImage %uint 2D 0 0 0 2 R32ui
391*61046927SAndroid Build Coastguard Worker %_ptr_UniformConstant_7 = OpTypePointer UniformConstant %7
392*61046927SAndroid Build Coastguard Worker %9 = OpVariable %_ptr_UniformConstant_7 UniformConstant
393*61046927SAndroid Build Coastguard Worker %int = OpTypeInt 32 1
394*61046927SAndroid Build Coastguard Worker %v2int = OpTypeVector %int 2
395*61046927SAndroid Build Coastguard Worker %int_0 = OpConstant %int 0
396*61046927SAndroid Build Coastguard Worker %14 = OpConstantComposite %v2int %int_0 %int_0
397*61046927SAndroid Build Coastguard Worker %v4uint = OpTypeVector %uint 4
398*61046927SAndroid Build Coastguard Worker %v3uint = OpTypeVector %uint 3
399*61046927SAndroid Build Coastguard Worker %uint_1 = OpConstant %uint 1
400*61046927SAndroid Build Coastguard Worker %4 = OpFunction %void None %3
401*61046927SAndroid Build Coastguard Worker %5 = OpLabel
402*61046927SAndroid Build Coastguard Worker %10 = OpLoad %7 %9
403*61046927SAndroid Build Coastguard Worker %15 = OpLoad %7 %9
404*61046927SAndroid Build Coastguard Worker %17 = OpImageRead %v4uint %15 %14
405*61046927SAndroid Build Coastguard Worker OpImageWrite %10 %14 %17 VolatileTexel
406*61046927SAndroid Build Coastguard Worker OpReturn
407*61046927SAndroid Build Coastguard Worker OpFunctionEnd
408*61046927SAndroid Build Coastguard Worker */
409*61046927SAndroid Build Coastguard Worker static const uint32_t words[] = {
410*61046927SAndroid Build Coastguard Worker 0x07230203, 0x00010500, 0x00070000, 0x00000014, 0x00000000, 0x00020011,
411*61046927SAndroid Build Coastguard Worker 0x00000001, 0x00020011, 0x000014e1, 0x0006000b, 0x00000001, 0x4c534c47,
412*61046927SAndroid Build Coastguard Worker 0x6474732e, 0x3035342e, 0x00000000, 0x0003000e, 0x00000000, 0x00000003,
413*61046927SAndroid Build Coastguard Worker 0x0006000f, 0x00000005, 0x00000002, 0x6e69616d, 0x00000000, 0x00000003,
414*61046927SAndroid Build Coastguard Worker 0x00060010, 0x00000002, 0x00000011, 0x00000001, 0x00000001, 0x00000001,
415*61046927SAndroid Build Coastguard Worker 0x00040047, 0x00000003, 0x00000022, 0x00000000, 0x00040047, 0x00000003,
416*61046927SAndroid Build Coastguard Worker 0x00000021, 0x00000001, 0x00020013, 0x00000004, 0x00030021, 0x00000005,
417*61046927SAndroid Build Coastguard Worker 0x00000004, 0x00040015, 0x00000006, 0x00000020, 0x00000000, 0x00090019,
418*61046927SAndroid Build Coastguard Worker 0x00000007, 0x00000006, 0x00000001, 0x00000000, 0x00000000, 0x00000000,
419*61046927SAndroid Build Coastguard Worker 0x00000002, 0x00000021, 0x00040020, 0x00000008, 0x00000000, 0x00000007,
420*61046927SAndroid Build Coastguard Worker 0x0004003b, 0x00000008, 0x00000003, 0x00000000, 0x00040015, 0x00000009,
421*61046927SAndroid Build Coastguard Worker 0x00000020, 0x00000001, 0x00040017, 0x0000000a, 0x00000009, 0x00000002,
422*61046927SAndroid Build Coastguard Worker 0x0004002b, 0x00000009, 0x0000000b, 0x00000000, 0x0005002c, 0x0000000a,
423*61046927SAndroid Build Coastguard Worker 0x0000000c, 0x0000000b, 0x0000000b, 0x00040017, 0x0000000d, 0x00000006,
424*61046927SAndroid Build Coastguard Worker 0x00000004, 0x00040017, 0x0000000e, 0x00000006, 0x00000003, 0x0004002b,
425*61046927SAndroid Build Coastguard Worker 0x00000006, 0x0000000f, 0x00000001, 0x00050036, 0x00000004, 0x00000002,
426*61046927SAndroid Build Coastguard Worker 0x00000000, 0x00000005, 0x000200f8, 0x00000010, 0x0004003d, 0x00000007,
427*61046927SAndroid Build Coastguard Worker 0x00000011, 0x00000003, 0x0004003d, 0x00000007, 0x00000012, 0x00000003,
428*61046927SAndroid Build Coastguard Worker 0x00050062, 0x0000000d, 0x00000013, 0x00000012, 0x0000000c, 0x00050063,
429*61046927SAndroid Build Coastguard Worker 0x00000011, 0x0000000c, 0x00000013, 0x00000800, 0x000100fd, 0x00010038,
430*61046927SAndroid Build Coastguard Worker };
431*61046927SAndroid Build Coastguard Worker
432*61046927SAndroid Build Coastguard Worker get_nir(sizeof(words) / sizeof(words[0]), words);
433*61046927SAndroid Build Coastguard Worker
434*61046927SAndroid Build Coastguard Worker nir_intrinsic_instr *intrinsic = find_intrinsic(nir_intrinsic_image_deref_store, 0);
435*61046927SAndroid Build Coastguard Worker ASSERT_NE(intrinsic, nullptr);
436*61046927SAndroid Build Coastguard Worker EXPECT_NE(nir_intrinsic_access(intrinsic) & ACCESS_VOLATILE, 0);
437*61046927SAndroid Build Coastguard Worker }
438*61046927SAndroid Build Coastguard Worker
TEST_F(Volatile,opatomicload_image_volatile)439*61046927SAndroid Build Coastguard Worker TEST_F(Volatile, opatomicload_image_volatile)
440*61046927SAndroid Build Coastguard Worker {
441*61046927SAndroid Build Coastguard Worker /*
442*61046927SAndroid Build Coastguard Worker OpCapability Shader
443*61046927SAndroid Build Coastguard Worker OpCapability VulkanMemoryModel
444*61046927SAndroid Build Coastguard Worker OpCapability VulkanMemoryModelDeviceScope
445*61046927SAndroid Build Coastguard Worker %1 = OpExtInstImport "GLSL.std.450"
446*61046927SAndroid Build Coastguard Worker OpMemoryModel Logical Vulkan
447*61046927SAndroid Build Coastguard Worker OpEntryPoint GLCompute %2 "main" %3
448*61046927SAndroid Build Coastguard Worker OpExecutionMode %2 LocalSize 1 1 1
449*61046927SAndroid Build Coastguard Worker OpDecorate %3 DescriptorSet 0
450*61046927SAndroid Build Coastguard Worker OpDecorate %3 Binding 1
451*61046927SAndroid Build Coastguard Worker %void = OpTypeVoid
452*61046927SAndroid Build Coastguard Worker %7 = OpTypeFunction %void
453*61046927SAndroid Build Coastguard Worker %uint = OpTypeInt 32 0
454*61046927SAndroid Build Coastguard Worker %10 = OpTypeImage %uint 2D 0 0 0 2 R32ui
455*61046927SAndroid Build Coastguard Worker %_ptr_UniformConstant_10 = OpTypePointer UniformConstant %10
456*61046927SAndroid Build Coastguard Worker %3 = OpVariable %_ptr_UniformConstant_10 UniformConstant
457*61046927SAndroid Build Coastguard Worker %int = OpTypeInt 32 1
458*61046927SAndroid Build Coastguard Worker %v2int = OpTypeVector %int 2
459*61046927SAndroid Build Coastguard Worker %int_0 = OpConstant %int 0
460*61046927SAndroid Build Coastguard Worker %15 = OpConstantComposite %v2int %int_0 %int_0
461*61046927SAndroid Build Coastguard Worker %int_1 = OpConstant %int 1
462*61046927SAndroid Build Coastguard Worker %uint_0 = OpConstant %uint 0
463*61046927SAndroid Build Coastguard Worker %_ptr_Image_uint = OpTypePointer Image %uint
464*61046927SAndroid Build Coastguard Worker %uint_1 = OpConstant %uint 1
465*61046927SAndroid Build Coastguard Worker %uint_2048 = OpConstant %uint 2048
466*61046927SAndroid Build Coastguard Worker %uint_34816 = OpConstant %uint 34816
467*61046927SAndroid Build Coastguard Worker %v3uint = OpTypeVector %uint 3
468*61046927SAndroid Build Coastguard Worker %2 = OpFunction %void None %7
469*61046927SAndroid Build Coastguard Worker %29 = OpLabel
470*61046927SAndroid Build Coastguard Worker %30 = OpImageTexelPointer %_ptr_Image_uint %3 %15 %uint_0
471*61046927SAndroid Build Coastguard Worker %31 = OpAtomicLoad %uint %30 %int_1 %uint_34816
472*61046927SAndroid Build Coastguard Worker OpAtomicStore %30 %int_1 %uint_2048 %31
473*61046927SAndroid Build Coastguard Worker OpReturn
474*61046927SAndroid Build Coastguard Worker OpFunctionEnd
475*61046927SAndroid Build Coastguard Worker */
476*61046927SAndroid Build Coastguard Worker static const uint32_t words[] = {
477*61046927SAndroid Build Coastguard Worker 0x07230203, 0x00010500, 0x00070000, 0x00000017, 0x00000000, 0x00020011,
478*61046927SAndroid Build Coastguard Worker 0x00000001, 0x00020011, 0x000014e1, 0x00020011, 0x000014e2, 0x0006000b,
479*61046927SAndroid Build Coastguard Worker 0x00000001, 0x4c534c47, 0x6474732e, 0x3035342e, 0x00000000, 0x0003000e,
480*61046927SAndroid Build Coastguard Worker 0x00000000, 0x00000003, 0x0006000f, 0x00000005, 0x00000002, 0x6e69616d,
481*61046927SAndroid Build Coastguard Worker 0x00000000, 0x00000003, 0x00060010, 0x00000002, 0x00000011, 0x00000001,
482*61046927SAndroid Build Coastguard Worker 0x00000001, 0x00000001, 0x00040047, 0x00000003, 0x00000022, 0x00000000,
483*61046927SAndroid Build Coastguard Worker 0x00040047, 0x00000003, 0x00000021, 0x00000001, 0x00020013, 0x00000004,
484*61046927SAndroid Build Coastguard Worker 0x00030021, 0x00000005, 0x00000004, 0x00040015, 0x00000006, 0x00000020,
485*61046927SAndroid Build Coastguard Worker 0x00000000, 0x00090019, 0x00000007, 0x00000006, 0x00000001, 0x00000000,
486*61046927SAndroid Build Coastguard Worker 0x00000000, 0x00000000, 0x00000002, 0x00000021, 0x00040020, 0x00000008,
487*61046927SAndroid Build Coastguard Worker 0x00000000, 0x00000007, 0x0004003b, 0x00000008, 0x00000003, 0x00000000,
488*61046927SAndroid Build Coastguard Worker 0x00040015, 0x00000009, 0x00000020, 0x00000001, 0x00040017, 0x0000000a,
489*61046927SAndroid Build Coastguard Worker 0x00000009, 0x00000002, 0x0004002b, 0x00000009, 0x0000000b, 0x00000000,
490*61046927SAndroid Build Coastguard Worker 0x0005002c, 0x0000000a, 0x0000000c, 0x0000000b, 0x0000000b, 0x0004002b,
491*61046927SAndroid Build Coastguard Worker 0x00000009, 0x0000000d, 0x00000001, 0x0004002b, 0x00000006, 0x0000000e,
492*61046927SAndroid Build Coastguard Worker 0x00000000, 0x00040020, 0x0000000f, 0x0000000b, 0x00000006, 0x0004002b,
493*61046927SAndroid Build Coastguard Worker 0x00000006, 0x00000010, 0x00000001, 0x0004002b, 0x00000006, 0x00000011,
494*61046927SAndroid Build Coastguard Worker 0x00000800, 0x0004002b, 0x00000006, 0x00000012, 0x00008800, 0x00040017,
495*61046927SAndroid Build Coastguard Worker 0x00000013, 0x00000006, 0x00000003, 0x00050036, 0x00000004, 0x00000002,
496*61046927SAndroid Build Coastguard Worker 0x00000000, 0x00000005, 0x000200f8, 0x00000014, 0x0006003c, 0x0000000f,
497*61046927SAndroid Build Coastguard Worker 0x00000015, 0x00000003, 0x0000000c, 0x0000000e, 0x000600e3, 0x00000006,
498*61046927SAndroid Build Coastguard Worker 0x00000016, 0x00000015, 0x0000000d, 0x00000012, 0x000500e4, 0x00000015,
499*61046927SAndroid Build Coastguard Worker 0x0000000d, 0x00000011, 0x00000016, 0x000100fd, 0x00010038,
500*61046927SAndroid Build Coastguard Worker };
501*61046927SAndroid Build Coastguard Worker
502*61046927SAndroid Build Coastguard Worker get_nir(sizeof(words) / sizeof(words[0]), words);
503*61046927SAndroid Build Coastguard Worker
504*61046927SAndroid Build Coastguard Worker nir_intrinsic_instr *intrinsic = find_intrinsic(nir_intrinsic_image_deref_load, 0);
505*61046927SAndroid Build Coastguard Worker ASSERT_NE(intrinsic, nullptr);
506*61046927SAndroid Build Coastguard Worker EXPECT_NE(nir_intrinsic_access(intrinsic) & ACCESS_VOLATILE, 0);
507*61046927SAndroid Build Coastguard Worker }
508*61046927SAndroid Build Coastguard Worker
TEST_F(Volatile,opatomicstore_image_volatile)509*61046927SAndroid Build Coastguard Worker TEST_F(Volatile, opatomicstore_image_volatile)
510*61046927SAndroid Build Coastguard Worker {
511*61046927SAndroid Build Coastguard Worker /*
512*61046927SAndroid Build Coastguard Worker OpCapability Shader
513*61046927SAndroid Build Coastguard Worker OpCapability VulkanMemoryModel
514*61046927SAndroid Build Coastguard Worker OpCapability VulkanMemoryModelDeviceScope
515*61046927SAndroid Build Coastguard Worker %1 = OpExtInstImport "GLSL.std.450"
516*61046927SAndroid Build Coastguard Worker OpMemoryModel Logical Vulkan
517*61046927SAndroid Build Coastguard Worker OpEntryPoint GLCompute %2 "main" %3
518*61046927SAndroid Build Coastguard Worker OpExecutionMode %2 LocalSize 1 1 1
519*61046927SAndroid Build Coastguard Worker OpDecorate %3 DescriptorSet 0
520*61046927SAndroid Build Coastguard Worker OpDecorate %3 Binding 1
521*61046927SAndroid Build Coastguard Worker %void = OpTypeVoid
522*61046927SAndroid Build Coastguard Worker %7 = OpTypeFunction %void
523*61046927SAndroid Build Coastguard Worker %uint = OpTypeInt 32 0
524*61046927SAndroid Build Coastguard Worker %10 = OpTypeImage %uint 2D 0 0 0 2 R32ui
525*61046927SAndroid Build Coastguard Worker %_ptr_UniformConstant_10 = OpTypePointer UniformConstant %10
526*61046927SAndroid Build Coastguard Worker %3 = OpVariable %_ptr_UniformConstant_10 UniformConstant
527*61046927SAndroid Build Coastguard Worker %int = OpTypeInt 32 1
528*61046927SAndroid Build Coastguard Worker %v2int = OpTypeVector %int 2
529*61046927SAndroid Build Coastguard Worker %int_0 = OpConstant %int 0
530*61046927SAndroid Build Coastguard Worker %15 = OpConstantComposite %v2int %int_0 %int_0
531*61046927SAndroid Build Coastguard Worker %int_1 = OpConstant %int 1
532*61046927SAndroid Build Coastguard Worker %uint_0 = OpConstant %uint 0
533*61046927SAndroid Build Coastguard Worker %_ptr_Image_uint = OpTypePointer Image %uint
534*61046927SAndroid Build Coastguard Worker %uint_1 = OpConstant %uint 1
535*61046927SAndroid Build Coastguard Worker %uint_2048 = OpConstant %uint 2048
536*61046927SAndroid Build Coastguard Worker %uint_34816 = OpConstant %uint 34816
537*61046927SAndroid Build Coastguard Worker %v3uint = OpTypeVector %uint 3
538*61046927SAndroid Build Coastguard Worker %2 = OpFunction %void None %7
539*61046927SAndroid Build Coastguard Worker %29 = OpLabel
540*61046927SAndroid Build Coastguard Worker %30 = OpImageTexelPointer %_ptr_Image_uint %3 %15 %uint_0
541*61046927SAndroid Build Coastguard Worker %31 = OpAtomicLoad %uint %30 %int_1 %uint_2048
542*61046927SAndroid Build Coastguard Worker OpAtomicStore %30 %int_1 %uint_34816 %31
543*61046927SAndroid Build Coastguard Worker OpReturn
544*61046927SAndroid Build Coastguard Worker OpFunctionEnd
545*61046927SAndroid Build Coastguard Worker */
546*61046927SAndroid Build Coastguard Worker static const uint32_t words[] = {
547*61046927SAndroid Build Coastguard Worker 0x07230203, 0x00010500, 0x00070000, 0x00000017, 0x00000000, 0x00020011,
548*61046927SAndroid Build Coastguard Worker 0x00000001, 0x00020011, 0x000014e1, 0x00020011, 0x000014e2, 0x0006000b,
549*61046927SAndroid Build Coastguard Worker 0x00000001, 0x4c534c47, 0x6474732e, 0x3035342e, 0x00000000, 0x0003000e,
550*61046927SAndroid Build Coastguard Worker 0x00000000, 0x00000003, 0x0006000f, 0x00000005, 0x00000002, 0x6e69616d,
551*61046927SAndroid Build Coastguard Worker 0x00000000, 0x00000003, 0x00060010, 0x00000002, 0x00000011, 0x00000001,
552*61046927SAndroid Build Coastguard Worker 0x00000001, 0x00000001, 0x00040047, 0x00000003, 0x00000022, 0x00000000,
553*61046927SAndroid Build Coastguard Worker 0x00040047, 0x00000003, 0x00000021, 0x00000001, 0x00020013, 0x00000004,
554*61046927SAndroid Build Coastguard Worker 0x00030021, 0x00000005, 0x00000004, 0x00040015, 0x00000006, 0x00000020,
555*61046927SAndroid Build Coastguard Worker 0x00000000, 0x00090019, 0x00000007, 0x00000006, 0x00000001, 0x00000000,
556*61046927SAndroid Build Coastguard Worker 0x00000000, 0x00000000, 0x00000002, 0x00000021, 0x00040020, 0x00000008,
557*61046927SAndroid Build Coastguard Worker 0x00000000, 0x00000007, 0x0004003b, 0x00000008, 0x00000003, 0x00000000,
558*61046927SAndroid Build Coastguard Worker 0x00040015, 0x00000009, 0x00000020, 0x00000001, 0x00040017, 0x0000000a,
559*61046927SAndroid Build Coastguard Worker 0x00000009, 0x00000002, 0x0004002b, 0x00000009, 0x0000000b, 0x00000000,
560*61046927SAndroid Build Coastguard Worker 0x0005002c, 0x0000000a, 0x0000000c, 0x0000000b, 0x0000000b, 0x0004002b,
561*61046927SAndroid Build Coastguard Worker 0x00000009, 0x0000000d, 0x00000001, 0x0004002b, 0x00000006, 0x0000000e,
562*61046927SAndroid Build Coastguard Worker 0x00000000, 0x00040020, 0x0000000f, 0x0000000b, 0x00000006, 0x0004002b,
563*61046927SAndroid Build Coastguard Worker 0x00000006, 0x00000010, 0x00000001, 0x0004002b, 0x00000006, 0x00000011,
564*61046927SAndroid Build Coastguard Worker 0x00000800, 0x0004002b, 0x00000006, 0x00000012, 0x00008800, 0x00040017,
565*61046927SAndroid Build Coastguard Worker 0x00000013, 0x00000006, 0x00000003, 0x00050036, 0x00000004, 0x00000002,
566*61046927SAndroid Build Coastguard Worker 0x00000000, 0x00000005, 0x000200f8, 0x00000014, 0x0006003c, 0x0000000f,
567*61046927SAndroid Build Coastguard Worker 0x00000015, 0x00000003, 0x0000000c, 0x0000000e, 0x000600e3, 0x00000006,
568*61046927SAndroid Build Coastguard Worker 0x00000016, 0x00000015, 0x0000000d, 0x00000011, 0x000500e4, 0x00000015,
569*61046927SAndroid Build Coastguard Worker 0x0000000d, 0x00000012, 0x00000016, 0x000100fd, 0x00010038,
570*61046927SAndroid Build Coastguard Worker };
571*61046927SAndroid Build Coastguard Worker
572*61046927SAndroid Build Coastguard Worker get_nir(sizeof(words) / sizeof(words[0]), words);
573*61046927SAndroid Build Coastguard Worker
574*61046927SAndroid Build Coastguard Worker nir_intrinsic_instr *intrinsic = find_intrinsic(nir_intrinsic_image_deref_store, 0);
575*61046927SAndroid Build Coastguard Worker ASSERT_NE(intrinsic, nullptr);
576*61046927SAndroid Build Coastguard Worker EXPECT_NE(nir_intrinsic_access(intrinsic) & ACCESS_VOLATILE, 0);
577*61046927SAndroid Build Coastguard Worker }
578