| //===- SPIRVBase.td - MLIR SPIR-V Op Definitions Base file -*- tablegen -*-===// |
| // |
| // Copyright 2019 The MLIR Authors. |
| // |
| // Licensed under the Apache License, Version 2.0 (the "License"); |
| // you may not use this file except in compliance with the License. |
| // You may obtain a copy of the License at |
| // |
| // http://www.apache.org/licenses/LICENSE-2.0 |
| // |
| // Unless required by applicable law or agreed to in writing, software |
| // distributed under the License is distributed on an "AS IS" BASIS, |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| // See the License for the specific language governing permissions and |
| // limitations under the License. |
| // ============================================================================= |
| // |
| // This is the base file for SPIR-V operation definition specification. |
| // This file defines the SPIR-V dialect, common SPIR-V types, and utilities |
| // for facilitating defining SPIR-V ops. |
| // |
| //===----------------------------------------------------------------------===// |
| |
| #ifndef SPIRV_BASE |
| #define SPIRV_BASE |
| |
| #ifndef OP_BASE |
| include "mlir/IR/OpBase.td" |
| #endif // OP_BASE |
| |
| //===----------------------------------------------------------------------===// |
| // SPIR-V dialect definitions |
| //===----------------------------------------------------------------------===// |
| |
| def SPV_Dialect : Dialect { |
| let name = "spv"; |
| |
| let description = [{ |
| The SPIR-V dialect in MLIR. |
| |
| SPIR-V is the Khronos Group's binary intermediate language for representing |
| graphical-shader stages and compute kernels for multiple Khronos APIs, |
| including OpenCL, OpenGL, and Vulkan. |
| See https://www.khronos.org/registry/spir-v for more details. |
| |
| This dialect aims to be a simple proxy for the SPIR-V binary format to |
| enable straightforward and lightweight conversion from/to the binary |
| format. Ops in this dialect should stay at the same semantic level and |
| try to be a mechanical mapping to the corresponding SPIR-V instructions; |
| but they may deviate representationally to allow using MLIR mechanisms. |
| As a convention, if such deviation happens, the op name follows "snake_case" |
| style; otherwise, the op name just follows the SPIR-V mnemonic (by removing |
| the leading `Op` prefix) to use "CamelCase" style. |
| }]; |
| |
| let cppNamespace = "spirv"; |
| } |
| |
| //===----------------------------------------------------------------------===// |
| // SPIR-V opcode specification |
| //===----------------------------------------------------------------------===// |
| |
| class SPV_OpCode<string name, int val> { |
| // Name used as reference to retrieve the opcode |
| string opname = name; |
| |
| // Opcode associated with the name |
| int opcode = val; |
| } |
| |
| // Begin opcode section. Generated from SPIR-V spec; DO NOT MODIFY! |
| |
| def SPV_OC_OpNop : I32EnumAttrCase<"OpNop", 0>; |
| def SPV_OC_OpUndef : I32EnumAttrCase<"OpUndef", 1>; |
| def SPV_OC_OpSourceContinued : I32EnumAttrCase<"OpSourceContinued", 2>; |
| def SPV_OC_OpSource : I32EnumAttrCase<"OpSource", 3>; |
| def SPV_OC_OpSourceExtension : I32EnumAttrCase<"OpSourceExtension", 4>; |
| def SPV_OC_OpName : I32EnumAttrCase<"OpName", 5>; |
| def SPV_OC_OpMemberName : I32EnumAttrCase<"OpMemberName", 6>; |
| def SPV_OC_OpString : I32EnumAttrCase<"OpString", 7>; |
| def SPV_OC_OpExtension : I32EnumAttrCase<"OpExtension", 10>; |
| def SPV_OC_OpExtInstImport : I32EnumAttrCase<"OpExtInstImport", 11>; |
| def SPV_OC_OpExtInst : I32EnumAttrCase<"OpExtInst", 12>; |
| def SPV_OC_OpMemoryModel : I32EnumAttrCase<"OpMemoryModel", 14>; |
| def SPV_OC_OpEntryPoint : I32EnumAttrCase<"OpEntryPoint", 15>; |
| def SPV_OC_OpExecutionMode : I32EnumAttrCase<"OpExecutionMode", 16>; |
| def SPV_OC_OpCapability : I32EnumAttrCase<"OpCapability", 17>; |
| def SPV_OC_OpTypeVoid : I32EnumAttrCase<"OpTypeVoid", 19>; |
| def SPV_OC_OpTypeBool : I32EnumAttrCase<"OpTypeBool", 20>; |
| def SPV_OC_OpTypeInt : I32EnumAttrCase<"OpTypeInt", 21>; |
| def SPV_OC_OpTypeFloat : I32EnumAttrCase<"OpTypeFloat", 22>; |
| def SPV_OC_OpTypeVector : I32EnumAttrCase<"OpTypeVector", 23>; |
| def SPV_OC_OpTypeArray : I32EnumAttrCase<"OpTypeArray", 28>; |
| def SPV_OC_OpTypeRuntimeArray : I32EnumAttrCase<"OpTypeRuntimeArray", 29>; |
| def SPV_OC_OpTypeStruct : I32EnumAttrCase<"OpTypeStruct", 30>; |
| def SPV_OC_OpTypePointer : I32EnumAttrCase<"OpTypePointer", 32>; |
| def SPV_OC_OpTypeFunction : I32EnumAttrCase<"OpTypeFunction", 33>; |
| def SPV_OC_OpConstantTrue : I32EnumAttrCase<"OpConstantTrue", 41>; |
| def SPV_OC_OpConstantFalse : I32EnumAttrCase<"OpConstantFalse", 42>; |
| def SPV_OC_OpConstant : I32EnumAttrCase<"OpConstant", 43>; |
| def SPV_OC_OpConstantComposite : I32EnumAttrCase<"OpConstantComposite", 44>; |
| def SPV_OC_OpConstantNull : I32EnumAttrCase<"OpConstantNull", 46>; |
| def SPV_OC_OpSpecConstantTrue : I32EnumAttrCase<"OpSpecConstantTrue", 48>; |
| def SPV_OC_OpSpecConstantFalse : I32EnumAttrCase<"OpSpecConstantFalse", 49>; |
| def SPV_OC_OpSpecConstant : I32EnumAttrCase<"OpSpecConstant", 50>; |
| def SPV_OC_OpSpecConstantComposite : I32EnumAttrCase<"OpSpecConstantComposite", 51>; |
| def SPV_OC_OpFunction : I32EnumAttrCase<"OpFunction", 54>; |
| def SPV_OC_OpFunctionParameter : I32EnumAttrCase<"OpFunctionParameter", 55>; |
| def SPV_OC_OpFunctionEnd : I32EnumAttrCase<"OpFunctionEnd", 56>; |
| def SPV_OC_OpFunctionCall : I32EnumAttrCase<"OpFunctionCall", 57>; |
| def SPV_OC_OpVariable : I32EnumAttrCase<"OpVariable", 59>; |
| def SPV_OC_OpLoad : I32EnumAttrCase<"OpLoad", 61>; |
| def SPV_OC_OpStore : I32EnumAttrCase<"OpStore", 62>; |
| def SPV_OC_OpAccessChain : I32EnumAttrCase<"OpAccessChain", 65>; |
| def SPV_OC_OpDecorate : I32EnumAttrCase<"OpDecorate", 71>; |
| def SPV_OC_OpMemberDecorate : I32EnumAttrCase<"OpMemberDecorate", 72>; |
| def SPV_OC_OpCompositeExtract : I32EnumAttrCase<"OpCompositeExtract", 81>; |
| def SPV_OC_OpConvertFToU : I32EnumAttrCase<"OpConvertFToU", 109>; |
| def SPV_OC_OpConvertFToS : I32EnumAttrCase<"OpConvertFToS", 110>; |
| def SPV_OC_OpConvertSToF : I32EnumAttrCase<"OpConvertSToF", 111>; |
| def SPV_OC_OpConvertUToF : I32EnumAttrCase<"OpConvertUToF", 112>; |
| def SPV_OC_OpUConvert : I32EnumAttrCase<"OpUConvert", 113>; |
| def SPV_OC_OpSConvert : I32EnumAttrCase<"OpSConvert", 114>; |
| def SPV_OC_OpFConvert : I32EnumAttrCase<"OpFConvert", 115>; |
| def SPV_OC_OpBitcast : I32EnumAttrCase<"OpBitcast", 124>; |
| def SPV_OC_OpFNegate : I32EnumAttrCase<"OpFNegate", 127>; |
| def SPV_OC_OpIAdd : I32EnumAttrCase<"OpIAdd", 128>; |
| def SPV_OC_OpFAdd : I32EnumAttrCase<"OpFAdd", 129>; |
| def SPV_OC_OpISub : I32EnumAttrCase<"OpISub", 130>; |
| def SPV_OC_OpFSub : I32EnumAttrCase<"OpFSub", 131>; |
| def SPV_OC_OpIMul : I32EnumAttrCase<"OpIMul", 132>; |
| def SPV_OC_OpFMul : I32EnumAttrCase<"OpFMul", 133>; |
| def SPV_OC_OpUDiv : I32EnumAttrCase<"OpUDiv", 134>; |
| def SPV_OC_OpSDiv : I32EnumAttrCase<"OpSDiv", 135>; |
| def SPV_OC_OpFDiv : I32EnumAttrCase<"OpFDiv", 136>; |
| def SPV_OC_OpUMod : I32EnumAttrCase<"OpUMod", 137>; |
| def SPV_OC_OpSRem : I32EnumAttrCase<"OpSRem", 138>; |
| def SPV_OC_OpSMod : I32EnumAttrCase<"OpSMod", 139>; |
| def SPV_OC_OpFRem : I32EnumAttrCase<"OpFRem", 140>; |
| def SPV_OC_OpFMod : I32EnumAttrCase<"OpFMod", 141>; |
| def SPV_OC_OpLogicalEqual : I32EnumAttrCase<"OpLogicalEqual", 164>; |
| def SPV_OC_OpLogicalNotEqual : I32EnumAttrCase<"OpLogicalNotEqual", 165>; |
| def SPV_OC_OpLogicalOr : I32EnumAttrCase<"OpLogicalOr", 166>; |
| def SPV_OC_OpLogicalAnd : I32EnumAttrCase<"OpLogicalAnd", 167>; |
| def SPV_OC_OpLogicalNot : I32EnumAttrCase<"OpLogicalNot", 168>; |
| def SPV_OC_OpSelect : I32EnumAttrCase<"OpSelect", 169>; |
| def SPV_OC_OpIEqual : I32EnumAttrCase<"OpIEqual", 170>; |
| def SPV_OC_OpINotEqual : I32EnumAttrCase<"OpINotEqual", 171>; |
| def SPV_OC_OpUGreaterThan : I32EnumAttrCase<"OpUGreaterThan", 172>; |
| def SPV_OC_OpSGreaterThan : I32EnumAttrCase<"OpSGreaterThan", 173>; |
| def SPV_OC_OpUGreaterThanEqual : I32EnumAttrCase<"OpUGreaterThanEqual", 174>; |
| def SPV_OC_OpSGreaterThanEqual : I32EnumAttrCase<"OpSGreaterThanEqual", 175>; |
| def SPV_OC_OpULessThan : I32EnumAttrCase<"OpULessThan", 176>; |
| def SPV_OC_OpSLessThan : I32EnumAttrCase<"OpSLessThan", 177>; |
| def SPV_OC_OpULessThanEqual : I32EnumAttrCase<"OpULessThanEqual", 178>; |
| def SPV_OC_OpSLessThanEqual : I32EnumAttrCase<"OpSLessThanEqual", 179>; |
| def SPV_OC_OpFOrdEqual : I32EnumAttrCase<"OpFOrdEqual", 180>; |
| def SPV_OC_OpFUnordEqual : I32EnumAttrCase<"OpFUnordEqual", 181>; |
| def SPV_OC_OpFOrdNotEqual : I32EnumAttrCase<"OpFOrdNotEqual", 182>; |
| def SPV_OC_OpFUnordNotEqual : I32EnumAttrCase<"OpFUnordNotEqual", 183>; |
| def SPV_OC_OpFOrdLessThan : I32EnumAttrCase<"OpFOrdLessThan", 184>; |
| def SPV_OC_OpFUnordLessThan : I32EnumAttrCase<"OpFUnordLessThan", 185>; |
| def SPV_OC_OpFOrdGreaterThan : I32EnumAttrCase<"OpFOrdGreaterThan", 186>; |
| def SPV_OC_OpFUnordGreaterThan : I32EnumAttrCase<"OpFUnordGreaterThan", 187>; |
| def SPV_OC_OpFOrdLessThanEqual : I32EnumAttrCase<"OpFOrdLessThanEqual", 188>; |
| def SPV_OC_OpFUnordLessThanEqual : I32EnumAttrCase<"OpFUnordLessThanEqual", 189>; |
| def SPV_OC_OpFOrdGreaterThanEqual : I32EnumAttrCase<"OpFOrdGreaterThanEqual", 190>; |
| def SPV_OC_OpFUnordGreaterThanEqual : I32EnumAttrCase<"OpFUnordGreaterThanEqual", 191>; |
| def SPV_OC_OpBitwiseOr : I32EnumAttrCase<"OpBitwiseOr", 197>; |
| def SPV_OC_OpBitwiseXor : I32EnumAttrCase<"OpBitwiseXor", 198>; |
| def SPV_OC_OpBitwiseAnd : I32EnumAttrCase<"OpBitwiseAnd", 199>; |
| def SPV_OC_OpControlBarrier : I32EnumAttrCase<"OpControlBarrier", 224>; |
| def SPV_OC_OpMemoryBarrier : I32EnumAttrCase<"OpMemoryBarrier", 225>; |
| def SPV_OC_OpPhi : I32EnumAttrCase<"OpPhi", 245>; |
| def SPV_OC_OpLoopMerge : I32EnumAttrCase<"OpLoopMerge", 246>; |
| def SPV_OC_OpSelectionMerge : I32EnumAttrCase<"OpSelectionMerge", 247>; |
| def SPV_OC_OpLabel : I32EnumAttrCase<"OpLabel", 248>; |
| def SPV_OC_OpBranch : I32EnumAttrCase<"OpBranch", 249>; |
| def SPV_OC_OpBranchConditional : I32EnumAttrCase<"OpBranchConditional", 250>; |
| def SPV_OC_OpReturn : I32EnumAttrCase<"OpReturn", 253>; |
| def SPV_OC_OpReturnValue : I32EnumAttrCase<"OpReturnValue", 254>; |
| def SPV_OC_OpUnreachable : I32EnumAttrCase<"OpUnreachable", 255>; |
| def SPV_OC_OpModuleProcessed : I32EnumAttrCase<"OpModuleProcessed", 330>; |
| |
| def SPV_OpcodeAttr : |
| I32EnumAttr<"Opcode", "valid SPIR-V instructions", [ |
| SPV_OC_OpNop, SPV_OC_OpUndef, SPV_OC_OpSourceContinued, SPV_OC_OpSource, |
| SPV_OC_OpSourceExtension, SPV_OC_OpName, SPV_OC_OpMemberName, SPV_OC_OpString, |
| SPV_OC_OpExtension, SPV_OC_OpExtInstImport, SPV_OC_OpExtInst, |
| SPV_OC_OpMemoryModel, SPV_OC_OpEntryPoint, SPV_OC_OpExecutionMode, |
| SPV_OC_OpCapability, SPV_OC_OpTypeVoid, SPV_OC_OpTypeBool, SPV_OC_OpTypeInt, |
| SPV_OC_OpTypeFloat, SPV_OC_OpTypeVector, SPV_OC_OpTypeArray, |
| SPV_OC_OpTypeRuntimeArray, SPV_OC_OpTypeStruct, SPV_OC_OpTypePointer, |
| SPV_OC_OpTypeFunction, SPV_OC_OpConstantTrue, SPV_OC_OpConstantFalse, |
| SPV_OC_OpConstant, SPV_OC_OpConstantComposite, SPV_OC_OpConstantNull, |
| SPV_OC_OpSpecConstantTrue, SPV_OC_OpSpecConstantFalse, SPV_OC_OpSpecConstant, |
| SPV_OC_OpSpecConstantComposite, SPV_OC_OpFunction, SPV_OC_OpFunctionParameter, |
| SPV_OC_OpFunctionEnd, SPV_OC_OpFunctionCall, SPV_OC_OpVariable, SPV_OC_OpLoad, |
| SPV_OC_OpStore, SPV_OC_OpAccessChain, SPV_OC_OpDecorate, |
| SPV_OC_OpMemberDecorate, SPV_OC_OpCompositeExtract, SPV_OC_OpConvertFToU, |
| SPV_OC_OpConvertFToS, SPV_OC_OpConvertSToF, SPV_OC_OpConvertUToF, |
| SPV_OC_OpUConvert, SPV_OC_OpSConvert, SPV_OC_OpFConvert, SPV_OC_OpBitcast, |
| SPV_OC_OpFNegate, SPV_OC_OpIAdd, SPV_OC_OpFAdd, SPV_OC_OpISub, SPV_OC_OpFSub, |
| SPV_OC_OpIMul, SPV_OC_OpFMul, SPV_OC_OpUDiv, SPV_OC_OpSDiv, SPV_OC_OpFDiv, |
| SPV_OC_OpUMod, SPV_OC_OpSRem, SPV_OC_OpSMod, SPV_OC_OpFRem, SPV_OC_OpFMod, |
| SPV_OC_OpLogicalEqual, SPV_OC_OpLogicalNotEqual, SPV_OC_OpLogicalOr, |
| SPV_OC_OpLogicalAnd, SPV_OC_OpLogicalNot, SPV_OC_OpSelect, SPV_OC_OpIEqual, |
| SPV_OC_OpINotEqual, SPV_OC_OpUGreaterThan, SPV_OC_OpSGreaterThan, |
| SPV_OC_OpUGreaterThanEqual, SPV_OC_OpSGreaterThanEqual, SPV_OC_OpULessThan, |
| SPV_OC_OpSLessThan, SPV_OC_OpULessThanEqual, SPV_OC_OpSLessThanEqual, |
| SPV_OC_OpFOrdEqual, SPV_OC_OpFUnordEqual, SPV_OC_OpFOrdNotEqual, |
| SPV_OC_OpFUnordNotEqual, SPV_OC_OpFOrdLessThan, SPV_OC_OpFUnordLessThan, |
| SPV_OC_OpFOrdGreaterThan, SPV_OC_OpFUnordGreaterThan, |
| SPV_OC_OpFOrdLessThanEqual, SPV_OC_OpFUnordLessThanEqual, |
| SPV_OC_OpFOrdGreaterThanEqual, SPV_OC_OpFUnordGreaterThanEqual, |
| SPV_OC_OpBitwiseOr, SPV_OC_OpBitwiseXor, SPV_OC_OpBitwiseAnd, |
| SPV_OC_OpControlBarrier, SPV_OC_OpMemoryBarrier, SPV_OC_OpPhi, |
| SPV_OC_OpLoopMerge, SPV_OC_OpSelectionMerge, SPV_OC_OpLabel, SPV_OC_OpBranch, |
| SPV_OC_OpBranchConditional, SPV_OC_OpReturn, SPV_OC_OpReturnValue, |
| SPV_OC_OpUnreachable, SPV_OC_OpModuleProcessed |
| ]> { |
| let returnType = "::mlir::spirv::Opcode"; |
| let convertFromStorage = "static_cast<::mlir::spirv::Opcode>($_self.getInt())"; |
| let cppNamespace = "::mlir::spirv"; |
| } |
| |
| // End opcode section. Generated from SPIR-V spec; DO NOT MODIFY! |
| |
| //===----------------------------------------------------------------------===// |
| // SPIR-V type definitions |
| //===----------------------------------------------------------------------===// |
| |
| def SPV_IsPtrType : CPred<"$_self.isa<::mlir::spirv::PointerType>()">; |
| def SPV_IsArrayType : CPred<"$_self.isa<::mlir::spirv::ArrayType>()">; |
| def SPV_IsRTArrayType : CPred<"$_self.isa<::mlir::spirv::RuntimeArrayType>()">; |
| def SPV_IsStructType : CPred<"$_self.isa<::mlir::spirv::StructType>()">; |
| |
| // See https://www.khronos.org/registry/spir-v/specs/unified1/SPIRV.html#_types |
| // for the definition of the following types and type categories. |
| |
| def SPV_Void : TypeAlias<NoneType, "void type">; |
| def SPV_Bool : IntOfWidths<[1]>; |
| def SPV_Integer : IntOfWidths<[8, 16, 32, 64]>; |
| def SPV_Float : FloatOfWidths<[16, 32, 64]>; |
| def SPV_Float16or32 : FloatOfWidths<[16, 32]>; |
| def SPV_Vector : VectorOfLengthAndType<[2, 3, 4], |
| [SPV_Bool, SPV_Integer, SPV_Float]>; |
| // Component type check is done in the type parser for the following SPIR-V |
| // dialect-specific types so we use "Any" here. |
| def SPV_AnyPtr : Type<SPV_IsPtrType, "any SPIR-V pointer type">; |
| def SPV_AnyArray : Type<SPV_IsArrayType, "any SPIR-V array type">; |
| def SPV_AnyRTArray : Type<SPV_IsRTArrayType, "any SPIR-V runtime array type">; |
| def SPV_AnyStruct : Type<SPV_IsStructType, "any SPIR-V struct type">; |
| |
| def SPV_Numerical : AnyTypeOf<[SPV_Integer, SPV_Float]>; |
| def SPV_Scalar : AnyTypeOf<[SPV_Numerical, SPV_Bool]>; |
| def SPV_Aggregate : AnyTypeOf<[SPV_AnyArray, SPV_AnyStruct]>; |
| def SPV_Composite : |
| AnyTypeOf<[SPV_Vector, SPV_AnyArray, SPV_AnyRTArray, SPV_AnyStruct]>; |
| def SPV_Type : AnyTypeOf<[ |
| SPV_Void, SPV_Bool, SPV_Integer, SPV_Float, SPV_Vector, |
| SPV_AnyPtr, SPV_AnyArray, SPV_AnyRTArray, SPV_AnyStruct |
| ]>; |
| |
| class SPV_ScalarOrVectorOf<Type type> : |
| AnyTypeOf<[type, VectorOfLengthAndType<[2, 3, 4], [type]>]>; |
| |
| def SPV_ScalarOrVector : AnyTypeOf<[SPV_Scalar, SPV_Vector]>; |
| def SPV_ScalarOrVectorOrPtr : AnyTypeOf<[SPV_ScalarOrVector, SPV_AnyPtr]>; |
| |
| // TODO(antiagainst): Use a more appropriate way to model optional operands |
| class SPV_Optional<Type type> : Variadic<type>; |
| |
| // TODO(ravishankarm): From 1.4, this should also include Composite type. |
| def SPV_SelectType : AnyTypeOf<[SPV_Scalar, SPV_Vector, SPV_AnyPtr]>; |
| |
| //===----------------------------------------------------------------------===// |
| // SPIR-V extension definitions |
| //===----------------------------------------------------------------------===// |
| |
| // Extensions known to the SPIR-V dialect. |
| // https://github.com/KhronosGroup/SPIRV-Registry has the full list. |
| def SPV_KHR_16bit_storage : StrEnumAttrCase<"SPV_KHR_16bit_storage">; |
| def SPV_KHR_8bit_storage : StrEnumAttrCase<"SPV_KHR_8bit_storage">; |
| def SPV_KHR_float_controls : StrEnumAttrCase<"SPV_KHR_float_controls">; |
| def SPV_KHR_shader_atomic_counter_ops : StrEnumAttrCase<"SPV_KHR_shader_atomic_counter_ops">; |
| def SPV_KHR_shader_ballot : StrEnumAttrCase<"SPV_KHR_shader_ballot">; |
| def SPV_KHR_storage_buffer_storage_class : StrEnumAttrCase<"SPV_KHR_storage_buffer_storage_class">; |
| def SPV_KHR_subgroup_vote : StrEnumAttrCase<"SPV_KHR_subgroup_vote">; |
| def SPV_KHR_variable_pointers : StrEnumAttrCase<"SPV_KHR_variable_pointers">; |
| def SPV_KHR_vulkan_memory_model : StrEnumAttrCase<"SPV_KHR_vulkan_memory_model">; |
| |
| def SPV_ExtensionAttr : |
| StrEnumAttr<"Extension", "supported SPIR-V extensions", [ |
| SPV_KHR_16bit_storage, SPV_KHR_8bit_storage, SPV_KHR_float_controls, |
| SPV_KHR_shader_atomic_counter_ops, SPV_KHR_shader_ballot, |
| SPV_KHR_storage_buffer_storage_class, SPV_KHR_subgroup_vote, |
| SPV_KHR_variable_pointers, SPV_KHR_vulkan_memory_model |
| ]> { |
| let cppNamespace = "::mlir::spirv"; |
| } |
| |
| //===----------------------------------------------------------------------===// |
| // SPIR-V enum definitions |
| //===----------------------------------------------------------------------===// |
| |
| // Begin enum section. Generated from SPIR-V spec; DO NOT MODIFY! |
| |
| def SPV_AM_Logical : I32EnumAttrCase<"Logical", 0>; |
| def SPV_AM_Physical32 : I32EnumAttrCase<"Physical32", 1>; |
| def SPV_AM_Physical64 : I32EnumAttrCase<"Physical64", 2>; |
| def SPV_AM_PhysicalStorageBuffer64 : I32EnumAttrCase<"PhysicalStorageBuffer64", 5348>; |
| |
| def SPV_AddressingModelAttr : |
| I32EnumAttr<"AddressingModel", "valid SPIR-V AddressingModel", [ |
| SPV_AM_Logical, SPV_AM_Physical32, SPV_AM_Physical64, |
| SPV_AM_PhysicalStorageBuffer64 |
| ]> { |
| let returnType = "::mlir::spirv::AddressingModel"; |
| let convertFromStorage = "static_cast<::mlir::spirv::AddressingModel>($_self.getInt())"; |
| let cppNamespace = "::mlir::spirv"; |
| } |
| |
| def SPV_BI_Position : I32EnumAttrCase<"Position", 0>; |
| def SPV_BI_PointSize : I32EnumAttrCase<"PointSize", 1>; |
| def SPV_BI_ClipDistance : I32EnumAttrCase<"ClipDistance", 3>; |
| def SPV_BI_CullDistance : I32EnumAttrCase<"CullDistance", 4>; |
| def SPV_BI_VertexId : I32EnumAttrCase<"VertexId", 5>; |
| def SPV_BI_InstanceId : I32EnumAttrCase<"InstanceId", 6>; |
| def SPV_BI_PrimitiveId : I32EnumAttrCase<"PrimitiveId", 7>; |
| def SPV_BI_InvocationId : I32EnumAttrCase<"InvocationId", 8>; |
| def SPV_BI_Layer : I32EnumAttrCase<"Layer", 9>; |
| def SPV_BI_ViewportIndex : I32EnumAttrCase<"ViewportIndex", 10>; |
| def SPV_BI_TessLevelOuter : I32EnumAttrCase<"TessLevelOuter", 11>; |
| def SPV_BI_TessLevelInner : I32EnumAttrCase<"TessLevelInner", 12>; |
| def SPV_BI_TessCoord : I32EnumAttrCase<"TessCoord", 13>; |
| def SPV_BI_PatchVertices : I32EnumAttrCase<"PatchVertices", 14>; |
| def SPV_BI_FragCoord : I32EnumAttrCase<"FragCoord", 15>; |
| def SPV_BI_PointCoord : I32EnumAttrCase<"PointCoord", 16>; |
| def SPV_BI_FrontFacing : I32EnumAttrCase<"FrontFacing", 17>; |
| def SPV_BI_SampleId : I32EnumAttrCase<"SampleId", 18>; |
| def SPV_BI_SamplePosition : I32EnumAttrCase<"SamplePosition", 19>; |
| def SPV_BI_SampleMask : I32EnumAttrCase<"SampleMask", 20>; |
| def SPV_BI_FragDepth : I32EnumAttrCase<"FragDepth", 22>; |
| def SPV_BI_HelperInvocation : I32EnumAttrCase<"HelperInvocation", 23>; |
| def SPV_BI_NumWorkgroups : I32EnumAttrCase<"NumWorkgroups", 24>; |
| def SPV_BI_WorkgroupSize : I32EnumAttrCase<"WorkgroupSize", 25>; |
| def SPV_BI_WorkgroupId : I32EnumAttrCase<"WorkgroupId", 26>; |
| def SPV_BI_LocalInvocationId : I32EnumAttrCase<"LocalInvocationId", 27>; |
| def SPV_BI_GlobalInvocationId : I32EnumAttrCase<"GlobalInvocationId", 28>; |
| def SPV_BI_LocalInvocationIndex : I32EnumAttrCase<"LocalInvocationIndex", 29>; |
| def SPV_BI_WorkDim : I32EnumAttrCase<"WorkDim", 30>; |
| def SPV_BI_GlobalSize : I32EnumAttrCase<"GlobalSize", 31>; |
| def SPV_BI_EnqueuedWorkgroupSize : I32EnumAttrCase<"EnqueuedWorkgroupSize", 32>; |
| def SPV_BI_GlobalOffset : I32EnumAttrCase<"GlobalOffset", 33>; |
| def SPV_BI_GlobalLinearId : I32EnumAttrCase<"GlobalLinearId", 34>; |
| def SPV_BI_SubgroupSize : I32EnumAttrCase<"SubgroupSize", 36>; |
| def SPV_BI_SubgroupMaxSize : I32EnumAttrCase<"SubgroupMaxSize", 37>; |
| def SPV_BI_NumSubgroups : I32EnumAttrCase<"NumSubgroups", 38>; |
| def SPV_BI_NumEnqueuedSubgroups : I32EnumAttrCase<"NumEnqueuedSubgroups", 39>; |
| def SPV_BI_SubgroupId : I32EnumAttrCase<"SubgroupId", 40>; |
| def SPV_BI_SubgroupLocalInvocationId : I32EnumAttrCase<"SubgroupLocalInvocationId", 41>; |
| def SPV_BI_VertexIndex : I32EnumAttrCase<"VertexIndex", 42>; |
| def SPV_BI_InstanceIndex : I32EnumAttrCase<"InstanceIndex", 43>; |
| def SPV_BI_SubgroupEqMask : I32EnumAttrCase<"SubgroupEqMask", 4416>; |
| def SPV_BI_SubgroupGeMask : I32EnumAttrCase<"SubgroupGeMask", 4417>; |
| def SPV_BI_SubgroupGtMask : I32EnumAttrCase<"SubgroupGtMask", 4418>; |
| def SPV_BI_SubgroupLeMask : I32EnumAttrCase<"SubgroupLeMask", 4419>; |
| def SPV_BI_SubgroupLtMask : I32EnumAttrCase<"SubgroupLtMask", 4420>; |
| def SPV_BI_BaseVertex : I32EnumAttrCase<"BaseVertex", 4424>; |
| def SPV_BI_BaseInstance : I32EnumAttrCase<"BaseInstance", 4425>; |
| def SPV_BI_DrawIndex : I32EnumAttrCase<"DrawIndex", 4426>; |
| def SPV_BI_DeviceIndex : I32EnumAttrCase<"DeviceIndex", 4438>; |
| def SPV_BI_ViewIndex : I32EnumAttrCase<"ViewIndex", 4440>; |
| def SPV_BI_BaryCoordNoPerspAMD : I32EnumAttrCase<"BaryCoordNoPerspAMD", 4992>; |
| def SPV_BI_BaryCoordNoPerspCentroidAMD : I32EnumAttrCase<"BaryCoordNoPerspCentroidAMD", 4993>; |
| def SPV_BI_BaryCoordNoPerspSampleAMD : I32EnumAttrCase<"BaryCoordNoPerspSampleAMD", 4994>; |
| def SPV_BI_BaryCoordSmoothAMD : I32EnumAttrCase<"BaryCoordSmoothAMD", 4995>; |
| def SPV_BI_BaryCoordSmoothCentroidAMD : I32EnumAttrCase<"BaryCoordSmoothCentroidAMD", 4996>; |
| def SPV_BI_BaryCoordSmoothSampleAMD : I32EnumAttrCase<"BaryCoordSmoothSampleAMD", 4997>; |
| def SPV_BI_BaryCoordPullModelAMD : I32EnumAttrCase<"BaryCoordPullModelAMD", 4998>; |
| def SPV_BI_FragStencilRefEXT : I32EnumAttrCase<"FragStencilRefEXT", 5014>; |
| def SPV_BI_ViewportMaskNV : I32EnumAttrCase<"ViewportMaskNV", 5253>; |
| def SPV_BI_SecondaryPositionNV : I32EnumAttrCase<"SecondaryPositionNV", 5257>; |
| def SPV_BI_SecondaryViewportMaskNV : I32EnumAttrCase<"SecondaryViewportMaskNV", 5258>; |
| def SPV_BI_PositionPerViewNV : I32EnumAttrCase<"PositionPerViewNV", 5261>; |
| def SPV_BI_ViewportMaskPerViewNV : I32EnumAttrCase<"ViewportMaskPerViewNV", 5262>; |
| def SPV_BI_FullyCoveredEXT : I32EnumAttrCase<"FullyCoveredEXT", 5264>; |
| def SPV_BI_TaskCountNV : I32EnumAttrCase<"TaskCountNV", 5274>; |
| def SPV_BI_PrimitiveCountNV : I32EnumAttrCase<"PrimitiveCountNV", 5275>; |
| def SPV_BI_PrimitiveIndicesNV : I32EnumAttrCase<"PrimitiveIndicesNV", 5276>; |
| def SPV_BI_ClipDistancePerViewNV : I32EnumAttrCase<"ClipDistancePerViewNV", 5277>; |
| def SPV_BI_CullDistancePerViewNV : I32EnumAttrCase<"CullDistancePerViewNV", 5278>; |
| def SPV_BI_LayerPerViewNV : I32EnumAttrCase<"LayerPerViewNV", 5279>; |
| def SPV_BI_MeshViewCountNV : I32EnumAttrCase<"MeshViewCountNV", 5280>; |
| def SPV_BI_MeshViewIndicesNV : I32EnumAttrCase<"MeshViewIndicesNV", 5281>; |
| def SPV_BI_BaryCoordNV : I32EnumAttrCase<"BaryCoordNV", 5286>; |
| def SPV_BI_BaryCoordNoPerspNV : I32EnumAttrCase<"BaryCoordNoPerspNV", 5287>; |
| def SPV_BI_FragSizeEXT : I32EnumAttrCase<"FragSizeEXT", 5292>; |
| def SPV_BI_FragInvocationCountEXT : I32EnumAttrCase<"FragInvocationCountEXT", 5293>; |
| def SPV_BI_LaunchIdNV : I32EnumAttrCase<"LaunchIdNV", 5319>; |
| def SPV_BI_LaunchSizeNV : I32EnumAttrCase<"LaunchSizeNV", 5320>; |
| def SPV_BI_WorldRayOriginNV : I32EnumAttrCase<"WorldRayOriginNV", 5321>; |
| def SPV_BI_WorldRayDirectionNV : I32EnumAttrCase<"WorldRayDirectionNV", 5322>; |
| def SPV_BI_ObjectRayOriginNV : I32EnumAttrCase<"ObjectRayOriginNV", 5323>; |
| def SPV_BI_ObjectRayDirectionNV : I32EnumAttrCase<"ObjectRayDirectionNV", 5324>; |
| def SPV_BI_RayTminNV : I32EnumAttrCase<"RayTminNV", 5325>; |
| def SPV_BI_RayTmaxNV : I32EnumAttrCase<"RayTmaxNV", 5326>; |
| def SPV_BI_InstanceCustomIndexNV : I32EnumAttrCase<"InstanceCustomIndexNV", 5327>; |
| def SPV_BI_ObjectToWorldNV : I32EnumAttrCase<"ObjectToWorldNV", 5330>; |
| def SPV_BI_WorldToObjectNV : I32EnumAttrCase<"WorldToObjectNV", 5331>; |
| def SPV_BI_HitTNV : I32EnumAttrCase<"HitTNV", 5332>; |
| def SPV_BI_HitKindNV : I32EnumAttrCase<"HitKindNV", 5333>; |
| def SPV_BI_IncomingRayFlagsNV : I32EnumAttrCase<"IncomingRayFlagsNV", 5351>; |
| def SPV_BI_WarpsPerSMNV : I32EnumAttrCase<"WarpsPerSMNV", 5374>; |
| def SPV_BI_SMCountNV : I32EnumAttrCase<"SMCountNV", 5375>; |
| def SPV_BI_WarpIDNV : I32EnumAttrCase<"WarpIDNV", 5376>; |
| def SPV_BI_SMIDNV : I32EnumAttrCase<"SMIDNV", 5377>; |
| |
| def SPV_BuiltInAttr : |
| I32EnumAttr<"BuiltIn", "valid SPIR-V BuiltIn", [ |
| SPV_BI_Position, SPV_BI_PointSize, SPV_BI_ClipDistance, SPV_BI_CullDistance, |
| SPV_BI_VertexId, SPV_BI_InstanceId, SPV_BI_PrimitiveId, SPV_BI_InvocationId, |
| SPV_BI_Layer, SPV_BI_ViewportIndex, SPV_BI_TessLevelOuter, |
| SPV_BI_TessLevelInner, SPV_BI_TessCoord, SPV_BI_PatchVertices, |
| SPV_BI_FragCoord, SPV_BI_PointCoord, SPV_BI_FrontFacing, SPV_BI_SampleId, |
| SPV_BI_SamplePosition, SPV_BI_SampleMask, SPV_BI_FragDepth, |
| SPV_BI_HelperInvocation, SPV_BI_NumWorkgroups, SPV_BI_WorkgroupSize, |
| SPV_BI_WorkgroupId, SPV_BI_LocalInvocationId, SPV_BI_GlobalInvocationId, |
| SPV_BI_LocalInvocationIndex, SPV_BI_WorkDim, SPV_BI_GlobalSize, |
| SPV_BI_EnqueuedWorkgroupSize, SPV_BI_GlobalOffset, SPV_BI_GlobalLinearId, |
| SPV_BI_SubgroupSize, SPV_BI_SubgroupMaxSize, SPV_BI_NumSubgroups, |
| SPV_BI_NumEnqueuedSubgroups, SPV_BI_SubgroupId, |
| SPV_BI_SubgroupLocalInvocationId, SPV_BI_VertexIndex, SPV_BI_InstanceIndex, |
| SPV_BI_SubgroupEqMask, SPV_BI_SubgroupGeMask, SPV_BI_SubgroupGtMask, |
| SPV_BI_SubgroupLeMask, SPV_BI_SubgroupLtMask, SPV_BI_BaseVertex, |
| SPV_BI_BaseInstance, SPV_BI_DrawIndex, SPV_BI_DeviceIndex, SPV_BI_ViewIndex, |
| SPV_BI_BaryCoordNoPerspAMD, SPV_BI_BaryCoordNoPerspCentroidAMD, |
| SPV_BI_BaryCoordNoPerspSampleAMD, SPV_BI_BaryCoordSmoothAMD, |
| SPV_BI_BaryCoordSmoothCentroidAMD, SPV_BI_BaryCoordSmoothSampleAMD, |
| SPV_BI_BaryCoordPullModelAMD, SPV_BI_FragStencilRefEXT, SPV_BI_ViewportMaskNV, |
| SPV_BI_SecondaryPositionNV, SPV_BI_SecondaryViewportMaskNV, |
| SPV_BI_PositionPerViewNV, SPV_BI_ViewportMaskPerViewNV, SPV_BI_FullyCoveredEXT, |
| SPV_BI_TaskCountNV, SPV_BI_PrimitiveCountNV, SPV_BI_PrimitiveIndicesNV, |
| SPV_BI_ClipDistancePerViewNV, SPV_BI_CullDistancePerViewNV, |
| SPV_BI_LayerPerViewNV, SPV_BI_MeshViewCountNV, SPV_BI_MeshViewIndicesNV, |
| SPV_BI_BaryCoordNV, SPV_BI_BaryCoordNoPerspNV, SPV_BI_FragSizeEXT, |
| SPV_BI_FragInvocationCountEXT, SPV_BI_LaunchIdNV, SPV_BI_LaunchSizeNV, |
| SPV_BI_WorldRayOriginNV, SPV_BI_WorldRayDirectionNV, SPV_BI_ObjectRayOriginNV, |
| SPV_BI_ObjectRayDirectionNV, SPV_BI_RayTminNV, SPV_BI_RayTmaxNV, |
| SPV_BI_InstanceCustomIndexNV, SPV_BI_ObjectToWorldNV, SPV_BI_WorldToObjectNV, |
| SPV_BI_HitTNV, SPV_BI_HitKindNV, SPV_BI_IncomingRayFlagsNV, |
| SPV_BI_WarpsPerSMNV, SPV_BI_SMCountNV, SPV_BI_WarpIDNV, SPV_BI_SMIDNV |
| ]> { |
| let returnType = "::mlir::spirv::BuiltIn"; |
| let convertFromStorage = "static_cast<::mlir::spirv::BuiltIn>($_self.getInt())"; |
| let cppNamespace = "::mlir::spirv"; |
| } |
| |
| def SPV_C_Matrix : I32EnumAttrCase<"Matrix", 0>; |
| def SPV_C_Shader : I32EnumAttrCase<"Shader", 1>; |
| def SPV_C_Geometry : I32EnumAttrCase<"Geometry", 2>; |
| def SPV_C_Tessellation : I32EnumAttrCase<"Tessellation", 3>; |
| def SPV_C_Addresses : I32EnumAttrCase<"Addresses", 4>; |
| def SPV_C_Linkage : I32EnumAttrCase<"Linkage", 5>; |
| def SPV_C_Kernel : I32EnumAttrCase<"Kernel", 6>; |
| def SPV_C_Vector16 : I32EnumAttrCase<"Vector16", 7>; |
| def SPV_C_Float16Buffer : I32EnumAttrCase<"Float16Buffer", 8>; |
| def SPV_C_Float16 : I32EnumAttrCase<"Float16", 9>; |
| def SPV_C_Float64 : I32EnumAttrCase<"Float64", 10>; |
| def SPV_C_Int64 : I32EnumAttrCase<"Int64", 11>; |
| def SPV_C_Int64Atomics : I32EnumAttrCase<"Int64Atomics", 12>; |
| def SPV_C_ImageBasic : I32EnumAttrCase<"ImageBasic", 13>; |
| def SPV_C_ImageReadWrite : I32EnumAttrCase<"ImageReadWrite", 14>; |
| def SPV_C_ImageMipmap : I32EnumAttrCase<"ImageMipmap", 15>; |
| def SPV_C_Pipes : I32EnumAttrCase<"Pipes", 17>; |
| def SPV_C_Groups : I32EnumAttrCase<"Groups", 18>; |
| def SPV_C_DeviceEnqueue : I32EnumAttrCase<"DeviceEnqueue", 19>; |
| def SPV_C_LiteralSampler : I32EnumAttrCase<"LiteralSampler", 20>; |
| def SPV_C_AtomicStorage : I32EnumAttrCase<"AtomicStorage", 21>; |
| def SPV_C_Int16 : I32EnumAttrCase<"Int16", 22>; |
| def SPV_C_TessellationPointSize : I32EnumAttrCase<"TessellationPointSize", 23>; |
| def SPV_C_GeometryPointSize : I32EnumAttrCase<"GeometryPointSize", 24>; |
| def SPV_C_ImageGatherExtended : I32EnumAttrCase<"ImageGatherExtended", 25>; |
| def SPV_C_StorageImageMultisample : I32EnumAttrCase<"StorageImageMultisample", 27>; |
| def SPV_C_UniformBufferArrayDynamicIndexing : I32EnumAttrCase<"UniformBufferArrayDynamicIndexing", 28>; |
| def SPV_C_SampledImageArrayDynamicIndexing : I32EnumAttrCase<"SampledImageArrayDynamicIndexing", 29>; |
| def SPV_C_StorageBufferArrayDynamicIndexing : I32EnumAttrCase<"StorageBufferArrayDynamicIndexing", 30>; |
| def SPV_C_StorageImageArrayDynamicIndexing : I32EnumAttrCase<"StorageImageArrayDynamicIndexing", 31>; |
| def SPV_C_ClipDistance : I32EnumAttrCase<"ClipDistance", 32>; |
| def SPV_C_CullDistance : I32EnumAttrCase<"CullDistance", 33>; |
| def SPV_C_ImageCubeArray : I32EnumAttrCase<"ImageCubeArray", 34>; |
| def SPV_C_SampleRateShading : I32EnumAttrCase<"SampleRateShading", 35>; |
| def SPV_C_ImageRect : I32EnumAttrCase<"ImageRect", 36>; |
| def SPV_C_SampledRect : I32EnumAttrCase<"SampledRect", 37>; |
| def SPV_C_GenericPointer : I32EnumAttrCase<"GenericPointer", 38>; |
| def SPV_C_Int8 : I32EnumAttrCase<"Int8", 39>; |
| def SPV_C_InputAttachment : I32EnumAttrCase<"InputAttachment", 40>; |
| def SPV_C_SparseResidency : I32EnumAttrCase<"SparseResidency", 41>; |
| def SPV_C_MinLod : I32EnumAttrCase<"MinLod", 42>; |
| def SPV_C_Sampled1D : I32EnumAttrCase<"Sampled1D", 43>; |
| def SPV_C_Image1D : I32EnumAttrCase<"Image1D", 44>; |
| def SPV_C_SampledCubeArray : I32EnumAttrCase<"SampledCubeArray", 45>; |
| def SPV_C_SampledBuffer : I32EnumAttrCase<"SampledBuffer", 46>; |
| def SPV_C_ImageBuffer : I32EnumAttrCase<"ImageBuffer", 47>; |
| def SPV_C_ImageMSArray : I32EnumAttrCase<"ImageMSArray", 48>; |
| def SPV_C_StorageImageExtendedFormats : I32EnumAttrCase<"StorageImageExtendedFormats", 49>; |
| def SPV_C_ImageQuery : I32EnumAttrCase<"ImageQuery", 50>; |
| def SPV_C_DerivativeControl : I32EnumAttrCase<"DerivativeControl", 51>; |
| def SPV_C_InterpolationFunction : I32EnumAttrCase<"InterpolationFunction", 52>; |
| def SPV_C_TransformFeedback : I32EnumAttrCase<"TransformFeedback", 53>; |
| def SPV_C_GeometryStreams : I32EnumAttrCase<"GeometryStreams", 54>; |
| def SPV_C_StorageImageReadWithoutFormat : I32EnumAttrCase<"StorageImageReadWithoutFormat", 55>; |
| def SPV_C_StorageImageWriteWithoutFormat : I32EnumAttrCase<"StorageImageWriteWithoutFormat", 56>; |
| def SPV_C_MultiViewport : I32EnumAttrCase<"MultiViewport", 57>; |
| def SPV_C_SubgroupDispatch : I32EnumAttrCase<"SubgroupDispatch", 58>; |
| def SPV_C_NamedBarrier : I32EnumAttrCase<"NamedBarrier", 59>; |
| def SPV_C_PipeStorage : I32EnumAttrCase<"PipeStorage", 60>; |
| def SPV_C_GroupNonUniform : I32EnumAttrCase<"GroupNonUniform", 61>; |
| def SPV_C_GroupNonUniformVote : I32EnumAttrCase<"GroupNonUniformVote", 62>; |
| def SPV_C_GroupNonUniformArithmetic : I32EnumAttrCase<"GroupNonUniformArithmetic", 63>; |
| def SPV_C_GroupNonUniformBallot : I32EnumAttrCase<"GroupNonUniformBallot", 64>; |
| def SPV_C_GroupNonUniformShuffle : I32EnumAttrCase<"GroupNonUniformShuffle", 65>; |
| def SPV_C_GroupNonUniformShuffleRelative : I32EnumAttrCase<"GroupNonUniformShuffleRelative", 66>; |
| def SPV_C_GroupNonUniformClustered : I32EnumAttrCase<"GroupNonUniformClustered", 67>; |
| def SPV_C_GroupNonUniformQuad : I32EnumAttrCase<"GroupNonUniformQuad", 68>; |
| def SPV_C_ShaderLayer : I32EnumAttrCase<"ShaderLayer", 69>; |
| def SPV_C_ShaderViewportIndex : I32EnumAttrCase<"ShaderViewportIndex", 70>; |
| def SPV_C_SubgroupBallotKHR : I32EnumAttrCase<"SubgroupBallotKHR", 4423>; |
| def SPV_C_DrawParameters : I32EnumAttrCase<"DrawParameters", 4427>; |
| def SPV_C_SubgroupVoteKHR : I32EnumAttrCase<"SubgroupVoteKHR", 4431>; |
| def SPV_C_StorageBuffer16BitAccess : I32EnumAttrCase<"StorageBuffer16BitAccess", 4433>; |
| def SPV_C_StorageUniform16 : I32EnumAttrCase<"StorageUniform16", 4434>; |
| def SPV_C_StoragePushConstant16 : I32EnumAttrCase<"StoragePushConstant16", 4435>; |
| def SPV_C_StorageInputOutput16 : I32EnumAttrCase<"StorageInputOutput16", 4436>; |
| def SPV_C_DeviceGroup : I32EnumAttrCase<"DeviceGroup", 4437>; |
| def SPV_C_MultiView : I32EnumAttrCase<"MultiView", 4439>; |
| def SPV_C_VariablePointersStorageBuffer : I32EnumAttrCase<"VariablePointersStorageBuffer", 4441>; |
| def SPV_C_VariablePointers : I32EnumAttrCase<"VariablePointers", 4442>; |
| def SPV_C_AtomicStorageOps : I32EnumAttrCase<"AtomicStorageOps", 4445>; |
| def SPV_C_SampleMaskPostDepthCoverage : I32EnumAttrCase<"SampleMaskPostDepthCoverage", 4447>; |
| def SPV_C_StorageBuffer8BitAccess : I32EnumAttrCase<"StorageBuffer8BitAccess", 4448>; |
| def SPV_C_UniformAndStorageBuffer8BitAccess : I32EnumAttrCase<"UniformAndStorageBuffer8BitAccess", 4449>; |
| def SPV_C_StoragePushConstant8 : I32EnumAttrCase<"StoragePushConstant8", 4450>; |
| def SPV_C_DenormPreserve : I32EnumAttrCase<"DenormPreserve", 4464>; |
| def SPV_C_DenormFlushToZero : I32EnumAttrCase<"DenormFlushToZero", 4465>; |
| def SPV_C_SignedZeroInfNanPreserve : I32EnumAttrCase<"SignedZeroInfNanPreserve", 4466>; |
| def SPV_C_RoundingModeRTE : I32EnumAttrCase<"RoundingModeRTE", 4467>; |
| def SPV_C_RoundingModeRTZ : I32EnumAttrCase<"RoundingModeRTZ", 4468>; |
| def SPV_C_Float16ImageAMD : I32EnumAttrCase<"Float16ImageAMD", 5008>; |
| def SPV_C_ImageGatherBiasLodAMD : I32EnumAttrCase<"ImageGatherBiasLodAMD", 5009>; |
| def SPV_C_FragmentMaskAMD : I32EnumAttrCase<"FragmentMaskAMD", 5010>; |
| def SPV_C_StencilExportEXT : I32EnumAttrCase<"StencilExportEXT", 5013>; |
| def SPV_C_ImageReadWriteLodAMD : I32EnumAttrCase<"ImageReadWriteLodAMD", 5015>; |
| def SPV_C_ShaderClockKHR : I32EnumAttrCase<"ShaderClockKHR", 5055>; |
| def SPV_C_SampleMaskOverrideCoverageNV : I32EnumAttrCase<"SampleMaskOverrideCoverageNV", 5249>; |
| def SPV_C_GeometryShaderPassthroughNV : I32EnumAttrCase<"GeometryShaderPassthroughNV", 5251>; |
| def SPV_C_ShaderViewportIndexLayerEXT : I32EnumAttrCase<"ShaderViewportIndexLayerEXT", 5254>; |
| def SPV_C_ShaderViewportMaskNV : I32EnumAttrCase<"ShaderViewportMaskNV", 5255>; |
| def SPV_C_ShaderStereoViewNV : I32EnumAttrCase<"ShaderStereoViewNV", 5259>; |
| def SPV_C_PerViewAttributesNV : I32EnumAttrCase<"PerViewAttributesNV", 5260>; |
| def SPV_C_FragmentFullyCoveredEXT : I32EnumAttrCase<"FragmentFullyCoveredEXT", 5265>; |
| def SPV_C_MeshShadingNV : I32EnumAttrCase<"MeshShadingNV", 5266>; |
| def SPV_C_ImageFootprintNV : I32EnumAttrCase<"ImageFootprintNV", 5282>; |
| def SPV_C_FragmentBarycentricNV : I32EnumAttrCase<"FragmentBarycentricNV", 5284>; |
| def SPV_C_ComputeDerivativeGroupQuadsNV : I32EnumAttrCase<"ComputeDerivativeGroupQuadsNV", 5288>; |
| def SPV_C_FragmentDensityEXT : I32EnumAttrCase<"FragmentDensityEXT", 5291>; |
| def SPV_C_GroupNonUniformPartitionedNV : I32EnumAttrCase<"GroupNonUniformPartitionedNV", 5297>; |
| def SPV_C_ShaderNonUniform : I32EnumAttrCase<"ShaderNonUniform", 5301>; |
| def SPV_C_RuntimeDescriptorArray : I32EnumAttrCase<"RuntimeDescriptorArray", 5302>; |
| def SPV_C_InputAttachmentArrayDynamicIndexing : I32EnumAttrCase<"InputAttachmentArrayDynamicIndexing", 5303>; |
| def SPV_C_UniformTexelBufferArrayDynamicIndexing : I32EnumAttrCase<"UniformTexelBufferArrayDynamicIndexing", 5304>; |
| def SPV_C_StorageTexelBufferArrayDynamicIndexing : I32EnumAttrCase<"StorageTexelBufferArrayDynamicIndexing", 5305>; |
| def SPV_C_UniformBufferArrayNonUniformIndexing : I32EnumAttrCase<"UniformBufferArrayNonUniformIndexing", 5306>; |
| def SPV_C_SampledImageArrayNonUniformIndexing : I32EnumAttrCase<"SampledImageArrayNonUniformIndexing", 5307>; |
| def SPV_C_StorageBufferArrayNonUniformIndexing : I32EnumAttrCase<"StorageBufferArrayNonUniformIndexing", 5308>; |
| def SPV_C_StorageImageArrayNonUniformIndexing : I32EnumAttrCase<"StorageImageArrayNonUniformIndexing", 5309>; |
| def SPV_C_InputAttachmentArrayNonUniformIndexing : I32EnumAttrCase<"InputAttachmentArrayNonUniformIndexing", 5310>; |
| def SPV_C_UniformTexelBufferArrayNonUniformIndexing : I32EnumAttrCase<"UniformTexelBufferArrayNonUniformIndexing", 5311>; |
| def SPV_C_StorageTexelBufferArrayNonUniformIndexing : I32EnumAttrCase<"StorageTexelBufferArrayNonUniformIndexing", 5312>; |
| def SPV_C_RayTracingNV : I32EnumAttrCase<"RayTracingNV", 5340>; |
| def SPV_C_VulkanMemoryModel : I32EnumAttrCase<"VulkanMemoryModel", 5345>; |
| def SPV_C_VulkanMemoryModelDeviceScope : I32EnumAttrCase<"VulkanMemoryModelDeviceScope", 5346>; |
| def SPV_C_PhysicalStorageBufferAddresses : I32EnumAttrCase<"PhysicalStorageBufferAddresses", 5347>; |
| def SPV_C_ComputeDerivativeGroupLinearNV : I32EnumAttrCase<"ComputeDerivativeGroupLinearNV", 5350>; |
| def SPV_C_CooperativeMatrixNV : I32EnumAttrCase<"CooperativeMatrixNV", 5357>; |
| def SPV_C_FragmentShaderSampleInterlockEXT : I32EnumAttrCase<"FragmentShaderSampleInterlockEXT", 5363>; |
| def SPV_C_FragmentShaderShadingRateInterlockEXT : I32EnumAttrCase<"FragmentShaderShadingRateInterlockEXT", 5372>; |
| def SPV_C_ShaderSMBuiltinsNV : I32EnumAttrCase<"ShaderSMBuiltinsNV", 5373>; |
| def SPV_C_FragmentShaderPixelInterlockEXT : I32EnumAttrCase<"FragmentShaderPixelInterlockEXT", 5378>; |
| def SPV_C_DemoteToHelperInvocationEXT : I32EnumAttrCase<"DemoteToHelperInvocationEXT", 5379>; |
| def SPV_C_SubgroupShuffleINTEL : I32EnumAttrCase<"SubgroupShuffleINTEL", 5568>; |
| def SPV_C_SubgroupBufferBlockIOINTEL : I32EnumAttrCase<"SubgroupBufferBlockIOINTEL", 5569>; |
| def SPV_C_SubgroupImageBlockIOINTEL : I32EnumAttrCase<"SubgroupImageBlockIOINTEL", 5570>; |
| def SPV_C_SubgroupImageMediaBlockIOINTEL : I32EnumAttrCase<"SubgroupImageMediaBlockIOINTEL", 5579>; |
| def SPV_C_IntegerFunctions2INTEL : I32EnumAttrCase<"IntegerFunctions2INTEL", 5584>; |
| def SPV_C_SubgroupAvcMotionEstimationINTEL : I32EnumAttrCase<"SubgroupAvcMotionEstimationINTEL", 5696>; |
| def SPV_C_SubgroupAvcMotionEstimationIntraINTEL : I32EnumAttrCase<"SubgroupAvcMotionEstimationIntraINTEL", 5697>; |
| def SPV_C_SubgroupAvcMotionEstimationChromaINTEL : I32EnumAttrCase<"SubgroupAvcMotionEstimationChromaINTEL", 5698>; |
| |
| def SPV_CapabilityAttr : |
| I32EnumAttr<"Capability", "valid SPIR-V Capability", [ |
| SPV_C_Matrix, SPV_C_Shader, SPV_C_Geometry, SPV_C_Tessellation, |
| SPV_C_Addresses, SPV_C_Linkage, SPV_C_Kernel, SPV_C_Vector16, |
| SPV_C_Float16Buffer, SPV_C_Float16, SPV_C_Float64, SPV_C_Int64, |
| SPV_C_Int64Atomics, SPV_C_ImageBasic, SPV_C_ImageReadWrite, SPV_C_ImageMipmap, |
| SPV_C_Pipes, SPV_C_Groups, SPV_C_DeviceEnqueue, SPV_C_LiteralSampler, |
| SPV_C_AtomicStorage, SPV_C_Int16, SPV_C_TessellationPointSize, |
| SPV_C_GeometryPointSize, SPV_C_ImageGatherExtended, |
| SPV_C_StorageImageMultisample, SPV_C_UniformBufferArrayDynamicIndexing, |
| SPV_C_SampledImageArrayDynamicIndexing, |
| SPV_C_StorageBufferArrayDynamicIndexing, |
| SPV_C_StorageImageArrayDynamicIndexing, SPV_C_ClipDistance, SPV_C_CullDistance, |
| SPV_C_ImageCubeArray, SPV_C_SampleRateShading, SPV_C_ImageRect, |
| SPV_C_SampledRect, SPV_C_GenericPointer, SPV_C_Int8, SPV_C_InputAttachment, |
| SPV_C_SparseResidency, SPV_C_MinLod, SPV_C_Sampled1D, SPV_C_Image1D, |
| SPV_C_SampledCubeArray, SPV_C_SampledBuffer, SPV_C_ImageBuffer, |
| SPV_C_ImageMSArray, SPV_C_StorageImageExtendedFormats, SPV_C_ImageQuery, |
| SPV_C_DerivativeControl, SPV_C_InterpolationFunction, SPV_C_TransformFeedback, |
| SPV_C_GeometryStreams, SPV_C_StorageImageReadWithoutFormat, |
| SPV_C_StorageImageWriteWithoutFormat, SPV_C_MultiViewport, |
| SPV_C_SubgroupDispatch, SPV_C_NamedBarrier, SPV_C_PipeStorage, |
| SPV_C_GroupNonUniform, SPV_C_GroupNonUniformVote, |
| SPV_C_GroupNonUniformArithmetic, SPV_C_GroupNonUniformBallot, |
| SPV_C_GroupNonUniformShuffle, SPV_C_GroupNonUniformShuffleRelative, |
| SPV_C_GroupNonUniformClustered, SPV_C_GroupNonUniformQuad, SPV_C_ShaderLayer, |
| SPV_C_ShaderViewportIndex, SPV_C_SubgroupBallotKHR, SPV_C_DrawParameters, |
| SPV_C_SubgroupVoteKHR, SPV_C_StorageBuffer16BitAccess, SPV_C_StorageUniform16, |
| SPV_C_StoragePushConstant16, SPV_C_StorageInputOutput16, SPV_C_DeviceGroup, |
| SPV_C_MultiView, SPV_C_VariablePointersStorageBuffer, SPV_C_VariablePointers, |
| SPV_C_AtomicStorageOps, SPV_C_SampleMaskPostDepthCoverage, |
| SPV_C_StorageBuffer8BitAccess, SPV_C_UniformAndStorageBuffer8BitAccess, |
| SPV_C_StoragePushConstant8, SPV_C_DenormPreserve, SPV_C_DenormFlushToZero, |
| SPV_C_SignedZeroInfNanPreserve, SPV_C_RoundingModeRTE, SPV_C_RoundingModeRTZ, |
| SPV_C_Float16ImageAMD, SPV_C_ImageGatherBiasLodAMD, SPV_C_FragmentMaskAMD, |
| SPV_C_StencilExportEXT, SPV_C_ImageReadWriteLodAMD, SPV_C_ShaderClockKHR, |
| SPV_C_SampleMaskOverrideCoverageNV, SPV_C_GeometryShaderPassthroughNV, |
| SPV_C_ShaderViewportIndexLayerEXT, SPV_C_ShaderViewportMaskNV, |
| SPV_C_ShaderStereoViewNV, SPV_C_PerViewAttributesNV, |
| SPV_C_FragmentFullyCoveredEXT, SPV_C_MeshShadingNV, SPV_C_ImageFootprintNV, |
| SPV_C_FragmentBarycentricNV, SPV_C_ComputeDerivativeGroupQuadsNV, |
| SPV_C_FragmentDensityEXT, SPV_C_GroupNonUniformPartitionedNV, |
| SPV_C_ShaderNonUniform, SPV_C_RuntimeDescriptorArray, |
| SPV_C_InputAttachmentArrayDynamicIndexing, |
| SPV_C_UniformTexelBufferArrayDynamicIndexing, |
| SPV_C_StorageTexelBufferArrayDynamicIndexing, |
| SPV_C_UniformBufferArrayNonUniformIndexing, |
| SPV_C_SampledImageArrayNonUniformIndexing, |
| SPV_C_StorageBufferArrayNonUniformIndexing, |
| SPV_C_StorageImageArrayNonUniformIndexing, |
| SPV_C_InputAttachmentArrayNonUniformIndexing, |
| SPV_C_UniformTexelBufferArrayNonUniformIndexing, |
| SPV_C_StorageTexelBufferArrayNonUniformIndexing, SPV_C_RayTracingNV, |
| SPV_C_VulkanMemoryModel, SPV_C_VulkanMemoryModelDeviceScope, |
| SPV_C_PhysicalStorageBufferAddresses, SPV_C_ComputeDerivativeGroupLinearNV, |
| SPV_C_CooperativeMatrixNV, SPV_C_FragmentShaderSampleInterlockEXT, |
| SPV_C_FragmentShaderShadingRateInterlockEXT, SPV_C_ShaderSMBuiltinsNV, |
| SPV_C_FragmentShaderPixelInterlockEXT, SPV_C_DemoteToHelperInvocationEXT, |
| SPV_C_SubgroupShuffleINTEL, SPV_C_SubgroupBufferBlockIOINTEL, |
| SPV_C_SubgroupImageBlockIOINTEL, SPV_C_SubgroupImageMediaBlockIOINTEL, |
| SPV_C_IntegerFunctions2INTEL, SPV_C_SubgroupAvcMotionEstimationINTEL, |
| SPV_C_SubgroupAvcMotionEstimationIntraINTEL, |
| SPV_C_SubgroupAvcMotionEstimationChromaINTEL |
| ]> { |
| let returnType = "::mlir::spirv::Capability"; |
| let convertFromStorage = "static_cast<::mlir::spirv::Capability>($_self.getInt())"; |
| let cppNamespace = "::mlir::spirv"; |
| } |
| |
| def SPV_D_RelaxedPrecision : I32EnumAttrCase<"RelaxedPrecision", 0>; |
| def SPV_D_SpecId : I32EnumAttrCase<"SpecId", 1>; |
| def SPV_D_Block : I32EnumAttrCase<"Block", 2>; |
| def SPV_D_BufferBlock : I32EnumAttrCase<"BufferBlock", 3>; |
| def SPV_D_RowMajor : I32EnumAttrCase<"RowMajor", 4>; |
| def SPV_D_ColMajor : I32EnumAttrCase<"ColMajor", 5>; |
| def SPV_D_ArrayStride : I32EnumAttrCase<"ArrayStride", 6>; |
| def SPV_D_MatrixStride : I32EnumAttrCase<"MatrixStride", 7>; |
| def SPV_D_GLSLShared : I32EnumAttrCase<"GLSLShared", 8>; |
| def SPV_D_GLSLPacked : I32EnumAttrCase<"GLSLPacked", 9>; |
| def SPV_D_CPacked : I32EnumAttrCase<"CPacked", 10>; |
| def SPV_D_BuiltIn : I32EnumAttrCase<"BuiltIn", 11>; |
| def SPV_D_NoPerspective : I32EnumAttrCase<"NoPerspective", 13>; |
| def SPV_D_Flat : I32EnumAttrCase<"Flat", 14>; |
| def SPV_D_Patch : I32EnumAttrCase<"Patch", 15>; |
| def SPV_D_Centroid : I32EnumAttrCase<"Centroid", 16>; |
| def SPV_D_Sample : I32EnumAttrCase<"Sample", 17>; |
| def SPV_D_Invariant : I32EnumAttrCase<"Invariant", 18>; |
| def SPV_D_Restrict : I32EnumAttrCase<"Restrict", 19>; |
| def SPV_D_Aliased : I32EnumAttrCase<"Aliased", 20>; |
| def SPV_D_Volatile : I32EnumAttrCase<"Volatile", 21>; |
| def SPV_D_Constant : I32EnumAttrCase<"Constant", 22>; |
| def SPV_D_Coherent : I32EnumAttrCase<"Coherent", 23>; |
| def SPV_D_NonWritable : I32EnumAttrCase<"NonWritable", 24>; |
| def SPV_D_NonReadable : I32EnumAttrCase<"NonReadable", 25>; |
| def SPV_D_Uniform : I32EnumAttrCase<"Uniform", 26>; |
| def SPV_D_UniformId : I32EnumAttrCase<"UniformId", 27>; |
| def SPV_D_SaturatedConversion : I32EnumAttrCase<"SaturatedConversion", 28>; |
| def SPV_D_Stream : I32EnumAttrCase<"Stream", 29>; |
| def SPV_D_Location : I32EnumAttrCase<"Location", 30>; |
| def SPV_D_Component : I32EnumAttrCase<"Component", 31>; |
| def SPV_D_Index : I32EnumAttrCase<"Index", 32>; |
| def SPV_D_Binding : I32EnumAttrCase<"Binding", 33>; |
| def SPV_D_DescriptorSet : I32EnumAttrCase<"DescriptorSet", 34>; |
| def SPV_D_Offset : I32EnumAttrCase<"Offset", 35>; |
| def SPV_D_XfbBuffer : I32EnumAttrCase<"XfbBuffer", 36>; |
| def SPV_D_XfbStride : I32EnumAttrCase<"XfbStride", 37>; |
| def SPV_D_FuncParamAttr : I32EnumAttrCase<"FuncParamAttr", 38>; |
| def SPV_D_FPRoundingMode : I32EnumAttrCase<"FPRoundingMode", 39>; |
| def SPV_D_FPFastMathMode : I32EnumAttrCase<"FPFastMathMode", 40>; |
| def SPV_D_LinkageAttributes : I32EnumAttrCase<"LinkageAttributes", 41>; |
| def SPV_D_NoContraction : I32EnumAttrCase<"NoContraction", 42>; |
| def SPV_D_InputAttachmentIndex : I32EnumAttrCase<"InputAttachmentIndex", 43>; |
| def SPV_D_Alignment : I32EnumAttrCase<"Alignment", 44>; |
| def SPV_D_MaxByteOffset : I32EnumAttrCase<"MaxByteOffset", 45>; |
| def SPV_D_AlignmentId : I32EnumAttrCase<"AlignmentId", 46>; |
| def SPV_D_MaxByteOffsetId : I32EnumAttrCase<"MaxByteOffsetId", 47>; |
| def SPV_D_NoSignedWrap : I32EnumAttrCase<"NoSignedWrap", 4469>; |
| def SPV_D_NoUnsignedWrap : I32EnumAttrCase<"NoUnsignedWrap", 4470>; |
| def SPV_D_ExplicitInterpAMD : I32EnumAttrCase<"ExplicitInterpAMD", 4999>; |
| def SPV_D_OverrideCoverageNV : I32EnumAttrCase<"OverrideCoverageNV", 5248>; |
| def SPV_D_PassthroughNV : I32EnumAttrCase<"PassthroughNV", 5250>; |
| def SPV_D_ViewportRelativeNV : I32EnumAttrCase<"ViewportRelativeNV", 5252>; |
| def SPV_D_SecondaryViewportRelativeNV : I32EnumAttrCase<"SecondaryViewportRelativeNV", 5256>; |
| def SPV_D_PerPrimitiveNV : I32EnumAttrCase<"PerPrimitiveNV", 5271>; |
| def SPV_D_PerViewNV : I32EnumAttrCase<"PerViewNV", 5272>; |
| def SPV_D_PerTaskNV : I32EnumAttrCase<"PerTaskNV", 5273>; |
| def SPV_D_PerVertexNV : I32EnumAttrCase<"PerVertexNV", 5285>; |
| def SPV_D_NonUniform : I32EnumAttrCase<"NonUniform", 5300>; |
| def SPV_D_RestrictPointer : I32EnumAttrCase<"RestrictPointer", 5355>; |
| def SPV_D_AliasedPointer : I32EnumAttrCase<"AliasedPointer", 5356>; |
| def SPV_D_CounterBuffer : I32EnumAttrCase<"CounterBuffer", 5634>; |
| def SPV_D_UserSemantic : I32EnumAttrCase<"UserSemantic", 5635>; |
| def SPV_D_UserTypeGOOGLE : I32EnumAttrCase<"UserTypeGOOGLE", 5636>; |
| |
| def SPV_DecorationAttr : |
| I32EnumAttr<"Decoration", "valid SPIR-V Decoration", [ |
| SPV_D_RelaxedPrecision, SPV_D_SpecId, SPV_D_Block, SPV_D_BufferBlock, |
| SPV_D_RowMajor, SPV_D_ColMajor, SPV_D_ArrayStride, SPV_D_MatrixStride, |
| SPV_D_GLSLShared, SPV_D_GLSLPacked, SPV_D_CPacked, SPV_D_BuiltIn, |
| SPV_D_NoPerspective, SPV_D_Flat, SPV_D_Patch, SPV_D_Centroid, SPV_D_Sample, |
| SPV_D_Invariant, SPV_D_Restrict, SPV_D_Aliased, SPV_D_Volatile, SPV_D_Constant, |
| SPV_D_Coherent, SPV_D_NonWritable, SPV_D_NonReadable, SPV_D_Uniform, |
| SPV_D_UniformId, SPV_D_SaturatedConversion, SPV_D_Stream, SPV_D_Location, |
| SPV_D_Component, SPV_D_Index, SPV_D_Binding, SPV_D_DescriptorSet, SPV_D_Offset, |
| SPV_D_XfbBuffer, SPV_D_XfbStride, SPV_D_FuncParamAttr, SPV_D_FPRoundingMode, |
| SPV_D_FPFastMathMode, SPV_D_LinkageAttributes, SPV_D_NoContraction, |
| SPV_D_InputAttachmentIndex, SPV_D_Alignment, SPV_D_MaxByteOffset, |
| SPV_D_AlignmentId, SPV_D_MaxByteOffsetId, SPV_D_NoSignedWrap, |
| SPV_D_NoUnsignedWrap, SPV_D_ExplicitInterpAMD, SPV_D_OverrideCoverageNV, |
| SPV_D_PassthroughNV, SPV_D_ViewportRelativeNV, |
| SPV_D_SecondaryViewportRelativeNV, SPV_D_PerPrimitiveNV, SPV_D_PerViewNV, |
| SPV_D_PerTaskNV, SPV_D_PerVertexNV, SPV_D_NonUniform, SPV_D_RestrictPointer, |
| SPV_D_AliasedPointer, SPV_D_CounterBuffer, SPV_D_UserSemantic, |
| SPV_D_UserTypeGOOGLE |
| ]> { |
| let returnType = "::mlir::spirv::Decoration"; |
| let convertFromStorage = "static_cast<::mlir::spirv::Decoration>($_self.getInt())"; |
| let cppNamespace = "::mlir::spirv"; |
| } |
| |
| def SPV_D_1D : I32EnumAttrCase<"1D", 0>; |
| def SPV_D_2D : I32EnumAttrCase<"2D", 1>; |
| def SPV_D_3D : I32EnumAttrCase<"3D", 2>; |
| def SPV_D_Cube : I32EnumAttrCase<"Cube", 3>; |
| def SPV_D_Rect : I32EnumAttrCase<"Rect", 4>; |
| def SPV_D_Buffer : I32EnumAttrCase<"Buffer", 5>; |
| def SPV_D_SubpassData : I32EnumAttrCase<"SubpassData", 6>; |
| |
| def SPV_DimAttr : |
| I32EnumAttr<"Dim", "valid SPIR-V Dim", [ |
| SPV_D_1D, SPV_D_2D, SPV_D_3D, SPV_D_Cube, SPV_D_Rect, SPV_D_Buffer, |
| SPV_D_SubpassData |
| ]> { |
| let returnType = "::mlir::spirv::Dim"; |
| let convertFromStorage = "static_cast<::mlir::spirv::Dim>($_self.getInt())"; |
| let cppNamespace = "::mlir::spirv"; |
| } |
| |
| def SPV_EM_Invocations : I32EnumAttrCase<"Invocations", 0>; |
| def SPV_EM_SpacingEqual : I32EnumAttrCase<"SpacingEqual", 1>; |
| def SPV_EM_SpacingFractionalEven : I32EnumAttrCase<"SpacingFractionalEven", 2>; |
| def SPV_EM_SpacingFractionalOdd : I32EnumAttrCase<"SpacingFractionalOdd", 3>; |
| def SPV_EM_VertexOrderCw : I32EnumAttrCase<"VertexOrderCw", 4>; |
| def SPV_EM_VertexOrderCcw : I32EnumAttrCase<"VertexOrderCcw", 5>; |
| def SPV_EM_PixelCenterInteger : I32EnumAttrCase<"PixelCenterInteger", 6>; |
| def SPV_EM_OriginUpperLeft : I32EnumAttrCase<"OriginUpperLeft", 7>; |
| def SPV_EM_OriginLowerLeft : I32EnumAttrCase<"OriginLowerLeft", 8>; |
| def SPV_EM_EarlyFragmentTests : I32EnumAttrCase<"EarlyFragmentTests", 9>; |
| def SPV_EM_PointMode : I32EnumAttrCase<"PointMode", 10>; |
| def SPV_EM_Xfb : I32EnumAttrCase<"Xfb", 11>; |
| def SPV_EM_DepthReplacing : I32EnumAttrCase<"DepthReplacing", 12>; |
| def SPV_EM_DepthGreater : I32EnumAttrCase<"DepthGreater", 14>; |
| def SPV_EM_DepthLess : I32EnumAttrCase<"DepthLess", 15>; |
| def SPV_EM_DepthUnchanged : I32EnumAttrCase<"DepthUnchanged", 16>; |
| def SPV_EM_LocalSize : I32EnumAttrCase<"LocalSize", 17>; |
| def SPV_EM_LocalSizeHint : I32EnumAttrCase<"LocalSizeHint", 18>; |
| def SPV_EM_InputPoints : I32EnumAttrCase<"InputPoints", 19>; |
| def SPV_EM_InputLines : I32EnumAttrCase<"InputLines", 20>; |
| def SPV_EM_InputLinesAdjacency : I32EnumAttrCase<"InputLinesAdjacency", 21>; |
| def SPV_EM_Triangles : I32EnumAttrCase<"Triangles", 22>; |
| def SPV_EM_InputTrianglesAdjacency : I32EnumAttrCase<"InputTrianglesAdjacency", 23>; |
| def SPV_EM_Quads : I32EnumAttrCase<"Quads", 24>; |
| def SPV_EM_Isolines : I32EnumAttrCase<"Isolines", 25>; |
| def SPV_EM_OutputVertices : I32EnumAttrCase<"OutputVertices", 26>; |
| def SPV_EM_OutputPoints : I32EnumAttrCase<"OutputPoints", 27>; |
| def SPV_EM_OutputLineStrip : I32EnumAttrCase<"OutputLineStrip", 28>; |
| def SPV_EM_OutputTriangleStrip : I32EnumAttrCase<"OutputTriangleStrip", 29>; |
| def SPV_EM_VecTypeHint : I32EnumAttrCase<"VecTypeHint", 30>; |
| def SPV_EM_ContractionOff : I32EnumAttrCase<"ContractionOff", 31>; |
| def SPV_EM_Initializer : I32EnumAttrCase<"Initializer", 33>; |
| def SPV_EM_Finalizer : I32EnumAttrCase<"Finalizer", 34>; |
| def SPV_EM_SubgroupSize : I32EnumAttrCase<"SubgroupSize", 35>; |
| def SPV_EM_SubgroupsPerWorkgroup : I32EnumAttrCase<"SubgroupsPerWorkgroup", 36>; |
| def SPV_EM_SubgroupsPerWorkgroupId : I32EnumAttrCase<"SubgroupsPerWorkgroupId", 37>; |
| def SPV_EM_LocalSizeId : I32EnumAttrCase<"LocalSizeId", 38>; |
| def SPV_EM_LocalSizeHintId : I32EnumAttrCase<"LocalSizeHintId", 39>; |
| def SPV_EM_PostDepthCoverage : I32EnumAttrCase<"PostDepthCoverage", 4446>; |
| def SPV_EM_DenormPreserve : I32EnumAttrCase<"DenormPreserve", 4459>; |
| def SPV_EM_DenormFlushToZero : I32EnumAttrCase<"DenormFlushToZero", 4460>; |
| def SPV_EM_SignedZeroInfNanPreserve : I32EnumAttrCase<"SignedZeroInfNanPreserve", 4461>; |
| def SPV_EM_RoundingModeRTE : I32EnumAttrCase<"RoundingModeRTE", 4462>; |
| def SPV_EM_RoundingModeRTZ : I32EnumAttrCase<"RoundingModeRTZ", 4463>; |
| def SPV_EM_StencilRefReplacingEXT : I32EnumAttrCase<"StencilRefReplacingEXT", 5027>; |
| def SPV_EM_OutputLinesNV : I32EnumAttrCase<"OutputLinesNV", 5269>; |
| def SPV_EM_OutputPrimitivesNV : I32EnumAttrCase<"OutputPrimitivesNV", 5270>; |
| def SPV_EM_DerivativeGroupQuadsNV : I32EnumAttrCase<"DerivativeGroupQuadsNV", 5289>; |
| def SPV_EM_DerivativeGroupLinearNV : I32EnumAttrCase<"DerivativeGroupLinearNV", 5290>; |
| def SPV_EM_OutputTrianglesNV : I32EnumAttrCase<"OutputTrianglesNV", 5298>; |
| def SPV_EM_PixelInterlockOrderedEXT : I32EnumAttrCase<"PixelInterlockOrderedEXT", 5366>; |
| def SPV_EM_PixelInterlockUnorderedEXT : I32EnumAttrCase<"PixelInterlockUnorderedEXT", 5367>; |
| def SPV_EM_SampleInterlockOrderedEXT : I32EnumAttrCase<"SampleInterlockOrderedEXT", 5368>; |
| def SPV_EM_SampleInterlockUnorderedEXT : I32EnumAttrCase<"SampleInterlockUnorderedEXT", 5369>; |
| def SPV_EM_ShadingRateInterlockOrderedEXT : I32EnumAttrCase<"ShadingRateInterlockOrderedEXT", 5370>; |
| def SPV_EM_ShadingRateInterlockUnorderedEXT : I32EnumAttrCase<"ShadingRateInterlockUnorderedEXT", 5371>; |
| |
| def SPV_ExecutionModeAttr : |
| I32EnumAttr<"ExecutionMode", "valid SPIR-V ExecutionMode", [ |
| SPV_EM_Invocations, SPV_EM_SpacingEqual, SPV_EM_SpacingFractionalEven, |
| SPV_EM_SpacingFractionalOdd, SPV_EM_VertexOrderCw, SPV_EM_VertexOrderCcw, |
| SPV_EM_PixelCenterInteger, SPV_EM_OriginUpperLeft, SPV_EM_OriginLowerLeft, |
| SPV_EM_EarlyFragmentTests, SPV_EM_PointMode, SPV_EM_Xfb, SPV_EM_DepthReplacing, |
| SPV_EM_DepthGreater, SPV_EM_DepthLess, SPV_EM_DepthUnchanged, SPV_EM_LocalSize, |
| SPV_EM_LocalSizeHint, SPV_EM_InputPoints, SPV_EM_InputLines, |
| SPV_EM_InputLinesAdjacency, SPV_EM_Triangles, SPV_EM_InputTrianglesAdjacency, |
| SPV_EM_Quads, SPV_EM_Isolines, SPV_EM_OutputVertices, SPV_EM_OutputPoints, |
| SPV_EM_OutputLineStrip, SPV_EM_OutputTriangleStrip, SPV_EM_VecTypeHint, |
| SPV_EM_ContractionOff, SPV_EM_Initializer, SPV_EM_Finalizer, |
| SPV_EM_SubgroupSize, SPV_EM_SubgroupsPerWorkgroup, |
| SPV_EM_SubgroupsPerWorkgroupId, SPV_EM_LocalSizeId, SPV_EM_LocalSizeHintId, |
| SPV_EM_PostDepthCoverage, SPV_EM_DenormPreserve, SPV_EM_DenormFlushToZero, |
| SPV_EM_SignedZeroInfNanPreserve, SPV_EM_RoundingModeRTE, |
| SPV_EM_RoundingModeRTZ, SPV_EM_StencilRefReplacingEXT, SPV_EM_OutputLinesNV, |
| SPV_EM_OutputPrimitivesNV, SPV_EM_DerivativeGroupQuadsNV, |
| SPV_EM_DerivativeGroupLinearNV, SPV_EM_OutputTrianglesNV, |
| SPV_EM_PixelInterlockOrderedEXT, SPV_EM_PixelInterlockUnorderedEXT, |
| SPV_EM_SampleInterlockOrderedEXT, SPV_EM_SampleInterlockUnorderedEXT, |
| SPV_EM_ShadingRateInterlockOrderedEXT, SPV_EM_ShadingRateInterlockUnorderedEXT |
| ]> { |
| let returnType = "::mlir::spirv::ExecutionMode"; |
| let convertFromStorage = "static_cast<::mlir::spirv::ExecutionMode>($_self.getInt())"; |
| let cppNamespace = "::mlir::spirv"; |
| } |
| |
| def SPV_EM_Vertex : I32EnumAttrCase<"Vertex", 0>; |
| def SPV_EM_TessellationControl : I32EnumAttrCase<"TessellationControl", 1>; |
| def SPV_EM_TessellationEvaluation : I32EnumAttrCase<"TessellationEvaluation", 2>; |
| def SPV_EM_Geometry : I32EnumAttrCase<"Geometry", 3>; |
| def SPV_EM_Fragment : I32EnumAttrCase<"Fragment", 4>; |
| def SPV_EM_GLCompute : I32EnumAttrCase<"GLCompute", 5>; |
| def SPV_EM_Kernel : I32EnumAttrCase<"Kernel", 6>; |
| def SPV_EM_TaskNV : I32EnumAttrCase<"TaskNV", 5267>; |
| def SPV_EM_MeshNV : I32EnumAttrCase<"MeshNV", 5268>; |
| def SPV_EM_RayGenerationNV : I32EnumAttrCase<"RayGenerationNV", 5313>; |
| def SPV_EM_IntersectionNV : I32EnumAttrCase<"IntersectionNV", 5314>; |
| def SPV_EM_AnyHitNV : I32EnumAttrCase<"AnyHitNV", 5315>; |
| def SPV_EM_ClosestHitNV : I32EnumAttrCase<"ClosestHitNV", 5316>; |
| def SPV_EM_MissNV : I32EnumAttrCase<"MissNV", 5317>; |
| def SPV_EM_CallableNV : I32EnumAttrCase<"CallableNV", 5318>; |
| |
| def SPV_ExecutionModelAttr : |
| I32EnumAttr<"ExecutionModel", "valid SPIR-V ExecutionModel", [ |
| SPV_EM_Vertex, SPV_EM_TessellationControl, SPV_EM_TessellationEvaluation, |
| SPV_EM_Geometry, SPV_EM_Fragment, SPV_EM_GLCompute, SPV_EM_Kernel, |
| SPV_EM_TaskNV, SPV_EM_MeshNV, SPV_EM_RayGenerationNV, SPV_EM_IntersectionNV, |
| SPV_EM_AnyHitNV, SPV_EM_ClosestHitNV, SPV_EM_MissNV, SPV_EM_CallableNV |
| ]> { |
| let returnType = "::mlir::spirv::ExecutionModel"; |
| let convertFromStorage = "static_cast<::mlir::spirv::ExecutionModel>($_self.getInt())"; |
| let cppNamespace = "::mlir::spirv"; |
| } |
| |
| def SPV_FC_None : BitEnumAttrCase<"None", 0x0000>; |
| def SPV_FC_Inline : BitEnumAttrCase<"Inline", 0x0001>; |
| def SPV_FC_DontInline : BitEnumAttrCase<"DontInline", 0x0002>; |
| def SPV_FC_Pure : BitEnumAttrCase<"Pure", 0x0004>; |
| def SPV_FC_Const : BitEnumAttrCase<"Const", 0x0008>; |
| |
| def SPV_FunctionControlAttr : |
| BitEnumAttr<"FunctionControl", "valid SPIR-V FunctionControl", [ |
| SPV_FC_None, SPV_FC_Inline, SPV_FC_DontInline, SPV_FC_Pure, SPV_FC_Const |
| ]> { |
| let returnType = "::mlir::spirv::FunctionControl"; |
| let convertFromStorage = "static_cast<::mlir::spirv::FunctionControl>($_self.getInt())"; |
| let cppNamespace = "::mlir::spirv"; |
| } |
| |
| def SPV_IF_Unknown : I32EnumAttrCase<"Unknown", 0>; |
| def SPV_IF_Rgba32f : I32EnumAttrCase<"Rgba32f", 1>; |
| def SPV_IF_Rgba16f : I32EnumAttrCase<"Rgba16f", 2>; |
| def SPV_IF_R32f : I32EnumAttrCase<"R32f", 3>; |
| def SPV_IF_Rgba8 : I32EnumAttrCase<"Rgba8", 4>; |
| def SPV_IF_Rgba8Snorm : I32EnumAttrCase<"Rgba8Snorm", 5>; |
| def SPV_IF_Rg32f : I32EnumAttrCase<"Rg32f", 6>; |
| def SPV_IF_Rg16f : I32EnumAttrCase<"Rg16f", 7>; |
| def SPV_IF_R11fG11fB10f : I32EnumAttrCase<"R11fG11fB10f", 8>; |
| def SPV_IF_R16f : I32EnumAttrCase<"R16f", 9>; |
| def SPV_IF_Rgba16 : I32EnumAttrCase<"Rgba16", 10>; |
| def SPV_IF_Rgb10A2 : I32EnumAttrCase<"Rgb10A2", 11>; |
| def SPV_IF_Rg16 : I32EnumAttrCase<"Rg16", 12>; |
| def SPV_IF_Rg8 : I32EnumAttrCase<"Rg8", 13>; |
| def SPV_IF_R16 : I32EnumAttrCase<"R16", 14>; |
| def SPV_IF_R8 : I32EnumAttrCase<"R8", 15>; |
| def SPV_IF_Rgba16Snorm : I32EnumAttrCase<"Rgba16Snorm", 16>; |
| def SPV_IF_Rg16Snorm : I32EnumAttrCase<"Rg16Snorm", 17>; |
| def SPV_IF_Rg8Snorm : I32EnumAttrCase<"Rg8Snorm", 18>; |
| def SPV_IF_R16Snorm : I32EnumAttrCase<"R16Snorm", 19>; |
| def SPV_IF_R8Snorm : I32EnumAttrCase<"R8Snorm", 20>; |
| def SPV_IF_Rgba32i : I32EnumAttrCase<"Rgba32i", 21>; |
| def SPV_IF_Rgba16i : I32EnumAttrCase<"Rgba16i", 22>; |
| def SPV_IF_Rgba8i : I32EnumAttrCase<"Rgba8i", 23>; |
| def SPV_IF_R32i : I32EnumAttrCase<"R32i", 24>; |
| def SPV_IF_Rg32i : I32EnumAttrCase<"Rg32i", 25>; |
| def SPV_IF_Rg16i : I32EnumAttrCase<"Rg16i", 26>; |
| def SPV_IF_Rg8i : I32EnumAttrCase<"Rg8i", 27>; |
| def SPV_IF_R16i : I32EnumAttrCase<"R16i", 28>; |
| def SPV_IF_R8i : I32EnumAttrCase<"R8i", 29>; |
| def SPV_IF_Rgba32ui : I32EnumAttrCase<"Rgba32ui", 30>; |
| def SPV_IF_Rgba16ui : I32EnumAttrCase<"Rgba16ui", 31>; |
| def SPV_IF_Rgba8ui : I32EnumAttrCase<"Rgba8ui", 32>; |
| def SPV_IF_R32ui : I32EnumAttrCase<"R32ui", 33>; |
| def SPV_IF_Rgb10a2ui : I32EnumAttrCase<"Rgb10a2ui", 34>; |
| def SPV_IF_Rg32ui : I32EnumAttrCase<"Rg32ui", 35>; |
| def SPV_IF_Rg16ui : I32EnumAttrCase<"Rg16ui", 36>; |
| def SPV_IF_Rg8ui : I32EnumAttrCase<"Rg8ui", 37>; |
| def SPV_IF_R16ui : I32EnumAttrCase<"R16ui", 38>; |
| def SPV_IF_R8ui : I32EnumAttrCase<"R8ui", 39>; |
| |
| def SPV_ImageFormatAttr : |
| I32EnumAttr<"ImageFormat", "valid SPIR-V ImageFormat", [ |
| SPV_IF_Unknown, SPV_IF_Rgba32f, SPV_IF_Rgba16f, SPV_IF_R32f, SPV_IF_Rgba8, |
| SPV_IF_Rgba8Snorm, SPV_IF_Rg32f, SPV_IF_Rg16f, SPV_IF_R11fG11fB10f, |
| SPV_IF_R16f, SPV_IF_Rgba16, SPV_IF_Rgb10A2, SPV_IF_Rg16, SPV_IF_Rg8, |
| SPV_IF_R16, SPV_IF_R8, SPV_IF_Rgba16Snorm, SPV_IF_Rg16Snorm, SPV_IF_Rg8Snorm, |
| SPV_IF_R16Snorm, SPV_IF_R8Snorm, SPV_IF_Rgba32i, SPV_IF_Rgba16i, SPV_IF_Rgba8i, |
| SPV_IF_R32i, SPV_IF_Rg32i, SPV_IF_Rg16i, SPV_IF_Rg8i, SPV_IF_R16i, SPV_IF_R8i, |
| SPV_IF_Rgba32ui, SPV_IF_Rgba16ui, SPV_IF_Rgba8ui, SPV_IF_R32ui, |
| SPV_IF_Rgb10a2ui, SPV_IF_Rg32ui, SPV_IF_Rg16ui, SPV_IF_Rg8ui, SPV_IF_R16ui, |
| SPV_IF_R8ui |
| ]> { |
| let returnType = "::mlir::spirv::ImageFormat"; |
| let convertFromStorage = "static_cast<::mlir::spirv::ImageFormat>($_self.getInt())"; |
| let cppNamespace = "::mlir::spirv"; |
| } |
| |
| def SPV_LT_Export : I32EnumAttrCase<"Export", 0>; |
| def SPV_LT_Import : I32EnumAttrCase<"Import", 1>; |
| |
| def SPV_LinkageTypeAttr : |
| I32EnumAttr<"LinkageType", "valid SPIR-V LinkageType", [ |
| SPV_LT_Export, SPV_LT_Import |
| ]> { |
| let returnType = "::mlir::spirv::LinkageType"; |
| let convertFromStorage = "static_cast<::mlir::spirv::LinkageType>($_self.getInt())"; |
| let cppNamespace = "::mlir::spirv"; |
| } |
| |
| def SPV_LC_None : BitEnumAttrCase<"None", 0x0000>; |
| def SPV_LC_Unroll : BitEnumAttrCase<"Unroll", 0x0001>; |
| def SPV_LC_DontUnroll : BitEnumAttrCase<"DontUnroll", 0x0002>; |
| def SPV_LC_DependencyInfinite : BitEnumAttrCase<"DependencyInfinite", 0x0004>; |
| def SPV_LC_DependencyLength : BitEnumAttrCase<"DependencyLength", 0x0008>; |
| def SPV_LC_MinIterations : BitEnumAttrCase<"MinIterations", 0x0010>; |
| def SPV_LC_MaxIterations : BitEnumAttrCase<"MaxIterations", 0x0020>; |
| def SPV_LC_IterationMultiple : BitEnumAttrCase<"IterationMultiple", 0x0040>; |
| def SPV_LC_PeelCount : BitEnumAttrCase<"PeelCount", 0x0080>; |
| def SPV_LC_PartialCount : BitEnumAttrCase<"PartialCount", 0x0100>; |
| |
| def SPV_LoopControlAttr : |
| BitEnumAttr<"LoopControl", "valid SPIR-V LoopControl", [ |
| SPV_LC_None, SPV_LC_Unroll, SPV_LC_DontUnroll, SPV_LC_DependencyInfinite, |
| SPV_LC_DependencyLength, SPV_LC_MinIterations, SPV_LC_MaxIterations, |
| SPV_LC_IterationMultiple, SPV_LC_PeelCount, SPV_LC_PartialCount |
| ]> { |
| let returnType = "::mlir::spirv::LoopControl"; |
| let convertFromStorage = "static_cast<::mlir::spirv::LoopControl>($_self.getInt())"; |
| let cppNamespace = "::mlir::spirv"; |
| } |
| |
| def SPV_MA_None : BitEnumAttrCase<"None", 0x0000>; |
| def SPV_MA_Volatile : BitEnumAttrCase<"Volatile", 0x0001>; |
| def SPV_MA_Aligned : BitEnumAttrCase<"Aligned", 0x0002>; |
| def SPV_MA_Nontemporal : BitEnumAttrCase<"Nontemporal", 0x0004>; |
| def SPV_MA_MakePointerAvailable : BitEnumAttrCase<"MakePointerAvailable", 0x0008>; |
| def SPV_MA_MakePointerVisible : BitEnumAttrCase<"MakePointerVisible", 0x0010>; |
| def SPV_MA_NonPrivatePointer : BitEnumAttrCase<"NonPrivatePointer", 0x0020>; |
| |
| def SPV_MemoryAccessAttr : |
| BitEnumAttr<"MemoryAccess", "valid SPIR-V MemoryAccess", [ |
| SPV_MA_None, SPV_MA_Volatile, SPV_MA_Aligned, SPV_MA_Nontemporal, |
| SPV_MA_MakePointerAvailable, SPV_MA_MakePointerVisible, |
| SPV_MA_NonPrivatePointer |
| ]> { |
| let returnType = "::mlir::spirv::MemoryAccess"; |
| let convertFromStorage = "static_cast<::mlir::spirv::MemoryAccess>($_self.getInt())"; |
| let cppNamespace = "::mlir::spirv"; |
| } |
| |
| def SPV_MM_Simple : I32EnumAttrCase<"Simple", 0>; |
| def SPV_MM_GLSL450 : I32EnumAttrCase<"GLSL450", 1>; |
| def SPV_MM_OpenCL : I32EnumAttrCase<"OpenCL", 2>; |
| def SPV_MM_Vulkan : I32EnumAttrCase<"Vulkan", 3>; |
| |
| def SPV_MemoryModelAttr : |
| I32EnumAttr<"MemoryModel", "valid SPIR-V MemoryModel", [ |
| SPV_MM_Simple, SPV_MM_GLSL450, SPV_MM_OpenCL, SPV_MM_Vulkan |
| ]> { |
| let returnType = "::mlir::spirv::MemoryModel"; |
| let convertFromStorage = "static_cast<::mlir::spirv::MemoryModel>($_self.getInt())"; |
| let cppNamespace = "::mlir::spirv"; |
| } |
| |
| def SPV_MS_None : BitEnumAttrCase<"None", 0x0000>; |
| def SPV_MS_Acquire : BitEnumAttrCase<"Acquire", 0x0002>; |
| def SPV_MS_Release : BitEnumAttrCase<"Release", 0x0004>; |
| def SPV_MS_AcquireRelease : BitEnumAttrCase<"AcquireRelease", 0x0008>; |
| def SPV_MS_SequentiallyConsistent : BitEnumAttrCase<"SequentiallyConsistent", 0x0010>; |
| def SPV_MS_UniformMemory : BitEnumAttrCase<"UniformMemory", 0x0040>; |
| def SPV_MS_SubgroupMemory : BitEnumAttrCase<"SubgroupMemory", 0x0080>; |
| def SPV_MS_WorkgroupMemory : BitEnumAttrCase<"WorkgroupMemory", 0x0100>; |
| def SPV_MS_CrossWorkgroupMemory : BitEnumAttrCase<"CrossWorkgroupMemory", 0x0200>; |
| def SPV_MS_AtomicCounterMemory : BitEnumAttrCase<"AtomicCounterMemory", 0x0400>; |
| def SPV_MS_ImageMemory : BitEnumAttrCase<"ImageMemory", 0x0800>; |
| def SPV_MS_OutputMemory : BitEnumAttrCase<"OutputMemory", 0x1000>; |
| def SPV_MS_MakeAvailable : BitEnumAttrCase<"MakeAvailable", 0x2000>; |
| def SPV_MS_MakeVisible : BitEnumAttrCase<"MakeVisible", 0x4000>; |
| def SPV_MS_Volatile : BitEnumAttrCase<"Volatile", 0x8000>; |
| |
| def SPV_MemorySemanticsAttr : |
| BitEnumAttr<"MemorySemantics", "valid SPIR-V MemorySemantics", [ |
| SPV_MS_None, SPV_MS_Acquire, SPV_MS_Release, SPV_MS_AcquireRelease, |
| SPV_MS_SequentiallyConsistent, SPV_MS_UniformMemory, SPV_MS_SubgroupMemory, |
| SPV_MS_WorkgroupMemory, SPV_MS_CrossWorkgroupMemory, |
| SPV_MS_AtomicCounterMemory, SPV_MS_ImageMemory, SPV_MS_OutputMemory, |
| SPV_MS_MakeAvailable, SPV_MS_MakeVisible, SPV_MS_Volatile |
| ]> { |
| let returnType = "::mlir::spirv::MemorySemantics"; |
| let convertFromStorage = "static_cast<::mlir::spirv::MemorySemantics>($_self.getInt())"; |
| let cppNamespace = "::mlir::spirv"; |
| } |
| |
| def SPV_S_CrossDevice : I32EnumAttrCase<"CrossDevice", 0>; |
| def SPV_S_Device : I32EnumAttrCase<"Device", 1>; |
| def SPV_S_Workgroup : I32EnumAttrCase<"Workgroup", 2>; |
| def SPV_S_Subgroup : I32EnumAttrCase<"Subgroup", 3>; |
| def SPV_S_Invocation : I32EnumAttrCase<"Invocation", 4>; |
| def SPV_S_QueueFamily : I32EnumAttrCase<"QueueFamily", 5>; |
| |
| def SPV_ScopeAttr : |
| I32EnumAttr<"Scope", "valid SPIR-V Scope", [ |
| SPV_S_CrossDevice, SPV_S_Device, SPV_S_Workgroup, SPV_S_Subgroup, |
| SPV_S_Invocation, SPV_S_QueueFamily |
| ]> { |
| let returnType = "::mlir::spirv::Scope"; |
| let convertFromStorage = "static_cast<::mlir::spirv::Scope>($_self.getInt())"; |
| let cppNamespace = "::mlir::spirv"; |
| } |
| |
| def SPV_SC_None : BitEnumAttrCase<"None", 0x0000>; |
| def SPV_SC_Flatten : BitEnumAttrCase<"Flatten", 0x0001>; |
| def SPV_SC_DontFlatten : BitEnumAttrCase<"DontFlatten", 0x0002>; |
| |
| def SPV_SelectionControlAttr : |
| BitEnumAttr<"SelectionControl", "valid SPIR-V SelectionControl", [ |
| SPV_SC_None, SPV_SC_Flatten, SPV_SC_DontFlatten |
| ]> { |
| let returnType = "::mlir::spirv::SelectionControl"; |
| let convertFromStorage = "static_cast<::mlir::spirv::SelectionControl>($_self.getInt())"; |
| let cppNamespace = "::mlir::spirv"; |
| } |
| |
| def SPV_SC_UniformConstant : I32EnumAttrCase<"UniformConstant", 0>; |
| def SPV_SC_Input : I32EnumAttrCase<"Input", 1>; |
| def SPV_SC_Uniform : I32EnumAttrCase<"Uniform", 2>; |
| def SPV_SC_Output : I32EnumAttrCase<"Output", 3>; |
| def SPV_SC_Workgroup : I32EnumAttrCase<"Workgroup", 4>; |
| def SPV_SC_CrossWorkgroup : I32EnumAttrCase<"CrossWorkgroup", 5>; |
| def SPV_SC_Private : I32EnumAttrCase<"Private", 6>; |
| def SPV_SC_Function : I32EnumAttrCase<"Function", 7>; |
| def SPV_SC_Generic : I32EnumAttrCase<"Generic", 8>; |
| def SPV_SC_PushConstant : I32EnumAttrCase<"PushConstant", 9>; |
| def SPV_SC_AtomicCounter : I32EnumAttrCase<"AtomicCounter", 10>; |
| def SPV_SC_Image : I32EnumAttrCase<"Image", 11>; |
| def SPV_SC_StorageBuffer : I32EnumAttrCase<"StorageBuffer", 12>; |
| def SPV_SC_CallableDataNV : I32EnumAttrCase<"CallableDataNV", 5328>; |
| def SPV_SC_IncomingCallableDataNV : I32EnumAttrCase<"IncomingCallableDataNV", 5329>; |
| def SPV_SC_RayPayloadNV : I32EnumAttrCase<"RayPayloadNV", 5338>; |
| def SPV_SC_HitAttributeNV : I32EnumAttrCase<"HitAttributeNV", 5339>; |
| def SPV_SC_IncomingRayPayloadNV : I32EnumAttrCase<"IncomingRayPayloadNV", 5342>; |
| def SPV_SC_ShaderRecordBufferNV : I32EnumAttrCase<"ShaderRecordBufferNV", 5343>; |
| def SPV_SC_PhysicalStorageBuffer : I32EnumAttrCase<"PhysicalStorageBuffer", 5349>; |
| |
| def SPV_StorageClassAttr : |
| I32EnumAttr<"StorageClass", "valid SPIR-V StorageClass", [ |
| SPV_SC_UniformConstant, SPV_SC_Input, SPV_SC_Uniform, SPV_SC_Output, |
| SPV_SC_Workgroup, SPV_SC_CrossWorkgroup, SPV_SC_Private, SPV_SC_Function, |
| SPV_SC_Generic, SPV_SC_PushConstant, SPV_SC_AtomicCounter, SPV_SC_Image, |
| SPV_SC_StorageBuffer, SPV_SC_CallableDataNV, SPV_SC_IncomingCallableDataNV, |
| SPV_SC_RayPayloadNV, SPV_SC_HitAttributeNV, SPV_SC_IncomingRayPayloadNV, |
| SPV_SC_ShaderRecordBufferNV, SPV_SC_PhysicalStorageBuffer |
| ]> { |
| let returnType = "::mlir::spirv::StorageClass"; |
| let convertFromStorage = "static_cast<::mlir::spirv::StorageClass>($_self.getInt())"; |
| let cppNamespace = "::mlir::spirv"; |
| } |
| |
| // End enum section. Generated from SPIR-V spec; DO NOT MODIFY! |
| |
| // Enums added manually that are not part of SPIRV spec |
| |
| def SPV_IDI_NoDepth : I32EnumAttrCase<"NoDepth", 0>; |
| def SPV_IDI_IsDepth : I32EnumAttrCase<"IsDepth", 1>; |
| def SPV_IDI_DepthUnknown : I32EnumAttrCase<"DepthUnknown", 2>; |
| |
| def SPV_DepthAttr : |
| I32EnumAttr<"ImageDepthInfo", "valid SPIR-V Image Depth specification", |
| [SPV_IDI_NoDepth, SPV_IDI_IsDepth, SPV_IDI_DepthUnknown]> { |
| let cppNamespace = "::mlir::spirv"; |
| } |
| |
| def SPV_IAI_NonArrayed : I32EnumAttrCase<"NonArrayed", 0>; |
| def SPV_IAI_Arrayed : I32EnumAttrCase<"Arrayed", 1>; |
| |
| def SPV_ArrayedAttr : |
| I32EnumAttr<"ImageArrayedInfo", "valid SPIR-V Image Arrayed specification", |
| [SPV_IAI_NonArrayed, SPV_IAI_Arrayed]> { |
| let cppNamespace = "::mlir::spirv"; |
| } |
| |
| def SPV_ISI_SingleSampled : I32EnumAttrCase<"SingleSampled", 0>; |
| def SPV_ISI_MultiSampled : I32EnumAttrCase<"MultiSampled", 1>; |
| |
| def SPV_SamplingAttr: |
| I32EnumAttr<"ImageSamplingInfo", "valid SPIR-V Image Sampling specification", |
| [SPV_ISI_SingleSampled, SPV_ISI_MultiSampled]> { |
| let cppNamespace = "::mlir::spirv"; |
| } |
| |
| def SPV_ISUI_SamplerUnknown : I32EnumAttrCase<"SamplerUnknown", 0>; |
| def SPV_ISUI_NeedSampler : I32EnumAttrCase<"NeedSampler", 1>; |
| def SPV_ISUI_NoSampler : I32EnumAttrCase<"NoSampler", 2>; |
| |
| def SPV_SamplerUseAttr: |
| I32EnumAttr<"ImageSamplerUseInfo", "valid SPIR-V Sampler Use specification", |
| [SPV_ISUI_SamplerUnknown, SPV_ISUI_NeedSampler, SPV_ISUI_NoSampler]> { |
| let cppNamespace = "::mlir::spirv"; |
| } |
| |
| //===----------------------------------------------------------------------===// |
| // SPIR-V OpTrait definitions |
| //===----------------------------------------------------------------------===// |
| |
| // Check that an op can only be used within the scope of a FuncOp. |
| def InFunctionScope : PredOpTrait< |
| "op must appear in a 'func' block", |
| CPred<"($_op.getParentOfType<FuncOp>())">>; |
| |
| // Check that an op can only be used within the scope of a SPIR-V ModuleOp. |
| def InModuleScope : PredOpTrait< |
| "op must appear in a 'spv.module' block", |
| CPred<"llvm::isa_and_nonnull<spirv::ModuleOp>($_op.getParentOp())">>; |
| |
| //===----------------------------------------------------------------------===// |
| // SPIR-V op definitions |
| //===----------------------------------------------------------------------===// |
| |
| // Base class for all SPIR-V ops. |
| class SPV_Op<string mnemonic, list<OpTrait> traits = []> : |
| Op<SPV_Dialect, mnemonic, traits> { |
| |
| // For each SPIR-V op, the following static functions need to be defined |
| // in SPVOps.cpp: |
| // |
| // * static ParseResult parse<op-c++-class-name>(OpAsmParser &parser, |
| // OperationState &result) |
| // * static void print(OpAsmPrinter &p, <op-c++-class-name> op) |
| // * static LogicalResult verify(<op-c++-class-name> op) |
| let parser = [{ return ::parse$cppClass(parser, result); }]; |
| let printer = [{ return ::print(*this, p); }]; |
| let verifier = [{ return ::verify(*this); }]; |
| |
| // Specifies whether this op has a direct corresponding SPIR-V binary |
| // instruction opcode. The (de)serializer use this field to determine whether |
| // to auto-generate an entry in the (de)serialization dispatch table for this |
| // op. |
| bit hasOpcode = 1; |
| |
| // Name of the corresponding SPIR-V op. Only valid to use when hasOpcode is 1. |
| string spirvOpName = "Op" # mnemonic; |
| |
| // Controls whether to auto-generate this op's (de)serialization method. |
| // If set, it results in generation of the following methods: |
| // |
| // ```c++ |
| // template<typename OpTy> Serializer::processOp(OpTy op); |
| // template<typename OpTy> Deserializer::processOp(ArrayRef<uint32_t>); |
| // ``` |
| // |
| // If this field is not set, then manual implementation of a specialization of |
| // these methods is required. |
| // |
| // Note: |
| // 1) If hasOpcode is set but autogenSerialization is not set, the |
| // (de)serializer dispatch method still calls the above method for |
| // (de)serializing this op. |
| // 2) If hasOpcode is not set, but autogenSerialization is set, the |
| // above methods for (de)serialization are generated, but there is no |
| // entry added in the dispatch tables to invoke these methods. The |
| // dispatch needs to be handled manually. SPV_ExtInstOps are an |
| // example of this. |
| bit autogenSerialization = 1; |
| } |
| |
| class SPV_UnaryOp<string mnemonic, Type resultType, Type operandType, |
| list<OpTrait> traits = []> : |
| SPV_Op<mnemonic, traits> { |
| let arguments = (ins |
| SPV_ScalarOrVectorOf<operandType>:$operand |
| ); |
| |
| let results = (outs |
| SPV_ScalarOrVectorOf<resultType>:$result |
| ); |
| |
| let parser = [{ return ::parseUnaryOp(parser, result); }]; |
| let printer = [{ return ::printUnaryOp(getOperation(), p); }]; |
| // No additional verification needed in addition to the ODS-generated ones. |
| let verifier = [{ return success(); }]; |
| } |
| |
| class SPV_BinaryOp<string mnemonic, Type resultType, Type operandsType, |
| list<OpTrait> traits = []> : |
| SPV_Op<mnemonic, traits> { |
| let arguments = (ins |
| SPV_ScalarOrVectorOf<operandsType>:$operand1, |
| SPV_ScalarOrVectorOf<operandsType>:$operand2 |
| ); |
| |
| let results = (outs |
| SPV_ScalarOrVectorOf<resultType>:$result |
| ); |
| |
| let parser = [{ return impl::parseOneResultSameOperandTypeOp(parser, result); }]; |
| let printer = [{ return impl::printOneResultOp(getOperation(), p); }]; |
| // No additional verification needed in addition to the ODS-generated ones. |
| let verifier = [{ return success(); }]; |
| } |
| |
| class SPV_ExtInstOp<string mnemonic, string setPrefix, string setName, |
| int opcode, list<OpTrait> traits = []> : |
| SPV_Op<setPrefix # "." # mnemonic, traits> { |
| |
| // Extended instruction sets have no direct opcode (they share the |
| // same `OpExtInst` instruction). So the hasOpcode field is set to |
| // false. So no entry corresponding to these ops are added in the |
| // dispatch functions for (de)serialization. The methods for |
| // (de)serialization are still automatically generated (since |
| // autogenSerialization remains 1). A separate method is generated |
| // for dispatching extended instruction set ops. |
| let hasOpcode = 0; |
| |
| // Opcode within extended instruction set. |
| int extendedInstOpcode = opcode; |
| |
| // Name used to import the extended instruction set. |
| string extendedInstSetName = setName; |
| } |
| |
| #endif // SPIRV_BASE |