blob: 6a82851b1a34689213a6fb932d3c71ace94aeeff [file] [log] [blame]
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +01001// Copyright (c) 2015 The Khronos Group Inc.
2//
3// Permission is hereby granted, free of charge, to any person obtaining a
4// copy of this software and/or associated documentation files (the
5// "Materials"), to deal in the Materials without restriction, including
6// without limitation the rights to use, copy, modify, merge, publish,
7// distribute, sublicense, and/or sell copies of the Materials, and to
8// permit persons to whom the Materials are furnished to do so, subject to
9// the following conditions:
10//
11// The above copyright notice and this permission notice shall be included
12// in all copies or substantial portions of the Materials.
13//
14// MODIFICATIONS TO THIS FILE MAY MEAN IT NO LONGER ACCURATELY REFLECTS
15// KHRONOS STANDARDS. THE UNMODIFIED, NORMATIVE VERSIONS OF KHRONOS
16// SPECIFICATIONS AND HEADER INFORMATION ARE LOCATED AT
17// https://www.khronos.org/registry/
18//
19// THE MATERIALS ARE PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
20// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
21// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
22// IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
23// CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
24// TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
25// MATERIALS OR THE USE OR OTHER DEALINGS IN THE MATERIALS.
26
27#include "operand.h"
28
29#include <assert.h>
30#include <string.h>
31
32static const spv_operand_desc_t sourceLanguageEntries[] = {
33 {"Unknown",
34 SourceLanguageUnknown,
35 SPV_OPCODE_FLAGS_NONE,
36 0,
37 {SPV_OPERAND_TYPE_NONE}},
38 {"ESSL",
39 SourceLanguageESSL,
40 SPV_OPCODE_FLAGS_NONE,
41 0,
42 {SPV_OPERAND_TYPE_NONE}},
43 {"GLSL",
44 SourceLanguageGLSL,
45 SPV_OPCODE_FLAGS_NONE,
46 0,
47 {SPV_OPERAND_TYPE_NONE}},
48 {"OpenCL",
49 SourceLanguageOpenCL,
50 SPV_OPCODE_FLAGS_NONE,
51 0,
52 {SPV_OPERAND_TYPE_NONE}},
53};
54
55static const spv_operand_desc_t executionModelEntries[] = {
56 {"Vertex",
57 ExecutionModelVertex,
58 SPV_OPCODE_FLAGS_CAPABILITIES,
59 CapabilityShader,
60 {SPV_OPERAND_TYPE_NONE}},
61 {"TessellationControl",
62 ExecutionModelTessellationControl,
63 SPV_OPCODE_FLAGS_CAPABILITIES,
64 CapabilityTessellation,
65 {SPV_OPERAND_TYPE_NONE}},
66 {"TessellationEvaluation",
67 ExecutionModelTessellationEvaluation,
68 SPV_OPCODE_FLAGS_CAPABILITIES,
69 CapabilityTessellation,
70 {SPV_OPERAND_TYPE_NONE}},
71 {"Geometry",
72 ExecutionModelGeometry,
73 SPV_OPCODE_FLAGS_CAPABILITIES,
74 CapabilityGeometry,
75 {SPV_OPERAND_TYPE_NONE}},
76 {"Fragment",
77 ExecutionModelFragment,
78 SPV_OPCODE_FLAGS_CAPABILITIES,
79 CapabilityShader,
80 {SPV_OPERAND_TYPE_NONE}},
81 {"GLCompute",
82 ExecutionModelGLCompute,
83 SPV_OPCODE_FLAGS_CAPABILITIES,
84 CapabilityShader,
85 {SPV_OPERAND_TYPE_NONE}},
86 {"Kernel",
87 ExecutionModelKernel,
88 SPV_OPCODE_FLAGS_CAPABILITIES,
89 CapabilityKernel,
90 {SPV_OPERAND_TYPE_NONE}},
91};
92
93static const spv_operand_desc_t addressingModelEntries[] = {
94 {"Logical",
95 AddressingModelLogical,
96 SPV_OPCODE_FLAGS_NONE,
97 0,
98 {SPV_OPERAND_TYPE_NONE}},
99 {"Physical32",
100 AddressingModelPhysical32,
101 SPV_OPCODE_FLAGS_CAPABILITIES,
102 CapabilityAddresses,
103 {SPV_OPERAND_TYPE_NONE}},
104 {"Physical64",
105 AddressingModelPhysical64,
106 SPV_OPCODE_FLAGS_CAPABILITIES,
107 CapabilityAddresses,
108 {SPV_OPERAND_TYPE_NONE}},
109};
110
111static const spv_operand_desc_t memoryModelEntries[] = {
112 {"Simple",
113 MemoryModelSimple,
114 SPV_OPCODE_FLAGS_CAPABILITIES,
115 CapabilityShader,
116 {SPV_OPERAND_TYPE_NONE}},
117 {"GLSL450",
118 MemoryModelGLSL450,
119 SPV_OPCODE_FLAGS_CAPABILITIES,
120 CapabilityShader,
121 {SPV_OPERAND_TYPE_NONE}},
Lei Zhang604e5ce2015-08-14 14:46:43 -0400122 {"OpenCL",
123 MemoryModelOpenCL,
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100124 SPV_OPCODE_FLAGS_CAPABILITIES,
125 CapabilityKernel,
126 {SPV_OPERAND_TYPE_NONE}},
127};
128
Lei Zhang85c6f792015-09-23 15:42:18 -0400129// Execution mode requiring the given capability and having no operands.
130#define ExecMode0(mode, cap) \
131 #mode, ExecutionMode##mode, SPV_OPCODE_FLAGS_CAPABILITIES, Capability##cap, \
132 { \
133 SPV_OPERAND_TYPE_NONE \
134 }
135// Execution mode requiring the given capability and having one literal number
136// operand.
137#define ExecMode1(mode, cap) \
138 #mode, ExecutionMode##mode, SPV_OPCODE_FLAGS_CAPABILITIES, Capability##cap, \
139 { \
140 SPV_OPERAND_TYPE_LITERAL_NUMBER, SPV_OPERAND_TYPE_NONE \
141 }
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100142static const spv_operand_desc_t executionModeEntries[] = {
Lei Zhang85c6f792015-09-23 15:42:18 -0400143 {ExecMode1(Invocations, Geometry)},
144 {ExecMode0(SpacingEqual, Tessellation)},
145 {ExecMode0(SpacingFractionalEven, Tessellation)},
146 {ExecMode0(SpacingFractionalOdd, Tessellation)},
147 {ExecMode0(VertexOrderCw, Tessellation)},
148 {ExecMode0(VertexOrderCcw, Tessellation)},
149 {ExecMode0(PixelCenterInteger, Shader)},
150 {ExecMode0(OriginUpperLeft, Shader)},
151 {ExecMode0(OriginLowerLeft, Shader)},
152 {ExecMode0(EarlyFragmentTests, Shader)},
153 {ExecMode0(PointMode, Tessellation)},
Lei Zhang863ddbe2015-09-23 17:09:01 -0400154 {ExecMode0(Xfb, TransformFeedback)},
Lei Zhang85c6f792015-09-23 15:42:18 -0400155 {ExecMode0(DepthReplacing, Shader)},
Lei Zhang85c6f792015-09-23 15:42:18 -0400156 {ExecMode0(DepthGreater, Shader)},
157 {ExecMode0(DepthLess, Shader)},
158 {ExecMode0(DepthUnchanged, Shader)},
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100159 {"LocalSize",
160 ExecutionModeLocalSize,
161 SPV_OPCODE_FLAGS_NONE,
162 0,
163 {SPV_OPERAND_TYPE_LITERAL_NUMBER, SPV_OPERAND_TYPE_LITERAL_NUMBER,
164 SPV_OPERAND_TYPE_LITERAL_NUMBER, SPV_OPERAND_TYPE_NONE}},
165 {"LocalSizeHint",
166 ExecutionModeLocalSizeHint,
167 SPV_OPCODE_FLAGS_CAPABILITIES,
168 CapabilityKernel,
169 {SPV_OPERAND_TYPE_LITERAL_NUMBER, SPV_OPERAND_TYPE_LITERAL_NUMBER,
170 SPV_OPERAND_TYPE_LITERAL_NUMBER, SPV_OPERAND_TYPE_NONE}},
Lei Zhang85c6f792015-09-23 15:42:18 -0400171 {ExecMode0(InputPoints, Geometry)},
172 {ExecMode0(InputLines, Geometry)},
173 {ExecMode0(InputLinesAdjacency, Geometry)},
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100174 {"InputTriangles",
175 ExecutionModeInputTriangles,
176 SPV_OPCODE_FLAGS_CAPABILITIES,
Lei Zhang85c6f792015-09-23 15:42:18 -0400177 // TODO(dneto): Capabilities are defined as sequential numbers instead of
178 // bit masks. They cannot be meaningfully combined with a bitwise OR.
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100179 CapabilityGeometry | CapabilityTessellation,
180 {SPV_OPERAND_TYPE_NONE}},
Lei Zhang85c6f792015-09-23 15:42:18 -0400181 {ExecMode0(InputTrianglesAdjacency, Geometry)},
182 {ExecMode0(InputQuads, Tessellation)},
183 {ExecMode0(InputIsolines, Tessellation)},
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100184 {"OutputVertices",
185 ExecutionModeOutputVertices,
186 SPV_OPCODE_FLAGS_CAPABILITIES,
Lei Zhang85c6f792015-09-23 15:42:18 -0400187 // TODO(dneto): Capabilities are defined as sequential numbers instead of
188 // bit masks. They cannot be meaningfully combined with a bitwise OR.
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100189 CapabilityGeometry | CapabilityTessellation,
190 {SPV_OPERAND_TYPE_LITERAL_NUMBER, SPV_OPERAND_TYPE_NONE}},
Lei Zhang85c6f792015-09-23 15:42:18 -0400191 {ExecMode0(OutputPoints, Geometry)},
192 {ExecMode0(OutputLineStrip, Geometry)},
193 {ExecMode0(OutputTriangleStrip, Geometry)},
194 {ExecMode1(VecTypeHint, Kernel)},
195 {ExecMode0(ContractionOff, Kernel)},
196 {ExecMode0(IndependentForwardProgress, Kernel)},
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100197};
Lei Zhang85c6f792015-09-23 15:42:18 -0400198#undef ExecMode0
199#undef ExecMode1
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100200
201static const spv_operand_desc_t storageClassEntries[] = {
David Neto5494dd42015-09-15 16:41:38 -0400202 // TODO(dneto): There are more storage classes in Rev32 and later.
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100203 {"UniformConstant",
204 StorageClassUniformConstant,
205 SPV_OPCODE_FLAGS_NONE,
206 0,
207 {SPV_OPERAND_TYPE_NONE}},
208 {"Input",
209 StorageClassInput,
210 SPV_OPCODE_FLAGS_CAPABILITIES,
211 CapabilityShader,
212 {SPV_OPERAND_TYPE_NONE}},
213 {"Uniform",
214 StorageClassUniform,
215 SPV_OPCODE_FLAGS_CAPABILITIES,
216 CapabilityShader,
217 {SPV_OPERAND_TYPE_NONE}},
218 {"Output",
219 StorageClassOutput,
220 SPV_OPCODE_FLAGS_CAPABILITIES,
221 CapabilityShader,
222 {SPV_OPERAND_TYPE_NONE}},
223 {"WorkgroupLocal",
224 StorageClassWorkgroupLocal,
225 SPV_OPCODE_FLAGS_NONE,
226 0,
227 {SPV_OPERAND_TYPE_NONE}},
228 {"WorkgroupGlobal",
229 StorageClassWorkgroupGlobal,
230 SPV_OPCODE_FLAGS_NONE,
231 0,
232 {SPV_OPERAND_TYPE_NONE}},
233 {"PrivateGlobal",
234 StorageClassPrivateGlobal,
235 SPV_OPCODE_FLAGS_CAPABILITIES,
236 CapabilityShader,
237 {SPV_OPERAND_TYPE_NONE}},
238 {"Function",
239 StorageClassFunction,
240 SPV_OPCODE_FLAGS_NONE,
241 0,
242 {SPV_OPERAND_TYPE_NONE}},
243 {"Generic",
244 StorageClassGeneric,
245 SPV_OPCODE_FLAGS_CAPABILITIES,
246 CapabilityKernel,
247 {SPV_OPERAND_TYPE_NONE}},
David Neto9819adf2015-09-23 10:19:57 -0400248 {"PushConstant",
249 StorageClassPushConstant,
250 SPV_OPCODE_FLAGS_CAPABILITIES,
251 CapabilityShader,
252 {SPV_OPERAND_TYPE_NONE}},
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100253 {"AtomicCounter",
254 StorageClassAtomicCounter,
255 SPV_OPCODE_FLAGS_CAPABILITIES,
256 CapabilityShader,
257 {SPV_OPERAND_TYPE_NONE}},
Lei Zhang604e5ce2015-08-14 14:46:43 -0400258 {"Image",
259 StorageClassImage,
260 SPV_OPCODE_FLAGS_NONE,
261 0,
262 {SPV_OPERAND_TYPE_NONE}},
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100263};
264
265static const spv_operand_desc_t dimensionalityEntries[] = {
David Netoaa0c3a52015-09-23 10:30:06 -0400266 // TODO(dneto): Update capability dependencies for Rev32
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100267 {"1D", Dim1D, SPV_OPCODE_FLAGS_NONE, 0, {SPV_OPERAND_TYPE_NONE}},
268 {"2D", Dim2D, SPV_OPCODE_FLAGS_NONE, 0, {SPV_OPERAND_TYPE_NONE}},
269 {"3D", Dim3D, SPV_OPCODE_FLAGS_NONE, 0, {SPV_OPERAND_TYPE_NONE}},
270 {"Cube",
271 DimCube,
272 SPV_OPCODE_FLAGS_CAPABILITIES,
273 CapabilityShader,
274 {SPV_OPERAND_TYPE_NONE}},
275 {"Rect",
276 DimRect,
277 SPV_OPCODE_FLAGS_CAPABILITIES,
278 CapabilityShader,
279 {SPV_OPERAND_TYPE_NONE}},
280 {"Buffer", DimBuffer, SPV_OPCODE_FLAGS_NONE, 0, {SPV_OPERAND_TYPE_NONE}},
David Netoaa0c3a52015-09-23 10:30:06 -0400281 {"InputTarget",
282 DimInputTarget,
283 SPV_OPCODE_FLAGS_CAPABILITIES,
284 CapabilityInputTarget,
285 {SPV_OPERAND_TYPE_NONE}},
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100286};
287
288static const spv_operand_desc_t samplerAddressingModeEntries[] = {
289 {"None",
290 SamplerAddressingModeNone,
291 SPV_OPCODE_FLAGS_CAPABILITIES,
292 CapabilityKernel,
293 {SPV_OPERAND_TYPE_NONE}},
294 {"ClampToEdge",
295 SamplerAddressingModeClampToEdge,
296 SPV_OPCODE_FLAGS_CAPABILITIES,
297 CapabilityKernel,
298 {SPV_OPERAND_TYPE_NONE}},
299 {"Clamp",
300 SamplerAddressingModeClamp,
301 SPV_OPCODE_FLAGS_CAPABILITIES,
302 CapabilityKernel,
303 {SPV_OPERAND_TYPE_NONE}},
304 {"Repeat",
305 SamplerAddressingModeRepeat,
306 SPV_OPCODE_FLAGS_CAPABILITIES,
307 CapabilityKernel,
308 {SPV_OPERAND_TYPE_NONE}},
309 {"RepeatMirrored",
310 SamplerAddressingModeRepeatMirrored,
311 SPV_OPCODE_FLAGS_CAPABILITIES,
312 CapabilityKernel,
313 {SPV_OPERAND_TYPE_NONE}},
314};
315
316static const spv_operand_desc_t samplerFilterModeEntries[] = {
317 {"Nearest",
318 SamplerFilterModeNearest,
319 SPV_OPCODE_FLAGS_CAPABILITIES,
320 CapabilityKernel,
321 {SPV_OPERAND_TYPE_NONE}},
322 {"Linear",
323 SamplerFilterModeLinear,
324 SPV_OPCODE_FLAGS_CAPABILITIES,
325 CapabilityKernel,
326 {SPV_OPERAND_TYPE_NONE}},
327};
328
David Netob30a0c52015-09-16 15:56:43 -0400329static const spv_operand_desc_t samplerImageFormatEntries[] = {
330// In Rev31, all the cases depend on the Shader capability.
331// TODO(dneto): In Rev32, many of these depend on the AdvancedFormats
332// capability instead.
333#define CASE(NAME) \
334 { \
335 #NAME, ImageFormat##NAME, SPV_OPCODE_FLAGS_CAPABILITIES, CapabilityShader, \
336 { \
337 SPV_OPERAND_TYPE_NONE \
338 } \
339 }
340 // clang-format off
341 CASE(Unknown),
342 CASE(Rgba32f),
343 CASE(Rgba16f),
344 CASE(R32f),
345 CASE(Rgba8),
346 CASE(Rgba8Snorm),
347 CASE(Rg32f),
348 CASE(Rg16f),
349 CASE(R11fG11fB10f),
350 CASE(R16f),
351 CASE(Rgba16),
352 CASE(Rgb10A2),
353 CASE(Rg16),
354 CASE(Rg8),
355 CASE(R16),
356 CASE(R8),
357 CASE(Rgba16Snorm),
358 CASE(Rg16Snorm),
359 CASE(Rg8Snorm),
360 CASE(R16Snorm),
361 CASE(R8Snorm),
362 CASE(Rgba32i),
363 CASE(Rgba16i),
364 CASE(Rgba8i),
365 CASE(R32i),
366 CASE(Rg32i),
367 CASE(Rg16i),
368 CASE(Rg8i),
369 CASE(R16i),
370 CASE(R8i),
371 CASE(Rgba32ui),
372 CASE(Rgba16ui),
373 CASE(Rgba8ui),
374 CASE(R32ui),
375 CASE(Rgb10a2ui),
376 CASE(Rg32ui),
377 CASE(Rg16ui),
378 CASE(Rg8ui),
379 CASE(R16ui),
380 CASE(R8ui),
381 // clang-format on
382#undef CASE
383};
384
David Netoee1b3bb2015-09-18 11:19:18 -0400385// Image operand definitions. Each enum value is a mask. When that mask
386// bit is set, the instruction should have further ID operands.
387// Some mask values depend on a capability.
388static const spv_operand_desc_t imageOperandEntries[] = {
389// Rev32 and later adds many more enums.
390#define CASE(NAME) \
391 #NAME, spv::ImageOperands##NAME##Mask, SPV_OPCODE_FLAGS_NONE, 0
392#define CASE_CAP(NAME, CAP) \
393 #NAME, spv::ImageOperands##NAME##Mask, SPV_OPCODE_FLAGS_CAPABILITIES, CAP
394#define ID SPV_OPERAND_TYPE_ID
395#define NONE SPV_OPERAND_TYPE_NONE
396 {"None", spv::ImageOperandsMaskNone, SPV_OPCODE_FLAGS_NONE, 0, {NONE}},
397 {CASE_CAP(Bias, CapabilityShader), {ID, NONE}},
398 {CASE(Lod), {ID, NONE}},
399 {CASE(Grad), {ID, ID, NONE}},
400 {CASE(ConstOffset), {ID, NONE}},
401 {CASE_CAP(Offset, CapabilityImageGatherExtended), {ID, NONE}},
402 {CASE(ConstOffsets), {ID, NONE}},
403 {CASE(Sample), {ID, NONE}},
David Neto8576c9c2015-09-23 14:32:37 -0400404 {CASE_CAP(MinLod, CapabilityMinLod), {ID, NONE}},
David Netoee1b3bb2015-09-18 11:19:18 -0400405#undef CASE
406#undef CASE_CAP
407#undef ID
408#undef NONE
409};
410
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100411static const spv_operand_desc_t fpFastMathModeEntries[] = {
412 {"None",
413 FPFastMathModeMaskNone,
414 SPV_OPCODE_FLAGS_NONE,
415 0,
416 {SPV_OPERAND_TYPE_NONE}},
417 {"NotNaN",
418 FPFastMathModeNotNaNMask,
419 SPV_OPCODE_FLAGS_CAPABILITIES,
420 CapabilityKernel,
421 {SPV_OPERAND_TYPE_NONE}},
422 {"NotInf",
423 FPFastMathModeNotInfMask,
424 SPV_OPCODE_FLAGS_CAPABILITIES,
425 CapabilityKernel,
426 {SPV_OPERAND_TYPE_NONE}},
427 {"NSZ",
428 FPFastMathModeNSZMask,
429 SPV_OPCODE_FLAGS_CAPABILITIES,
430 CapabilityKernel,
431 {SPV_OPERAND_TYPE_NONE}},
432 {"AllowRecip",
433 FPFastMathModeAllowRecipMask,
434 SPV_OPCODE_FLAGS_CAPABILITIES,
435 CapabilityKernel,
436 {SPV_OPERAND_TYPE_NONE}},
437 {"Fast",
438 FPFastMathModeFastMask,
439 SPV_OPCODE_FLAGS_CAPABILITIES,
440 CapabilityKernel,
441 {SPV_OPERAND_TYPE_NONE}},
442};
443
444static const spv_operand_desc_t fpRoundingModeEntries[] = {
445 {"RTE",
446 FPRoundingModeRTE,
447 SPV_OPCODE_FLAGS_CAPABILITIES,
448 CapabilityKernel,
449 {SPV_OPERAND_TYPE_NONE}},
450 {"RTZ",
451 FPRoundingModeRTZ,
452 SPV_OPCODE_FLAGS_CAPABILITIES,
453 CapabilityKernel,
454 {SPV_OPERAND_TYPE_NONE}},
455 {"RTP",
456 FPRoundingModeRTP,
457 SPV_OPCODE_FLAGS_CAPABILITIES,
458 CapabilityKernel,
459 {SPV_OPERAND_TYPE_NONE}},
460 {"RTN",
461 FPRoundingModeRTN,
462 SPV_OPCODE_FLAGS_CAPABILITIES,
463 CapabilityKernel,
464 {SPV_OPERAND_TYPE_NONE}},
465};
466
467static const spv_operand_desc_t linkageTypeEntries[] = {
468 {"Export",
469 LinkageTypeExport,
470 SPV_OPCODE_FLAGS_CAPABILITIES,
471 CapabilityLinkage,
472 {SPV_OPERAND_TYPE_NONE}},
473 {"Import",
474 LinkageTypeImport,
475 SPV_OPCODE_FLAGS_CAPABILITIES,
476 CapabilityLinkage,
477 {SPV_OPERAND_TYPE_NONE}},
478};
479
480static const spv_operand_desc_t accessQualifierEntries[] = {
481 {"ReadOnly",
482 AccessQualifierReadOnly,
483 SPV_OPCODE_FLAGS_CAPABILITIES,
484 CapabilityKernel,
485 {SPV_OPERAND_TYPE_NONE}},
486 {"WriteOnly",
487 AccessQualifierWriteOnly,
488 SPV_OPCODE_FLAGS_CAPABILITIES,
489 CapabilityKernel,
490 {SPV_OPERAND_TYPE_NONE}},
491 {"ReadWrite",
492 AccessQualifierReadWrite,
493 SPV_OPCODE_FLAGS_CAPABILITIES,
494 CapabilityKernel,
495 {SPV_OPERAND_TYPE_NONE}},
496};
497
498static const spv_operand_desc_t functionParameterAttributeEntries[] = {
499 {"Zext",
500 FunctionParameterAttributeZext,
501 SPV_OPCODE_FLAGS_CAPABILITIES,
502 CapabilityKernel,
503 {SPV_OPERAND_TYPE_NONE}},
504 {"Sext",
505 FunctionParameterAttributeSext,
506 SPV_OPCODE_FLAGS_CAPABILITIES,
507 CapabilityKernel,
508 {SPV_OPERAND_TYPE_NONE}},
509 {"ByVal",
510 FunctionParameterAttributeByVal,
511 SPV_OPCODE_FLAGS_CAPABILITIES,
512 CapabilityKernel,
513 {SPV_OPERAND_TYPE_NONE}},
514 {"Sret",
515 FunctionParameterAttributeSret,
516 SPV_OPCODE_FLAGS_CAPABILITIES,
517 CapabilityKernel,
518 {SPV_OPERAND_TYPE_NONE}},
519 {"NoAlias",
520 FunctionParameterAttributeNoAlias,
521 SPV_OPCODE_FLAGS_CAPABILITIES,
522 CapabilityKernel,
523 {SPV_OPERAND_TYPE_NONE}},
David Neto37547b22015-09-10 13:23:11 -0400524 {"NoCapture",
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100525 FunctionParameterAttributeNoCapture,
526 SPV_OPCODE_FLAGS_CAPABILITIES,
527 CapabilityKernel,
528 {SPV_OPERAND_TYPE_NONE}},
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100529 {"NoWrite",
530 FunctionParameterAttributeNoWrite,
531 SPV_OPCODE_FLAGS_CAPABILITIES,
532 CapabilityKernel,
533 {SPV_OPERAND_TYPE_NONE}},
534 {"NoReadWrite",
535 FunctionParameterAttributeNoReadWrite,
536 SPV_OPCODE_FLAGS_CAPABILITIES,
537 CapabilityKernel,
538 {SPV_OPERAND_TYPE_NONE}},
539};
540
541static const spv_operand_desc_t decorationEntries[] = {
Lei Zhang604e5ce2015-08-14 14:46:43 -0400542 {"RelaxedPrecision",
543 DecorationRelaxedPrecision,
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100544 SPV_OPCODE_FLAGS_CAPABILITIES,
545 CapabilityShader,
546 {SPV_OPERAND_TYPE_NONE}},
Lei Zhang604e5ce2015-08-14 14:46:43 -0400547 {
548 "SpecId",
549 DecorationSpecId,
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100550 SPV_OPCODE_FLAGS_CAPABILITIES,
551 CapabilityShader,
Lei Zhang604e5ce2015-08-14 14:46:43 -0400552 {SPV_OPERAND_TYPE_LITERAL_NUMBER},
553 },
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100554 {"Block",
555 DecorationBlock,
556 SPV_OPCODE_FLAGS_CAPABILITIES,
557 CapabilityShader,
558 {SPV_OPERAND_TYPE_NONE}},
559 {"BufferBlock",
560 DecorationBufferBlock,
561 SPV_OPCODE_FLAGS_CAPABILITIES,
562 CapabilityShader,
563 {SPV_OPERAND_TYPE_NONE}},
564 {"RowMajor",
565 DecorationRowMajor,
566 SPV_OPCODE_FLAGS_CAPABILITIES,
567 CapabilityMatrix,
568 {SPV_OPERAND_TYPE_NONE}},
569 {"ColMajor",
570 DecorationColMajor,
571 SPV_OPCODE_FLAGS_CAPABILITIES,
572 CapabilityMatrix,
573 {SPV_OPERAND_TYPE_NONE}},
Lei Zhang604e5ce2015-08-14 14:46:43 -0400574 {"ArrayStride",
575 DecorationArrayStride,
576 SPV_OPCODE_FLAGS_CAPABILITIES,
577 CapabilityShader,
578 {SPV_OPERAND_TYPE_LITERAL_NUMBER, SPV_OPERAND_TYPE_NONE}},
579 {"MatrixStride",
580 DecorationMatrixStride,
581 SPV_OPCODE_FLAGS_CAPABILITIES,
582 CapabilityShader,
583 {SPV_OPERAND_TYPE_LITERAL_NUMBER, SPV_OPERAND_TYPE_NONE}},
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100584 {"GLSLShared",
585 DecorationGLSLShared,
586 SPV_OPCODE_FLAGS_CAPABILITIES,
587 CapabilityShader,
588 {SPV_OPERAND_TYPE_NONE}},
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100589 {"GLSLPacked",
590 DecorationGLSLPacked,
591 SPV_OPCODE_FLAGS_CAPABILITIES,
592 CapabilityShader,
593 {SPV_OPERAND_TYPE_NONE}},
Lei Zhang604e5ce2015-08-14 14:46:43 -0400594 {"CPacked",
595 DecorationCPacked,
596 SPV_OPCODE_FLAGS_CAPABILITIES,
597 CapabilityKernel,
598 {SPV_OPERAND_TYPE_NONE}},
599 {"BuiltIn",
600 DecorationBuiltIn,
601 SPV_OPCODE_FLAGS_CAPABILITIES,
602 CapabilityShader,
603 {SPV_OPERAND_TYPE_BUILT_IN, SPV_OPERAND_TYPE_NONE}},
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100604 {"Smooth",
605 DecorationSmooth,
606 SPV_OPCODE_FLAGS_CAPABILITIES,
607 CapabilityShader,
608 {SPV_OPERAND_TYPE_NONE}},
David Netodbaf4072015-09-22 16:23:06 -0400609 {"NoPerspective",
610 DecorationNoPerspective,
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100611 SPV_OPCODE_FLAGS_CAPABILITIES,
612 CapabilityShader,
613 {SPV_OPERAND_TYPE_NONE}},
614 {"Flat",
615 DecorationFlat,
616 SPV_OPCODE_FLAGS_CAPABILITIES,
617 CapabilityShader,
618 {SPV_OPERAND_TYPE_NONE}},
619 {"Patch",
620 DecorationPatch,
621 SPV_OPCODE_FLAGS_CAPABILITIES,
622 CapabilityTessellation,
623 {SPV_OPERAND_TYPE_NONE}},
624 {"Centroid",
625 DecorationCentroid,
626 SPV_OPCODE_FLAGS_CAPABILITIES,
627 CapabilityShader,
628 {SPV_OPERAND_TYPE_NONE}},
629 {"Sample",
630 DecorationSample,
631 SPV_OPCODE_FLAGS_CAPABILITIES,
632 CapabilityShader,
633 {SPV_OPERAND_TYPE_NONE}},
634 {"Invariant",
635 DecorationInvariant,
636 SPV_OPCODE_FLAGS_CAPABILITIES,
637 CapabilityShader,
638 {SPV_OPERAND_TYPE_NONE}},
639 {"Restrict",
640 DecorationRestrict,
641 SPV_OPCODE_FLAGS_NONE,
642 0,
643 {SPV_OPERAND_TYPE_NONE}},
644 {"Aliased",
645 DecorationAliased,
646 SPV_OPCODE_FLAGS_NONE,
647 0,
648 {SPV_OPERAND_TYPE_NONE}},
649 {"Volatile",
650 DecorationVolatile,
651 SPV_OPCODE_FLAGS_NONE,
652 0,
653 {SPV_OPERAND_TYPE_NONE}},
654 {"Constant",
655 DecorationConstant,
656 SPV_OPCODE_FLAGS_CAPABILITIES,
657 CapabilityKernel,
658 {SPV_OPERAND_TYPE_NONE}},
659 {"Coherent",
660 DecorationCoherent,
661 SPV_OPCODE_FLAGS_NONE,
662 0,
663 {SPV_OPERAND_TYPE_NONE}},
David Netodbaf4072015-09-22 16:23:06 -0400664 {"NonWritable",
665 DecorationNonWritable,
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100666 SPV_OPCODE_FLAGS_NONE,
667 0,
668 {SPV_OPERAND_TYPE_NONE}},
David Netodbaf4072015-09-22 16:23:06 -0400669 {"NonReadable",
670 DecorationNonReadable,
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100671 SPV_OPCODE_FLAGS_NONE,
672 0,
673 {SPV_OPERAND_TYPE_NONE}},
674 {"Uniform",
675 DecorationUniform,
676 SPV_OPCODE_FLAGS_CAPABILITIES,
677 CapabilityShader,
678 {SPV_OPERAND_TYPE_NONE}},
David Neto37547b22015-09-10 13:23:11 -0400679 {"SaturatedConversion",
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100680 DecorationSaturatedConversion,
681 SPV_OPCODE_FLAGS_CAPABILITIES,
682 CapabilityKernel,
683 {SPV_OPERAND_TYPE_NONE}},
684 {"Stream",
685 DecorationStream,
686 SPV_OPCODE_FLAGS_CAPABILITIES,
687 CapabilityGeometry,
688 {SPV_OPERAND_TYPE_LITERAL_NUMBER, SPV_OPERAND_TYPE_NONE}},
689 {"Location",
690 DecorationLocation,
691 SPV_OPCODE_FLAGS_CAPABILITIES,
692 CapabilityShader,
693 {SPV_OPERAND_TYPE_LITERAL_NUMBER, SPV_OPERAND_TYPE_NONE}},
694 {"Component",
695 DecorationComponent,
696 SPV_OPCODE_FLAGS_CAPABILITIES,
697 CapabilityShader,
698 {SPV_OPERAND_TYPE_LITERAL_NUMBER, SPV_OPERAND_TYPE_NONE}},
699 {"Index",
700 DecorationIndex,
701 SPV_OPCODE_FLAGS_CAPABILITIES,
702 CapabilityShader,
703 {SPV_OPERAND_TYPE_LITERAL_NUMBER, SPV_OPERAND_TYPE_NONE}},
704 {"Binding",
705 DecorationBinding,
706 SPV_OPCODE_FLAGS_CAPABILITIES,
707 CapabilityShader,
708 {SPV_OPERAND_TYPE_LITERAL_NUMBER, SPV_OPERAND_TYPE_NONE}},
709 {"DescriptorSet",
710 DecorationDescriptorSet,
711 SPV_OPCODE_FLAGS_CAPABILITIES,
712 CapabilityShader,
713 {SPV_OPERAND_TYPE_LITERAL_NUMBER, SPV_OPERAND_TYPE_NONE}},
714 {"Offset",
715 DecorationOffset,
716 SPV_OPCODE_FLAGS_NONE,
717 0,
718 {SPV_OPERAND_TYPE_LITERAL_NUMBER, SPV_OPERAND_TYPE_NONE}},
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100719 {"XfbBuffer",
720 DecorationXfbBuffer,
721 SPV_OPCODE_FLAGS_CAPABILITIES,
722 CapabilityShader,
723 {SPV_OPERAND_TYPE_LITERAL_NUMBER, SPV_OPERAND_TYPE_NONE}},
Lei Zhang604e5ce2015-08-14 14:46:43 -0400724 {"XfbStride",
725 DecorationXfbStride,
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100726 SPV_OPCODE_FLAGS_CAPABILITIES,
727 CapabilityShader,
728 {SPV_OPERAND_TYPE_LITERAL_NUMBER, SPV_OPERAND_TYPE_NONE}},
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100729 {"FuncParamAttr",
730 DecorationFuncParamAttr,
731 SPV_OPCODE_FLAGS_CAPABILITIES,
732 CapabilityKernel,
733 {SPV_OPERAND_TYPE_FUNCTION_PARAMETER_ATTRIBUTE, SPV_OPERAND_TYPE_NONE}},
734 {"FPRoundingMode",
735 DecorationFPRoundingMode,
736 SPV_OPCODE_FLAGS_CAPABILITIES,
737 CapabilityKernel,
738 {SPV_OPERAND_TYPE_FP_ROUNDING_MODE, SPV_OPERAND_TYPE_NONE}},
739 {"FPFastMathMode",
David Neto37547b22015-09-10 13:23:11 -0400740 DecorationFPFastMathMode,
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100741 SPV_OPCODE_FLAGS_CAPABILITIES,
742 CapabilityKernel,
743 {SPV_OPERAND_TYPE_FP_FAST_MATH_MODE, SPV_OPERAND_TYPE_NONE}},
744 {"LinkageAttributes",
745 DecorationLinkageAttributes,
746 SPV_OPCODE_FLAGS_CAPABILITIES,
747 CapabilityLinkage,
David Neto55bdfcb2015-09-10 15:51:57 -0400748 {SPV_OPERAND_TYPE_LITERAL_STRING, SPV_OPERAND_TYPE_LINKAGE_TYPE, SPV_OPERAND_TYPE_NONE}},
David Netod7687982015-09-23 14:59:27 -0400749 {"NoContraction",
750 DecorationNoContraction,
751 SPV_OPCODE_FLAGS_CAPABILITIES,
752 CapabilityShader,
753 {SPV_OPERAND_TYPE_NONE}},
754 {"InputTargetIndex",
755 DecorationInputTargetIndex,
756 SPV_OPCODE_FLAGS_CAPABILITIES,
757 CapabilityShader, // TODO(dneto): Should this be CapabilityInputTarget?
758 {SPV_OPERAND_TYPE_NONE}}, // TODO(dneto): Should this have a literal number argument?
759 {"Alignment",
760 DecorationAlignment,
761 SPV_OPCODE_FLAGS_CAPABILITIES,
762 CapabilityKernel,
763 {SPV_OPERAND_TYPE_LITERAL_NUMBER, SPV_OPERAND_TYPE_NONE}},
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100764};
765
766static const spv_operand_desc_t builtInEntries[] = {
767 {"Position",
768 BuiltInPosition,
769 SPV_OPCODE_FLAGS_CAPABILITIES,
770 CapabilityShader,
771 {SPV_OPERAND_TYPE_NONE}},
772 {"PointSize",
773 BuiltInPointSize,
774 SPV_OPCODE_FLAGS_CAPABILITIES,
775 CapabilityShader,
776 {SPV_OPERAND_TYPE_NONE}},
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100777 {"ClipDistance",
778 BuiltInClipDistance,
779 SPV_OPCODE_FLAGS_CAPABILITIES,
780 CapabilityShader,
781 {SPV_OPERAND_TYPE_NONE}},
782 {"CullDistance",
783 BuiltInCullDistance,
784 SPV_OPCODE_FLAGS_CAPABILITIES,
785 CapabilityShader,
786 {SPV_OPERAND_TYPE_NONE}},
787 {"VertexId",
788 BuiltInVertexId,
789 SPV_OPCODE_FLAGS_CAPABILITIES,
790 CapabilityShader,
791 {SPV_OPERAND_TYPE_NONE}},
792 {"InstanceId",
793 BuiltInInstanceId,
794 SPV_OPCODE_FLAGS_CAPABILITIES,
795 CapabilityShader,
796 {SPV_OPERAND_TYPE_NONE}},
797 {"PrimitiveId",
798 BuiltInPrimitiveId,
799 SPV_OPCODE_FLAGS_CAPABILITIES,
800 CapabilityGeometry | CapabilityTessellation,
801 {SPV_OPERAND_TYPE_NONE}},
802 {"InvocationId",
803 BuiltInInvocationId,
804 SPV_OPCODE_FLAGS_CAPABILITIES,
805 CapabilityGeometry | CapabilityTessellation,
806 {SPV_OPERAND_TYPE_NONE}},
807 {"Layer",
808 BuiltInLayer,
809 SPV_OPCODE_FLAGS_CAPABILITIES,
810 CapabilityGeometry,
811 {SPV_OPERAND_TYPE_NONE}},
812 {"ViewportIndex",
813 BuiltInViewportIndex,
814 SPV_OPCODE_FLAGS_CAPABILITIES,
815 CapabilityGeometry,
816 {SPV_OPERAND_TYPE_NONE}},
817 {"TessLevelOuter",
818 BuiltInTessLevelOuter,
819 SPV_OPCODE_FLAGS_CAPABILITIES,
820 CapabilityTessellation,
821 {SPV_OPERAND_TYPE_NONE}},
822 {"TessLevelInner",
823 BuiltInTessLevelInner,
824 SPV_OPCODE_FLAGS_CAPABILITIES,
825 CapabilityTessellation,
826 {SPV_OPERAND_TYPE_NONE}},
827 {"TessCoord",
828 BuiltInTessCoord,
829 SPV_OPCODE_FLAGS_CAPABILITIES,
830 CapabilityTessellation,
831 {SPV_OPERAND_TYPE_NONE}},
832 {"PatchVertices",
833 BuiltInPatchVertices,
834 SPV_OPCODE_FLAGS_CAPABILITIES,
835 CapabilityTessellation,
836 {SPV_OPERAND_TYPE_NONE}},
837 {"FragCoord",
838 BuiltInFragCoord,
839 SPV_OPCODE_FLAGS_CAPABILITIES,
840 CapabilityShader,
841 {SPV_OPERAND_TYPE_NONE}},
842 {"PointCoord",
843 BuiltInPointCoord,
844 SPV_OPCODE_FLAGS_CAPABILITIES,
845 CapabilityShader,
846 {SPV_OPERAND_TYPE_NONE}},
847 {"FrontFacing",
848 BuiltInFrontFacing,
849 SPV_OPCODE_FLAGS_CAPABILITIES,
850 CapabilityShader,
851 {SPV_OPERAND_TYPE_NONE}},
852 {"SampleId",
853 BuiltInSampleId,
854 SPV_OPCODE_FLAGS_CAPABILITIES,
855 CapabilityShader,
856 {SPV_OPERAND_TYPE_NONE}},
857 {"SamplePosition",
858 BuiltInSamplePosition,
859 SPV_OPCODE_FLAGS_CAPABILITIES,
860 CapabilityShader,
861 {SPV_OPERAND_TYPE_NONE}},
862 {"SampleMask",
863 BuiltInSampleMask,
864 SPV_OPCODE_FLAGS_CAPABILITIES,
865 CapabilityShader,
866 {SPV_OPERAND_TYPE_NONE}},
867 {"FragColor",
868 BuiltInFragColor,
869 SPV_OPCODE_FLAGS_CAPABILITIES,
870 CapabilityShader,
871 {SPV_OPERAND_TYPE_NONE}},
872 {"FragDepth",
873 BuiltInFragDepth,
874 SPV_OPCODE_FLAGS_CAPABILITIES,
875 CapabilityShader,
876 {SPV_OPERAND_TYPE_NONE}},
877 {"HelperInvocation",
878 BuiltInHelperInvocation,
879 SPV_OPCODE_FLAGS_CAPABILITIES,
880 CapabilityShader,
881 {SPV_OPERAND_TYPE_NONE}},
882 {"NumWorkgroups",
883 BuiltInNumWorkgroups,
884 SPV_OPCODE_FLAGS_NONE,
885 0,
886 {SPV_OPERAND_TYPE_NONE}},
887 {"WorkgroupSize",
888 BuiltInWorkgroupSize,
889 SPV_OPCODE_FLAGS_NONE,
890 0,
891 {SPV_OPERAND_TYPE_NONE}},
892 {"WorkgroupId",
893 BuiltInWorkgroupId,
894 SPV_OPCODE_FLAGS_NONE,
895 0,
896 {SPV_OPERAND_TYPE_NONE}},
897 {"LocalInvocationId",
898 BuiltInLocalInvocationId,
899 SPV_OPCODE_FLAGS_NONE,
900 0,
901 {SPV_OPERAND_TYPE_NONE}},
902 {"GlobalInvocationId",
903 BuiltInGlobalInvocationId,
904 SPV_OPCODE_FLAGS_NONE,
905 0,
906 {SPV_OPERAND_TYPE_NONE}},
907 {"LocalInvocationIndex",
David Neto37547b22015-09-10 13:23:11 -0400908 BuiltInLocalInvocationIndex,
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100909 SPV_OPCODE_FLAGS_CAPABILITIES,
910 CapabilityShader,
911 {SPV_OPERAND_TYPE_NONE}},
912 {"WorkDim",
913 BuiltInWorkDim,
914 SPV_OPCODE_FLAGS_CAPABILITIES,
915 CapabilityKernel,
916 {SPV_OPERAND_TYPE_NONE}},
917 {"GlobalSize",
918 BuiltInGlobalSize,
919 SPV_OPCODE_FLAGS_CAPABILITIES,
920 CapabilityKernel,
921 {SPV_OPERAND_TYPE_NONE}},
922 {"EnqueuedWorkgroupSize",
923 BuiltInEnqueuedWorkgroupSize,
924 SPV_OPCODE_FLAGS_CAPABILITIES,
925 CapabilityKernel,
926 {SPV_OPERAND_TYPE_NONE}},
927 {"GlobalOffset",
928 BuiltInGlobalOffset,
929 SPV_OPCODE_FLAGS_CAPABILITIES,
930 CapabilityKernel,
931 {SPV_OPERAND_TYPE_NONE}},
932 {"GlobalLinearId",
933 BuiltInGlobalLinearId,
934 SPV_OPCODE_FLAGS_CAPABILITIES,
935 CapabilityKernel,
936 {SPV_OPERAND_TYPE_NONE}},
937 {"WorkgroupLinearId",
938 BuiltInWorkgroupLinearId,
939 SPV_OPCODE_FLAGS_CAPABILITIES,
940 CapabilityKernel,
941 {SPV_OPERAND_TYPE_NONE}},
942 {"SubgroupSize",
943 BuiltInSubgroupSize,
944 SPV_OPCODE_FLAGS_CAPABILITIES,
945 CapabilityKernel,
946 {SPV_OPERAND_TYPE_NONE}},
947 {"SubgroupMaxSize",
948 BuiltInSubgroupMaxSize,
949 SPV_OPCODE_FLAGS_CAPABILITIES,
950 CapabilityKernel,
951 {SPV_OPERAND_TYPE_NONE}},
952 {"NumSubgroups",
953 BuiltInNumSubgroups,
954 SPV_OPCODE_FLAGS_CAPABILITIES,
955 CapabilityKernel,
956 {SPV_OPERAND_TYPE_NONE}},
957 {"NumEnqueuedSubgroups",
958 BuiltInNumEnqueuedSubgroups,
959 SPV_OPCODE_FLAGS_CAPABILITIES,
960 CapabilityKernel,
961 {SPV_OPERAND_TYPE_NONE}},
962 {"SubgroupId",
David Neto37547b22015-09-10 13:23:11 -0400963 BuiltInSubgroupId,
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100964 SPV_OPCODE_FLAGS_CAPABILITIES,
965 CapabilityKernel,
966 {SPV_OPERAND_TYPE_NONE}},
967 {"SubgroupLocalInvocationId",
968 BuiltInSubgroupLocalInvocationId,
969 SPV_OPCODE_FLAGS_CAPABILITIES,
970 CapabilityKernel,
971 {SPV_OPERAND_TYPE_NONE}},
David Neto2d1b5e52015-09-23 15:35:27 -0400972 {"VertexIndex",
973 BuiltInVertexIndex,
974 SPV_OPCODE_FLAGS_CAPABILITIES,
975 CapabilityShader,
976 {SPV_OPERAND_TYPE_NONE}},
977 {"InstanceIndex",
978 BuiltInInstanceIndex,
979 SPV_OPCODE_FLAGS_CAPABILITIES,
980 CapabilityShader,
981 {SPV_OPERAND_TYPE_NONE}},
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +0100982};
983
984static const spv_operand_desc_t selectionControlEntries[] = {
985 {"None",
986 SelectionControlMaskNone,
987 SPV_OPCODE_FLAGS_NONE,
988 0,
989 {SPV_OPERAND_TYPE_NONE}},
990 {"Flatten",
991 SelectionControlFlattenMask,
992 SPV_OPCODE_FLAGS_NONE,
993 0,
994 {SPV_OPERAND_TYPE_NONE}},
995 {"DontFlatten",
996 SelectionControlDontFlattenMask,
997 SPV_OPCODE_FLAGS_NONE,
998 0,
999 {SPV_OPERAND_TYPE_NONE}},
1000};
1001
1002static const spv_operand_desc_t loopControlEntries[] = {
1003 {"None",
1004 LoopControlMaskNone,
1005 SPV_OPCODE_FLAGS_NONE,
1006 0,
1007 {SPV_OPERAND_TYPE_NONE}},
1008 {"Unroll",
1009 LoopControlUnrollMask,
1010 SPV_OPCODE_FLAGS_NONE,
1011 0,
1012 {SPV_OPERAND_TYPE_NONE}},
1013 {"DontUnroll",
1014 LoopControlDontUnrollMask,
1015 SPV_OPCODE_FLAGS_NONE,
1016 0,
1017 {SPV_OPERAND_TYPE_NONE}},
1018};
1019
1020static const spv_operand_desc_t functionControlEntries[] = {
1021 {"None",
1022 FunctionControlMaskNone,
1023 SPV_OPCODE_FLAGS_NONE,
1024 0,
1025 {SPV_OPERAND_TYPE_NONE}},
David Netof4fde6c2015-09-14 14:50:37 -04001026 {"Inline",
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +01001027 FunctionControlInlineMask,
1028 SPV_OPCODE_FLAGS_NONE,
1029 0,
1030 {SPV_OPERAND_TYPE_NONE}},
1031 {"DontInline",
1032 FunctionControlDontInlineMask,
1033 SPV_OPCODE_FLAGS_NONE,
1034 0,
1035 {SPV_OPERAND_TYPE_NONE}},
1036 {"Pure",
1037 FunctionControlPureMask,
1038 SPV_OPCODE_FLAGS_NONE,
1039 0,
1040 {SPV_OPERAND_TYPE_NONE}},
1041 {"Const",
1042 FunctionControlConstMask,
1043 SPV_OPCODE_FLAGS_NONE,
1044 0,
1045 {SPV_OPERAND_TYPE_NONE}},
1046};
1047
1048static const spv_operand_desc_t memorySemanticsEntries[] = {
David Netobfa3d862015-09-25 10:30:27 -04001049 // "Relaxed" should be a synonym for "None".
1050 // Put the Relaxed entry first so that the disassembler
1051 // will prefer to emit "Relaxed".
1052 {"Relaxed",
1053 MemorySemanticsMaskNone,
1054 SPV_OPCODE_FLAGS_NONE,
1055 0,
1056 {SPV_OPERAND_TYPE_NONE}},
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +01001057 {"None",
1058 MemorySemanticsMaskNone,
1059 SPV_OPCODE_FLAGS_NONE,
1060 0,
1061 {SPV_OPERAND_TYPE_NONE}},
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +01001062 {"SequentiallyConsistent",
1063 MemorySemanticsSequentiallyConsistentMask,
1064 SPV_OPCODE_FLAGS_NONE,
1065 0,
1066 {SPV_OPERAND_TYPE_NONE}},
1067 {"Acquire",
1068 MemorySemanticsAcquireMask,
1069 SPV_OPCODE_FLAGS_NONE,
1070 0,
1071 {SPV_OPERAND_TYPE_NONE}},
1072 {"Release",
1073 MemorySemanticsReleaseMask,
1074 SPV_OPCODE_FLAGS_NONE,
1075 0,
1076 {SPV_OPERAND_TYPE_NONE}},
1077 {"UniformMemory",
1078 MemorySemanticsUniformMemoryMask,
1079 SPV_OPCODE_FLAGS_CAPABILITIES,
1080 CapabilityShader,
1081 {SPV_OPERAND_TYPE_NONE}},
1082 {"SubgroupMemory",
1083 MemorySemanticsSubgroupMemoryMask,
1084 SPV_OPCODE_FLAGS_NONE,
1085 0,
1086 {SPV_OPERAND_TYPE_NONE}},
1087 {"WorkgroupLocalMemory",
1088 MemorySemanticsWorkgroupLocalMemoryMask,
1089 SPV_OPCODE_FLAGS_NONE,
1090 0,
1091 {SPV_OPERAND_TYPE_NONE}},
1092 {"WorkgroupGlobalMemory",
1093 MemorySemanticsWorkgroupGlobalMemoryMask,
1094 SPV_OPCODE_FLAGS_NONE,
1095 0,
1096 {SPV_OPERAND_TYPE_NONE}},
1097 {"AtomicCounterMemory",
1098 MemorySemanticsAtomicCounterMemoryMask,
1099 SPV_OPCODE_FLAGS_CAPABILITIES,
1100 CapabilityShader,
1101 {SPV_OPERAND_TYPE_NONE}},
1102 {
1103 "ImageMemory",
1104 MemorySemanticsImageMemoryMask,
1105 SPV_OPCODE_FLAGS_NONE,
1106 0,
1107 {SPV_OPERAND_TYPE_NONE},
1108 },
1109};
1110
1111static const spv_operand_desc_t memoryAccessEntries[] = {
1112 {"None",
1113 MemoryAccessMaskNone,
1114 SPV_OPCODE_FLAGS_NONE,
1115 0,
1116 {SPV_OPERAND_TYPE_NONE}},
1117 {"Volatile",
1118 MemoryAccessVolatileMask,
1119 SPV_OPCODE_FLAGS_NONE,
1120 0,
1121 {SPV_OPERAND_TYPE_NONE}},
1122 {
1123 "Aligned",
1124 MemoryAccessAlignedMask,
1125 SPV_OPCODE_FLAGS_NONE,
1126 0,
David Neto4a291312015-09-14 15:08:48 -04001127 {SPV_OPERAND_TYPE_LITERAL_NUMBER, SPV_OPERAND_TYPE_NONE},
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +01001128 },
David Neto49c299b2015-09-23 15:38:59 -04001129 {"Nontemporal",
1130 MemoryAccessNontemporalMask,
1131 SPV_OPCODE_FLAGS_NONE,
1132 0,
1133 {SPV_OPERAND_TYPE_NONE}},
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +01001134};
1135
1136static const spv_operand_desc_t scopeEntries[] = {
1137 {"CrossDevice",
1138 ScopeCrossDevice,
1139 SPV_OPCODE_FLAGS_NONE,
1140 0,
1141 {SPV_OPERAND_TYPE_NONE}},
1142 {"Device", ScopeDevice, SPV_OPCODE_FLAGS_NONE, 0, {SPV_OPERAND_TYPE_NONE}},
1143 {"Workgroup",
1144 ScopeWorkgroup,
1145 SPV_OPCODE_FLAGS_NONE,
1146 0,
1147 {SPV_OPERAND_TYPE_NONE}},
1148 {"Subgroup",
1149 ScopeSubgroup,
1150 SPV_OPCODE_FLAGS_NONE,
1151 0,
1152 {SPV_OPERAND_TYPE_NONE}},
1153 {
1154 "Invocation",
1155 ScopeInvocation,
1156 SPV_OPCODE_FLAGS_NONE,
1157 0,
1158 {SPV_OPERAND_TYPE_NONE},
1159 },
1160};
1161
1162static const spv_operand_desc_t groupOperationEntries[] = {
1163 {"Reduce",
1164 GroupOperationReduce,
1165 SPV_OPCODE_FLAGS_CAPABILITIES,
1166 CapabilityKernel,
1167 {SPV_OPERAND_TYPE_NONE}},
1168 {"InclusiveScan",
1169 GroupOperationInclusiveScan,
1170 SPV_OPCODE_FLAGS_CAPABILITIES,
1171 CapabilityKernel,
1172 {SPV_OPERAND_TYPE_NONE}},
1173 {"ExclusiveScan",
1174 GroupOperationExclusiveScan,
1175 SPV_OPCODE_FLAGS_CAPABILITIES,
1176 CapabilityKernel,
1177 {SPV_OPERAND_TYPE_NONE}},
1178};
1179
1180static const spv_operand_desc_t kernelKernelEnqueueFlagssEntries[] = {
1181 {"NoWait",
1182 KernelEnqueueFlagsNoWait,
1183 SPV_OPCODE_FLAGS_CAPABILITIES,
1184 CapabilityKernel,
1185 {SPV_OPERAND_TYPE_NONE}},
1186 {"WaitKernel",
1187 KernelEnqueueFlagsWaitKernel,
1188 SPV_OPCODE_FLAGS_CAPABILITIES,
1189 CapabilityKernel,
1190 {SPV_OPERAND_TYPE_NONE}},
1191 {"WaitWorkGroup",
1192 KernelEnqueueFlagsWaitWorkGroup,
1193 SPV_OPCODE_FLAGS_CAPABILITIES,
1194 CapabilityKernel,
1195 {SPV_OPERAND_TYPE_NONE}},
1196};
1197
1198static const spv_operand_desc_t kernelProfilingInfoEntries[] = {
1199 {"None",
1200 KernelProfilingInfoMaskNone,
1201 SPV_OPCODE_FLAGS_NONE,
1202 0,
1203 {SPV_OPERAND_TYPE_NONE}},
1204 {"CmdExecTime",
1205 KernelProfilingInfoCmdExecTimeMask,
1206 SPV_OPCODE_FLAGS_CAPABILITIES,
1207 CapabilityKernel,
1208 {SPV_OPERAND_TYPE_NONE}},
1209};
1210
David Netod30b2332015-09-23 16:04:24 -04001211// A macro for defining a capability that doesn't depend on another capability.
1212#define CASE(NAME) \
1213 { \
1214 #NAME, Capability##NAME, SPV_OPCODE_FLAGS_NONE, 0, { \
1215 SPV_OPERAND_TYPE_NONE \
1216 } \
1217 }
1218
1219// A macro for defining a capability that depends on another.
1220#define CASE_CAP(NAME, CAP) \
1221 { \
1222 #NAME, Capability##NAME, SPV_OPCODE_FLAGS_CAPABILITIES, Capability##CAP, { \
1223 SPV_OPERAND_TYPE_NONE \
1224 } \
1225 }
1226
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +01001227static const spv_operand_desc_t capabilityInfoEntries[] = {
David Netod30b2332015-09-23 16:04:24 -04001228 CASE(Matrix),
1229 CASE_CAP(Shader, Matrix),
1230 CASE_CAP(Geometry, Shader),
1231 CASE_CAP(Tessellation, Shader),
1232 CASE(Addresses),
1233 CASE(Linkage),
1234 CASE(Kernel),
1235 CASE_CAP(Vector16, Kernel),
1236 CASE_CAP(Float16Buffer, Kernel),
1237 CASE_CAP(Float16, Float16Buffer),
1238 CASE(Float64),
1239 CASE(Int64),
1240 CASE_CAP(Int64Atomics, Int64),
1241 CASE_CAP(ImageBasic, Kernel),
1242 CASE_CAP(ImageReadWrite, Kernel),
1243 CASE_CAP(ImageMipmap, Kernel),
1244 CASE_CAP(ImageSRGBWrite, Kernel),
1245 CASE_CAP(Pipes, Kernel),
1246 CASE(Groups),
1247 CASE_CAP(DeviceEnqueue, Kernel),
1248 CASE_CAP(LiteralSampler, Kernel),
1249 CASE_CAP(AtomicStorage, Shader),
1250 CASE(Int16),
1251 CASE_CAP(TessellationPointSize, Tessellation),
1252 CASE_CAP(GeometryPointSize, Geometry),
1253 CASE_CAP(ImageGatherExtended, Shader),
1254 CASE_CAP(StorageImageExtendedFormats, Shader),
1255 CASE_CAP(StorageImageMultisample, Shader),
1256 CASE_CAP(UniformBufferArrayDynamicIndexing, Shader),
1257 CASE_CAP(SampledImageArrayDynamicIndexing, Shader),
1258 CASE_CAP(StorageBufferArrayDynamicIndexing, Shader),
1259 CASE_CAP(StorageImageArrayDynamicIndexing, Shader),
1260 CASE_CAP(ClipDistance, Shader),
1261 CASE_CAP(CullDistance, Shader),
1262 CASE_CAP(ImageCubeArray, SampledCubeArray),
1263 CASE_CAP(SampleRateShading, Shader),
1264 CASE_CAP(ImageRect, SampledRect),
1265 CASE_CAP(SampledRect, Shader),
1266 CASE_CAP(GenericPointer, Addresses),
1267 CASE_CAP(Int8, Kernel),
1268 CASE_CAP(InputTarget, Shader),
1269 CASE_CAP(SparseResidency, Shader),
1270 CASE_CAP(MinLod, Shader),
1271 CASE_CAP(Sampled1D, Shader),
1272 CASE_CAP(Image1D, Sampled1D),
1273 CASE_CAP(SampledCubeArray, Shader),
1274 CASE_CAP(SampledBuffer, Shader),
1275 CASE_CAP(ImageBuffer, SampledBuffer),
1276 CASE_CAP(ImageMSArray, Shader),
1277 CASE_CAP(AdvancedFormats, Shader),
1278 CASE_CAP(ImageQuery, Shader),
1279 CASE_CAP(DerivativeControl, Shader),
1280 CASE_CAP(InterpolationFunction, Shader),
1281 CASE_CAP(TransformFeedback, Shader),
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +01001282};
David Netod30b2332015-09-23 16:04:24 -04001283#undef CASE
1284#undef CASE_CAP
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +01001285
1286static const spv_operand_desc_group_t opcodeEntryTypes[] = {
1287 {SPV_OPERAND_TYPE_SOURCE_LANGUAGE,
1288 sizeof(sourceLanguageEntries) / sizeof(spv_operand_desc_t),
1289 sourceLanguageEntries},
1290 {SPV_OPERAND_TYPE_EXECUTION_MODEL,
1291 sizeof(executionModelEntries) / sizeof(spv_operand_desc_t),
1292 executionModelEntries},
1293 {SPV_OPERAND_TYPE_ADDRESSING_MODEL,
1294 sizeof(addressingModelEntries) / sizeof(spv_operand_desc_t),
1295 addressingModelEntries},
1296 {SPV_OPERAND_TYPE_MEMORY_MODEL,
1297 sizeof(memoryModelEntries) / sizeof(spv_operand_desc_t),
1298 memoryModelEntries},
1299 {SPV_OPERAND_TYPE_EXECUTION_MODE,
1300 sizeof(executionModeEntries) / sizeof(spv_operand_desc_t),
1301 executionModeEntries},
1302 {SPV_OPERAND_TYPE_STORAGE_CLASS,
1303 sizeof(storageClassEntries) / sizeof(spv_operand_desc_t),
1304 storageClassEntries},
1305 {SPV_OPERAND_TYPE_DIMENSIONALITY,
1306 sizeof(dimensionalityEntries) / sizeof(spv_operand_desc_t),
1307 dimensionalityEntries},
1308 {SPV_OPERAND_TYPE_SAMPLER_ADDRESSING_MODE,
1309 sizeof(samplerAddressingModeEntries) / sizeof(spv_operand_desc_t),
1310 samplerAddressingModeEntries},
1311 {SPV_OPERAND_TYPE_SAMPLER_FILTER_MODE,
1312 sizeof(samplerFilterModeEntries) / sizeof(spv_operand_desc_t),
1313 samplerFilterModeEntries},
David Netob30a0c52015-09-16 15:56:43 -04001314 {SPV_OPERAND_TYPE_SAMPLER_IMAGE_FORMAT,
1315 sizeof(samplerImageFormatEntries) / sizeof(spv_operand_desc_t),
1316 samplerImageFormatEntries},
David Netoee1b3bb2015-09-18 11:19:18 -04001317 {SPV_OPERAND_TYPE_OPTIONAL_IMAGE,
1318 sizeof(imageOperandEntries) / sizeof(spv_operand_desc_t),
1319 imageOperandEntries},
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +01001320 {SPV_OPERAND_TYPE_FP_FAST_MATH_MODE,
1321 sizeof(fpFastMathModeEntries) / sizeof(spv_operand_desc_t),
1322 fpFastMathModeEntries},
1323 {SPV_OPERAND_TYPE_FP_ROUNDING_MODE,
1324 sizeof(fpRoundingModeEntries) / sizeof(spv_operand_desc_t),
1325 fpRoundingModeEntries},
1326 {SPV_OPERAND_TYPE_LINKAGE_TYPE,
1327 sizeof(linkageTypeEntries) / sizeof(spv_operand_desc_t),
1328 linkageTypeEntries},
1329 {SPV_OPERAND_TYPE_ACCESS_QUALIFIER,
1330 sizeof(accessQualifierEntries) / sizeof(spv_operand_desc_t),
1331 accessQualifierEntries},
1332 {SPV_OPERAND_TYPE_FUNCTION_PARAMETER_ATTRIBUTE,
1333 sizeof(functionParameterAttributeEntries) / sizeof(spv_operand_desc_t),
1334 functionParameterAttributeEntries},
1335 {SPV_OPERAND_TYPE_DECORATION,
1336 sizeof(decorationEntries) / sizeof(spv_operand_desc_t), decorationEntries},
1337 {SPV_OPERAND_TYPE_BUILT_IN,
1338 sizeof(builtInEntries) / sizeof(spv_operand_desc_t), builtInEntries},
1339 {SPV_OPERAND_TYPE_SELECTION_CONTROL,
1340 sizeof(selectionControlEntries) / sizeof(spv_operand_desc_t),
1341 selectionControlEntries},
1342 {SPV_OPERAND_TYPE_LOOP_CONTROL,
1343 sizeof(loopControlEntries) / sizeof(spv_operand_desc_t),
1344 loopControlEntries},
1345 {SPV_OPERAND_TYPE_FUNCTION_CONTROL,
1346 sizeof(functionControlEntries) / sizeof(spv_operand_desc_t),
1347 functionControlEntries},
1348 {SPV_OPERAND_TYPE_MEMORY_SEMANTICS,
1349 sizeof(memorySemanticsEntries) / sizeof(spv_operand_desc_t),
1350 memorySemanticsEntries},
David Neto78c3b432015-08-27 13:03:52 -04001351 {SPV_OPERAND_TYPE_OPTIONAL_MEMORY_ACCESS,
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +01001352 sizeof(memoryAccessEntries) / sizeof(spv_operand_desc_t),
1353 memoryAccessEntries},
1354 {SPV_OPERAND_TYPE_EXECUTION_SCOPE,
1355 sizeof(scopeEntries) / sizeof(spv_operand_desc_t), scopeEntries},
1356 {SPV_OPERAND_TYPE_GROUP_OPERATION,
1357 sizeof(groupOperationEntries) / sizeof(spv_operand_desc_t),
1358 groupOperationEntries},
1359 {SPV_OPERAND_TYPE_KERNEL_ENQ_FLAGS,
1360 sizeof(kernelKernelEnqueueFlagssEntries) / sizeof(spv_operand_desc_t),
1361 kernelKernelEnqueueFlagssEntries},
David Neto47994822015-08-27 13:11:01 -04001362 {SPV_OPERAND_TYPE_KERNEL_PROFILING_INFO,
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +01001363 sizeof(kernelProfilingInfoEntries) / sizeof(spv_operand_desc_t),
1364 kernelProfilingInfoEntries},
1365 {SPV_OPERAND_TYPE_CAPABILITY,
1366 sizeof(capabilityInfoEntries) / sizeof(spv_operand_desc_t),
1367 capabilityInfoEntries},
1368};
1369
1370spv_result_t spvOperandTableGet(spv_operand_table *pOperandTable) {
Lei Zhang40056702015-09-11 14:31:27 -04001371 if (!pOperandTable) return SPV_ERROR_INVALID_POINTER;
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +01001372
1373 static const spv_operand_table_t table = {
1374 sizeof(opcodeEntryTypes) / sizeof(spv_operand_desc_group_t),
1375 opcodeEntryTypes};
1376
1377 *pOperandTable = &table;
1378
1379 return SPV_SUCCESS;
1380}
1381
1382spv_result_t spvOperandTableNameLookup(const spv_operand_table table,
1383 const spv_operand_type_t type,
David Neto388c40d2015-09-16 16:42:56 -04001384 const char* name,
1385 const size_t nameLength,
1386 spv_operand_desc* pEntry) {
Lei Zhang40056702015-09-11 14:31:27 -04001387 if (!table) return SPV_ERROR_INVALID_TABLE;
1388 if (!name || !pEntry) return SPV_ERROR_INVALID_POINTER;
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +01001389
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +01001390 for (uint64_t typeIndex = 0; typeIndex < table->count; ++typeIndex) {
1391 if (type == table->types[typeIndex].type) {
1392 for (uint64_t operandIndex = 0;
1393 operandIndex < table->types[typeIndex].count; ++operandIndex) {
1394 if (nameLength ==
1395 strlen(table->types[typeIndex].entries[operandIndex].name) &&
1396 !strncmp(table->types[typeIndex].entries[operandIndex].name, name,
David Neto388c40d2015-09-16 16:42:56 -04001397 nameLength)) {
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +01001398 *pEntry = &table->types[typeIndex].entries[operandIndex];
1399 return SPV_SUCCESS;
1400 }
1401 }
1402 }
1403 }
1404
1405 return SPV_ERROR_INVALID_LOOKUP;
1406}
1407
1408spv_result_t spvOperandTableValueLookup(const spv_operand_table table,
1409 const spv_operand_type_t type,
1410 const uint32_t value,
1411 spv_operand_desc *pEntry) {
Lei Zhang40056702015-09-11 14:31:27 -04001412 if (!table) return SPV_ERROR_INVALID_TABLE;
1413 if (!pEntry) return SPV_ERROR_INVALID_POINTER;
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +01001414
1415 for (uint64_t typeIndex = 0; typeIndex < table->count; ++typeIndex) {
1416 if (type == table->types[typeIndex].type) {
1417 for (uint64_t operandIndex = 0;
1418 operandIndex < table->types[typeIndex].count; ++operandIndex) {
1419 if (value == table->types[typeIndex].entries[operandIndex].value) {
1420 *pEntry = &table->types[typeIndex].entries[operandIndex];
1421 return SPV_SUCCESS;
1422 }
1423 }
1424 }
1425 }
1426
1427 return SPV_ERROR_INVALID_LOOKUP;
1428}
1429
1430const char *spvOperandTypeStr(spv_operand_type_t type) {
1431 switch (type) {
1432 case SPV_OPERAND_TYPE_ID:
David Netofadbf622015-09-14 17:07:11 -04001433 case SPV_OPERAND_TYPE_OPTIONAL_ID:
1434 case SPV_OPERAND_TYPE_ID_IN_OPTIONAL_TUPLE:
1435 return "ID";
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +01001436 case SPV_OPERAND_TYPE_RESULT_ID:
1437 return "result ID";
1438 case SPV_OPERAND_TYPE_LITERAL:
1439 return "literal";
1440 case SPV_OPERAND_TYPE_LITERAL_NUMBER:
1441 return "literal number";
Lei Zhangb41d1502015-09-14 15:22:23 -04001442 case SPV_OPERAND_TYPE_MULTIWORD_LITERAL_NUMBER:
1443 return "multiple word literal number";
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +01001444 case SPV_OPERAND_TYPE_LITERAL_STRING:
1445 return "literal string";
1446 case SPV_OPERAND_TYPE_SOURCE_LANGUAGE:
1447 return "source langauge";
1448 case SPV_OPERAND_TYPE_EXECUTION_MODEL:
1449 return "execution model";
1450 case SPV_OPERAND_TYPE_ADDRESSING_MODEL:
1451 return "addressing model";
1452 case SPV_OPERAND_TYPE_MEMORY_MODEL:
1453 return "memory model";
1454 case SPV_OPERAND_TYPE_EXECUTION_MODE:
1455 return "execution mode";
1456 case SPV_OPERAND_TYPE_STORAGE_CLASS:
1457 return "storage class";
1458 case SPV_OPERAND_TYPE_DIMENSIONALITY:
1459 return "dimensionality";
1460 case SPV_OPERAND_TYPE_SAMPLER_ADDRESSING_MODE:
1461 return "addressing mode";
1462 case SPV_OPERAND_TYPE_SAMPLER_FILTER_MODE:
1463 return "sampler filter mode";
David Netob30a0c52015-09-16 15:56:43 -04001464 case SPV_OPERAND_TYPE_SAMPLER_IMAGE_FORMAT:
1465 return "sampler image format";
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +01001466 case SPV_OPERAND_TYPE_FP_FAST_MATH_MODE:
1467 return "floating pointer fast math mode";
1468 case SPV_OPERAND_TYPE_FP_ROUNDING_MODE:
1469 return "floating point rounding mode";
1470 case SPV_OPERAND_TYPE_LINKAGE_TYPE:
1471 return "linkage type";
1472 case SPV_OPERAND_TYPE_ACCESS_QUALIFIER:
1473 return "access qualifier";
1474 case SPV_OPERAND_TYPE_FUNCTION_PARAMETER_ATTRIBUTE:
1475 return "function parameter attribute";
1476 case SPV_OPERAND_TYPE_DECORATION:
1477 return "decoration";
1478 case SPV_OPERAND_TYPE_BUILT_IN:
1479 return "built in";
1480 case SPV_OPERAND_TYPE_SELECTION_CONTROL:
1481 return "selection control";
1482 case SPV_OPERAND_TYPE_LOOP_CONTROL:
1483 return "loop control";
1484 case SPV_OPERAND_TYPE_FUNCTION_CONTROL:
1485 return "function control";
1486 case SPV_OPERAND_TYPE_MEMORY_SEMANTICS:
1487 return "memory semantics";
David Neto78c3b432015-08-27 13:03:52 -04001488 case SPV_OPERAND_TYPE_OPTIONAL_MEMORY_ACCESS:
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +01001489 return "memory access";
1490 case SPV_OPERAND_TYPE_EXECUTION_SCOPE:
David Netofadbf622015-09-14 17:07:11 -04001491 return "execution scope ID";
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +01001492 case SPV_OPERAND_TYPE_GROUP_OPERATION:
1493 return "group operation";
1494 case SPV_OPERAND_TYPE_KERNEL_ENQ_FLAGS:
1495 return "kernel enqeue flags";
David Neto47994822015-08-27 13:11:01 -04001496 case SPV_OPERAND_TYPE_KERNEL_PROFILING_INFO:
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +01001497 return "kernel profiling info";
1498 case SPV_OPERAND_TYPE_CAPABILITY:
1499 return "capability";
David Netoee1b3bb2015-09-18 11:19:18 -04001500 case SPV_OPERAND_TYPE_OPTIONAL_IMAGE:
1501 return "image operand";
David Neto78c3b432015-08-27 13:03:52 -04001502 case SPV_OPERAND_TYPE_NONE:
1503 return "NONE";
Kenneth Benzie (Benie)83e5a292015-05-22 18:26:19 +01001504 default:
1505 assert(0 && "Unhandled operand type!");
1506 break;
1507 }
1508 return "unknown";
1509}
David Neto78c3b432015-08-27 13:03:52 -04001510
1511void spvPrependOperandTypes(const spv_operand_type_t* types,
1512 spv_operand_pattern_t* pattern) {
1513 const spv_operand_type_t* endTypes;
1514 for (endTypes = types ; *endTypes != SPV_OPERAND_TYPE_NONE ; ++endTypes)
1515 ;
1516 pattern->insert(pattern->begin(), types, endTypes);
1517}
1518
David Neto5bf88fc2015-09-17 17:06:10 -04001519void spvPrependOperandTypesForMask(const spv_operand_table operandTable,
1520 const spv_operand_type_t type,
1521 const uint32_t mask,
1522 spv_operand_pattern_t* pattern) {
1523 // Scan from highest bits to lowest bits because we will prepend in LIFO
1524 // fashion, and we need the operands for lower order bits to appear first.
1525 for (uint32_t candidate_bit = (1 << 31); candidate_bit; candidate_bit >>= 1) {
1526 if (candidate_bit & mask) {
1527 spv_operand_desc entry = nullptr;
1528 if (SPV_SUCCESS == spvOperandTableValueLookup(operandTable, type,
1529 candidate_bit, &entry)) {
1530 spvPrependOperandTypes(entry->operandTypes, pattern);
1531 }
1532 }
1533 }
1534}
1535
David Neto78c3b432015-08-27 13:03:52 -04001536bool spvOperandIsOptional(spv_operand_type_t type) {
1537 // Variable means zero or more times.
1538 if (spvOperandIsVariable(type))
1539 return true;
1540
1541 switch (type) {
1542 case SPV_OPERAND_TYPE_OPTIONAL_ID:
1543 case SPV_OPERAND_TYPE_OPTIONAL_IMAGE:
1544 case SPV_OPERAND_TYPE_OPTIONAL_LITERAL:
1545 case SPV_OPERAND_TYPE_OPTIONAL_LITERAL_STRING:
1546 case SPV_OPERAND_TYPE_OPTIONAL_MEMORY_ACCESS:
1547 case SPV_OPERAND_TYPE_OPTIONAL_EXECUTION_MODE:
1548 return true;
1549 default:
1550 break;
1551 }
1552 return false;
1553}
1554
1555bool spvOperandIsVariable(spv_operand_type_t type) {
1556 switch (type) {
1557 case SPV_OPERAND_TYPE_VARIABLE_ID:
1558 case SPV_OPERAND_TYPE_VARIABLE_LITERAL:
1559 case SPV_OPERAND_TYPE_VARIABLE_ID_LITERAL:
1560 case SPV_OPERAND_TYPE_VARIABLE_LITERAL_ID:
David Neto78c3b432015-08-27 13:03:52 -04001561 case SPV_OPERAND_TYPE_VARIABLE_EXECUTION_MODE:
1562 return true;
1563 default:
1564 break;
1565 }
1566 return false;
1567}
1568
1569
1570bool spvExpandOperandSequenceOnce(spv_operand_type_t type,
1571 spv_operand_pattern_t* pattern) {
1572 switch (type) {
1573 case SPV_OPERAND_TYPE_VARIABLE_ID:
1574 pattern->insert(pattern->begin(), {SPV_OPERAND_TYPE_OPTIONAL_ID, type});
1575 return true;
1576 case SPV_OPERAND_TYPE_VARIABLE_LITERAL:
1577 pattern->insert(pattern->begin(),
1578 {SPV_OPERAND_TYPE_OPTIONAL_LITERAL, type});
1579 return true;
1580 case SPV_OPERAND_TYPE_VARIABLE_LITERAL_ID:
1581 // Represents Zero or more (Literal, Id) pairs.
1582 pattern->insert(pattern->begin(),
1583 {SPV_OPERAND_TYPE_OPTIONAL_LITERAL,
1584 SPV_OPERAND_TYPE_ID_IN_OPTIONAL_TUPLE, type});
1585 return true;
1586 case SPV_OPERAND_TYPE_VARIABLE_ID_LITERAL:
1587 // Represents Zero or more (Id, Literal) pairs.
1588 pattern->insert(pattern->begin(),
1589 {SPV_OPERAND_TYPE_OPTIONAL_ID,
1590 SPV_OPERAND_TYPE_LITERAL_IN_OPTIONAL_TUPLE, type});
1591 return true;
David Neto78c3b432015-08-27 13:03:52 -04001592 case SPV_OPERAND_TYPE_VARIABLE_EXECUTION_MODE:
1593 pattern->insert(pattern->begin(), {SPV_OPERAND_TYPE_OPTIONAL_EXECUTION_MODE, type});
1594 return true;
1595 default:
1596 break;
1597 }
1598 return false;
1599}
1600
1601spv_operand_type_t spvTakeFirstMatchableOperand(spv_operand_pattern_t* pattern) {
1602 assert(!pattern->empty());
1603 spv_operand_type_t result;
1604 do {
1605 result = pattern->front();
1606 pattern->pop_front();
1607 } while(spvExpandOperandSequenceOnce(result, pattern));
1608 return result;
1609}