-
Notifications
You must be signed in to change notification settings - Fork 103
/
GL_EXT_control_flow_attributes.txt
193 lines (127 loc) · 5.94 KB
/
GL_EXT_control_flow_attributes.txt
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
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
Name
EXT_control_flow_attributes
Name Strings
GL_EXT_control_flow_attributes
Contact
John Kessenich (johnkessenich 'at' google.com), Google
Contributors
Khronos members
Notice
Copyright (c) 2018 Google, Inc.
Status
Draft.
Version
Last Modified Date: 31-Jan-2018
Revision: 4
Number
TBD
Dependencies
Written against SPIR-V 1.2.
Written against GLSL 4.6.
This extension can be applied to OpenGL GLSL versions 1.40
(#version 140) and higher.
This extension can be applied to OpenGL ES ESSL versions 3.10
(#version 310) and higher.
Overview
Adds attributes to declare how loops and selections should be lowered by
a consumer.
This is done through an attribute "[[ ... ]]" syntax. For example,
[[unroll]] for (int i = 0; i < 8; ++i) { ... }
[[dont_unroll]] while(...) { ... }
[[dependency_infinite]] do { ... } while(...);
[[dependency_length(4)]] for (int i = 0; i < 8; ++i) { ... }
[[flatten]] if (...) { ... } else { ... }
[[dont_flatten]] switch(...) { ... }
These can be combined into a single use of an attribute, e.g.:
[[unroll, dependency_length(4)]] for (int x = 0; i < 8; ++i) { ... }
Combinations that don't make sense are allowed, but result in only an
unknown subset getting applied.
Add to Chapter 3 of the OpenGL Shading Language Specification
Including the following line in a shader will control the language
features described in this extension:
#extension GL_EXT_control_flow_attributes : <behavior>
Where <behavior> is as specified in section 3.3.
This new definition is added to the OpenGL Shading Language:
#define GL_EXT_control_flow_attributes 1
Add to Chapter 6 "Statements and Structure" to the OpenGL Shading Language
Specification:
6.5 Control-Flow Attributes
Control-flow attributes are declared with the following example syntax:
[[attribute1]]
[[attribute1, attribute2, ...]]
The full syntax is normatively defined by the grammar in Section 9.
To take effect, the attribute must appear immediately in front of the *if*,
*switch*, *for*, *do*, or *while* keyword of the control-flow construct it
wants to affect.
Control-Flow Attributes
Attribute | Relevant on | Intent
-----------------------+-------------+------------------------------------
*unroll* | Loop | remove or reduce loop control flow
*dont_unroll* | Loop | keep loop control flow
*loop* | Loop | same as *dont_unroll*
*dependency_infinite* | Loop | declare no dependencies between
| | loop iterations
*dependency_length(L)* | Loop | declare no dependencies between
| | L iterations of the loop
*flatten* | Selection | remove selection control flow
*dont_flatten* | Selection | keep selection control flow
*branch* | Selection | same as *dont_flatten*
"Loop" includes *for*, *while*, and *do-while* loops.
"Selection" includes *if*, *if-else*, and *switch* statements.
/L/ in *dependency_length* must be a positive signed or unsigned
non-specialization compile-time constant integral expression, or a
compile-time error results.
The *unroll*, *dont_unroll*, *flatten*, and *dont_flatten* attributes are
strong requests to the consumer. The *dependency_infinite* and
*dependency_length* attributes are guarantees that the consumer can rely on.
There are no constraints on which attributes can be used or combined on
which control-flow constructs. If contradictory or irrelevant attributes
are declared, the consumer is free to subset or ignore, respectively, the
attributes.
Attributes are case sensitive.
Unrecognized attributes, and attributes with unexpected arguments or lack of
arguments, do not cause errors but are instead ignored. (Implementations
would likely want to emit warnings for these situations.)
Changes to Chapter 9 of the OpenGL Shading Language Specification
Add these:
attribute:
LEFT_BRACKET LEFT_BRACKET attribute_list RIGHT_BRACKET RIGHT_BRACKET
attribute_list:
single_attribute
attribute_list COMMA single_attribute
single_attribute:
IDENTIFIER
IDENTIFIER LEFT_PAREN constant_expression RIGHT_PAREN
Change "selection_statement: ..." to
selection_statement:
selection_statement_nonattributed
attribute selection_statement_nonattributed
selection_statement_nonattributed:
...
Change "switch_statemment: ..." to
switch_statement:
switch_statement_nonattributed
attribute switch_statement_nonattributed
switch_statement_nonattributed:
...
Change "iteration_statement: ..." to
iteration_statement:
iteration_statement_nonattributed
attribute iteration_statement_nonattributed
iteration_statement_nonattributed:
...
Issues
1. Should we use namespaces? E.g. [[spv::unroll]]. These seem pretty
universal. OpenCL has [[cl::unroll]].
2. Should "[[" be a single token or two "[" tokens?
Past discussions around this have come down on the side of separate
tokens, allowing white space between the brackets.
RESOLVED. Use two LEFT_BRACKET tokens. Same for RIGHT_BRACKET.
Revision History
Rev. Date Author Changes
---- ----------- ------- ----------------------------------------------
1 25-Jan-2018 JohnK initial draft
2 25-Jan-2018 JohnK be more clear what L can be, complete the
grammar, and add issue 2
3 29-Jan-2018 JohnK discuss errors and warnings
4 31-Jan-2018 JohnK attributes are case sensitive