mirror of
https://github.com/KhronosGroup/glslang
synced 2024-11-09 12:00:05 +00:00
Add constant expression with mod
Purpose: glsl spec allows to define array with the length of the result of constant expression, the arithmetic operation of "mod(float (7.1), float (4.0))" should be generate the array length at the shader compile time, but glslang didn't support mod operation for the constant expression in previous implementation; An example is as following: ########### #version 460 flat out highp int vtx_out_out0; void main (void) { float array[int(mod(float (7.1), float (4.0)))]; vtx_out_out0 = array.length(); } ###########
This commit is contained in:
parent
bd97b6f9f2
commit
44e842cd9c
@ -7,6 +7,7 @@ float f;;;
|
||||
void main()
|
||||
{
|
||||
bool b1;
|
||||
float array[int(mod(float (7.1), float (4.0)))];
|
||||
b1 = anyInvocation(b1);
|
||||
b1 = allInvocations(b1);
|
||||
b1 = allInvocationsEqual(b1);
|
||||
|
@ -4,18 +4,18 @@ Shader version: 460
|
||||
0:7 Function Definition: main( ( global void)
|
||||
0:7 Function Parameters:
|
||||
0:? Sequence
|
||||
0:10 move second child to first child ( temp bool)
|
||||
0:10 'b1' ( temp bool)
|
||||
0:10 anyInvocation ( global bool)
|
||||
0:10 'b1' ( temp bool)
|
||||
0:11 move second child to first child ( temp bool)
|
||||
0:11 'b1' ( temp bool)
|
||||
0:11 allInvocations ( global bool)
|
||||
0:11 anyInvocation ( global bool)
|
||||
0:11 'b1' ( temp bool)
|
||||
0:12 move second child to first child ( temp bool)
|
||||
0:12 'b1' ( temp bool)
|
||||
0:12 allInvocationsEqual ( global bool)
|
||||
0:12 allInvocations ( global bool)
|
||||
0:12 'b1' ( temp bool)
|
||||
0:13 move second child to first child ( temp bool)
|
||||
0:13 'b1' ( temp bool)
|
||||
0:13 allInvocationsEqual ( global bool)
|
||||
0:13 'b1' ( temp bool)
|
||||
0:? Linker Objects
|
||||
0:? 'i' ( global int)
|
||||
0:? 'f' ( global float)
|
||||
@ -31,18 +31,18 @@ Shader version: 460
|
||||
0:7 Function Definition: main( ( global void)
|
||||
0:7 Function Parameters:
|
||||
0:? Sequence
|
||||
0:10 move second child to first child ( temp bool)
|
||||
0:10 'b1' ( temp bool)
|
||||
0:10 anyInvocation ( global bool)
|
||||
0:10 'b1' ( temp bool)
|
||||
0:11 move second child to first child ( temp bool)
|
||||
0:11 'b1' ( temp bool)
|
||||
0:11 allInvocations ( global bool)
|
||||
0:11 anyInvocation ( global bool)
|
||||
0:11 'b1' ( temp bool)
|
||||
0:12 move second child to first child ( temp bool)
|
||||
0:12 'b1' ( temp bool)
|
||||
0:12 allInvocationsEqual ( global bool)
|
||||
0:12 allInvocations ( global bool)
|
||||
0:12 'b1' ( temp bool)
|
||||
0:13 move second child to first child ( temp bool)
|
||||
0:13 'b1' ( temp bool)
|
||||
0:13 allInvocationsEqual ( global bool)
|
||||
0:13 'b1' ( temp bool)
|
||||
0:? Linker Objects
|
||||
0:? 'i' ( global int)
|
||||
0:? 'f' ( global float)
|
||||
|
@ -1012,6 +1012,7 @@ TIntermTyped* TIntermediate::fold(TIntermAggregate* aggrNode)
|
||||
case EOpMin:
|
||||
case EOpMax:
|
||||
case EOpMix:
|
||||
case EOpMod:
|
||||
case EOpClamp:
|
||||
case EOpLessThan:
|
||||
case EOpGreaterThan:
|
||||
@ -1074,6 +1075,15 @@ TIntermTyped* TIntermediate::fold(TIntermAggregate* aggrNode)
|
||||
case EOpPow:
|
||||
newConstArray[comp].setDConst(pow(childConstUnions[0][arg0comp].getDConst(), childConstUnions[1][arg1comp].getDConst()));
|
||||
break;
|
||||
case EOpMod:
|
||||
{
|
||||
double arg0 = childConstUnions[0][arg0comp].getDConst();
|
||||
double arg1 = childConstUnions[1][arg1comp].getDConst();
|
||||
assert(arg1 != 0.0);
|
||||
double result = arg0 - arg1 * floor(arg0 / arg1);
|
||||
newConstArray[comp].setDConst(result);
|
||||
break;
|
||||
}
|
||||
case EOpMin:
|
||||
switch(children[0]->getAsTyped()->getBasicType()) {
|
||||
case EbtFloat16:
|
||||
|
Loading…
Reference in New Issue
Block a user