File: fs-deref-literal-array-of-structs-with-multiple-members-large-array.shader_test

package info (click to toggle)
piglit 0~git20220119-124bca3c9-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 109,012 kB
  • sloc: ansic: 273,511; xml: 46,666; python: 33,098; lisp: 20,392; cpp: 12,480; sh: 22; makefile: 22; pascal: 5
file content (56 lines) | stat: -rw-r--r-- 1,335 bytes parent folder | download | duplicates (3)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
# Verify that an array of structs appearing in the shader as a literal
# can be successfully dereferenced to access the values inside the
# structs.
#
# This test has a slightly larger array to better check that we calculate
# offsets correctly. This exposed a bug in the glsl to tgsi pass in gallium
# based drivers.

[require]
GLSL >= 1.20

[vertex shader]
void main()
{
  gl_Position = gl_Vertex;
}

[fragment shader]
struct Foo {
  int value;

  /* A second member of a different size ensures we calculate member offsets
   * correctly.
   */
  ivec2 value2;
};

uniform int i;
uniform ivec2 expected_value;

void main()
{
  ivec2 actual_value = Foo[4](Foo(100, ivec2(200, 300)),
                              Foo(400, ivec2(500, 600)),
                              Foo(700, ivec2(800, 900)),
                              Foo(1000, ivec2(1100, 1200)))[i].value2;
  if (actual_value == expected_value)
    gl_FragColor = vec4(0.0, 1.0, 0.0, 1.0);
  else
    gl_FragColor = vec4(1.0, 0.0, 0.0, 1.0);
}

[test]
uniform int i 0
uniform ivec2 expected_value 200 300
draw rect -1 -1 1 1
uniform int i 1
uniform ivec2 expected_value 500 600
draw rect 0 -1 1 1
uniform int i 2
uniform ivec2 expected_value 800 900
draw rect -1 0 1 1
uniform int i 3
uniform ivec2 expected_value 1100 1200
draw rect 0 0 1 1
probe all rgba 0.0 1.0 0.0 1.0