Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
G
glslang
Project
Overview
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Chen Yisong
glslang
Commits
af201e8a
Commit
af201e8a
authored
Dec 29, 2015
by
John Kessenich
Browse files
Options
Browse Files
Download
Plain Diff
Merge branch GitHub 'master' into GitLab master
parents
4c42a976
c9e0a42b
Hide whitespace changes
Inline
Side-by-side
Showing
10 changed files
with
324 additions
and
274 deletions
+324
-274
GlslangToSpv.cpp
SPIRV/GlslangToSpv.cpp
+46
-26
SpvBuilder.cpp
SPIRV/SpvBuilder.cpp
+12
-7
SpvBuilder.h
SPIRV/SpvBuilder.h
+1
-1
spv.140.frag.out
Test/baseResults/spv.140.frag.out
+41
-40
spv.layoutNested.vert.out
Test/baseResults/spv.layoutNested.vert.out
+191
-188
Types.h
glslang/Include/Types.h
+4
-0
ParseHelper.cpp
glslang/MachineIndependent/ParseHelper.cpp
+2
-1
linkValidate.cpp
glslang/MachineIndependent/linkValidate.cpp
+22
-8
localintermediate.h
glslang/MachineIndependent/localintermediate.h
+1
-1
reflection.cpp
glslang/MachineIndependent/reflection.cpp
+4
-2
No files found.
SPIRV/GlslangToSpv.cpp
View file @
af201e8a
...
...
@@ -1651,10 +1651,37 @@ spv::Id TGlslangToSpvTraverser::convertGlslangToSpvType(const glslang::TType& ty
}
if
(
type
.
isArray
())
{
int
stride
=
0
;
// keep this 0 unless doing an explicit layout; 0 will mean no decoration, no stride
// Do all but the outer dimension
for
(
int
dim
=
type
.
getArraySizes
()
->
getNumDims
()
-
1
;
dim
>
0
;
--
dim
)
{
assert
(
type
.
getArraySizes
()
->
getDimSize
(
dim
)
>
0
);
spvType
=
builder
.
makeArrayType
(
spvType
,
type
.
getArraySizes
()
->
getDimSize
(
dim
));
if
(
type
.
getArraySizes
()
->
getNumDims
()
>
1
)
{
if
(
explicitLayout
!=
glslang
::
ElpNone
)
{
// Use a dummy glslang type for querying internal strides of
// arrays of arrays, but using just a one-dimensional array.
glslang
::
TType
simpleArrayType
(
type
,
0
);
// deference type of the array
while
(
simpleArrayType
.
getArraySizes
().
getNumDims
()
>
1
)
simpleArrayType
.
getArraySizes
().
dereference
();
// Will compute the higher-order strides here, rather than making a whole
// pile of types and doing repetitive recursion on their contents.
stride
=
getArrayStride
(
simpleArrayType
,
explicitLayout
,
qualifier
.
layoutMatrix
);
}
for
(
int
dim
=
type
.
getArraySizes
()
->
getNumDims
()
-
1
;
dim
>
0
;
--
dim
)
{
int
size
=
type
.
getArraySizes
()
->
getDimSize
(
dim
);
assert
(
size
>
0
);
spvType
=
builder
.
makeArrayType
(
spvType
,
size
,
stride
);
if
(
stride
>
0
)
builder
.
addDecoration
(
spvType
,
spv
::
DecorationArrayStride
,
stride
);
stride
*=
size
;
}
}
else
{
// single-dimensional array, and don't yet have stride
// We need to decorate array strides for types needing explicit layout,
// except for the very top if it is an array of blocks; that array is
// not laid out in memory in a way needing a stride.
if
(
explicitLayout
!=
glslang
::
ElpNone
&&
type
.
getBasicType
()
!=
glslang
::
EbtBlock
)
stride
=
getArrayStride
(
type
,
explicitLayout
,
qualifier
.
layoutMatrix
);
}
// Do the outer dimension, which might not be known for a runtime-sized array
...
...
@@ -1662,18 +1689,10 @@ spv::Id TGlslangToSpvTraverser::convertGlslangToSpvType(const glslang::TType& ty
spvType
=
builder
.
makeRuntimeArray
(
spvType
);
}
else
{
assert
(
type
.
getOuterArraySize
()
>
0
);
spvType
=
builder
.
makeArrayType
(
spvType
,
type
.
getOuterArraySize
());
spvType
=
builder
.
makeArrayType
(
spvType
,
type
.
getOuterArraySize
()
,
stride
);
}
// TODO: explicit layout still needs to be done hierarchically for arrays of arrays, which
// may still require additional "link time" support from the front-end
// for arrays of arrays
// We need to decorate array strides for types needing explicit layout,
// except for the very top if it is an array of blocks; that array is
// not laid out in memory in a way needing a stride.
if
(
explicitLayout
&&
type
.
getBasicType
()
!=
glslang
::
EbtBlock
)
builder
.
addDecoration
(
spvType
,
spv
::
DecorationArrayStride
,
getArrayStride
(
type
,
explicitLayout
,
qualifier
.
layoutMatrix
));
if
(
stride
>
0
)
builder
.
addDecoration
(
spvType
,
spv
::
DecorationArrayStride
,
stride
);
}
return
spvType
;
...
...
@@ -1707,25 +1726,25 @@ glslang::TLayoutPacking TGlslangToSpvTraverser::getExplicitLayout(const glslang:
int
TGlslangToSpvTraverser
::
getArrayStride
(
const
glslang
::
TType
&
arrayType
,
glslang
::
TLayoutPacking
explicitLayout
,
glslang
::
TLayoutMatrix
matrixLayout
)
{
int
size
;
int
stride
=
glslangIntermediate
->
getBaseAlignment
(
arrayType
,
size
,
explicitLayout
==
glslang
::
ElpStd140
,
matrixLayout
==
glslang
::
ElmRowMajor
);
if
(
arrayType
.
isMatrix
())
{
// GLSL strides are set to alignments of the matrix flattened to individual rows/cols,
// but SPV needs an array stride for the whole matrix, not the rows/cols
if
(
matrixLayout
==
glslang
::
ElmRowMajor
)
stride
*=
arrayType
.
getMatrixRows
();
else
stride
*=
arrayType
.
getMatrixCols
();
}
int
stride
;
glslangIntermediate
->
getBaseAlignment
(
arrayType
,
size
,
stride
,
explicitLayout
==
glslang
::
ElpStd140
,
matrixLayout
==
glslang
::
ElmRowMajor
);
return
stride
;
}
// Given a matrix type, returns the integer stride required for that matrix
// Given a matrix type,
or array (of array) of matrixes type,
returns the integer stride required for that matrix
// when used as a member of an interface block
int
TGlslangToSpvTraverser
::
getMatrixStride
(
const
glslang
::
TType
&
matrixType
,
glslang
::
TLayoutPacking
explicitLayout
,
glslang
::
TLayoutMatrix
matrixLayout
)
{
glslang
::
TType
elementType
;
elementType
.
shallowCopy
(
matrixType
);
elementType
.
clearArraySizes
();
int
size
;
return
glslangIntermediate
->
getBaseAlignment
(
matrixType
,
size
,
explicitLayout
==
glslang
::
ElpStd140
,
matrixLayout
==
glslang
::
ElmRowMajor
);
int
stride
;
glslangIntermediate
->
getBaseAlignment
(
elementType
,
size
,
stride
,
explicitLayout
==
glslang
::
ElpStd140
,
matrixLayout
==
glslang
::
ElmRowMajor
);
return
stride
;
}
// Given a member type of a struct, realign the current offset for it, and compute
...
...
@@ -1764,7 +1783,8 @@ void TGlslangToSpvTraverser::updateMemberOffset(const glslang::TType& structType
// but possibly not yet correctly aligned.
int
memberSize
;
int
memberAlignment
=
glslangIntermediate
->
getBaseAlignment
(
memberType
,
memberSize
,
explicitLayout
==
glslang
::
ElpStd140
,
matrixLayout
==
glslang
::
ElmRowMajor
);
int
dummyStride
;
int
memberAlignment
=
glslangIntermediate
->
getBaseAlignment
(
memberType
,
memberSize
,
dummyStride
,
explicitLayout
==
glslang
::
ElpStd140
,
matrixLayout
==
glslang
::
ElmRowMajor
);
glslang
::
RoundToPow2
(
currentOffset
,
memberAlignment
);
nextOffset
=
currentOffset
+
memberSize
;
}
...
...
SPIRV/SpvBuilder.cpp
View file @
af201e8a
...
...
@@ -281,18 +281,23 @@ Id Builder::makeMatrixType(Id component, int cols, int rows)
return
type
->
getResultId
();
}
Id
Builder
::
makeArrayType
(
Id
element
,
unsigned
size
)
// TODO: performance: track arrays per stride
// If a stride is supplied (non-zero) make an array.
// If no stride (0), reuse previous array types.
Id
Builder
::
makeArrayType
(
Id
element
,
unsigned
size
,
int
stride
)
{
// First, we need a constant instruction for the size
Id
sizeId
=
makeUintConstant
(
size
);
// try to find existing type
Instruction
*
type
;
for
(
int
t
=
0
;
t
<
(
int
)
groupedTypes
[
OpTypeArray
].
size
();
++
t
)
{
type
=
groupedTypes
[
OpTypeArray
][
t
];
if
(
type
->
getIdOperand
(
0
)
==
element
&&
type
->
getIdOperand
(
1
)
==
sizeId
)
return
type
->
getResultId
();
if
(
stride
==
0
)
{
// try to find existing type
for
(
int
t
=
0
;
t
<
(
int
)
groupedTypes
[
OpTypeArray
].
size
();
++
t
)
{
type
=
groupedTypes
[
OpTypeArray
][
t
];
if
(
type
->
getIdOperand
(
0
)
==
element
&&
type
->
getIdOperand
(
1
)
==
sizeId
)
return
type
->
getResultId
();
}
}
// not found, make it
...
...
SPIRV/SpvBuilder.h
View file @
af201e8a
...
...
@@ -102,7 +102,7 @@ public:
Id
makeStructResultType
(
Id
type0
,
Id
type1
);
Id
makeVectorType
(
Id
component
,
int
size
);
Id
makeMatrixType
(
Id
component
,
int
cols
,
int
rows
);
Id
makeArrayType
(
Id
element
,
unsigned
size
);
Id
makeArrayType
(
Id
element
,
unsigned
size
,
int
stride
);
// 0 means no stride decoration
Id
makeRuntimeArray
(
Id
element
);
Id
makeFunctionType
(
Id
returnType
,
std
::
vector
<
Id
>&
paramTypes
);
Id
makeImageType
(
Id
sampledType
,
Dim
,
bool
depth
,
bool
arrayed
,
bool
ms
,
unsigned
sampled
,
ImageFormat
format
);
...
...
Test/baseResults/spv.140.frag.out
View file @
af201e8a
...
...
@@ -5,7 +5,7 @@ Linked fragment stage:
// Module Version 10000
// Generated by (magic number): 80001
// Id's are bound by
99
// Id's are bound by
100
Capability Shader
1: ExtInstImport "GLSL.std.450"
...
...
@@ -24,39 +24,39 @@ Linked fragment stage:
Name 55 "sampR"
Name 63 "sampB"
Name 86 "samp2Da"
Name 9
0
"bn"
MemberName 9
0
(bn) 0 "matra"
MemberName 9
0
(bn) 1 "matca"
MemberName 9
0
(bn) 2 "matr"
MemberName 9
0
(bn) 3 "matc"
MemberName 9
0
(bn) 4 "matrdef"
Name 9
2
""
Name 9
5
"bi"
MemberName 9
5
(bi) 0 "v"
Name 9
8
"bname"
Name 9
1
"bn"
MemberName 9
1
(bn) 0 "matra"
MemberName 9
1
(bn) 1 "matca"
MemberName 9
1
(bn) 2 "matr"
MemberName 9
1
(bn) 3 "matc"
MemberName 9
1
(bn) 4 "matrdef"
Name 9
3
""
Name 9
6
"bi"
MemberName 9
6
(bi) 0 "v"
Name 9
9
"bname"
Decorate 16(gl_FrontFacing) BuiltIn FrontFacing
Decorate 33(gl_ClipDistance) BuiltIn ClipDistance
Decorate 89 ArrayStride 64
Decorate
89
ArrayStride 64
MemberDecorate 9
0
(bn) 0 RowMajor
MemberDecorate 9
0
(bn) 0 Offset 0
MemberDecorate 9
0
(bn) 0 MatrixStride 16
MemberDecorate 9
0
(bn) 1 ColMajor
MemberDecorate 9
0
(bn) 1 Offset 256
MemberDecorate 9
0
(bn) 1 MatrixStride 16
MemberDecorate 9
0
(bn) 2 RowMajor
MemberDecorate 9
0
(bn) 2 Offset 512
MemberDecorate 9
0
(bn) 2 MatrixStride 16
MemberDecorate 9
0
(bn) 3 ColMajor
MemberDecorate 9
0
(bn) 3 Offset 576
MemberDecorate 9
0
(bn) 3 MatrixStride 16
MemberDecorate 9
0
(bn) 4 RowMajor
MemberDecorate 9
0
(bn) 4 Offset 640
MemberDecorate 9
0
(bn) 4 MatrixStride 16
Decorate 9
0
(bn) Block
Decorate 9
4
ArrayStride 16
MemberDecorate 9
5
(bi) 0 Offset 0
Decorate 9
5
(bi) Block
Decorate
90
ArrayStride 64
MemberDecorate 9
1
(bn) 0 RowMajor
MemberDecorate 9
1
(bn) 0 Offset 0
MemberDecorate 9
1
(bn) 0 MatrixStride 16
MemberDecorate 9
1
(bn) 1 ColMajor
MemberDecorate 9
1
(bn) 1 Offset 256
MemberDecorate 9
1
(bn) 1 MatrixStride 16
MemberDecorate 9
1
(bn) 2 RowMajor
MemberDecorate 9
1
(bn) 2 Offset 512
MemberDecorate 9
1
(bn) 2 MatrixStride 16
MemberDecorate 9
1
(bn) 3 ColMajor
MemberDecorate 9
1
(bn) 3 Offset 576
MemberDecorate 9
1
(bn) 3 MatrixStride 16
MemberDecorate 9
1
(bn) 4 RowMajor
MemberDecorate 9
1
(bn) 4 Offset 640
MemberDecorate 9
1
(bn) 4 MatrixStride 16
Decorate 9
1
(bn) Block
Decorate 9
5
ArrayStride 16
MemberDecorate 9
6
(bi) 0 Offset 0
Decorate 9
6
(bi) Block
2: TypeVoid
3: TypeFunction 2
6: TypeFloat 32
...
...
@@ -108,15 +108,16 @@ Linked fragment stage:
87: TypeMatrix 26(fvec4) 4
88: 29(int) Constant 4
89: TypeArray 87 88
90(bn): TypeStruct 89 89 87 87 87
91: TypePointer Uniform 90(bn)
92: 91(ptr) Variable Uniform
93: TypeVector 6(float) 3
94: TypeArray 93(fvec3) 50
95(bi): TypeStruct 94
96: TypeArray 95(bi) 88
97: TypePointer Uniform 96
98(bname): 97(ptr) Variable Uniform
90: TypeArray 87 88
91(bn): TypeStruct 89 90 87 87 87
92: TypePointer Uniform 91(bn)
93: 92(ptr) Variable Uniform
94: TypeVector 6(float) 3
95: TypeArray 94(fvec3) 50
96(bi): TypeStruct 95
97: TypeArray 96(bi) 88
98: TypePointer Uniform 97
99(bname): 98(ptr) Variable Uniform
4(main): 2 Function None 3
5: Label
13: 12(ptr) Variable Function
...
...
Test/baseResults/spv.layoutNested.vert.out
View file @
af201e8a
...
...
@@ -7,12 +7,12 @@ Linked vertex stage:
// Module Version 10000
// Generated by (magic number): 80001
// Id's are bound by
69
// Id's are bound by
70
Capability Shader
1: ExtInstImport "GLSL.std.450"
MemoryModel Logical GLSL450
EntryPoint Vertex 4 "main" 6
2 65 67 68
EntryPoint Vertex 4 "main" 6
3 66 68 69
Source GLSL 450
Name 4 "main"
Name 14 "S"
...
...
@@ -24,157 +24,159 @@ Linked vertex stage:
MemberName 19(Block140) 1 "s"
MemberName 19(Block140) 2 "v"
Name 21 "inst140"
Name 2
2
"S"
MemberName 2
2
(S) 0 "a"
MemberName 2
2
(S) 1 "b"
MemberName 2
2
(S) 2 "c"
Name 2
5
"Block430"
MemberName 2
5
(Block430) 0 "u"
MemberName 2
5
(Block430) 1 "s"
MemberName 2
5
(Block430) 2 "v"
Name 2
7
"inst430"
Name 2
8
"S"
MemberName 2
8
(S) 0 "a"
MemberName 2
8
(S) 1 "b"
MemberName 2
8
(S) 2 "c"
Name 3
0
"s"
Name 3
1
"T"
MemberName 3
1
(T) 0 "m"
MemberName 3
1
(T) 1 "a"
Name 3
3
"t"
Name 3
4
"T"
MemberName 3
4
(T) 0 "m"
MemberName 3
4
(T) 1 "a"
Name 3
5
"Nestor"
MemberName 3
5
(Nestor) 0 "nestorT"
Name 3
6
"Bt1"
MemberName 3
6
(Bt1) 0 "nt"
Name 3
8
"Btn1"
Name
39
"T"
MemberName
39
(T) 0 "m"
MemberName
39
(T) 1 "a"
Name 4
0
"Nestor"
MemberName 4
0
(Nestor) 0 "nestorT"
Name 4
1
"Bt2"
MemberName 4
1
(Bt2) 0 "nt"
Name 4
3
"Btn2"
Name 4
4
"Bt3"
MemberName 4
4
(Bt3) 0 "ntcol"
MemberName 4
4
(Bt3) 1 "ntrow"
Name 4
6
"Btn3"
Name 4
7
"T"
MemberName 4
7
(T) 0 "m"
MemberName 4
7
(T) 1 "a"
Name 4
8
"Nestor"
MemberName 4
8
(Nestor) 0 "nestorT"
Name
49
"bBt1"
MemberName
49
(bBt1) 0 "nt"
Name 5
1
"bBtn1"
Name 5
2
"T"
MemberName 5
2
(T) 0 "m"
MemberName 5
2
(T) 1 "a"
Name 5
3
"Nestor"
MemberName 5
3
(Nestor) 0 "nestorT"
Name 5
4
"bBt2"
MemberName 5
4
(bBt2) 0 "nt"
Name 5
6
"bBtn2"
Name 5
7
"bBt3"
MemberName 5
7
(bBt3) 0 "ntcol"
MemberName 5
7
(bBt3) 1 "ntrow"
Name
59
"bBtn3"
Name 6
0
"S"
MemberName 6
0
(S) 0 "a"
MemberName 6
0
(S) 1 "b"
MemberName 6
0
(S) 2 "c"
Name 6
2
"sout"
Name 6
3
"S"
MemberName 6
3
(S) 0 "a"
MemberName 6
3
(S) 1 "b"
MemberName 6
3
(S) 2 "c"
Name 6
5
"soutinv"
Name 6
7
"gl_VertexID"
Name 6
8
"gl_InstanceID"
Name 2
3
"S"
MemberName 2
3
(S) 0 "a"
MemberName 2
3
(S) 1 "b"
MemberName 2
3
(S) 2 "c"
Name 2
6
"Block430"
MemberName 2
6
(Block430) 0 "u"
MemberName 2
6
(Block430) 1 "s"
MemberName 2
6
(Block430) 2 "v"
Name 2
8
"inst430"
Name 2
9
"S"
MemberName 2
9
(S) 0 "a"
MemberName 2
9
(S) 1 "b"
MemberName 2
9
(S) 2 "c"
Name 3
1
"s"
Name 3
2
"T"
MemberName 3
2
(T) 0 "m"
MemberName 3
2
(T) 1 "a"
Name 3
4
"t"
Name 3
5
"T"
MemberName 3
5
(T) 0 "m"
MemberName 3
5
(T) 1 "a"
Name 3
6
"Nestor"
MemberName 3
6
(Nestor) 0 "nestorT"
Name 3
7
"Bt1"
MemberName 3
7
(Bt1) 0 "nt"
Name 3
9
"Btn1"
Name
40
"T"
MemberName
40
(T) 0 "m"
MemberName
40
(T) 1 "a"
Name 4
1
"Nestor"
MemberName 4
1
(Nestor) 0 "nestorT"
Name 4
2
"Bt2"
MemberName 4
2
(Bt2) 0 "nt"
Name 4
4
"Btn2"
Name 4
5
"Bt3"
MemberName 4
5
(Bt3) 0 "ntcol"
MemberName 4
5
(Bt3) 1 "ntrow"
Name 4
7
"Btn3"
Name 4
8
"T"
MemberName 4
8
(T) 0 "m"
MemberName 4
8
(T) 1 "a"
Name 4
9
"Nestor"
MemberName 4
9
(Nestor) 0 "nestorT"
Name
50
"bBt1"
MemberName
50
(bBt1) 0 "nt"
Name 5
2
"bBtn1"
Name 5
3
"T"
MemberName 5
3
(T) 0 "m"
MemberName 5
3
(T) 1 "a"
Name 5
4
"Nestor"
MemberName 5
4
(Nestor) 0 "nestorT"
Name 5
5
"bBt2"
MemberName 5
5
(bBt2) 0 "nt"
Name 5
7
"bBtn2"
Name 5
8
"bBt3"
MemberName 5
8
(bBt3) 0 "ntcol"
MemberName 5
8
(bBt3) 1 "ntrow"
Name
60
"bBtn3"
Name 6
1
"S"
MemberName 6
1
(S) 0 "a"
MemberName 6
1
(S) 1 "b"
MemberName 6
1
(S) 2 "c"
Name 6
3
"sout"
Name 6
4
"S"
MemberName 6
4
(S) 0 "a"
MemberName 6
4
(S) 1 "b"
MemberName 6
4
(S) 2 "c"
Name 6
6
"soutinv"
Name 6
8
"gl_VertexID"
Name 6
9
"gl_InstanceID"
Decorate 13 ArrayStride 32
MemberDecorate 14(S) 0 Offset 0
MemberDecorate 14(S) 1 ColMajor
MemberDecorate 14(S) 1 Offset 16
MemberDecorate 14(S) 1 MatrixStride 16
MemberDecorate 14(S) 2 Offset 144
Decorate 18 ArrayStride 16
Decorate 16 ArrayStride 160
Decorate 18 ArrayStride 480
MemberDecorate 19(Block140) 0 Offset 0
MemberDecorate 19(Block140) 1 Offset 16
MemberDecorate 19(Block140) 2 Offset 976
Decorate 19(Block140) Block
Decorate 21(inst140) DescriptorSet 0
Decorate 21(inst140) Binding 0
Decorate 13 ArrayStride 16
MemberDecorate 22(S) 0 Offset 0
MemberDecorate 22(S) 1 ColMajor
MemberDecorate 22(S) 1 Offset 16
MemberDecorate 22(S) 1 MatrixStride 8
MemberDecorate 22(S) 2 Offset 80
Decorate 24 ArrayStride 16
MemberDecorate 25(Block430) 0 Offset 0
MemberDecorate 25(Block430) 1 Offset 16
MemberDecorate 25(Block430) 2 Offset 592
Decorate 25(Block430) BufferBlock
Decorate 27(inst430) DescriptorSet 0
Decorate 27(inst430) Binding 1
MemberDecorate 34(T) 0 RowMajor
MemberDecorate 34(T) 0 Offset 0
MemberDecorate 34(T) 0 MatrixStride 16
MemberDecorate 34(T) 1 Offset 32
MemberDecorate 35(Nestor) 0 Offset 0
MemberDecorate 36(Bt1) 0 Offset 0
Decorate 36(Bt1) Block
Decorate 38(Btn1) DescriptorSet 1
Decorate 38(Btn1) Binding 0
MemberDecorate 39(T) 0 ColMajor
MemberDecorate 39(T) 0 Offset 0
MemberDecorate 39(T) 0 MatrixStride 16
MemberDecorate 39(T) 1 Offset 32
MemberDecorate 40(Nestor) 0 Offset 0
MemberDecorate 41(Bt2) 0 Offset 0
Decorate 41(Bt2) Block
Decorate 43(Btn2) DescriptorSet 1
Decorate 43(Btn2) Binding 0
MemberDecorate 44(Bt3) 0 Offset 0
MemberDecorate 44(Bt3) 1 Offset 48
Decorate 44(Bt3) Block
Decorate 46(Btn3) DescriptorSet 1
Decorate 46(Btn3) Binding 0
MemberDecorate 47(T) 0 RowMajor
MemberDecorate 47(T) 0 Offset 0
MemberDecorate 47(T) 0 MatrixStride 8
MemberDecorate 47(T) 1 Offset 16
MemberDecorate 48(Nestor) 0 Offset 0
MemberDecorate 49(bBt1) 0 Offset 0
Decorate 49(bBt1) BufferBlock
Decorate 51(bBtn1) DescriptorSet 1
Decorate 51(bBtn1) Binding 0
MemberDecorate 52(T) 0 ColMajor
MemberDecorate 52(T) 0 Offset 0
MemberDecorate 52(T) 0 MatrixStride 8
MemberDecorate 52(T) 1 Offset 16
MemberDecorate 53(Nestor) 0 Offset 0
MemberDecorate 54(bBt2) 0 Offset 0
Decorate 54(bBt2) BufferBlock
Decorate 56(bBtn2) DescriptorSet 1
Decorate 56(bBtn2) Binding 0
MemberDecorate 57(bBt3) 0 Offset 0
MemberDecorate 57(bBt3) 1 Offset 24
Decorate 57(bBt3) BufferBlock
Decorate 59(bBtn3) DescriptorSet 1
Decorate 59(bBtn3) Binding 0
MemberDecorate 60(S) 0 Flat
MemberDecorate 60(S) 1 Flat
MemberDecorate 60(S) 2 Flat
MemberDecorate 63(S) 0 Invariant
MemberDecorate 63(S) 1 Invariant
MemberDecorate 63(S) 2 Invariant
Decorate 65(soutinv) Invariant
Decorate 67(gl_VertexID) BuiltIn VertexId
Decorate 68(gl_InstanceID) BuiltIn InstanceId
Decorate 22 ArrayStride 16
MemberDecorate 23(S) 0 Offset 0
MemberDecorate 23(S) 1 ColMajor
MemberDecorate 23(S) 1 Offset 16
MemberDecorate 23(S) 1 MatrixStride 8
MemberDecorate 23(S) 2 Offset 80
Decorate 24 ArrayStride 96
Decorate 25 ArrayStride 288
MemberDecorate 26(Block430) 0 Offset 0
MemberDecorate 26(Block430) 1 Offset 16
MemberDecorate 26(Block430) 2 Offset 592
Decorate 26(Block430) BufferBlock
Decorate 28(inst430) DescriptorSet 0
Decorate 28(inst430) Binding 1
MemberDecorate 35(T) 0 RowMajor
MemberDecorate 35(T) 0 Offset 0
MemberDecorate 35(T) 0 MatrixStride 16
MemberDecorate 35(T) 1 Offset 32
MemberDecorate 36(Nestor) 0 Offset 0
MemberDecorate 37(Bt1) 0 Offset 0
Decorate 37(Bt1) Block
Decorate 39(Btn1) DescriptorSet 1
Decorate 39(Btn1) Binding 0
MemberDecorate 40(T) 0 ColMajor
MemberDecorate 40(T) 0 Offset 0
MemberDecorate 40(T) 0 MatrixStride 16
MemberDecorate 40(T) 1 Offset 32
MemberDecorate 41(Nestor) 0 Offset 0
MemberDecorate 42(Bt2) 0 Offset 0
Decorate 42(Bt2) Block
Decorate 44(Btn2) DescriptorSet 1
Decorate 44(Btn2) Binding 0
MemberDecorate 45(Bt3) 0 Offset 0
MemberDecorate 45(Bt3) 1 Offset 48
Decorate 45(Bt3) Block
Decorate 47(Btn3) DescriptorSet 1
Decorate 47(Btn3) Binding 0
MemberDecorate 48(T) 0 RowMajor
MemberDecorate 48(T) 0 Offset 0
MemberDecorate 48(T) 0 MatrixStride 8
MemberDecorate 48(T) 1 Offset 16
MemberDecorate 49(Nestor) 0 Offset 0
MemberDecorate 50(bBt1) 0 Offset 0
Decorate 50(bBt1) BufferBlock
Decorate 52(bBtn1) DescriptorSet 1
Decorate 52(bBtn1) Binding 0
MemberDecorate 53(T) 0 ColMajor
MemberDecorate 53(T) 0 Offset 0
MemberDecorate 53(T) 0 MatrixStride 8
MemberDecorate 53(T) 1 Offset 16
MemberDecorate 54(Nestor) 0 Offset 0
MemberDecorate 55(bBt2) 0 Offset 0
Decorate 55(bBt2) BufferBlock
Decorate 57(bBtn2) DescriptorSet 1
Decorate 57(bBtn2) Binding 0
MemberDecorate 58(bBt3) 0 Offset 0
MemberDecorate 58(bBt3) 1 Offset 24
Decorate 58(bBt3) BufferBlock
Decorate 60(bBtn3) DescriptorSet 1
Decorate 60(bBtn3) Binding 0
MemberDecorate 61(S) 0 Flat
MemberDecorate 61(S) 1 Flat
MemberDecorate 61(S) 2 Flat
MemberDecorate 64(S) 0 Invariant
MemberDecorate 64(S) 1 Invariant
MemberDecorate 64(S) 2 Invariant
Decorate 66(soutinv) Invariant
Decorate 68(gl_VertexID) BuiltIn VertexId
Decorate 69(gl_InstanceID) BuiltIn InstanceId
2: TypeVoid
3: TypeFunction 2
6: TypeInt 32 1
...
...
@@ -193,53 +195,54 @@ Linked vertex stage:
19(Block140): TypeStruct 6(int) 18 10(fvec2)
20: TypePointer Uniform 19(Block140)
21(inst140): 20(ptr) Variable Uniform
22(S): TypeStruct 8(ivec3) 13 7(int)
23: TypeArray 22(S) 15
24: TypeArray 23 17
25(Block430): TypeStruct 6(int) 24 10(fvec2)
26: TypePointer Uniform 25(Block430)
27(inst430): 26(ptr) Variable Uniform
28(S): TypeStruct 8(ivec3) 13 7(int)
29: TypePointer Private 28(S)
30(s): 29(ptr) Variable Private
31(T): TypeStruct 11 6(int)
32: TypePointer Private 31(T)
33(t): 32(ptr) Variable Private
34(T): TypeStruct 11 6(int)
35(Nestor): TypeStruct 34(T)
36(Bt1): TypeStruct 35(Nestor)
37: TypePointer Uniform 36(Bt1)
38(Btn1): 37(ptr) Variable Uniform
39(T): TypeStruct 11 6(int)
40(Nestor): TypeStruct 39(T)
41(Bt2): TypeStruct 40(Nestor)
42: TypePointer Uniform 41(Bt2)
43(Btn2): 42(ptr) Variable Uniform
44(Bt3): TypeStruct 40(Nestor) 35(Nestor)
45: TypePointer Uniform 44(Bt3)
46(Btn3): 45(ptr) Variable Uniform
47(T): TypeStruct 11 6(int)
48(Nestor): TypeStruct 47(T)
49(bBt1): TypeStruct 48(Nestor)
50: TypePointer Uniform 49(bBt1)
51(bBtn1): 50(ptr) Variable Uniform
52(T): TypeStruct 11 6(int)
53(Nestor): TypeStruct 52(T)
54(bBt2): TypeStruct 53(Nestor)
55: TypePointer Uniform 54(bBt2)
56(bBtn2): 55(ptr) Variable Uniform
57(bBt3): TypeStruct 48(Nestor) 53(Nestor)
58: TypePointer Uniform 57(bBt3)
59(bBtn3): 58(ptr) Variable Uniform
60(S): TypeStruct 8(ivec3) 13 7(int)
61: TypePointer Output 60(S)
62(sout): 61(ptr) Variable Output
63(S): TypeStruct 8(ivec3) 13 7(int)
64: TypePointer Output 63(S)
65(soutinv): 64(ptr) Variable Output
66: TypePointer Input 6(int)
67(gl_VertexID): 66(ptr) Variable Input
68(gl_InstanceID): 66(ptr) Variable Input
22: TypeArray 11 12
23(S): TypeStruct 8(ivec3) 22 7(int)
24: TypeArray 23(S) 15
25: TypeArray 24 17
26(Block430): TypeStruct 6(int) 25 10(fvec2)
27: TypePointer Uniform 26(Block430)
28(inst430): 27(ptr) Variable Uniform
29(S): TypeStruct 8(ivec3) 13 7(int)
30: TypePointer Private 29(S)
31(s): 30(ptr) Variable Private
32(T): TypeStruct 11 6(int)
33: TypePointer Private 32(T)
34(t): 33(ptr) Variable Private
35(T): TypeStruct 11 6(int)
36(Nestor): TypeStruct 35(T)
37(Bt1): TypeStruct 36(Nestor)
38: TypePointer Uniform 37(Bt1)
39(Btn1): 38(ptr) Variable Uniform
40(T): TypeStruct 11 6(int)
41(Nestor): TypeStruct 40(T)
42(Bt2): TypeStruct 41(Nestor)
43: TypePointer Uniform 42(Bt2)
44(Btn2): 43(ptr) Variable Uniform
45(Bt3): TypeStruct 41(Nestor) 36(Nestor)
46: TypePointer Uniform 45(Bt3)
47(Btn3): 46(ptr) Variable Uniform
48(T): TypeStruct 11 6(int)
49(Nestor): TypeStruct 48(T)
50(bBt1): TypeStruct 49(Nestor)
51: TypePointer Uniform 50(bBt1)
52(bBtn1): 51(ptr) Variable Uniform
53(T): TypeStruct 11 6(int)
54(Nestor): TypeStruct 53(T)
55(bBt2): TypeStruct 54(Nestor)
56: TypePointer Uniform 55(bBt2)
57(bBtn2): 56(ptr) Variable Uniform
58(bBt3): TypeStruct 49(Nestor) 54(Nestor)
59: TypePointer Uniform 58(bBt3)
60(bBtn3): 59(ptr) Variable Uniform
61(S): TypeStruct 8(ivec3) 13 7(int)
62: TypePointer Output 61(S)
63(sout): 62(ptr) Variable Output
64(S): TypeStruct 8(ivec3) 13 7(int)
65: TypePointer Output 64(S)
66(soutinv): 65(ptr) Variable Output
67: TypePointer Input 6(int)
68(gl_VertexID): 67(ptr) Variable Input
69(gl_InstanceID): 67(ptr) Variable Input
4(main): 2 Function None 3
5: Label
Return
...
...
glslang/Include/Types.h
View file @
af201e8a
...
...
@@ -1206,6 +1206,10 @@ public:
arraySizes
=
new
TArraySizes
;
*
arraySizes
=
s
;
}
void
clearArraySizes
()
{
arraySizes
=
0
;
}
void
addArrayOuterSizes
(
const
TArraySizes
&
s
)
{
if
(
arraySizes
==
nullptr
)
...
...
glslang/MachineIndependent/ParseHelper.cpp
View file @
af201e8a
...
...
@@ -5353,7 +5353,8 @@ void TParseContext::fixBlockUniformOffsets(TQualifier& qualifier, TTypeList& typ
// modify just the children's view of matrix layout, if there is one for this member
TLayoutMatrix
subMatrixLayout
=
typeList
[
member
].
type
->
getQualifier
().
layoutMatrix
;
int
memberAlignment
=
intermediate
.
getBaseAlignment
(
*
typeList
[
member
].
type
,
memberSize
,
qualifier
.
layoutPacking
==
ElpStd140
,
int
dummyStride
;
int
memberAlignment
=
intermediate
.
getBaseAlignment
(
*
typeList
[
member
].
type
,
memberSize
,
dummyStride
,
qualifier
.
layoutPacking
==
ElpStd140
,
subMatrixLayout
!=
ElmNone
?
subMatrixLayout
==
ElmRowMajor
:
qualifier
.
layoutMatrix
==
ElmRowMajor
);
if
(
memberQualifier
.
hasOffset
())
{
// "The specified offset must be a multiple
...
...
glslang/MachineIndependent/linkValidate.cpp
View file @
af201e8a
...
...
@@ -858,8 +858,14 @@ int TIntermediate::getBaseAlignmentScalar(const TType& type, int& size)
// otherwise it does not, yielding std430 rules.
//
// The size is returned in the 'size' parameter
//
// The stride is only non-0 for arrays or matrices, and is the stride of the
// top-level object nested within the type. E.g., for an array of matrices,
// it is the distances needed between matrices, despite the rules saying the
// stride comes from the flattening down to vectors.
//
// Return value is the alignment of the type.
int
TIntermediate
::
getBaseAlignment
(
const
TType
&
type
,
int
&
size
,
bool
std140
,
bool
rowMajor
)
int
TIntermediate
::
getBaseAlignment
(
const
TType
&
type
,
int
&
size
,
int
&
stride
,
bool
std140
,
bool
rowMajor
)
{
int
alignment
;
...
...
@@ -916,16 +922,23 @@ int TIntermediate::getBaseAlignment(const TType& type, int& size, bool std140, b
//
// 10. If the member is an array of S structures, the S elements of the array are laid
// out in order, according to rule (9).
//
// Assuming, for rule 10: The stride is the same as the size of an element.
stride
=
0
;
int
dummyStride
;
// rules 4, 6,
and 8
// rules 4, 6,
8, and 10
if
(
type
.
isArray
())
{
// TODO: perf: this might be flattened by using getCumulativeArraySize(), and a deref that discards all arrayness
TType
derefType
(
type
,
0
);
alignment
=
getBaseAlignment
(
derefType
,
size
,
std140
,
rowMajor
);
alignment
=
getBaseAlignment
(
derefType
,
size
,
dummyStride
,
std140
,
rowMajor
);
if
(
std140
)
alignment
=
std
::
max
(
baseAlignmentVec4Std140
,
alignment
);
RoundToPow2
(
size
,
alignment
);
size
*=
type
.
getOuterArraySize
();
stride
=
size
;
// uses full matrix size for stride of an array of matrices (not quite what rule 6/8, but what's expected)
// uses the assumption for rule 10 in the comment above
size
=
stride
*
type
.
getOuterArraySize
();
return
alignment
;
}
...
...
@@ -939,7 +952,7 @@ int TIntermediate::getBaseAlignment(const TType& type, int& size, bool std140, b
int
memberSize
;
// modify just the children's view of matrix layout, if there is one for this member
TLayoutMatrix
subMatrixLayout
=
memberList
[
m
].
type
->
getQualifier
().
layoutMatrix
;
int
memberAlignment
=
getBaseAlignment
(
*
memberList
[
m
].
type
,
memberSize
,
std140
,
int
memberAlignment
=
getBaseAlignment
(
*
memberList
[
m
].
type
,
memberSize
,
dummyStride
,
std140
,
(
subMatrixLayout
!=
ElmNone
)
?
(
subMatrixLayout
==
ElmRowMajor
)
:
rowMajor
);
maxAlignment
=
std
::
max
(
maxAlignment
,
memberAlignment
);
RoundToPow2
(
size
,
memberAlignment
);
...
...
@@ -971,14 +984,15 @@ int TIntermediate::getBaseAlignment(const TType& type, int& size, bool std140, b
// rule 5: deref to row, not to column, meaning the size of vector is num columns instead of num rows
TType
derefType
(
type
,
0
,
type
.
getQualifier
().
layoutMatrix
==
ElmRowMajor
);
alignment
=
getBaseAlignment
(
derefType
,
size
,
std140
,
rowMajor
);
alignment
=
getBaseAlignment
(
derefType
,
size
,
dummyStride
,
std140
,
rowMajor
);
if
(
std140
)
alignment
=
std
::
max
(
baseAlignmentVec4Std140
,
alignment
);
RoundToPow2
(
size
,
alignment
);
stride
=
size
;
// use intra-matrix stride for stride of a just a matrix
if
(
rowMajor
)
size
*=
type
.
getMatrixRows
();
size
=
stride
*
type
.
getMatrixRows
();
else
size
*=
type
.
getMatrixCols
();
size
=
stride
*
type
.
getMatrixCols
();
return
alignment
;
}
...
...
glslang/MachineIndependent/localintermediate.h
View file @
af201e8a
...
...
@@ -305,7 +305,7 @@ public:
}
int
addXfbBufferOffset
(
const
TType
&
);
unsigned
int
computeTypeXfbSize
(
const
TType
&
,
bool
&
containsDouble
)
const
;
static
int
getBaseAlignment
(
const
TType
&
,
int
&
size
,
bool
std140
,
bool
rowMajor
);
static
int
getBaseAlignment
(
const
TType
&
,
int
&
size
,
int
&
stride
,
bool
std140
,
bool
rowMajor
);
protected
:
void
error
(
TInfoSink
&
infoSink
,
const
char
*
);
...
...
glslang/MachineIndependent/reflection.cpp
View file @
af201e8a
...
...
@@ -121,11 +121,12 @@ public:
return
memberList
[
index
].
type
->
getQualifier
().
layoutOffset
;
int
memberSize
;
int
dummyStride
;
int
offset
=
0
;
for
(
int
m
=
0
;
m
<=
index
;
++
m
)
{
// modify just the children's view of matrix layout, if there is one for this member
TLayoutMatrix
subMatrixLayout
=
memberList
[
m
].
type
->
getQualifier
().
layoutMatrix
;
int
memberAlignment
=
intermediate
.
getBaseAlignment
(
*
memberList
[
m
].
type
,
memberSize
,
type
.
getQualifier
().
layoutPacking
==
ElpStd140
,
int
memberAlignment
=
intermediate
.
getBaseAlignment
(
*
memberList
[
m
].
type
,
memberSize
,
dummyStride
,
type
.
getQualifier
().
layoutPacking
==
ElpStd140
,
subMatrixLayout
!=
ElmNone
?
subMatrixLayout
==
ElmRowMajor
:
type
.
getQualifier
().
layoutMatrix
==
ElmRowMajor
);
RoundToPow2
(
offset
,
memberAlignment
);
if
(
m
<
index
)
...
...
@@ -144,7 +145,8 @@ public:
int
lastOffset
=
getOffset
(
blockType
,
lastIndex
);
int
lastMemberSize
;
intermediate
.
getBaseAlignment
(
*
memberList
[
lastIndex
].
type
,
lastMemberSize
,
blockType
.
getQualifier
().
layoutPacking
==
ElpStd140
,
int
dummyStride
;
intermediate
.
getBaseAlignment
(
*
memberList
[
lastIndex
].
type
,
lastMemberSize
,
dummyStride
,
blockType
.
getQualifier
().
layoutPacking
==
ElpStd140
,
blockType
.
getQualifier
().
layoutMatrix
==
ElmRowMajor
);
return
lastOffset
+
lastMemberSize
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment