rspirv 0.13.0+sdk-1.4.341.0

Rust library APIs for SPIR-V module manipulation
Documentation
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
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
677
678
679
680
681
682
683
684
685
686
687
688
689
690
691
692
693
694
695
696
697
698
699
700
701
702
703
704
705
706
707
708
709
710
711
712
713
714
715
716
717
718
719
720
721
722
// AUTOMATICALLY GENERATED from the SPIR-V JSON grammar:
//   external/spirv.core.grammar.json.
// DO NOT MODIFY!

impl Parser<'_, '_> {
    fn parse_operand(&mut self, kind: GOpKind) -> Result<Vec<dr::Operand>> {
        Ok(match kind {
            GOpKind::FPFastMathMode => vec![dr::Operand::FPFastMathMode(
                self.decoder.fp_fast_math_mode()?,
            )],
            GOpKind::SelectionControl => vec![dr::Operand::SelectionControl(
                self.decoder.selection_control()?,
            )],
            GOpKind::FunctionControl => vec![dr::Operand::FunctionControl(
                self.decoder.function_control()?,
            )],
            GOpKind::MemorySemantics => vec![dr::Operand::MemorySemantics(
                self.decoder.memory_semantics()?,
            )],
            GOpKind::KernelProfilingInfo => vec![dr::Operand::KernelProfilingInfo(
                self.decoder.kernel_profiling_info()?,
            )],
            GOpKind::RayFlags => vec![dr::Operand::RayFlags(self.decoder.ray_flags()?)],
            GOpKind::FragmentShadingRate => vec![dr::Operand::FragmentShadingRate(
                self.decoder.fragment_shading_rate()?,
            )],
            GOpKind::RawAccessChainOperands => vec![dr::Operand::RawAccessChainOperands(
                self.decoder.raw_access_chain_operands()?,
            )],
            GOpKind::SourceLanguage => {
                vec![dr::Operand::SourceLanguage(self.decoder.source_language()?)]
            }
            GOpKind::ExecutionModel => {
                vec![dr::Operand::ExecutionModel(self.decoder.execution_model()?)]
            }
            GOpKind::AddressingModel => vec![dr::Operand::AddressingModel(
                self.decoder.addressing_model()?,
            )],
            GOpKind::MemoryModel => vec![dr::Operand::MemoryModel(self.decoder.memory_model()?)],
            GOpKind::StorageClass => vec![dr::Operand::StorageClass(self.decoder.storage_class()?)],
            GOpKind::Dim => vec![dr::Operand::Dim(self.decoder.dim()?)],
            GOpKind::SamplerAddressingMode => vec![dr::Operand::SamplerAddressingMode(
                self.decoder.sampler_addressing_mode()?,
            )],
            GOpKind::SamplerFilterMode => vec![dr::Operand::SamplerFilterMode(
                self.decoder.sampler_filter_mode()?,
            )],
            GOpKind::ImageFormat => vec![dr::Operand::ImageFormat(self.decoder.image_format()?)],
            GOpKind::ImageChannelOrder => vec![dr::Operand::ImageChannelOrder(
                self.decoder.image_channel_order()?,
            )],
            GOpKind::ImageChannelDataType => vec![dr::Operand::ImageChannelDataType(
                self.decoder.image_channel_data_type()?,
            )],
            GOpKind::FPRoundingMode => vec![dr::Operand::FPRoundingMode(
                self.decoder.fp_rounding_mode()?,
            )],
            GOpKind::FPDenormMode => {
                vec![dr::Operand::FPDenormMode(self.decoder.fp_denorm_mode()?)]
            }
            GOpKind::QuantizationModes => vec![dr::Operand::QuantizationModes(
                self.decoder.quantization_modes()?,
            )],
            GOpKind::FPOperationMode => vec![dr::Operand::FPOperationMode(
                self.decoder.fp_operation_mode()?,
            )],
            GOpKind::OverflowModes => {
                vec![dr::Operand::OverflowModes(self.decoder.overflow_modes()?)]
            }
            GOpKind::LinkageType => vec![dr::Operand::LinkageType(self.decoder.linkage_type()?)],
            GOpKind::AccessQualifier => vec![dr::Operand::AccessQualifier(
                self.decoder.access_qualifier()?,
            )],
            GOpKind::HostAccessQualifier => vec![dr::Operand::HostAccessQualifier(
                self.decoder.host_access_qualifier()?,
            )],
            GOpKind::FunctionParameterAttribute => vec![dr::Operand::FunctionParameterAttribute(
                self.decoder.function_parameter_attribute()?,
            )],
            GOpKind::BuiltIn => vec![dr::Operand::BuiltIn(self.decoder.built_in()?)],
            GOpKind::Scope => vec![dr::Operand::Scope(self.decoder.scope()?)],
            GOpKind::GroupOperation => {
                vec![dr::Operand::GroupOperation(self.decoder.group_operation()?)]
            }
            GOpKind::KernelEnqueueFlags => vec![dr::Operand::KernelEnqueueFlags(
                self.decoder.kernel_enqueue_flags()?,
            )],
            GOpKind::Capability => vec![dr::Operand::Capability(self.decoder.capability()?)],
            GOpKind::RayQueryIntersection => vec![dr::Operand::RayQueryIntersection(
                self.decoder.ray_query_intersection()?,
            )],
            GOpKind::RayQueryCommittedIntersectionType => {
                vec![dr::Operand::RayQueryCommittedIntersectionType(
                    self.decoder.ray_query_committed_intersection_type()?,
                )]
            }
            GOpKind::RayQueryCandidateIntersectionType => {
                vec![dr::Operand::RayQueryCandidateIntersectionType(
                    self.decoder.ray_query_candidate_intersection_type()?,
                )]
            }
            GOpKind::PackedVectorFormat => vec![dr::Operand::PackedVectorFormat(
                self.decoder.packed_vector_format()?,
            )],
            GOpKind::CooperativeMatrixOperands => vec![dr::Operand::CooperativeMatrixOperands(
                self.decoder.cooperative_matrix_operands()?,
            )],
            GOpKind::CooperativeMatrixLayout => vec![dr::Operand::CooperativeMatrixLayout(
                self.decoder.cooperative_matrix_layout()?,
            )],
            GOpKind::CooperativeMatrixUse => vec![dr::Operand::CooperativeMatrixUse(
                self.decoder.cooperative_matrix_use()?,
            )],
            GOpKind::CooperativeMatrixReduce => vec![dr::Operand::CooperativeMatrixReduce(
                self.decoder.cooperative_matrix_reduce()?,
            )],
            GOpKind::TensorClampMode => vec![dr::Operand::TensorClampMode(
                self.decoder.tensor_clamp_mode()?,
            )],
            GOpKind::InitializationModeQualifier => vec![dr::Operand::InitializationModeQualifier(
                self.decoder.initialization_mode_qualifier()?,
            )],
            GOpKind::LoadCacheControl => vec![dr::Operand::LoadCacheControl(
                self.decoder.load_cache_control()?,
            )],
            GOpKind::StoreCacheControl => vec![dr::Operand::StoreCacheControl(
                self.decoder.store_cache_control()?,
            )],
            GOpKind::NamedMaximumNumberOfRegisters => {
                vec![dr::Operand::NamedMaximumNumberOfRegisters(
                    self.decoder.named_maximum_number_of_registers()?,
                )]
            }
            GOpKind::MatrixMultiplyAccumulateOperands => {
                vec![dr::Operand::MatrixMultiplyAccumulateOperands(
                    self.decoder.matrix_multiply_accumulate_operands()?,
                )]
            }
            GOpKind::FPEncoding => vec![dr::Operand::FPEncoding(self.decoder.fp_encoding()?)],
            GOpKind::CooperativeVectorMatrixLayout => {
                vec![dr::Operand::CooperativeVectorMatrixLayout(
                    self.decoder.cooperative_vector_matrix_layout()?,
                )]
            }
            GOpKind::ComponentType => {
                vec![dr::Operand::ComponentType(self.decoder.component_type()?)]
            }
            GOpKind::IdMemorySemantics => vec![dr::Operand::IdMemorySemantics(self.decoder.id()?)],
            GOpKind::IdScope => vec![dr::Operand::IdScope(self.decoder.id()?)],
            GOpKind::IdRef => vec![dr::Operand::IdRef(self.decoder.id()?)],
            GOpKind::LiteralInteger => vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)],
            GOpKind::LiteralString => vec![dr::Operand::LiteralString(self.decoder.string()?)],
            GOpKind::LiteralFloat => vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)],
            GOpKind::LiteralExtInstInteger => vec![dr::Operand::LiteralExtInstInteger(
                self.decoder.ext_inst_integer()?,
            )],
            GOpKind::PairIdRefLiteralInteger => vec![
                dr::Operand::IdRef(self.decoder.id()?),
                dr::Operand::LiteralBit32(self.decoder.bit32()?),
            ],
            GOpKind::PairIdRefIdRef => vec![
                dr::Operand::IdRef(self.decoder.id()?),
                dr::Operand::IdRef(self.decoder.id()?),
            ],
            GOpKind::ImageOperands => {
                let val = self.decoder.image_operands()?;
                let mut ops = vec![dr::Operand::ImageOperands(val)];
                ops.append(&mut self.parse_image_operands_arguments(val)?);
                ops
            }
            GOpKind::LoopControl => {
                let val = self.decoder.loop_control()?;
                let mut ops = vec![dr::Operand::LoopControl(val)];
                ops.append(&mut self.parse_loop_control_arguments(val)?);
                ops
            }
            GOpKind::MemoryAccess => {
                let val = self.decoder.memory_access()?;
                let mut ops = vec![dr::Operand::MemoryAccess(val)];
                ops.append(&mut self.parse_memory_access_arguments(val)?);
                ops
            }
            GOpKind::ExecutionMode => {
                let val = self.decoder.execution_mode()?;
                let mut ops = vec![dr::Operand::ExecutionMode(val)];
                ops.append(&mut self.parse_execution_mode_arguments(val)?);
                ops
            }
            GOpKind::Decoration => {
                let val = self.decoder.decoration()?;
                let mut ops = vec![dr::Operand::Decoration(val)];
                ops.append(&mut self.parse_decoration_arguments(val)?);
                ops
            }
            GOpKind::TensorAddressingOperands => {
                let val = self.decoder.tensor_addressing_operands()?;
                let mut ops = vec![dr::Operand::TensorAddressingOperands(val)];
                ops.append(&mut self.parse_tensor_addressing_operands_arguments(val)?);
                ops
            }
            GOpKind::TensorOperands => {
                let val = self.decoder.tensor_operands()?;
                let mut ops = vec![dr::Operand::TensorOperands(val)];
                ops.append(&mut self.parse_tensor_operands_arguments(val)?);
                ops
            }
            GOpKind::IdResultType => panic!(),
            GOpKind::IdResult => panic!(),
            GOpKind::LiteralContextDependentNumber => panic!(),
            GOpKind::LiteralSpecConstantOpInteger => panic!(),
            GOpKind::PairLiteralIntegerIdRef => panic!(),
            GOpKind::Debuginfo(_) => {
                todo!("extended instruction operand kind not yet supported for parsing")
            }
            GOpKind::NonsemanticClspvreflection(_) => {
                todo!("extended instruction operand kind not yet supported for parsing")
            }
            GOpKind::NonsemanticShaderDebuginfo100(_) => {
                todo!("extended instruction operand kind not yet supported for parsing")
            }
            GOpKind::OpenclDebuginfo100(_) => {
                todo!("extended instruction operand kind not yet supported for parsing")
            }
        })
    }
    fn parse_image_operands_arguments(
        &mut self,
        image_operands: spirv::ImageOperands,
    ) -> Result<Vec<dr::Operand>> {
        let mut params = vec![];
        if image_operands.contains(spirv::ImageOperands::BIAS) {
            params.append(&mut vec![dr::Operand::IdRef(self.decoder.id()?)]);
        }
        if image_operands.contains(spirv::ImageOperands::LOD) {
            params.append(&mut vec![dr::Operand::IdRef(self.decoder.id()?)]);
        }
        if image_operands.contains(spirv::ImageOperands::GRAD) {
            params.append(&mut vec![
                dr::Operand::IdRef(self.decoder.id()?),
                dr::Operand::IdRef(self.decoder.id()?),
            ]);
        }
        if image_operands.contains(spirv::ImageOperands::CONST_OFFSET) {
            params.append(&mut vec![dr::Operand::IdRef(self.decoder.id()?)]);
        }
        if image_operands.contains(spirv::ImageOperands::OFFSET) {
            params.append(&mut vec![dr::Operand::IdRef(self.decoder.id()?)]);
        }
        if image_operands.contains(spirv::ImageOperands::CONST_OFFSETS) {
            params.append(&mut vec![dr::Operand::IdRef(self.decoder.id()?)]);
        }
        if image_operands.contains(spirv::ImageOperands::SAMPLE) {
            params.append(&mut vec![dr::Operand::IdRef(self.decoder.id()?)]);
        }
        if image_operands.contains(spirv::ImageOperands::MIN_LOD) {
            params.append(&mut vec![dr::Operand::IdRef(self.decoder.id()?)]);
        }
        if image_operands.contains(spirv::ImageOperands::MAKE_TEXEL_AVAILABLE) {
            params.append(&mut vec![dr::Operand::IdScope(self.decoder.id()?)]);
        }
        if image_operands.contains(spirv::ImageOperands::MAKE_TEXEL_VISIBLE) {
            params.append(&mut vec![dr::Operand::IdScope(self.decoder.id()?)]);
        }
        if image_operands.contains(spirv::ImageOperands::OFFSETS) {
            params.append(&mut vec![dr::Operand::IdRef(self.decoder.id()?)]);
        }
        Ok(params)
    }
    fn parse_loop_control_arguments(
        &mut self,
        loop_control: spirv::LoopControl,
    ) -> Result<Vec<dr::Operand>> {
        let mut params = vec![];
        if loop_control.contains(spirv::LoopControl::DEPENDENCY_LENGTH) {
            params.append(&mut vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]);
        }
        if loop_control.contains(spirv::LoopControl::MIN_ITERATIONS) {
            params.append(&mut vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]);
        }
        if loop_control.contains(spirv::LoopControl::MAX_ITERATIONS) {
            params.append(&mut vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]);
        }
        if loop_control.contains(spirv::LoopControl::ITERATION_MULTIPLE) {
            params.append(&mut vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]);
        }
        if loop_control.contains(spirv::LoopControl::PEEL_COUNT) {
            params.append(&mut vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]);
        }
        if loop_control.contains(spirv::LoopControl::PARTIAL_COUNT) {
            params.append(&mut vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]);
        }
        if loop_control.contains(spirv::LoopControl::INITIATION_INTERVAL_ALTERA) {
            params.append(&mut vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]);
        }
        if loop_control.contains(spirv::LoopControl::MAX_CONCURRENCY_ALTERA) {
            params.append(&mut vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]);
        }
        if loop_control.contains(spirv::LoopControl::DEPENDENCY_ARRAY_ALTERA) {
            params.append(&mut vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]);
        }
        if loop_control.contains(spirv::LoopControl::PIPELINE_ENABLE_ALTERA) {
            params.append(&mut vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]);
        }
        if loop_control.contains(spirv::LoopControl::LOOP_COALESCE_ALTERA) {
            params.append(&mut vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]);
        }
        if loop_control.contains(spirv::LoopControl::MAX_INTERLEAVING_ALTERA) {
            params.append(&mut vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]);
        }
        if loop_control.contains(spirv::LoopControl::SPECULATED_ITERATIONS_ALTERA) {
            params.append(&mut vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]);
        }
        if loop_control.contains(spirv::LoopControl::LOOP_COUNT_ALTERA) {
            params.append(&mut vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]);
        }
        if loop_control.contains(spirv::LoopControl::MAX_REINVOCATION_DELAY_ALTERA) {
            params.append(&mut vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]);
        }
        Ok(params)
    }
    fn parse_memory_access_arguments(
        &mut self,
        memory_access: spirv::MemoryAccess,
    ) -> Result<Vec<dr::Operand>> {
        let mut params = vec![];
        if memory_access.contains(spirv::MemoryAccess::ALIGNED) {
            params.append(&mut vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]);
        }
        if memory_access.contains(spirv::MemoryAccess::MAKE_POINTER_AVAILABLE) {
            params.append(&mut vec![dr::Operand::IdScope(self.decoder.id()?)]);
        }
        if memory_access.contains(spirv::MemoryAccess::MAKE_POINTER_VISIBLE) {
            params.append(&mut vec![dr::Operand::IdScope(self.decoder.id()?)]);
        }
        if memory_access.contains(spirv::MemoryAccess::ALIAS_SCOPE_INTEL_MASK) {
            params.append(&mut vec![dr::Operand::IdRef(self.decoder.id()?)]);
        }
        if memory_access.contains(spirv::MemoryAccess::NO_ALIAS_INTEL_MASK) {
            params.append(&mut vec![dr::Operand::IdRef(self.decoder.id()?)]);
        }
        Ok(params)
    }
    fn parse_execution_mode_arguments(
        &mut self,
        execution_mode: spirv::ExecutionMode,
    ) -> Result<Vec<dr::Operand>> {
        Ok(match execution_mode {
            spirv::ExecutionMode::Invocations => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::ExecutionMode::LocalSize => vec![
                dr::Operand::LiteralBit32(self.decoder.bit32()?),
                dr::Operand::LiteralBit32(self.decoder.bit32()?),
                dr::Operand::LiteralBit32(self.decoder.bit32()?),
            ],
            spirv::ExecutionMode::LocalSizeHint => vec![
                dr::Operand::LiteralBit32(self.decoder.bit32()?),
                dr::Operand::LiteralBit32(self.decoder.bit32()?),
                dr::Operand::LiteralBit32(self.decoder.bit32()?),
            ],
            spirv::ExecutionMode::OutputVertices => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::ExecutionMode::VecTypeHint => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::ExecutionMode::SubgroupSize => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::ExecutionMode::SubgroupsPerWorkgroup => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::ExecutionMode::SubgroupsPerWorkgroupId => {
                vec![dr::Operand::IdRef(self.decoder.id()?)]
            }
            spirv::ExecutionMode::LocalSizeId => vec![
                dr::Operand::IdRef(self.decoder.id()?),
                dr::Operand::IdRef(self.decoder.id()?),
                dr::Operand::IdRef(self.decoder.id()?),
            ],
            spirv::ExecutionMode::LocalSizeHintId => vec![
                dr::Operand::IdRef(self.decoder.id()?),
                dr::Operand::IdRef(self.decoder.id()?),
                dr::Operand::IdRef(self.decoder.id()?),
            ],
            spirv::ExecutionMode::DenormPreserve => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::ExecutionMode::DenormFlushToZero => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::ExecutionMode::SignedZeroInfNanPreserve => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::ExecutionMode::RoundingModeRTE => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::ExecutionMode::RoundingModeRTZ => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::ExecutionMode::TileShadingRateQCOM => vec![
                dr::Operand::LiteralBit32(self.decoder.bit32()?),
                dr::Operand::LiteralBit32(self.decoder.bit32()?),
                dr::Operand::LiteralBit32(self.decoder.bit32()?),
            ],
            spirv::ExecutionMode::IsApiEntryAMDX => vec![dr::Operand::IdRef(self.decoder.id()?)],
            spirv::ExecutionMode::MaxNodeRecursionAMDX => {
                vec![dr::Operand::IdRef(self.decoder.id()?)]
            }
            spirv::ExecutionMode::StaticNumWorkgroupsAMDX => vec![
                dr::Operand::IdRef(self.decoder.id()?),
                dr::Operand::IdRef(self.decoder.id()?),
                dr::Operand::IdRef(self.decoder.id()?),
            ],
            spirv::ExecutionMode::ShaderIndexAMDX => vec![dr::Operand::IdRef(self.decoder.id()?)],
            spirv::ExecutionMode::MaxNumWorkgroupsAMDX => vec![
                dr::Operand::IdRef(self.decoder.id()?),
                dr::Operand::IdRef(self.decoder.id()?),
                dr::Operand::IdRef(self.decoder.id()?),
            ],
            spirv::ExecutionMode::SharesInputWithAMDX => vec![
                dr::Operand::IdRef(self.decoder.id()?),
                dr::Operand::IdRef(self.decoder.id()?),
            ],
            spirv::ExecutionMode::OutputPrimitivesEXT => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::ExecutionMode::SharedLocalMemorySizeINTEL => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::ExecutionMode::RoundingModeRTPINTEL => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::ExecutionMode::RoundingModeRTNINTEL => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::ExecutionMode::FloatingPointModeALTINTEL => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::ExecutionMode::FloatingPointModeIEEEINTEL => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::ExecutionMode::MaxWorkgroupSizeINTEL => vec![
                dr::Operand::LiteralBit32(self.decoder.bit32()?),
                dr::Operand::LiteralBit32(self.decoder.bit32()?),
                dr::Operand::LiteralBit32(self.decoder.bit32()?),
            ],
            spirv::ExecutionMode::MaxWorkDimINTEL => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::ExecutionMode::NumSIMDWorkitemsINTEL => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::ExecutionMode::SchedulerTargetFmaxMhzINTEL => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::ExecutionMode::FPFastMathDefault => vec![
                dr::Operand::IdRef(self.decoder.id()?),
                dr::Operand::IdRef(self.decoder.id()?),
            ],
            spirv::ExecutionMode::StreamingInterfaceINTEL => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::ExecutionMode::RegisterMapInterfaceINTEL => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::ExecutionMode::NamedBarrierCountINTEL => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::ExecutionMode::MaximumRegistersINTEL => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::ExecutionMode::MaximumRegistersIdINTEL => {
                vec![dr::Operand::IdRef(self.decoder.id()?)]
            }
            spirv::ExecutionMode::NamedMaximumRegistersINTEL => {
                vec![dr::Operand::NamedMaximumNumberOfRegisters(
                    self.decoder.named_maximum_number_of_registers()?,
                )]
            }
            _ => vec![],
        })
    }
    fn parse_decoration_arguments(
        &mut self,
        decoration: spirv::Decoration,
    ) -> Result<Vec<dr::Operand>> {
        Ok(match decoration {
            spirv::Decoration::SpecId => vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)],
            spirv::Decoration::ArrayStride => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::MatrixStride => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::BuiltIn => vec![dr::Operand::BuiltIn(self.decoder.built_in()?)],
            spirv::Decoration::UniformId => vec![dr::Operand::IdScope(self.decoder.id()?)],
            spirv::Decoration::Stream => vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)],
            spirv::Decoration::Location => vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)],
            spirv::Decoration::Component => vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)],
            spirv::Decoration::Index => vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)],
            spirv::Decoration::Binding => vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)],
            spirv::Decoration::DescriptorSet => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::Offset => vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)],
            spirv::Decoration::XfbBuffer => vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)],
            spirv::Decoration::XfbStride => vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)],
            spirv::Decoration::FuncParamAttr => vec![dr::Operand::FunctionParameterAttribute(
                self.decoder.function_parameter_attribute()?,
            )],
            spirv::Decoration::FPRoundingMode => vec![dr::Operand::FPRoundingMode(
                self.decoder.fp_rounding_mode()?,
            )],
            spirv::Decoration::FPFastMathMode => vec![dr::Operand::FPFastMathMode(
                self.decoder.fp_fast_math_mode()?,
            )],
            spirv::Decoration::LinkageAttributes => vec![
                dr::Operand::LiteralString(self.decoder.string()?),
                dr::Operand::LinkageType(self.decoder.linkage_type()?),
            ],
            spirv::Decoration::InputAttachmentIndex => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::Alignment => vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)],
            spirv::Decoration::MaxByteOffset => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::AlignmentId => vec![dr::Operand::IdRef(self.decoder.id()?)],
            spirv::Decoration::MaxByteOffsetId => vec![dr::Operand::IdRef(self.decoder.id()?)],
            spirv::Decoration::NodeSharesPayloadLimitsWithAMDX => {
                vec![dr::Operand::IdRef(self.decoder.id()?)]
            }
            spirv::Decoration::NodeMaxPayloadsAMDX => vec![dr::Operand::IdRef(self.decoder.id()?)],
            spirv::Decoration::PayloadNodeNameAMDX => vec![dr::Operand::IdRef(self.decoder.id()?)],
            spirv::Decoration::PayloadNodeBaseIndexAMDX => {
                vec![dr::Operand::IdRef(self.decoder.id()?)]
            }
            spirv::Decoration::PayloadNodeArraySizeAMDX => {
                vec![dr::Operand::IdRef(self.decoder.id()?)]
            }
            spirv::Decoration::ArrayStrideIdEXT => vec![dr::Operand::IdRef(self.decoder.id()?)],
            spirv::Decoration::OffsetIdEXT => vec![dr::Operand::IdRef(self.decoder.id()?)],
            spirv::Decoration::SecondaryViewportRelativeNV => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::MemberOffsetNV => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::BankNV => vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)],
            spirv::Decoration::SIMTCallINTEL => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::ClobberINTEL => {
                vec![dr::Operand::LiteralString(self.decoder.string()?)]
            }
            spirv::Decoration::FuncParamIOKindINTEL => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::GlobalVariableOffsetINTEL => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::CounterBuffer => vec![dr::Operand::IdRef(self.decoder.id()?)],
            spirv::Decoration::UserSemantic => {
                vec![dr::Operand::LiteralString(self.decoder.string()?)]
            }
            spirv::Decoration::UserTypeGOOGLE => {
                vec![dr::Operand::LiteralString(self.decoder.string()?)]
            }
            spirv::Decoration::FunctionRoundingModeINTEL => vec![
                dr::Operand::LiteralBit32(self.decoder.bit32()?),
                dr::Operand::FPRoundingMode(self.decoder.fp_rounding_mode()?),
            ],
            spirv::Decoration::FunctionDenormModeINTEL => vec![
                dr::Operand::LiteralBit32(self.decoder.bit32()?),
                dr::Operand::FPDenormMode(self.decoder.fp_denorm_mode()?),
            ],
            spirv::Decoration::MemoryALTERA => {
                vec![dr::Operand::LiteralString(self.decoder.string()?)]
            }
            spirv::Decoration::NumbanksALTERA => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::BankwidthALTERA => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::MaxPrivateCopiesALTERA => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::MaxReplicatesALTERA => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::MergeALTERA => vec![
                dr::Operand::LiteralString(self.decoder.string()?),
                dr::Operand::LiteralString(self.decoder.string()?),
            ],
            spirv::Decoration::BankBitsALTERA => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::ForcePow2DepthALTERA => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::StridesizeALTERA => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::WordsizeALTERA => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::CacheSizeALTERA => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::PrefetchALTERA => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::MathOpDSPModeALTERA => vec![
                dr::Operand::LiteralBit32(self.decoder.bit32()?),
                dr::Operand::LiteralBit32(self.decoder.bit32()?),
            ],
            spirv::Decoration::AliasScopeINTEL => vec![dr::Operand::IdRef(self.decoder.id()?)],
            spirv::Decoration::NoAliasINTEL => vec![dr::Operand::IdRef(self.decoder.id()?)],
            spirv::Decoration::InitiationIntervalALTERA => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::MaxConcurrencyALTERA => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::PipelineEnableALTERA => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::BufferLocationALTERA => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::IOPipeStorageALTERA => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::FunctionFloatingPointModeINTEL => vec![
                dr::Operand::LiteralBit32(self.decoder.bit32()?),
                dr::Operand::FPOperationMode(self.decoder.fp_operation_mode()?),
            ],
            spirv::Decoration::FPMaxErrorDecorationINTEL => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::LatencyControlLabelALTERA => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::LatencyControlConstraintALTERA => vec![
                dr::Operand::LiteralBit32(self.decoder.bit32()?),
                dr::Operand::LiteralBit32(self.decoder.bit32()?),
                dr::Operand::LiteralBit32(self.decoder.bit32()?),
            ],
            spirv::Decoration::MMHostInterfaceAddressWidthALTERA => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::MMHostInterfaceDataWidthALTERA => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::MMHostInterfaceLatencyALTERA => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::MMHostInterfaceReadWriteModeALTERA => {
                vec![dr::Operand::AccessQualifier(
                    self.decoder.access_qualifier()?,
                )]
            }
            spirv::Decoration::MMHostInterfaceMaxBurstALTERA => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::MMHostInterfaceWaitRequestALTERA => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::HostAccessINTEL => vec![
                dr::Operand::HostAccessQualifier(self.decoder.host_access_qualifier()?),
                dr::Operand::LiteralString(self.decoder.string()?),
            ],
            spirv::Decoration::InitModeALTERA => vec![dr::Operand::InitializationModeQualifier(
                self.decoder.initialization_mode_qualifier()?,
            )],
            spirv::Decoration::ImplementInRegisterMapALTERA => {
                vec![dr::Operand::LiteralBit32(self.decoder.bit32()?)]
            }
            spirv::Decoration::ConditionalINTEL => vec![dr::Operand::IdRef(self.decoder.id()?)],
            spirv::Decoration::CacheControlLoadINTEL => vec![
                dr::Operand::LiteralBit32(self.decoder.bit32()?),
                dr::Operand::LoadCacheControl(self.decoder.load_cache_control()?),
            ],
            spirv::Decoration::CacheControlStoreINTEL => vec![
                dr::Operand::LiteralBit32(self.decoder.bit32()?),
                dr::Operand::StoreCacheControl(self.decoder.store_cache_control()?),
            ],
            _ => vec![],
        })
    }
    fn parse_tensor_addressing_operands_arguments(
        &mut self,
        tensor_addressing_operands: spirv::TensorAddressingOperands,
    ) -> Result<Vec<dr::Operand>> {
        let mut params = vec![];
        if tensor_addressing_operands.contains(spirv::TensorAddressingOperands::TENSOR_VIEW) {
            params.append(&mut vec![dr::Operand::IdRef(self.decoder.id()?)]);
        }
        if tensor_addressing_operands.contains(spirv::TensorAddressingOperands::DECODE_FUNC) {
            params.append(&mut vec![dr::Operand::IdRef(self.decoder.id()?)]);
        }
        Ok(params)
    }
    fn parse_tensor_operands_arguments(
        &mut self,
        tensor_operands: spirv::TensorOperands,
    ) -> Result<Vec<dr::Operand>> {
        let mut params = vec![];
        if tensor_operands.contains(spirv::TensorOperands::OUT_OF_BOUNDS_VALUE_ARM) {
            params.append(&mut vec![dr::Operand::IdRef(self.decoder.id()?)]);
        }
        if tensor_operands.contains(spirv::TensorOperands::MAKE_ELEMENT_AVAILABLE_ARM) {
            params.append(&mut vec![dr::Operand::IdRef(self.decoder.id()?)]);
        }
        if tensor_operands.contains(spirv::TensorOperands::MAKE_ELEMENT_VISIBLE_ARM) {
            params.append(&mut vec![dr::Operand::IdRef(self.decoder.id()?)]);
        }
        Ok(params)
    }
}