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 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74
|
# This tests we inline functions correctly. Chaining the functions helps
# us reach the GLSL IR -> NIR code with some functions intact when the
# conservative optimise flag is set in Mesa. This allows us to test the
# GLSL IR -> NIR conversion code for functions and the NIR function inlining
# code.
[require]
GLSL >= 1.10
[vertex shader]
void main()
{
gl_Position = gl_Vertex;
}
[fragment shader]
float f01(in float f[4]);
float f02(in float f[4]);
float f06(in float f[4]);
float f10(in float f[4]);
float f14(in float f[4]);
void main()
{
float g[4];
g[0] = 0.0;
g[1] = 1.0;
g[2] = 0.0;
g[3] = 0.1;
f01(g);
gl_FragColor = vec4(f01(g), g[0], g[2], g[1]);
}
float f01(in float f[4]) {return f02(f);}
float f05(in float f[4]) {return f06(f);}
float f09(in float f[4]) {return f10(f);}
float f13(in float f[4]) {return f14(f);}
[fragment shader]
float f03(in float f[4]);
float f07(in float f[4]);
float f11(in float f[4]);
float f15(in float f[4]);
float f02(in float f[4]) {return f03(f);}
float f06(in float f[4]) {return f07(f);}
float f10(in float f[4]) {return f11(f);}
float f14(in float f[4]) {return f15(f);}
[fragment shader]
float f04(in float f[4]);
float f08(in float f[4]);
float f12(in float f[4]);
float f16(in float f[4]);
float f03(in float f[4]) {return f04(f);}
float f07(in float f[4]) {return f08(f);}
float f11(in float f[4]) {return f12(f);}
float f15(in float f[4]) {return f16(f);}
[fragment shader]
uniform int i;
float f05(in float f[4]);
float f09(in float f[4]);
float f13(in float f[4]);
float f04(in float f[4]) {return f05(f);}
float f08(in float f[4]) {return f09(f);}
float f12(in float f[4]) {return f13(f);}
float f16(in float f[4]) {return f[i] + 0.1;}
[test]
uniform int i 3
draw rect -1 -1 2 2
probe all rgba 0.2 0 0 1.0
|