Merge pull request #234 from KhronosGroup/member-name-fix

Fix default member name implementation.
This commit is contained in:
Hans-Kristian Arntzen 2017-07-30 06:32:12 +02:00 committed by GitHub
commit 0817869797
10 changed files with 178 additions and 89 deletions

View File

@ -3,25 +3,25 @@ layout(local_size_x = 1, local_size_y = 1, local_size_z = 1) in;
layout(binding = 0, std430) restrict buffer _3
{
ivec4 _0;
uvec4 _1;
ivec4 _m0;
uvec4 _m1;
} _5;
layout(binding = 1, std430) restrict buffer _4
{
uvec4 _0;
ivec4 _1;
uvec4 _m0;
ivec4 _m1;
} _6;
void main()
{
_6._0 = _5._1 + uvec4(_5._0);
_6._0 = uvec4(_5._0) + _5._1;
_6._0 = _5._1 + _5._1;
_6._0 = uvec4(_5._0 + _5._0);
_6._1 = ivec4(_5._1 + _5._1);
_6._1 = _5._0 + _5._0;
_6._1 = ivec4(_5._1) + _5._0;
_6._1 = _5._0 + ivec4(_5._1);
_6._m0 = _5._m1 + uvec4(_5._m0);
_6._m0 = uvec4(_5._m0) + _5._m1;
_6._m0 = _5._m1 + _5._m1;
_6._m0 = uvec4(_5._m0 + _5._m0);
_6._m1 = ivec4(_5._m1 + _5._m1);
_6._m1 = _5._m0 + _5._m0;
_6._m1 = ivec4(_5._m1) + _5._m0;
_6._m1 = _5._m0 + ivec4(_5._m1);
}

View File

@ -3,29 +3,29 @@ layout(local_size_x = 1, local_size_y = 1, local_size_z = 1) in;
layout(binding = 0, std430) buffer _3
{
ivec4 _0;
uvec4 _1;
ivec4 _m0;
uvec4 _m1;
} _5;
layout(binding = 1, std430) buffer _4
{
uvec4 _0;
ivec4 _1;
uvec4 _m0;
ivec4 _m1;
} _6;
void main()
{
bvec4 _34 = equal(ivec4(_5._1), _5._0);
bvec4 _35 = equal(_5._0, ivec4(_5._1));
bvec4 _36 = equal(_5._1, _5._1);
bvec4 _37 = equal(_5._0, _5._0);
_6._0 = mix(uvec4(0u), uvec4(1u), _34);
_6._0 = mix(uvec4(0u), uvec4(1u), _35);
_6._0 = mix(uvec4(0u), uvec4(1u), _36);
_6._0 = mix(uvec4(0u), uvec4(1u), _37);
_6._1 = mix(ivec4(0), ivec4(1), _34);
_6._1 = mix(ivec4(0), ivec4(1), _35);
_6._1 = mix(ivec4(0), ivec4(1), _36);
_6._1 = mix(ivec4(0), ivec4(1), _37);
bvec4 _34 = equal(ivec4(_5._m1), _5._m0);
bvec4 _35 = equal(_5._m0, ivec4(_5._m1));
bvec4 _36 = equal(_5._m1, _5._m1);
bvec4 _37 = equal(_5._m0, _5._m0);
_6._m0 = mix(uvec4(0u), uvec4(1u), _34);
_6._m0 = mix(uvec4(0u), uvec4(1u), _35);
_6._m0 = mix(uvec4(0u), uvec4(1u), _36);
_6._m0 = mix(uvec4(0u), uvec4(1u), _37);
_6._m1 = mix(ivec4(0), ivec4(1), _34);
_6._m1 = mix(ivec4(0), ivec4(1), _35);
_6._m1 = mix(ivec4(0), ivec4(1), _36);
_6._m1 = mix(ivec4(0), ivec4(1), _37);
}

View File

@ -3,25 +3,25 @@ layout(local_size_x = 1, local_size_y = 1, local_size_z = 1) in;
layout(binding = 0, std430) buffer _3
{
ivec4 _0;
uvec4 _1;
ivec4 _m0;
uvec4 _m1;
} _5;
layout(binding = 1, std430) buffer _4
{
uvec4 _0;
ivec4 _1;
uvec4 _m0;
ivec4 _m1;
} _6;
void main()
{
_6._0 = uvec4(ivec4(_5._1) >> _5._0);
_6._0 = uvec4(_5._0 >> ivec4(_5._1));
_6._0 = uvec4(ivec4(_5._1) >> ivec4(_5._1));
_6._0 = uvec4(_5._0 >> _5._0);
_6._1 = ivec4(_5._1) >> ivec4(_5._1);
_6._1 = _5._0 >> _5._0;
_6._1 = ivec4(_5._1) >> _5._0;
_6._1 = _5._0 >> ivec4(_5._1);
_6._m0 = uvec4(ivec4(_5._m1) >> _5._m0);
_6._m0 = uvec4(_5._m0 >> ivec4(_5._m1));
_6._m0 = uvec4(ivec4(_5._m1) >> ivec4(_5._m1));
_6._m0 = uvec4(_5._m0 >> _5._m0);
_6._m1 = ivec4(_5._m1) >> ivec4(_5._m1);
_6._m1 = _5._m0 >> _5._m0;
_6._m1 = ivec4(_5._m1) >> _5._m0;
_6._m1 = _5._m0 >> ivec4(_5._m1);
}

View File

@ -3,25 +3,25 @@ layout(local_size_x = 1, local_size_y = 1, local_size_z = 1) in;
layout(binding = 0, std430) buffer _3
{
ivec4 _0;
uvec4 _1;
ivec4 _m0;
uvec4 _m1;
} _5;
layout(binding = 1, std430) buffer _4
{
uvec4 _0;
ivec4 _1;
uvec4 _m0;
ivec4 _m1;
} _6;
void main()
{
_6._0 = uvec4(ivec4(_5._1) / _5._0);
_6._0 = uvec4(_5._0 / ivec4(_5._1));
_6._0 = uvec4(ivec4(_5._1) / ivec4(_5._1));
_6._0 = uvec4(_5._0 / _5._0);
_6._1 = ivec4(_5._1) / ivec4(_5._1);
_6._1 = _5._0 / _5._0;
_6._1 = ivec4(_5._1) / _5._0;
_6._1 = _5._0 / ivec4(_5._1);
_6._m0 = uvec4(ivec4(_5._m1) / _5._m0);
_6._m0 = uvec4(_5._m0 / ivec4(_5._m1));
_6._m0 = uvec4(ivec4(_5._m1) / ivec4(_5._m1));
_6._m0 = uvec4(_5._m0 / _5._m0);
_6._m1 = ivec4(_5._m1) / ivec4(_5._m1);
_6._m1 = _5._m0 / _5._m0;
_6._m1 = ivec4(_5._m1) / _5._m0;
_6._m1 = _5._m0 / ivec4(_5._m1);
}

View File

@ -3,25 +3,25 @@ layout(local_size_x = 1, local_size_y = 1, local_size_z = 1) in;
layout(binding = 0, std430) buffer _3
{
ivec4 _0;
uvec4 _1;
ivec4 _m0;
uvec4 _m1;
} _5;
layout(binding = 1, std430) buffer _4
{
uvec4 _0;
ivec4 _1;
uvec4 _m0;
ivec4 _m1;
} _6;
void main()
{
_6._0 = _5._1 >> uvec4(_5._0);
_6._0 = uvec4(_5._0) >> _5._1;
_6._0 = _5._1 >> _5._1;
_6._0 = uvec4(_5._0) >> uvec4(_5._0);
_6._1 = ivec4(_5._1 >> _5._1);
_6._1 = ivec4(uvec4(_5._0) >> uvec4(_5._0));
_6._1 = ivec4(_5._1 >> uvec4(_5._0));
_6._1 = ivec4(uvec4(_5._0) >> _5._1);
_6._m0 = _5._m1 >> uvec4(_5._m0);
_6._m0 = uvec4(_5._m0) >> _5._m1;
_6._m0 = _5._m1 >> _5._m1;
_6._m0 = uvec4(_5._m0) >> uvec4(_5._m0);
_6._m1 = ivec4(_5._m1 >> _5._m1);
_6._m1 = ivec4(uvec4(_5._m0) >> uvec4(_5._m0));
_6._m1 = ivec4(_5._m1 >> uvec4(_5._m0));
_6._m1 = ivec4(uvec4(_5._m0) >> _5._m1);
}

View File

@ -3,25 +3,25 @@ layout(local_size_x = 1, local_size_y = 1, local_size_z = 1) in;
layout(binding = 0, std430) buffer _3
{
ivec4 _0;
uvec4 _1;
ivec4 _m0;
uvec4 _m1;
} _5;
layout(binding = 1, std430) buffer _4
{
uvec4 _0;
ivec4 _1;
uvec4 _m0;
ivec4 _m1;
} _6;
void main()
{
_6._0 = _5._1 / uvec4(_5._0);
_6._0 = uvec4(_5._0) / _5._1;
_6._0 = _5._1 / _5._1;
_6._0 = uvec4(_5._0) / uvec4(_5._0);
_6._1 = ivec4(_5._1 / _5._1);
_6._1 = ivec4(uvec4(_5._0) / uvec4(_5._0));
_6._1 = ivec4(_5._1 / uvec4(_5._0));
_6._1 = ivec4(uvec4(_5._0) / _5._1);
_6._m0 = _5._m1 / uvec4(_5._m0);
_6._m0 = uvec4(_5._m0) / _5._m1;
_6._m0 = _5._m1 / _5._m1;
_6._m0 = uvec4(_5._m0) / uvec4(_5._m0);
_6._m1 = ivec4(_5._m1 / _5._m1);
_6._m1 = ivec4(uvec4(_5._m0) / uvec4(_5._m0));
_6._m1 = ivec4(_5._m1 / uvec4(_5._m0));
_6._m1 = ivec4(uvec4(_5._m0) / _5._m1);
}

View File

@ -3,25 +3,25 @@ layout(local_size_x = 1, local_size_y = 1, local_size_z = 1) in;
layout(binding = 0, std430) restrict buffer _6
{
ivec4 _0;
uvec4 _1;
ivec4 _m0;
uvec4 _m1;
} _8;
layout(binding = 1, std430) restrict buffer _7
{
uvec4 _0;
ivec4 _1;
uvec4 _m0;
ivec4 _m1;
} _9;
void main()
{
_9._0 = _8._1 + uvec4(_8._0);
_9._0 = uvec4(_8._0) + _8._1;
_9._0 = _8._1 + _8._1;
_9._0 = uvec4(_8._0 + _8._0);
_9._1 = ivec4(_8._1 + _8._1);
_9._1 = _8._0 + _8._0;
_9._1 = ivec4(_8._1) + _8._0;
_9._1 = _8._0 + ivec4(_8._1);
_9._m0 = _8._m1 + uvec4(_8._m0);
_9._m0 = uvec4(_8._m0) + _8._m1;
_9._m0 = _8._m1 + _8._m1;
_9._m0 = uvec4(_8._m0 + _8._m0);
_9._m1 = ivec4(_8._m1 + _8._m1);
_9._m1 = _8._m0 + _8._m0;
_9._m1 = ivec4(_8._m1) + _8._m0;
_9._m1 = _8._m0 + ivec4(_8._m1);
}

View File

@ -0,0 +1,32 @@
#version 450
struct _9
{
float _m0;
};
struct _10
{
float _m0;
float _m1;
float _m2;
float _m3;
float _m4;
float _m5;
float _m6;
float _m7;
float _m8;
float _m9;
float _m10;
float _m11;
_9 _m12;
};
layout(location = 0) out vec4 _3;
void main()
{
_10 _21;
_3 = vec4(_21._m0, _21._m1, _21._m2, _21._m3);
}

View File

@ -0,0 +1,57 @@
; SPIR-V
; Version: 1.0
; Generator: Khronos Glslang Reference Front End; 1
; Bound: 43
; Schema: 0
OpCapability Shader
%1 = OpExtInstImport "GLSL.std.450"
OpMemoryModel Logical GLSL450
OpEntryPoint Fragment %2 "main" %3
OpExecutionMode %2 OriginLowerLeft
OpDecorate %3 Location 0
%void = OpTypeVoid
%9 = OpTypeFunction %void
%float = OpTypeFloat 32
%v4float = OpTypeVector %float 4
%12 = OpTypeFunction %v4float
%_struct_5 = OpTypeStruct %float
%_struct_6 = OpTypeStruct %float %float %float %float %float %float %float %float %float %float %float %float %_struct_5
%_ptr_Function__struct_6 = OpTypePointer Function %_struct_6
%int = OpTypeInt 32 1
%int_0 = OpConstant %int 0
%_ptr_Function_float = OpTypePointer Function %float
%int_1 = OpConstant %int 1
%int_2 = OpConstant %int 2
%int_3 = OpConstant %int 3
%_ptr_Output_v4float = OpTypePointer Output %v4float
%3 = OpVariable %_ptr_Output_v4float Output
%_ptr_Function_v4float = OpTypePointer Function %v4float
%2 = OpFunction %void None %9
%22 = OpLabel
%23 = OpVariable %_ptr_Function__struct_6 Function
%24 = OpAccessChain %_ptr_Function_float %23 %int_0
%25 = OpLoad %float %24
%26 = OpAccessChain %_ptr_Function_float %23 %int_1
%27 = OpLoad %float %26
%28 = OpAccessChain %_ptr_Function_float %23 %int_2
%29 = OpLoad %float %28
%30 = OpAccessChain %_ptr_Function_float %23 %int_3
%31 = OpLoad %float %30
%32 = OpCompositeConstruct %v4float %25 %27 %29 %31
OpStore %3 %32
OpReturn
OpFunctionEnd
%4 = OpFunction %v4float None %12
%33 = OpLabel
%7 = OpVariable %_ptr_Function__struct_6 Function
%34 = OpAccessChain %_ptr_Function_float %7 %int_0
%35 = OpLoad %float %34
%36 = OpAccessChain %_ptr_Function_float %7 %int_1
%37 = OpLoad %float %36
%38 = OpAccessChain %_ptr_Function_float %7 %int_2
%39 = OpLoad %float %38
%40 = OpAccessChain %_ptr_Function_float %7 %int_3
%41 = OpLoad %float %40
%42 = OpCompositeConstruct %v4float %35 %37 %39 %41
OpReturnValue %42
OpFunctionEnd

View File

@ -5815,7 +5815,7 @@ string CompilerGLSL::to_member_name(const SPIRType &type, uint32_t index)
if (index < memb.size() && !memb[index].alias.empty())
return memb[index].alias;
else
return join("_", index);
return join("_m", index);
}
void CompilerGLSL::add_member_name(SPIRType &type, uint32_t index)