From: Ian Romanick <ian.d.roman...@intel.com>

Signed-off-by: Ian Romanick <ian.d.roman...@intel.com>
---
 .../execution/ssbo-atomicExchange-int.shader_test  | 76 ++++++++++++++++++++++
 1 file changed, 76 insertions(+)
 create mode 100644 
tests/spec/arb_shader_storage_buffer_object/execution/ssbo-atomicExchange-int.shader_test

diff --git 
a/tests/spec/arb_shader_storage_buffer_object/execution/ssbo-atomicExchange-int.shader_test
 
b/tests/spec/arb_shader_storage_buffer_object/execution/ssbo-atomicExchange-int.shader_test
new file mode 100644
index 000000000..6fbaa8178
--- /dev/null
+++ 
b/tests/spec/arb_shader_storage_buffer_object/execution/ssbo-atomicExchange-int.shader_test
@@ -0,0 +1,76 @@
+[require]
+GL >= 3.3
+GLSL >= 3.30
+GL_ARB_shader_storage_buffer_object
+GL_ARB_shader_atomic_counters
+GL_ARB_shader_atomic_counter_ops
+
+[vertex shader passthrough]
+
+[fragment shader]
+#version 330
+#extension GL_ARB_shader_storage_buffer_object: require
+#extension GL_ARB_shader_atomic_counters: require
+#extension GL_ARB_shader_atomic_counter_ops: require
+
+layout(binding = 0) buffer bufblock {
+       int value;
+};
+
+/* GL_ARB_shader_atomic_counters requires at least 8 total counters. */
+layout(binding = 0) uniform atomic_uint mask[7];
+layout(binding = 0) uniform atomic_uint fail;
+
+out vec4 color;
+
+const uint max_index = uint(mask.length()) * 32u + 31u;
+
+void main()
+{
+       uint x = uint(gl_FragCoord.x);
+       uint y = uint(gl_FragCoord.y);
+       uint local_index = y * 32u + x;
+
+       int new_value = (x < 32u && y < uint(mask.length()))
+               ? int(4u * local_index) : 0x7fffffff;
+
+       int f = atomicExchange(value, new_value);
+       uint i = uint(f) / 4u;
+       uint bit = i % 32u;
+       int c = int(i / 32u);
+       uint m = 1u << bit;
+
+       if (i <= max_index) {
+               /* If the bit was already set, the test fails. */
+               uint r = atomicCounterOrARB(mask[c], m);
+               if ((r & m) != 0u)
+                       atomicCounterIncrement(fail);
+
+               if (bit == local_index)
+                       atomicCounterIncrement(fail);
+
+               color = vec4(0.0, 1.0, 0.0, 1.0);
+       } else {
+               color = vec4(0.0, 0.0, 1.0, 1.0);
+       }
+}
+
+[test]
+atomic counters 8
+
+ssbo 0 32
+ssbo 0 subdata int 0 65536
+
+clear color 0.5 0.5 0.5 0.5
+clear
+
+draw rect -1 -1 2 2
+
+probe atomic counter 0 == 4294967295
+probe atomic counter 1 == 4294967295
+probe atomic counter 2 == 4294967295
+probe atomic counter 3 == 4294967295
+probe atomic counter 4 == 4294967295
+probe atomic counter 5 == 4294967295
+probe atomic counter 6 == 4294967295
+probe atomic counter 7 == 0
-- 
2.14.4

_______________________________________________
Piglit mailing list
Piglit@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/piglit

Reply via email to