• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1#!amber
2# Copyright 2020 Google LLC.
3# Copyright 2020 The Khronos Group Inc.
4#
5# Licensed under the Apache License, Version 2.0 (the "License");
6# you may not use this file except in compliance with the License.
7# You may obtain a copy of the License at
8#
9#     https://www.apache.org/licenses/LICENSE-2.0
10#
11# Unless required by applicable law or agreed to in writing, software
12# distributed under the License is distributed on an "AS IS" BASIS,
13# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14# See the License for the specific language governing permissions and
15# limitations under the License.
16
17DEVICE_FEATURE fillModeNonSolid
18
19SHADER vertex vert_shader PASSTHROUGH
20
21SHADER fragment frag_shader GLSL
22#version 430
23
24layout(location = 0) out vec4 color;
25
26void main()
27{
28    color = vec4(1);
29}
30END
31
32SHADER fragment frag_shader_tex GLSL
33#version 430
34layout(location = 0) out vec4 color_out;
35uniform layout(set=0, binding=0, rgba8) readonly image2D texture;
36void main()
37{
38    color_out = imageLoad(texture, ivec2(gl_FragCoord.xy));
39}
40END
41
42SHADER compute compute_shader GLSL
43#version 430
44layout(local_size_x=32, local_size_y=4) in;
45uniform layout (set=0, binding=0, rgba8) image2D img;
46
47int w = 256;
48int h = 256;
49vec4 bg = vec4(0, 0, 0, 1);
50vec4 marked = vec4(0, 1, 1, 1);
51vec4 error = vec4(1, 0, 0, 1);
52
53shared ivec2 stack[256];
54shared int stackPtr;
55shared bool done;
56shared ivec2 pixel;
57
58void pushMarkedPixel(ivec2 p)
59{
60    imageStore(img, p, marked);
61    int slot = atomicAdd(stackPtr, 1);
62    stack[slot] = p;
63}
64
65ivec2 popMarkedPixel()
66{
67    int slot = atomicAdd(stackPtr, -1) - 1;
68    ivec2 p = stack[slot];
69    imageStore(img, p, bg);
70
71    return p;
72}
73
74void main ()
75{
76    if (gl_LocalInvocationIndex == 0)
77    {
78        stack[0] = ivec2(-1);
79        stackPtr = 0;
80        done = false;
81
82        // Use this to break the lines and verify the checker is correct.
83        //for (int x = 0; x < w; x++)
84        //    imageStore(img, ivec2(x, 128), bg);
85    }
86
87    barrier();
88
89    // Search for any pixel belonging to a line.
90    // Use 32 x 4 block for the search.
91    ivec2 p = ivec2(gl_LocalInvocationID) + ivec2(0, 10);
92    vec4 c = imageLoad(img, p);
93    // Any of the pixels found by a thread will do as a starting point.
94    if (c != bg)
95        stack[0] = p;
96
97    barrier();
98
99    if (gl_LocalInvocationIndex == 0 && stack[0] != ivec2(-1))
100    {
101        imageStore(img, stack[0], marked);
102        stackPtr++;
103    }
104
105    barrier();
106
107    while (!done)
108    {
109        if (gl_LocalInvocationIndex == 0 && stackPtr != 0)
110            pixel = popMarkedPixel();
111
112        barrier();
113
114        if (gl_LocalInvocationID.x < 3 && gl_LocalInvocationID.y < 3)
115        {
116            ivec2 p = pixel + ivec2(gl_LocalInvocationID) - ivec2(1);
117            if (p.x >= 0 && p.y >= 0 && p.x < w && p.y < h)
118            {
119                vec4 c = imageLoad(img, p);
120                if (c != marked && c != bg)
121                {
122                    pushMarkedPixel(p);
123                }
124            }
125        }
126
127        barrier();
128
129        if (gl_LocalInvocationIndex == 0 && stackPtr < 1)
130            done = true;
131
132        barrier();
133    }
134}
135END
136
137BUFFER position DATA_TYPE R8G8B8A8_SNORM DATA
138-120 -120  0 127
139   0  120  0 127
140 120 -120  0 127
141
142  0     0  0 127
143120     0  0 127
144 60   -60  0 127
145
146-100  100  0 127
147 110  100  0 127
148 110  103  0 127
149END
150
151BUFFER texture FORMAT R8G8B8A8_UNORM
152BUFFER framebuffer FORMAT B8G8R8A8_UNORM
153
154PIPELINE graphics pipeline
155  ATTACH vert_shader
156  ATTACH frag_shader
157
158  VERTEX_DATA position LOCATION 0
159  POLYGON_MODE line
160
161  BIND BUFFER texture AS color LOCATION 0
162  FRAMEBUFFER_SIZE 256 256
163END
164
165PIPELINE graphics tex_pipeline
166  ATTACH vert_shader
167  ATTACH frag_shader_tex
168  BIND BUFFER texture AS storage_image DESCRIPTOR_SET 0 BINDING 0
169  FRAMEBUFFER_SIZE 256 256
170  BIND BUFFER framebuffer AS color LOCATION 0
171END
172
173PIPELINE compute verification_pipeline
174  ATTACH compute_shader
175  BIND BUFFER texture AS storage_image DESCRIPTOR_SET 0 BINDING 0
176  FRAMEBUFFER_SIZE 256 256
177END
178
179CLEAR_COLOR pipeline 0 0 0 255
180CLEAR pipeline
181
182RUN pipeline DRAW_ARRAY AS TRIANGLE_LIST START_IDX 0 COUNT 9
183RUN verification_pipeline 1 1 1
184RUN tex_pipeline DRAW_RECT POS 0 0 SIZE 256 256
185
186# Everything should be clear color since the checker consumes
187# the drawn pixels if they are continuous.
188EXPECT framebuffer IDX 0 0 SIZE 256 255 EQ_RGBA 0 0 0 255
189