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
// AUTOMATICALLY GENERATED from the SPIR-V JSON grammar:
//   external/spirv.core.grammar.json.
// DO NOT MODIFY!

#![allow(clippy::upper_case_acronyms)]
#[doc = r" SPIR-V decorations."]
#[derive(Clone, Debug, Eq, PartialEq)]
pub enum Decoration {
    RelaxedPrecision,
    SpecId(u32),
    Block,
    BufferBlock,
    RowMajor,
    ColMajor,
    ArrayStride(u32),
    MatrixStride(u32),
    GLSLShared,
    GLSLPacked,
    CPacked,
    BuiltIn(spirv::BuiltIn),
    NoPerspective,
    Flat,
    Patch,
    Centroid,
    Sample,
    Invariant,
    Restrict,
    Aliased,
    Volatile,
    Constant,
    Coherent,
    NonWritable,
    NonReadable,
    Uniform,
    UniformId(spirv::Word),
    SaturatedConversion,
    Stream(u32),
    Location(u32),
    Component(u32),
    Index(u32),
    Binding(u32),
    DescriptorSet(u32),
    Offset(u32),
    XfbBuffer(u32),
    XfbStride(u32),
    FuncParamAttr(spirv::FunctionParameterAttribute),
    FPRoundingMode(spirv::FPRoundingMode),
    FPFastMathMode(spirv::FPFastMathMode),
    LinkageAttributes(String, spirv::LinkageType),
    NoContraction,
    InputAttachmentIndex(u32),
    Alignment(u32),
    MaxByteOffset(u32),
    AlignmentId(spirv::Word),
    MaxByteOffsetId(spirv::Word),
    NoSignedWrap,
    NoUnsignedWrap,
    WeightTextureQCOM,
    BlockMatchTextureQCOM,
    ExplicitInterpAMD,
    NodeSharesPayloadLimitsWithAMDX(spirv::Word),
    NodeMaxPayloadsAMDX(spirv::Word),
    TrackFinishWritingAMDX,
    PayloadNodeNameAMDX(String),
    OverrideCoverageNV,
    PassthroughNV,
    ViewportRelativeNV,
    SecondaryViewportRelativeNV(u32),
    PerPrimitiveNV,
    PerPrimitiveEXT,
    PerViewNV,
    PerTaskNV,
    PerVertexKHR,
    PerVertexNV,
    NonUniform,
    NonUniformEXT,
    RestrictPointer,
    RestrictPointerEXT,
    AliasedPointer,
    AliasedPointerEXT,
    HitObjectShaderRecordBufferNV,
    BindlessSamplerNV,
    BindlessImageNV,
    BoundSamplerNV,
    BoundImageNV,
    SIMTCallINTEL(u32),
    ReferencedIndirectlyINTEL,
    ClobberINTEL(String),
    SideEffectsINTEL,
    VectorComputeVariableINTEL,
    FuncParamIOKindINTEL(u32),
    VectorComputeFunctionINTEL,
    StackCallINTEL,
    GlobalVariableOffsetINTEL(u32),
    CounterBuffer(spirv::Word),
    HlslCounterBufferGOOGLE(spirv::Word),
    UserSemantic(String),
    HlslSemanticGOOGLE(String),
    UserTypeGOOGLE(String),
    FunctionRoundingModeINTEL(u32, spirv::FPRoundingMode),
    FunctionDenormModeINTEL(u32, spirv::FPDenormMode),
    RegisterINTEL,
    MemoryINTEL(String),
    NumbanksINTEL(u32),
    BankwidthINTEL(u32),
    MaxPrivateCopiesINTEL(u32),
    SinglepumpINTEL,
    DoublepumpINTEL,
    MaxReplicatesINTEL(u32),
    SimpleDualPortINTEL,
    MergeINTEL(String, String),
    BankBitsINTEL(Vec<u32>),
    ForcePow2DepthINTEL(u32),
    BurstCoalesceINTEL,
    CacheSizeINTEL(u32),
    DontStaticallyCoalesceINTEL,
    PrefetchINTEL(u32),
    StallEnableINTEL,
    FuseLoopsInFunctionINTEL,
    MathOpDSPModeINTEL(u32, u32),
    AliasScopeINTEL(spirv::Word),
    NoAliasINTEL(spirv::Word),
    InitiationIntervalINTEL(u32),
    MaxConcurrencyINTEL(u32),
    PipelineEnableINTEL(u32),
    BufferLocationINTEL(u32),
    IOPipeStorageINTEL(u32),
    FunctionFloatingPointModeINTEL(u32, spirv::FPOperationMode),
    SingleElementVectorINTEL,
    VectorComputeCallableFunctionINTEL,
    MediaBlockIOINTEL,
    InitModeINTEL(spirv::InitializationModeQualifier),
    ImplementInRegisterMapINTEL(u32),
    HostAccessINTEL(spirv::HostAccessQualifier, String),
    FPMaxErrorDecorationINTEL(u32),
    LatencyControlLabelINTEL(u32),
    LatencyControlConstraintINTEL(u32, u32, u32),
    ConduitKernelArgumentINTEL,
    RegisterMapKernelArgumentINTEL,
    MMHostInterfaceAddressWidthINTEL(u32),
    MMHostInterfaceDataWidthINTEL(u32),
    MMHostInterfaceLatencyINTEL(u32),
    MMHostInterfaceReadWriteModeINTEL(spirv::AccessQualifier),
    MMHostInterfaceMaxBurstINTEL(u32),
    MMHostInterfaceWaitRequestINTEL(u32),
    StableKernelArgumentINTEL,
    CacheControlLoadINTEL(u32, spirv::LoadCacheControl),
    CacheControlStoreINTEL(u32, spirv::StoreCacheControl),
}