blob: f114c878569d6d62d33e57afcbd62017324e271b [file] [log] [blame]
//===- SPIRVBase.td - MLIR SPIR-V Op Definitions Base file -*- tablegen -*-===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
//
// 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
include "mlir/IR/OpBase.td"
include "mlir/Dialect/SPIRV/SPIRVAvailability.td"
//===----------------------------------------------------------------------===//
// SPIR-V dialect definitions
//===----------------------------------------------------------------------===//
def SPIRV_Dialect : Dialect {
let name = "spv";
let summary = "The SPIR-V dialect in MLIR.";
let description = [{
SPIR-V is a 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 regarding
SPIR-V itself.
The SPIR-V dialect aims to be a proper compiler intermediate representation
to facilitate transformations. Ops in this dialect stay at the same semantic
level as the SPIR-V specification and try to have one-to-one mapping to the
corresponding SPIR-V instructions; but they may deviate representationally
to utilize MLIR mechanisms if it results in better representation and thus
benefits transformations. The dialect also aims to maintain straightforward
serialization into and deserialization from the SPIR-V binary format.
See https://mlir.llvm.org/docs/Dialects/SPIR-V/ for more details regarding
high-level designs and implementation structures of the SPIR-V dialect.
}];
let cppNamespace = "spirv";
let hasConstantMaterializer = 1;
let hasOperationAttrVerify = 1;
let hasRegionArgAttrVerify = 1;
let hasRegionResultAttrVerify = 1;
let extraClassDeclaration = [{
//===------------------------------------------------------------------===//
// Attribute
//===------------------------------------------------------------------===//
/// Returns the attribute name to use when specifying decorations on results
/// of operations.
static std::string getAttributeName(Decoration decoration);
}];
}
//===----------------------------------------------------------------------===//
// Utility definitions
//===----------------------------------------------------------------------===//
// A predicate that checks whether `$_self` is a known enum case for the
// enum class with `name`.
class SPV_IsKnownEnumCaseFor<string name> :
CPred<"::mlir::spirv::symbolize" # name # "("
"$_self.cast<IntegerAttr>().getValue().getZExtValue()).hasValue()">;
// Wrapper over base BitEnumAttr to set common fields.
class SPV_BitEnumAttr<string name, string description,
list<BitEnumAttrCase> cases> :
BitEnumAttr<name, description, cases> {
let predicate = And<[
I32Attr.predicate,
SPV_IsKnownEnumCaseFor<name>,
]>;
let cppNamespace = "::mlir::spirv";
}
// Wrapper over base I32EnumAttr to set common fields.
class SPV_I32EnumAttr<string name, string description,
list<I32EnumAttrCase> cases> :
I32EnumAttr<name, description, cases> {
let predicate = And<[
I32Attr.predicate,
SPV_IsKnownEnumCaseFor<name>,
]>;
let cppNamespace = "::mlir::spirv";
}
// Wrapper over base StrEnumAttr to set common fields.
class SPV_StrEnumAttr<string name, string description,
list<StrEnumAttrCase> cases> :
StrEnumAttr<name, description, cases> {
let predicate = And<[
StrAttr.predicate,
CPred<"::mlir::spirv::symbolize" # name # "("
"$_self.cast<StringAttr>().getValue()).hasValue()">,
]>;
let cppNamespace = "::mlir::spirv";
}
//===----------------------------------------------------------------------===//
// SPIR-V availability definitions
//===----------------------------------------------------------------------===//
def SPV_V_1_0 : I32EnumAttrCase<"V_1_0", 0, "v1.0">;
def SPV_V_1_1 : I32EnumAttrCase<"V_1_1", 1, "v1.1">;
def SPV_V_1_2 : I32EnumAttrCase<"V_1_2", 2, "v1.2">;
def SPV_V_1_3 : I32EnumAttrCase<"V_1_3", 3, "v1.3">;
def SPV_V_1_4 : I32EnumAttrCase<"V_1_4", 4, "v1.4">;
def SPV_V_1_5 : I32EnumAttrCase<"V_1_5", 5, "v1.5">;
def SPV_VersionAttr : SPV_I32EnumAttr<"Version", "valid SPIR-V version", [
SPV_V_1_0, SPV_V_1_1, SPV_V_1_2, SPV_V_1_3, SPV_V_1_4, SPV_V_1_5]>;
class MinVersion<I32EnumAttrCase min> : MinVersionBase<
"QueryMinVersionInterface", SPV_VersionAttr, min> {
let interfaceDescription = [{
Querying interface for minimal required SPIR-V version.
This interface provides a `getMinVersion()` method to query the minimal
required version for the implementing SPIR-V operation. The returned value
is a `mlir::spirv::Version` enumerant.
}];
}
class MaxVersion<I32EnumAttrCase max> : MaxVersionBase<
"QueryMaxVersionInterface", SPV_VersionAttr, max> {
let interfaceDescription = [{
Querying interface for maximal supported SPIR-V version.
This interface provides a `getMaxVersion()` method to query the maximal
supported version for the implementing SPIR-V operation. The returned value
is a `mlir::spirv::Version` enumerant.
}];
}
class Extension<list<StrEnumAttrCase> extensions> : Availability {
let interfaceName = "QueryExtensionInterface";
let interfaceDescription = [{
Querying interface for required SPIR-V extensions.
This interface provides a `getExtensions()` method to query the required
extensions for the implementing SPIR-V operation. The returned value
is a nested vector whose element is `mlir::spirv::Extension`s. The outer
vector's elements (which are vectors) should be interpreted as conjunction
while the inner vector's elements (which are `mlir::spirv::Extension`s)
should be interpreted as disjunction. For example, given
```
{{Extension::A, Extension::B}, {Extension::C}, {{Extension::D, Extension::E}}
```
The operation instance is available when (`Extension::A` OR `Extension::B`)
AND (`Extension::C`) AND (`Extension::D` OR `Extension::E`) is enabled.
}];
// TODO: Returning SmallVector<ArrayRef<...>> is not recommended.
// Find a better way for this.
let queryFnRetType = "::llvm::SmallVector<::llvm::ArrayRef<"
"::mlir::spirv::Extension>, 1>";
let queryFnName = "getExtensions";
let mergeAction = !if(
!empty(extensions), "", "$overall.emplace_back($instance)");
let initializer = "{}";
let instanceType = "::llvm::ArrayRef<::mlir::spirv::Extension>";
// Pack all extensions as a static array and get its reference.
let instancePreparation = !if(!empty(extensions), "",
"static const ::mlir::spirv::Extension exts[] = {" #
StrJoin<!foreach(ext, extensions,
"::mlir::spirv::Extension::" # ext.symbol)>.result #
"}; " #
// The following manual ArrayRef constructor call is to satisfy GCC 5.
"ArrayRef<::mlir::spirv::Extension> " #
"ref(exts, ::llvm::array_lengthof(exts));");
let instance = "ref";
}
class Capability<list<I32EnumAttrCase> capabilities> : Availability {
let interfaceName = "QueryCapabilityInterface";
let interfaceDescription = [{
Querying interface for required SPIR-V capabilities.
This interface provides a `getCapabilities()` method to query the required
capabilities for the implementing SPIR-V operation. The returned value
is a nested vector whose element is `mlir::spirv::Capability`s. The outer
vector's elements (which are vectors) should be interpreted as conjunction
while the inner vector's elements (which are `mlir::spirv::Capability`s)
should be interpreted as disjunction. For example, given
```
{{Capability::A, Capability::B}, {Capability::C}, {{Capability::D, Capability::E}}
```
The operation instance is available when (`Capability::A` OR `Capability::B`)
AND (`Capability::C`) AND (`Capability::D` OR `Capability::E`) is enabled.
}];
let queryFnRetType = "::llvm::SmallVector<::llvm::ArrayRef<"
"::mlir::spirv::Capability>, 1>";
let queryFnName = "getCapabilities";
let mergeAction = !if(
!empty(capabilities), "", "$overall.emplace_back($instance)");
let initializer = "{}";
let instanceType = "::llvm::ArrayRef<::mlir::spirv::Capability>";
// Pack all capabilities as a static array and get its reference.
let instancePreparation = !if(!empty(capabilities), "",
"static const ::mlir::spirv::Capability caps[] = {" #
StrJoin<!foreach(cap, capabilities,
"::mlir::spirv::Capability::" # cap.symbol)>.result #
"}; " #
// The following manual ArrayRef constructor call is to satisfy GCC 5.
"ArrayRef<::mlir::spirv::Capability> " #
"ref(caps, ::llvm::array_lengthof(caps));");
let instance = "ref";
}
// TODO: the following interfaces definitions are duplicating with the above.
// Remove them once we are able to support dialect-specific contents in ODS.
def QueryMinVersionInterface : OpInterface<"QueryMinVersionInterface"> {
let methods = [InterfaceMethod<"", "::mlir::spirv::Version", "getMinVersion">];
}
def QueryMaxVersionInterface : OpInterface<"QueryMaxVersionInterface"> {
let methods = [InterfaceMethod<"", "::mlir::spirv::Version", "getMaxVersion">];
}
def QueryExtensionInterface : OpInterface<"QueryExtensionInterface"> {
let methods = [InterfaceMethod<
"",
"::llvm::SmallVector<::llvm::ArrayRef<::mlir::spirv::Extension>, 1>",
"getExtensions">];
}
def QueryCapabilityInterface : OpInterface<"QueryCapabilityInterface"> {
let methods = [InterfaceMethod<
"",
"::llvm::SmallVector<::llvm::ArrayRef<::mlir::spirv::Capability>, 1>",
"getCapabilities">];
}
//===----------------------------------------------------------------------===//
// 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_device_group : StrEnumAttrCase<"SPV_KHR_device_group">;
def SPV_KHR_float_controls : StrEnumAttrCase<"SPV_KHR_float_controls">;
def SPV_KHR_physical_storage_buffer : StrEnumAttrCase<"SPV_KHR_physical_storage_buffer">;
def SPV_KHR_multiview : StrEnumAttrCase<"SPV_KHR_multiview">;
def SPV_KHR_no_integer_wrap_decoration : StrEnumAttrCase<"SPV_KHR_no_integer_wrap_decoration">;
def SPV_KHR_post_depth_coverage : StrEnumAttrCase<"SPV_KHR_post_depth_coverage">;
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_shader_clock : StrEnumAttrCase<"SPV_KHR_shader_clock">;
def SPV_KHR_shader_draw_parameters : StrEnumAttrCase<"SPV_KHR_shader_draw_parameters">;
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_EXT_demote_to_helper_invocation : StrEnumAttrCase<"SPV_EXT_demote_to_helper_invocation">;
def SPV_EXT_descriptor_indexing : StrEnumAttrCase<"SPV_EXT_descriptor_indexing">;
def SPV_EXT_fragment_fully_covered : StrEnumAttrCase<"SPV_EXT_fragment_fully_covered">;
def SPV_EXT_fragment_invocation_density : StrEnumAttrCase<"SPV_EXT_fragment_invocation_density">;
def SPV_EXT_fragment_shader_interlock : StrEnumAttrCase<"SPV_EXT_fragment_shader_interlock">;
def SPV_EXT_physical_storage_buffer : StrEnumAttrCase<"SPV_EXT_physical_storage_buffer">;
def SPV_EXT_shader_stencil_export : StrEnumAttrCase<"SPV_EXT_shader_stencil_export">;
def SPV_EXT_shader_viewport_index_layer : StrEnumAttrCase<"SPV_EXT_shader_viewport_index_layer">;
def SPV_AMD_gpu_shader_half_float_fetch : StrEnumAttrCase<"SPV_AMD_gpu_shader_half_float_fetch">;
def SPV_AMD_shader_ballot : StrEnumAttrCase<"SPV_AMD_shader_ballot">;
def SPV_AMD_shader_explicit_vertex_parameter : StrEnumAttrCase<"SPV_AMD_shader_explicit_vertex_parameter">;
def SPV_AMD_shader_fragment_mask : StrEnumAttrCase<"SPV_AMD_shader_fragment_mask">;
def SPV_AMD_shader_image_load_store_lod : StrEnumAttrCase<"SPV_AMD_shader_image_load_store_lod">;
def SPV_AMD_texture_gather_bias_lod : StrEnumAttrCase<"SPV_AMD_texture_gather_bias_lod">;
def SPV_GOOGLE_decorate_string : StrEnumAttrCase<"SPV_GOOGLE_decorate_string">;
def SPV_GOOGLE_hlsl_functionality1 : StrEnumAttrCase<"SPV_GOOGLE_hlsl_functionality1">;
def SPV_GOOGLE_user_type : StrEnumAttrCase<"SPV_GOOGLE_user_type">;
def SPV_INTEL_device_side_avc_motion_estimation : StrEnumAttrCase<"SPV_INTEL_device_side_avc_motion_estimation">;
def SPV_INTEL_media_block_io : StrEnumAttrCase<"SPV_INTEL_media_block_io">;
def SPV_INTEL_shader_integer_functions2 : StrEnumAttrCase<"SPV_INTEL_shader_integer_functions2">;
def SPV_INTEL_subgroups : StrEnumAttrCase<"SPV_INTEL_subgroups">;
def SPV_NV_compute_shader_derivatives : StrEnumAttrCase<"SPV_NV_compute_shader_derivatives">;
def SPV_NV_cooperative_matrix : StrEnumAttrCase<"SPV_NV_cooperative_matrix">;
def SPV_NV_fragment_shader_barycentric : StrEnumAttrCase<"SPV_NV_fragment_shader_barycentric">;
def SPV_NV_geometry_shader_passthrough : StrEnumAttrCase<"SPV_NV_geometry_shader_passthrough">;
def SPV_NV_mesh_shader : StrEnumAttrCase<"SPV_NV_mesh_shader">;
def SPV_NV_ray_tracing : StrEnumAttrCase<"SPV_NV_ray_tracing">;
def SPV_NV_sample_mask_override_coverage : StrEnumAttrCase<"SPV_NV_sample_mask_override_coverage">;
def SPV_NV_shader_image_footprint : StrEnumAttrCase<"SPV_NV_shader_image_footprint">;
def SPV_NV_shader_sm_builtins : StrEnumAttrCase<"SPV_NV_shader_sm_builtins">;
def SPV_NV_shader_subgroup_partitioned : StrEnumAttrCase<"SPV_NV_shader_subgroup_partitioned">;
def SPV_NV_shading_rate : StrEnumAttrCase<"SPV_NV_shading_rate">;
def SPV_NV_stereo_view_rendering : StrEnumAttrCase<"SPV_NV_stereo_view_rendering">;
def SPV_NV_viewport_array2 : StrEnumAttrCase<"SPV_NV_viewport_array2">;
def SPV_NVX_multiview_per_view_attributes : StrEnumAttrCase<"SPV_NVX_multiview_per_view_attributes">;
def SPV_ExtensionAttr :
SPV_StrEnumAttr<"Extension", "supported SPIR-V extensions", [
SPV_KHR_16bit_storage, SPV_KHR_8bit_storage, SPV_KHR_device_group,
SPV_KHR_float_controls, SPV_KHR_physical_storage_buffer, SPV_KHR_multiview,
SPV_KHR_no_integer_wrap_decoration, SPV_KHR_post_depth_coverage,
SPV_KHR_shader_atomic_counter_ops, SPV_KHR_shader_ballot,
SPV_KHR_shader_clock, SPV_KHR_shader_draw_parameters,
SPV_KHR_storage_buffer_storage_class, SPV_KHR_subgroup_vote,
SPV_KHR_variable_pointers, SPV_KHR_vulkan_memory_model,
SPV_EXT_demote_to_helper_invocation, SPV_EXT_descriptor_indexing,
SPV_EXT_fragment_fully_covered, SPV_EXT_fragment_invocation_density,
SPV_EXT_fragment_shader_interlock, SPV_EXT_physical_storage_buffer,
SPV_EXT_shader_stencil_export, SPV_EXT_shader_viewport_index_layer,
SPV_AMD_gpu_shader_half_float_fetch, SPV_AMD_shader_ballot,
SPV_AMD_shader_explicit_vertex_parameter, SPV_AMD_shader_fragment_mask,
SPV_AMD_shader_image_load_store_lod, SPV_AMD_texture_gather_bias_lod,
SPV_GOOGLE_decorate_string, SPV_GOOGLE_hlsl_functionality1, SPV_GOOGLE_user_type,
SPV_INTEL_device_side_avc_motion_estimation, SPV_INTEL_media_block_io,
SPV_INTEL_shader_integer_functions2, SPV_INTEL_subgroups,
SPV_NV_compute_shader_derivatives, SPV_NV_cooperative_matrix,
SPV_NV_fragment_shader_barycentric, SPV_NV_geometry_shader_passthrough,
SPV_NV_mesh_shader, SPV_NV_ray_tracing, SPV_NV_sample_mask_override_coverage,
SPV_NV_shader_image_footprint, SPV_NV_shader_sm_builtins,
SPV_NV_shader_subgroup_partitioned, SPV_NV_shading_rate,
SPV_NV_stereo_view_rendering, SPV_NV_viewport_array2,
SPV_NVX_multiview_per_view_attributes
]>;
//===----------------------------------------------------------------------===//
// SPIR-V enum definitions
//===----------------------------------------------------------------------===//
// Begin enum section. Generated from SPIR-V spec; DO NOT MODIFY!
def SPV_C_Matrix : I32EnumAttrCase<"Matrix", 0>;
def SPV_C_Addresses : I32EnumAttrCase<"Addresses", 4>;
def SPV_C_Linkage : I32EnumAttrCase<"Linkage", 5>;
def SPV_C_Kernel : I32EnumAttrCase<"Kernel", 6>;
def SPV_C_Float16 : I32EnumAttrCase<"Float16", 9>;
def SPV_C_Float64 : I32EnumAttrCase<"Float64", 10>;
def SPV_C_Int64 : I32EnumAttrCase<"Int64", 11>;
def SPV_C_Groups : I32EnumAttrCase<"Groups", 18> {
list<Availability> availability = [
Extension<[SPV_AMD_shader_ballot]>
];
}
def SPV_C_Int16 : I32EnumAttrCase<"Int16", 22>;
def SPV_C_Int8 : I32EnumAttrCase<"Int8", 39>;
def SPV_C_Sampled1D : I32EnumAttrCase<"Sampled1D", 43>;
def SPV_C_SampledBuffer : I32EnumAttrCase<"SampledBuffer", 46>;
def SPV_C_GroupNonUniform : I32EnumAttrCase<"GroupNonUniform", 61> {
list<Availability> availability = [
MinVersion<SPV_V_1_3>
];
}
def SPV_C_ShaderLayer : I32EnumAttrCase<"ShaderLayer", 69> {
list<Availability> availability = [
MinVersion<SPV_V_1_5>
];
}
def SPV_C_ShaderViewportIndex : I32EnumAttrCase<"ShaderViewportIndex", 70> {
list<Availability> availability = [
MinVersion<SPV_V_1_5>
];
}
def SPV_C_SubgroupBallotKHR : I32EnumAttrCase<"SubgroupBallotKHR", 4423> {
list<Availability> availability = [
Extension<[SPV_KHR_shader_ballot]>
];
}
def SPV_C_SubgroupVoteKHR : I32EnumAttrCase<"SubgroupVoteKHR", 4431> {
list<Availability> availability = [
Extension<[SPV_KHR_subgroup_vote]>
];
}
def SPV_C_StorageBuffer16BitAccess : I32EnumAttrCase<"StorageBuffer16BitAccess", 4433> {
list<Availability> availability = [
Extension<[SPV_KHR_16bit_storage]>
];
}
def SPV_C_StoragePushConstant16 : I32EnumAttrCase<"StoragePushConstant16", 4435> {
list<Availability> availability = [
Extension<[SPV_KHR_16bit_storage]>
];
}
def SPV_C_StorageInputOutput16 : I32EnumAttrCase<"StorageInputOutput16", 4436> {
list<Availability> availability = [
Extension<[SPV_KHR_16bit_storage]>
];
}
def SPV_C_DeviceGroup : I32EnumAttrCase<"DeviceGroup", 4437> {
list<Availability> availability = [
Extension<[SPV_KHR_device_group]>
];
}
def SPV_C_AtomicStorageOps : I32EnumAttrCase<"AtomicStorageOps", 4445> {
list<Availability> availability = [
Extension<[SPV_KHR_shader_atomic_counter_ops]>
];
}
def SPV_C_SampleMaskPostDepthCoverage : I32EnumAttrCase<"SampleMaskPostDepthCoverage", 4447> {
list<Availability> availability = [
Extension<[SPV_KHR_post_depth_coverage]>
];
}
def SPV_C_StorageBuffer8BitAccess : I32EnumAttrCase<"StorageBuffer8BitAccess", 4448> {
list<Availability> availability = [
Extension<[SPV_KHR_8bit_storage]>
];
}
def SPV_C_StoragePushConstant8 : I32EnumAttrCase<"StoragePushConstant8", 4450> {
list<Availability> availability = [
Extension<[SPV_KHR_8bit_storage]>
];
}
def SPV_C_DenormPreserve : I32EnumAttrCase<"DenormPreserve", 4464> {
list<Availability> availability = [
Extension<[SPV_KHR_float_controls]>
];
}
def SPV_C_DenormFlushToZero : I32EnumAttrCase<"DenormFlushToZero", 4465> {
list<Availability> availability = [
Extension<[SPV_KHR_float_controls]>
];
}
def SPV_C_SignedZeroInfNanPreserve : I32EnumAttrCase<"SignedZeroInfNanPreserve", 4466> {
list<Availability> availability = [
Extension<[SPV_KHR_float_controls]>
];
}
def SPV_C_RoundingModeRTE : I32EnumAttrCase<"RoundingModeRTE", 4467> {
list<Availability> availability = [
Extension<[SPV_KHR_float_controls]>
];
}
def SPV_C_RoundingModeRTZ : I32EnumAttrCase<"RoundingModeRTZ", 4468> {
list<Availability> availability = [
Extension<[SPV_KHR_float_controls]>
];
}
def SPV_C_ImageFootprintNV : I32EnumAttrCase<"ImageFootprintNV", 5282> {
list<Availability> availability = [
Extension<[SPV_NV_shader_image_footprint]>
];
}
def SPV_C_FragmentBarycentricNV : I32EnumAttrCase<"FragmentBarycentricNV", 5284> {
list<Availability> availability = [
Extension<[SPV_NV_fragment_shader_barycentric]>
];
}
def SPV_C_ComputeDerivativeGroupQuadsNV : I32EnumAttrCase<"ComputeDerivativeGroupQuadsNV", 5288> {
list<Availability> availability = [
Extension<[SPV_NV_compute_shader_derivatives]>
];
}
def SPV_C_GroupNonUniformPartitionedNV : I32EnumAttrCase<"GroupNonUniformPartitionedNV", 5297> {
list<Availability> availability = [
Extension<[SPV_NV_shader_subgroup_partitioned]>
];
}
def SPV_C_VulkanMemoryModel : I32EnumAttrCase<"VulkanMemoryModel", 5345> {
list<Availability> availability = [
MinVersion<SPV_V_1_5>
];
}
def SPV_C_VulkanMemoryModelDeviceScope : I32EnumAttrCase<"VulkanMemoryModelDeviceScope", 5346> {
list<Availability> availability = [
MinVersion<SPV_V_1_5>
];
}
def SPV_C_ComputeDerivativeGroupLinearNV : I32EnumAttrCase<"ComputeDerivativeGroupLinearNV", 5350> {
list<Availability> availability = [
Extension<[SPV_NV_compute_shader_derivatives]>
];
}
def SPV_C_SubgroupShuffleINTEL : I32EnumAttrCase<"SubgroupShuffleINTEL", 5568> {
list<Availability> availability = [
Extension<[SPV_INTEL_subgroups]>
];
}
def SPV_C_SubgroupBufferBlockIOINTEL : I32EnumAttrCase<"SubgroupBufferBlockIOINTEL", 5569> {
list<Availability> availability = [
Extension<[SPV_INTEL_subgroups]>
];
}
def SPV_C_SubgroupImageBlockIOINTEL : I32EnumAttrCase<"SubgroupImageBlockIOINTEL", 5570> {
list<Availability> availability = [
Extension<[SPV_INTEL_subgroups]>
];
}
def SPV_C_SubgroupImageMediaBlockIOINTEL : I32EnumAttrCase<"SubgroupImageMediaBlockIOINTEL", 5579> {
list<Availability> availability = [
Extension<[SPV_INTEL_media_block_io]>
];
}
def SPV_C_SubgroupAvcMotionEstimationINTEL : I32EnumAttrCase<"SubgroupAvcMotionEstimationINTEL", 5696> {
list<Availability> availability = [
Extension<[SPV_INTEL_device_side_avc_motion_estimation]>
];
}
def SPV_C_SubgroupAvcMotionEstimationIntraINTEL : I32EnumAttrCase<"SubgroupAvcMotionEstimationIntraINTEL", 5697> {
list<Availability> availability = [
Extension<[SPV_INTEL_device_side_avc_motion_estimation]>
];
}
def SPV_C_SubgroupAvcMotionEstimationChromaINTEL : I32EnumAttrCase<"SubgroupAvcMotionEstimationChromaINTEL", 5698> {
list<Availability> availability = [
Extension<[SPV_INTEL_device_side_avc_motion_estimation]>
];
}
def SPV_C_Shader : I32EnumAttrCase<"Shader", 1> {
list<I32EnumAttrCase> implies = [SPV_C_Matrix];
}
def SPV_C_Vector16 : I32EnumAttrCase<"Vector16", 7> {
list<I32EnumAttrCase> implies = [SPV_C_Kernel];
}
def SPV_C_Float16Buffer : I32EnumAttrCase<"Float16Buffer", 8> {
list<I32EnumAttrCase> implies = [SPV_C_Kernel];
}
def SPV_C_Int64Atomics : I32EnumAttrCase<"Int64Atomics", 12> {
list<I32EnumAttrCase> implies = [SPV_C_Int64];
}
def SPV_C_ImageBasic : I32EnumAttrCase<"ImageBasic", 13> {
list<I32EnumAttrCase> implies = [SPV_C_Kernel];
}
def SPV_C_Pipes : I32EnumAttrCase<"Pipes", 17> {
list<I32EnumAttrCase> implies = [SPV_C_Kernel];
}
def SPV_C_DeviceEnqueue : I32EnumAttrCase<"DeviceEnqueue", 19> {
list<I32EnumAttrCase> implies = [SPV_C_Kernel];
}
def SPV_C_LiteralSampler : I32EnumAttrCase<"LiteralSampler", 20> {
list<I32EnumAttrCase> implies = [SPV_C_Kernel];
}
def SPV_C_GenericPointer : I32EnumAttrCase<"GenericPointer", 38> {
list<I32EnumAttrCase> implies = [SPV_C_Addresses];
}
def SPV_C_Image1D : I32EnumAttrCase<"Image1D", 44> {
list<I32EnumAttrCase> implies = [SPV_C_Sampled1D];
}
def SPV_C_ImageBuffer : I32EnumAttrCase<"ImageBuffer", 47> {
list<I32EnumAttrCase> implies = [SPV_C_SampledBuffer];
}
def SPV_C_NamedBarrier : I32EnumAttrCase<"NamedBarrier", 59> {
list<I32EnumAttrCase> implies = [SPV_C_Kernel];
list<Availability> availability = [
MinVersion<SPV_V_1_1>
];
}
def SPV_C_GroupNonUniformVote : I32EnumAttrCase<"GroupNonUniformVote", 62> {
list<I32EnumAttrCase> implies = [SPV_C_GroupNonUniform];
list<Availability> availability = [
MinVersion<SPV_V_1_3>
];
}
def SPV_C_GroupNonUniformArithmetic : I32EnumAttrCase<"GroupNonUniformArithmetic", 63> {
list<I32EnumAttrCase> implies = [SPV_C_GroupNonUniform];
list<Availability> availability = [
MinVersion<SPV_V_1_3>
];
}
def SPV_C_GroupNonUniformBallot : I32EnumAttrCase<"GroupNonUniformBallot", 64> {
list<I32EnumAttrCase> implies = [SPV_C_GroupNonUniform];
list<Availability> availability = [
MinVersion<SPV_V_1_3>
];
}
def SPV_C_GroupNonUniformShuffle : I32EnumAttrCase<"GroupNonUniformShuffle", 65> {
list<I32EnumAttrCase> implies = [SPV_C_GroupNonUniform];
list<Availability> availability = [
MinVersion<SPV_V_1_3>
];
}
def SPV_C_GroupNonUniformShuffleRelative : I32EnumAttrCase<"GroupNonUniformShuffleRelative", 66> {
list<I32EnumAttrCase> implies = [SPV_C_GroupNonUniform];
list<Availability> availability = [
MinVersion<SPV_V_1_3>
];
}
def SPV_C_GroupNonUniformClustered : I32EnumAttrCase<"GroupNonUniformClustered", 67> {
list<I32EnumAttrCase> implies = [SPV_C_GroupNonUniform];
list<Availability> availability = [
MinVersion<SPV_V_1_3>
];
}
def SPV_C_GroupNonUniformQuad : I32EnumAttrCase<"GroupNonUniformQuad", 68> {
list<I32EnumAttrCase> implies = [SPV_C_GroupNonUniform];
list<Availability> availability = [
MinVersion<SPV_V_1_3>
];
}
def SPV_C_StorageUniform16 : I32EnumAttrCase<"StorageUniform16", 4434> {
list<I32EnumAttrCase> implies = [SPV_C_StorageBuffer16BitAccess];
list<Availability> availability = [
Extension<[SPV_KHR_16bit_storage]>
];
}
def SPV_C_UniformAndStorageBuffer8BitAccess : I32EnumAttrCase<"UniformAndStorageBuffer8BitAccess", 4449> {
list<I32EnumAttrCase> implies = [SPV_C_StorageBuffer8BitAccess];
list<Availability> availability = [
Extension<[SPV_KHR_8bit_storage]>
];
}
def SPV_C_UniformTexelBufferArrayDynamicIndexing : I32EnumAttrCase<"UniformTexelBufferArrayDynamicIndexing", 5304> {
list<I32EnumAttrCase> implies = [SPV_C_SampledBuffer];
list<Availability> availability = [
MinVersion<SPV_V_1_5>
];
}
def SPV_C_Geometry : I32EnumAttrCase<"Geometry", 2> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
}
def SPV_C_Tessellation : I32EnumAttrCase<"Tessellation", 3> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
}
def SPV_C_ImageReadWrite : I32EnumAttrCase<"ImageReadWrite", 14> {
list<I32EnumAttrCase> implies = [SPV_C_ImageBasic];
}
def SPV_C_ImageMipmap : I32EnumAttrCase<"ImageMipmap", 15> {
list<I32EnumAttrCase> implies = [SPV_C_ImageBasic];
}
def SPV_C_AtomicStorage : I32EnumAttrCase<"AtomicStorage", 21> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
}
def SPV_C_ImageGatherExtended : I32EnumAttrCase<"ImageGatherExtended", 25> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
}
def SPV_C_StorageImageMultisample : I32EnumAttrCase<"StorageImageMultisample", 27> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
}
def SPV_C_UniformBufferArrayDynamicIndexing : I32EnumAttrCase<"UniformBufferArrayDynamicIndexing", 28> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
}
def SPV_C_SampledImageArrayDynamicIndexing : I32EnumAttrCase<"SampledImageArrayDynamicIndexing", 29> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
}
def SPV_C_StorageBufferArrayDynamicIndexing : I32EnumAttrCase<"StorageBufferArrayDynamicIndexing", 30> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
}
def SPV_C_StorageImageArrayDynamicIndexing : I32EnumAttrCase<"StorageImageArrayDynamicIndexing", 31> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
}
def SPV_C_ClipDistance : I32EnumAttrCase<"ClipDistance", 32> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
}
def SPV_C_CullDistance : I32EnumAttrCase<"CullDistance", 33> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
}
def SPV_C_SampleRateShading : I32EnumAttrCase<"SampleRateShading", 35> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
}
def SPV_C_SampledRect : I32EnumAttrCase<"SampledRect", 37> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
}
def SPV_C_InputAttachment : I32EnumAttrCase<"InputAttachment", 40> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
}
def SPV_C_SparseResidency : I32EnumAttrCase<"SparseResidency", 41> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
}
def SPV_C_MinLod : I32EnumAttrCase<"MinLod", 42> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
}
def SPV_C_SampledCubeArray : I32EnumAttrCase<"SampledCubeArray", 45> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
}
def SPV_C_ImageMSArray : I32EnumAttrCase<"ImageMSArray", 48> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
}
def SPV_C_StorageImageExtendedFormats : I32EnumAttrCase<"StorageImageExtendedFormats", 49> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
}
def SPV_C_ImageQuery : I32EnumAttrCase<"ImageQuery", 50> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
}
def SPV_C_DerivativeControl : I32EnumAttrCase<"DerivativeControl", 51> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
}
def SPV_C_InterpolationFunction : I32EnumAttrCase<"InterpolationFunction", 52> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
}
def SPV_C_TransformFeedback : I32EnumAttrCase<"TransformFeedback", 53> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
}
def SPV_C_StorageImageReadWithoutFormat : I32EnumAttrCase<"StorageImageReadWithoutFormat", 55> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
}
def SPV_C_StorageImageWriteWithoutFormat : I32EnumAttrCase<"StorageImageWriteWithoutFormat", 56> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
}
def SPV_C_SubgroupDispatch : I32EnumAttrCase<"SubgroupDispatch", 58> {
list<I32EnumAttrCase> implies = [SPV_C_DeviceEnqueue];
list<Availability> availability = [
MinVersion<SPV_V_1_1>
];
}
def SPV_C_PipeStorage : I32EnumAttrCase<"PipeStorage", 60> {
list<I32EnumAttrCase> implies = [SPV_C_Pipes];
list<Availability> availability = [
MinVersion<SPV_V_1_1>
];
}
def SPV_C_DrawParameters : I32EnumAttrCase<"DrawParameters", 4427> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
list<Availability> availability = [
Extension<[SPV_KHR_shader_draw_parameters]>
];
}
def SPV_C_MultiView : I32EnumAttrCase<"MultiView", 4439> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
list<Availability> availability = [
Extension<[SPV_KHR_multiview]>
];
}
def SPV_C_VariablePointersStorageBuffer : I32EnumAttrCase<"VariablePointersStorageBuffer", 4441> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
list<Availability> availability = [
Extension<[SPV_KHR_variable_pointers]>
];
}
def SPV_C_Float16ImageAMD : I32EnumAttrCase<"Float16ImageAMD", 5008> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
list<Availability> availability = [
Extension<[SPV_AMD_gpu_shader_half_float_fetch]>
];
}
def SPV_C_ImageGatherBiasLodAMD : I32EnumAttrCase<"ImageGatherBiasLodAMD", 5009> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
list<Availability> availability = [
Extension<[SPV_AMD_texture_gather_bias_lod]>
];
}
def SPV_C_FragmentMaskAMD : I32EnumAttrCase<"FragmentMaskAMD", 5010> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
list<Availability> availability = [
Extension<[SPV_AMD_shader_fragment_mask]>
];
}
def SPV_C_StencilExportEXT : I32EnumAttrCase<"StencilExportEXT", 5013> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
list<Availability> availability = [
Extension<[SPV_EXT_shader_stencil_export]>
];
}
def SPV_C_ImageReadWriteLodAMD : I32EnumAttrCase<"ImageReadWriteLodAMD", 5015> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
list<Availability> availability = [
Extension<[SPV_AMD_shader_image_load_store_lod]>
];
}
def SPV_C_ShaderClockKHR : I32EnumAttrCase<"ShaderClockKHR", 5055> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
list<Availability> availability = [
Extension<[SPV_KHR_shader_clock]>
];
}
def SPV_C_FragmentFullyCoveredEXT : I32EnumAttrCase<"FragmentFullyCoveredEXT", 5265> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
list<Availability> availability = [
Extension<[SPV_EXT_fragment_fully_covered]>
];
}
def SPV_C_MeshShadingNV : I32EnumAttrCase<"MeshShadingNV", 5266> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
list<Availability> availability = [
Extension<[SPV_NV_mesh_shader]>
];
}
def SPV_C_FragmentDensityEXT : I32EnumAttrCase<"FragmentDensityEXT", 5291> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
list<Availability> availability = [
Extension<[SPV_EXT_fragment_invocation_density, SPV_NV_shading_rate]>
];
}
def SPV_C_ShaderNonUniform : I32EnumAttrCase<"ShaderNonUniform", 5301> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
list<Availability> availability = [
MinVersion<SPV_V_1_5>
];
}
def SPV_C_RuntimeDescriptorArray : I32EnumAttrCase<"RuntimeDescriptorArray", 5302> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
list<Availability> availability = [
MinVersion<SPV_V_1_5>
];
}
def SPV_C_StorageTexelBufferArrayDynamicIndexing : I32EnumAttrCase<"StorageTexelBufferArrayDynamicIndexing", 5305> {
list<I32EnumAttrCase> implies = [SPV_C_ImageBuffer];
list<Availability> availability = [
MinVersion<SPV_V_1_5>
];
}
def SPV_C_RayTracingNV : I32EnumAttrCase<"RayTracingNV", 5340> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
list<Availability> availability = [
Extension<[SPV_NV_ray_tracing]>
];
}
def SPV_C_PhysicalStorageBufferAddresses : I32EnumAttrCase<"PhysicalStorageBufferAddresses", 5347> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
list<Availability> availability = [
Extension<[SPV_EXT_physical_storage_buffer, SPV_KHR_physical_storage_buffer]>
];
}
def SPV_C_CooperativeMatrixNV : I32EnumAttrCase<"CooperativeMatrixNV", 5357> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
list<Availability> availability = [
Extension<[SPV_NV_cooperative_matrix]>
];
}
def SPV_C_FragmentShaderSampleInterlockEXT : I32EnumAttrCase<"FragmentShaderSampleInterlockEXT", 5363> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
list<Availability> availability = [
Extension<[SPV_EXT_fragment_shader_interlock]>
];
}
def SPV_C_FragmentShaderShadingRateInterlockEXT : I32EnumAttrCase<"FragmentShaderShadingRateInterlockEXT", 5372> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
list<Availability> availability = [
Extension<[SPV_EXT_fragment_shader_interlock]>
];
}
def SPV_C_ShaderSMBuiltinsNV : I32EnumAttrCase<"ShaderSMBuiltinsNV", 5373> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
list<Availability> availability = [
Extension<[SPV_NV_shader_sm_builtins]>
];
}
def SPV_C_FragmentShaderPixelInterlockEXT : I32EnumAttrCase<"FragmentShaderPixelInterlockEXT", 5378> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
list<Availability> availability = [
Extension<[SPV_EXT_fragment_shader_interlock]>
];
}
def SPV_C_DemoteToHelperInvocationEXT : I32EnumAttrCase<"DemoteToHelperInvocationEXT", 5379> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
list<Availability> availability = [
Extension<[SPV_EXT_demote_to_helper_invocation]>
];
}
def SPV_C_IntegerFunctions2INTEL : I32EnumAttrCase<"IntegerFunctions2INTEL", 5584> {
list<I32EnumAttrCase> implies = [SPV_C_Shader];
list<Availability> availability = [
Extension<[SPV_INTEL_shader_integer_functions2]>
];
}
def SPV_C_TessellationPointSize : I32EnumAttrCase<"TessellationPointSize", 23> {
list<I32EnumAttrCase> implies = [SPV_C_Tessellation];
}
def SPV_C_GeometryPointSize : I32EnumAttrCase<"GeometryPointSize", 24> {
list<I32EnumAttrCase> implies = [SPV_C_Geometry];
}
def SPV_C_ImageCubeArray : I32EnumAttrCase<"ImageCubeArray", 34> {
list<I32EnumAttrCase> implies = [SPV_C_SampledCubeArray];
}
def SPV_C_ImageRect : I32EnumAttrCase<"ImageRect", 36> {
list<I32EnumAttrCase> implies = [SPV_C_SampledRect];
}
def SPV_C_GeometryStreams : I32EnumAttrCase<"GeometryStreams", 54> {
list<I32EnumAttrCase> implies = [SPV_C_Geometry];
}
def SPV_C_MultiViewport : I32EnumAttrCase<"MultiViewport", 57> {
list<I32EnumAttrCase> implies = [SPV_C_Geometry];
}
def SPV_C_VariablePointers : I32EnumAttrCase<"VariablePointers", 4442> {
list<I32EnumAttrCase> implies = [SPV_C_VariablePointersStorageBuffer];
list<Availability> availability = [
Extension<[SPV_KHR_variable_pointers]>
];
}
def SPV_C_SampleMaskOverrideCoverageNV : I32EnumAttrCase<"SampleMaskOverrideCoverageNV", 5249> {
list<I32EnumAttrCase> implies = [SPV_C_SampleRateShading];
list<Availability> availability = [
Extension<[SPV_NV_sample_mask_override_coverage]>
];
}
def SPV_C_GeometryShaderPassthroughNV : I32EnumAttrCase<"GeometryShaderPassthroughNV", 5251> {
list<I32EnumAttrCase> implies = [SPV_C_Geometry];
list<Availability> availability = [
Extension<[SPV_NV_geometry_shader_passthrough]>
];
}
def SPV_C_PerViewAttributesNV : I32EnumAttrCase<"PerViewAttributesNV", 5260> {
list<I32EnumAttrCase> implies = [SPV_C_MultiView];
list<Availability> availability = [
Extension<[SPV_NVX_multiview_per_view_attributes]>
];
}
def SPV_C_InputAttachmentArrayDynamicIndexing : I32EnumAttrCase<"InputAttachmentArrayDynamicIndexing", 5303> {
list<I32EnumAttrCase> implies = [SPV_C_InputAttachment];
list<Availability> availability = [
MinVersion<SPV_V_1_5>
];
}
def SPV_C_UniformBufferArrayNonUniformIndexing : I32EnumAttrCase<"UniformBufferArrayNonUniformIndexing", 5306> {
list<I32EnumAttrCase> implies = [SPV_C_ShaderNonUniform];
list<Availability> availability = [
MinVersion<SPV_V_1_5>
];
}
def SPV_C_SampledImageArrayNonUniformIndexing : I32EnumAttrCase<"SampledImageArrayNonUniformIndexing", 5307> {
list<I32EnumAttrCase> implies = [SPV_C_ShaderNonUniform];
list<Availability> availability = [
MinVersion<SPV_V_1_5>
];
}
def SPV_C_StorageBufferArrayNonUniformIndexing : I32EnumAttrCase<"StorageBufferArrayNonUniformIndexing", 5308> {
list<I32EnumAttrCase> implies = [SPV_C_ShaderNonUniform];
list<Availability> availability = [
MinVersion<SPV_V_1_5>
];
}
def SPV_C_StorageImageArrayNonUniformIndexing : I32EnumAttrCase<"StorageImageArrayNonUniformIndexing", 5309> {
list<I32EnumAttrCase> implies = [SPV_C_ShaderNonUniform];
list<Availability> availability = [
MinVersion<SPV_V_1_5>
];
}
def SPV_C_InputAttachmentArrayNonUniformIndexing : I32EnumAttrCase<"InputAttachmentArrayNonUniformIndexing", 5310> {
list<I32EnumAttrCase> implies = [SPV_C_InputAttachment, SPV_C_ShaderNonUniform];
list<Availability> availability = [
MinVersion<SPV_V_1_5>
];
}
def SPV_C_UniformTexelBufferArrayNonUniformIndexing : I32EnumAttrCase<"UniformTexelBufferArrayNonUniformIndexing", 5311> {
list<I32EnumAttrCase> implies = [SPV_C_SampledBuffer, SPV_C_ShaderNonUniform];
list<Availability> availability = [
MinVersion<SPV_V_1_5>
];
}
def SPV_C_StorageTexelBufferArrayNonUniformIndexing : I32EnumAttrCase<"StorageTexelBufferArrayNonUniformIndexing", 5312> {
list<I32EnumAttrCase> implies = [SPV_C_ImageBuffer, SPV_C_ShaderNonUniform];
list<Availability> availability = [
MinVersion<SPV_V_1_5>
];
}
def SPV_C_ShaderViewportIndexLayerEXT : I32EnumAttrCase<"ShaderViewportIndexLayerEXT", 5254> {
list<I32EnumAttrCase> implies = [SPV_C_MultiViewport];
list<Availability> availability = [
Extension<[SPV_EXT_shader_viewport_index_layer]>
];
}
def SPV_C_ShaderViewportMaskNV : I32EnumAttrCase<"ShaderViewportMaskNV", 5255> {
list<I32EnumAttrCase> implies = [SPV_C_ShaderViewportIndexLayerEXT];
list<Availability> availability = [
Extension<[SPV_NV_viewport_array2]>
];
}
def SPV_C_ShaderStereoViewNV : I32EnumAttrCase<"ShaderStereoViewNV", 5259> {
list<I32EnumAttrCase> implies = [SPV_C_ShaderViewportMaskNV];
list<Availability> availability = [
Extension<[SPV_NV_stereo_view_rendering]>
];
}
def SPV_CapabilityAttr :
SPV_I32EnumAttr<"Capability", "valid SPIR-V Capability", [
SPV_C_Matrix, SPV_C_Addresses, SPV_C_Linkage, SPV_C_Kernel, SPV_C_Float16,
SPV_C_Float64, SPV_C_Int64, SPV_C_Groups, SPV_C_Int16, SPV_C_Int8,
SPV_C_Sampled1D, SPV_C_SampledBuffer, SPV_C_GroupNonUniform, SPV_C_ShaderLayer,
SPV_C_ShaderViewportIndex, SPV_C_SubgroupBallotKHR, SPV_C_SubgroupVoteKHR,
SPV_C_StorageBuffer16BitAccess, SPV_C_StoragePushConstant16,
SPV_C_StorageInputOutput16, SPV_C_DeviceGroup, SPV_C_AtomicStorageOps,
SPV_C_SampleMaskPostDepthCoverage, SPV_C_StorageBuffer8BitAccess,
SPV_C_StoragePushConstant8, SPV_C_DenormPreserve, SPV_C_DenormFlushToZero,
SPV_C_SignedZeroInfNanPreserve, SPV_C_RoundingModeRTE, SPV_C_RoundingModeRTZ,
SPV_C_ImageFootprintNV, SPV_C_FragmentBarycentricNV,
SPV_C_ComputeDerivativeGroupQuadsNV, SPV_C_GroupNonUniformPartitionedNV,
SPV_C_VulkanMemoryModel, SPV_C_VulkanMemoryModelDeviceScope,
SPV_C_ComputeDerivativeGroupLinearNV, SPV_C_SubgroupShuffleINTEL,
SPV_C_SubgroupBufferBlockIOINTEL, SPV_C_SubgroupImageBlockIOINTEL,
SPV_C_SubgroupImageMediaBlockIOINTEL, SPV_C_SubgroupAvcMotionEstimationINTEL,
SPV_C_SubgroupAvcMotionEstimationIntraINTEL,
SPV_C_SubgroupAvcMotionEstimationChromaINTEL, SPV_C_Shader, SPV_C_Vector16,
SPV_C_Float16Buffer, SPV_C_Int64Atomics, SPV_C_ImageBasic, SPV_C_Pipes,
SPV_C_DeviceEnqueue, SPV_C_LiteralSampler, SPV_C_GenericPointer, SPV_C_Image1D,
SPV_C_ImageBuffer, SPV_C_NamedBarrier, SPV_C_GroupNonUniformVote,
SPV_C_GroupNonUniformArithmetic, SPV_C_GroupNonUniformBallot,
SPV_C_GroupNonUniformShuffle, SPV_C_GroupNonUniformShuffleRelative,
SPV_C_GroupNonUniformClustered, SPV_C_GroupNonUniformQuad,
SPV_C_StorageUniform16, SPV_C_UniformAndStorageBuffer8BitAccess,
SPV_C_UniformTexelBufferArrayDynamicIndexing, SPV_C_Geometry,
SPV_C_Tessellation, SPV_C_ImageReadWrite, SPV_C_ImageMipmap,
SPV_C_AtomicStorage, 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_SampleRateShading, SPV_C_SampledRect, SPV_C_InputAttachment,
SPV_C_SparseResidency, SPV_C_MinLod, SPV_C_SampledCubeArray,
SPV_C_ImageMSArray, SPV_C_StorageImageExtendedFormats, SPV_C_ImageQuery,
SPV_C_DerivativeControl, SPV_C_InterpolationFunction, SPV_C_TransformFeedback,
SPV_C_StorageImageReadWithoutFormat, SPV_C_StorageImageWriteWithoutFormat,
SPV_C_SubgroupDispatch, SPV_C_PipeStorage, SPV_C_DrawParameters,
SPV_C_MultiView, SPV_C_VariablePointersStorageBuffer, SPV_C_Float16ImageAMD,
SPV_C_ImageGatherBiasLodAMD, SPV_C_FragmentMaskAMD, SPV_C_StencilExportEXT,
SPV_C_ImageReadWriteLodAMD, SPV_C_ShaderClockKHR,
SPV_C_FragmentFullyCoveredEXT, SPV_C_MeshShadingNV, SPV_C_FragmentDensityEXT,
SPV_C_ShaderNonUniform, SPV_C_RuntimeDescriptorArray,
SPV_C_StorageTexelBufferArrayDynamicIndexing, SPV_C_RayTracingNV,
SPV_C_PhysicalStorageBufferAddresses, SPV_C_CooperativeMatrixNV,
SPV_C_FragmentShaderSampleInterlockEXT,
SPV_C_FragmentShaderShadingRateInterlockEXT, SPV_C_ShaderSMBuiltinsNV,
SPV_C_FragmentShaderPixelInterlockEXT, SPV_C_DemoteToHelperInvocationEXT,
SPV_C_IntegerFunctions2INTEL, SPV_C_TessellationPointSize,
SPV_C_GeometryPointSize, SPV_C_ImageCubeArray, SPV_C_ImageRect,
SPV_C_GeometryStreams, SPV_C_MultiViewport, SPV_C_VariablePointers,
SPV_C_SampleMaskOverrideCoverageNV, SPV_C_GeometryShaderPassthroughNV,
SPV_C_PerViewAttributesNV, SPV_C_InputAttachmentArrayDynamicIndexing,
SPV_C_UniformBufferArrayNonUniformIndexing,
SPV_C_SampledImageArrayNonUniformIndexing,
SPV_C_StorageBufferArrayNonUniformIndexing,
SPV_C_StorageImageArrayNonUniformIndexing,
SPV_C_InputAttachmentArrayNonUniformIndexing,
SPV_C_UniformTexelBufferArrayNonUniformIndexing,
SPV_C_StorageTexelBufferArrayNonUniformIndexing,
SPV_C_ShaderViewportIndexLayerEXT, SPV_C_ShaderViewportMaskNV,
SPV_C_ShaderStereoViewNV
]>;
def SPV_AM_Logical : I32EnumAttrCase<"Logical", 0>;
def SPV_AM_Physical32 : I32EnumAttrCase<"Physical32", 1> {
list<Availability> availability = [
Capability<[SPV_C_Addresses]>
];
}
def SPV_AM_Physical64 : I32EnumAttrCase<"Physical64", 2> {
list<Availability> availability = [
Capability<[SPV_C_Addresses]>
];
}
def SPV_AM_PhysicalStorageBuffer64 : I32EnumAttrCase<"PhysicalStorageBuffer64", 5348> {
list<Availability> availability = [
Extension<[SPV_EXT_physical_storage_buffer, SPV_KHR_physical_storage_buffer]>,
Capability<[SPV_C_PhysicalStorageBufferAddresses]>
];
}
def SPV_AddressingModelAttr :
SPV_I32EnumAttr<"AddressingModel", "valid SPIR-V AddressingModel", [
SPV_AM_Logical, SPV_AM_Physical32, SPV_AM_Physical64,
SPV_AM_PhysicalStorageBuffer64
]>;
def SPV_BI_Position : I32EnumAttrCase<"Position", 0> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_BI_PointSize : I32EnumAttrCase<"PointSize", 1> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_BI_ClipDistance : I32EnumAttrCase<"ClipDistance", 3> {
list<Availability> availability = [
Capability<[SPV_C_ClipDistance]>
];
}
def SPV_BI_CullDistance : I32EnumAttrCase<"CullDistance", 4> {
list<Availability> availability = [
Capability<[SPV_C_CullDistance]>
];
}
def SPV_BI_VertexId : I32EnumAttrCase<"VertexId", 5> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_BI_InstanceId : I32EnumAttrCase<"InstanceId", 6> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_BI_PrimitiveId : I32EnumAttrCase<"PrimitiveId", 7> {
list<Availability> availability = [
Capability<[SPV_C_Geometry, SPV_C_RayTracingNV, SPV_C_Tessellation]>
];
}
def SPV_BI_InvocationId : I32EnumAttrCase<"InvocationId", 8> {
list<Availability> availability = [
Capability<[SPV_C_Geometry, SPV_C_Tessellation]>
];
}
def SPV_BI_Layer : I32EnumAttrCase<"Layer", 9> {
list<Availability> availability = [
Capability<[SPV_C_Geometry, SPV_C_ShaderLayer, SPV_C_ShaderViewportIndexLayerEXT]>
];
}
def SPV_BI_ViewportIndex : I32EnumAttrCase<"ViewportIndex", 10> {
list<Availability> availability = [
Capability<[SPV_C_MultiViewport, SPV_C_ShaderViewportIndex, SPV_C_ShaderViewportIndexLayerEXT]>
];
}
def SPV_BI_TessLevelOuter : I32EnumAttrCase<"TessLevelOuter", 11> {
list<Availability> availability = [
Capability<[SPV_C_Tessellation]>
];
}
def SPV_BI_TessLevelInner : I32EnumAttrCase<"TessLevelInner", 12> {
list<Availability> availability = [
Capability<[SPV_C_Tessellation]>
];
}
def SPV_BI_TessCoord : I32EnumAttrCase<"TessCoord", 13> {
list<Availability> availability = [
Capability<[SPV_C_Tessellation]>
];
}
def SPV_BI_PatchVertices : I32EnumAttrCase<"PatchVertices", 14> {
list<Availability> availability = [
Capability<[SPV_C_Tessellation]>
];
}
def SPV_BI_FragCoord : I32EnumAttrCase<"FragCoord", 15> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_BI_PointCoord : I32EnumAttrCase<"PointCoord", 16> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_BI_FrontFacing : I32EnumAttrCase<"FrontFacing", 17> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_BI_SampleId : I32EnumAttrCase<"SampleId", 18> {
list<Availability> availability = [
Capability<[SPV_C_SampleRateShading]>
];
}
def SPV_BI_SamplePosition : I32EnumAttrCase<"SamplePosition", 19> {
list<Availability> availability = [
Capability<[SPV_C_SampleRateShading]>
];
}
def SPV_BI_SampleMask : I32EnumAttrCase<"SampleMask", 20> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_BI_FragDepth : I32EnumAttrCase<"FragDepth", 22> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_BI_HelperInvocation : I32EnumAttrCase<"HelperInvocation", 23> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
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> {
list<Availability> availability = [
Capability<[SPV_C_Kernel]>
];
}
def SPV_BI_GlobalSize : I32EnumAttrCase<"GlobalSize", 31> {
list<Availability> availability = [
Capability<[SPV_C_Kernel]>
];
}
def SPV_BI_EnqueuedWorkgroupSize : I32EnumAttrCase<"EnqueuedWorkgroupSize", 32> {
list<Availability> availability = [
Capability<[SPV_C_Kernel]>
];
}
def SPV_BI_GlobalOffset : I32EnumAttrCase<"GlobalOffset", 33> {
list<Availability> availability = [
Capability<[SPV_C_Kernel]>
];
}
def SPV_BI_GlobalLinearId : I32EnumAttrCase<"GlobalLinearId", 34> {
list<Availability> availability = [
Capability<[SPV_C_Kernel]>
];
}
def SPV_BI_SubgroupSize : I32EnumAttrCase<"SubgroupSize", 36> {
list<Availability> availability = [
Capability<[SPV_C_GroupNonUniform, SPV_C_Kernel, SPV_C_SubgroupBallotKHR]>
];
}
def SPV_BI_SubgroupMaxSize : I32EnumAttrCase<"SubgroupMaxSize", 37> {
list<Availability> availability = [
Capability<[SPV_C_Kernel]>
];
}
def SPV_BI_NumSubgroups : I32EnumAttrCase<"NumSubgroups", 38> {
list<Availability> availability = [
Capability<[SPV_C_GroupNonUniform, SPV_C_Kernel]>
];
}
def SPV_BI_NumEnqueuedSubgroups : I32EnumAttrCase<"NumEnqueuedSubgroups", 39> {
list<Availability> availability = [
Capability<[SPV_C_Kernel]>
];
}
def SPV_BI_SubgroupId : I32EnumAttrCase<"SubgroupId", 40> {
list<Availability> availability = [
Capability<[SPV_C_GroupNonUniform, SPV_C_Kernel]>
];
}
def SPV_BI_SubgroupLocalInvocationId : I32EnumAttrCase<"SubgroupLocalInvocationId", 41> {
list<Availability> availability = [
Capability<[SPV_C_GroupNonUniform, SPV_C_Kernel, SPV_C_SubgroupBallotKHR]>
];
}
def SPV_BI_VertexIndex : I32EnumAttrCase<"VertexIndex", 42> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_BI_InstanceIndex : I32EnumAttrCase<"InstanceIndex", 43> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_BI_SubgroupEqMask : I32EnumAttrCase<"SubgroupEqMask", 4416> {
list<Availability> availability = [
MinVersion<SPV_V_1_3>,
Capability<[SPV_C_GroupNonUniformBallot, SPV_C_SubgroupBallotKHR]>
];
}
def SPV_BI_SubgroupGeMask : I32EnumAttrCase<"SubgroupGeMask", 4417> {
list<Availability> availability = [
MinVersion<SPV_V_1_3>,
Capability<[SPV_C_GroupNonUniformBallot, SPV_C_SubgroupBallotKHR]>
];
}
def SPV_BI_SubgroupGtMask : I32EnumAttrCase<"SubgroupGtMask", 4418> {
list<Availability> availability = [
MinVersion<SPV_V_1_3>,
Capability<[SPV_C_GroupNonUniformBallot, SPV_C_SubgroupBallotKHR]>
];
}
def SPV_BI_SubgroupLeMask : I32EnumAttrCase<"SubgroupLeMask", 4419> {
list<Availability> availability = [
MinVersion<SPV_V_1_3>,
Capability<[SPV_C_GroupNonUniformBallot, SPV_C_SubgroupBallotKHR]>
];
}
def SPV_BI_SubgroupLtMask : I32EnumAttrCase<"SubgroupLtMask", 4420> {
list<Availability> availability = [
MinVersion<SPV_V_1_3>,
Capability<[SPV_C_GroupNonUniformBallot, SPV_C_SubgroupBallotKHR]>
];
}
def SPV_BI_BaseVertex : I32EnumAttrCase<"BaseVertex", 4424> {
list<Availability> availability = [
Extension<[SPV_KHR_shader_draw_parameters]>,
Capability<[SPV_C_DrawParameters]>
];
}
def SPV_BI_BaseInstance : I32EnumAttrCase<"BaseInstance", 4425> {
list<Availability> availability = [
Extension<[SPV_KHR_shader_draw_parameters]>,
Capability<[SPV_C_DrawParameters]>
];
}
def SPV_BI_DrawIndex : I32EnumAttrCase<"DrawIndex", 4426> {
list<Availability> availability = [
Extension<[SPV_KHR_shader_draw_parameters, SPV_NV_mesh_shader]>,
Capability<[SPV_C_DrawParameters, SPV_C_MeshShadingNV]>
];
}
def SPV_BI_DeviceIndex : I32EnumAttrCase<"DeviceIndex", 4438> {
list<Availability> availability = [
Extension<[SPV_KHR_device_group]>,
Capability<[SPV_C_DeviceGroup]>
];
}
def SPV_BI_ViewIndex : I32EnumAttrCase<"ViewIndex", 4440> {
list<Availability> availability = [
Extension<[SPV_KHR_multiview]>,
Capability<[SPV_C_MultiView]>
];
}
def SPV_BI_BaryCoordNoPerspAMD : I32EnumAttrCase<"BaryCoordNoPerspAMD", 4992> {
list<Availability> availability = [
Extension<[SPV_AMD_shader_explicit_vertex_parameter]>
];
}
def SPV_BI_BaryCoordNoPerspCentroidAMD : I32EnumAttrCase<"BaryCoordNoPerspCentroidAMD", 4993> {
list<Availability> availability = [
Extension<[SPV_AMD_shader_explicit_vertex_parameter]>
];
}
def SPV_BI_BaryCoordNoPerspSampleAMD : I32EnumAttrCase<"BaryCoordNoPerspSampleAMD", 4994> {
list<Availability> availability = [
Extension<[SPV_AMD_shader_explicit_vertex_parameter]>
];
}
def SPV_BI_BaryCoordSmoothAMD : I32EnumAttrCase<"BaryCoordSmoothAMD", 4995> {
list<Availability> availability = [
Extension<[SPV_AMD_shader_explicit_vertex_parameter]>
];
}
def SPV_BI_BaryCoordSmoothCentroidAMD : I32EnumAttrCase<"BaryCoordSmoothCentroidAMD", 4996> {
list<Availability> availability = [
Extension<[SPV_AMD_shader_explicit_vertex_parameter]>
];
}
def SPV_BI_BaryCoordSmoothSampleAMD : I32EnumAttrCase<"BaryCoordSmoothSampleAMD", 4997> {
list<Availability> availability = [
Extension<[SPV_AMD_shader_explicit_vertex_parameter]>
];
}
def SPV_BI_BaryCoordPullModelAMD : I32EnumAttrCase<"BaryCoordPullModelAMD", 4998> {
list<Availability> availability = [
Extension<[SPV_AMD_shader_explicit_vertex_parameter]>
];
}
def SPV_BI_FragStencilRefEXT : I32EnumAttrCase<"FragStencilRefEXT", 5014> {
list<Availability> availability = [
Extension<[SPV_EXT_shader_stencil_export]>,
Capability<[SPV_C_StencilExportEXT]>
];
}
def SPV_BI_ViewportMaskNV : I32EnumAttrCase<"ViewportMaskNV", 5253> {
list<Availability> availability = [
Extension<[SPV_NV_mesh_shader, SPV_NV_viewport_array2]>,
Capability<[SPV_C_MeshShadingNV, SPV_C_ShaderViewportMaskNV]>
];
}
def SPV_BI_SecondaryPositionNV : I32EnumAttrCase<"SecondaryPositionNV", 5257> {
list<Availability> availability = [
Extension<[SPV_NV_stereo_view_rendering]>,
Capability<[SPV_C_ShaderStereoViewNV]>
];
}
def SPV_BI_SecondaryViewportMaskNV : I32EnumAttrCase<"SecondaryViewportMaskNV", 5258> {
list<Availability> availability = [
Extension<[SPV_NV_stereo_view_rendering]>,
Capability<[SPV_C_ShaderStereoViewNV]>
];
}
def SPV_BI_PositionPerViewNV : I32EnumAttrCase<"PositionPerViewNV", 5261> {
list<Availability> availability = [
Extension<[SPV_NVX_multiview_per_view_attributes, SPV_NV_mesh_shader]>,
Capability<[SPV_C_MeshShadingNV, SPV_C_PerViewAttributesNV]>
];
}
def SPV_BI_ViewportMaskPerViewNV : I32EnumAttrCase<"ViewportMaskPerViewNV", 5262> {
list<Availability> availability = [
Extension<[SPV_NVX_multiview_per_view_attributes, SPV_NV_mesh_shader]>,
Capability<[SPV_C_MeshShadingNV, SPV_C_PerViewAttributesNV]>
];
}
def SPV_BI_FullyCoveredEXT : I32EnumAttrCase<"FullyCoveredEXT", 5264> {
list<Availability> availability = [
Extension<[SPV_EXT_fragment_fully_covered]>,
Capability<[SPV_C_FragmentFullyCoveredEXT]>
];
}
def SPV_BI_TaskCountNV : I32EnumAttrCase<"TaskCountNV", 5274> {
list<Availability> availability = [
Extension<[SPV_NV_mesh_shader]>,
Capability<[SPV_C_MeshShadingNV]>
];
}
def SPV_BI_PrimitiveCountNV : I32EnumAttrCase<"PrimitiveCountNV", 5275> {
list<Availability> availability = [
Extension<[SPV_NV_mesh_shader]>,
Capability<[SPV_C_MeshShadingNV]>
];
}
def SPV_BI_PrimitiveIndicesNV : I32EnumAttrCase<"PrimitiveIndicesNV", 5276> {
list<Availability> availability = [
Extension<[SPV_NV_mesh_shader]>,
Capability<[SPV_C_MeshShadingNV]>
];
}
def SPV_BI_ClipDistancePerViewNV : I32EnumAttrCase<"ClipDistancePerViewNV", 5277> {
list<Availability> availability = [
Extension<[SPV_NV_mesh_shader]>,
Capability<[SPV_C_MeshShadingNV]>
];
}
def SPV_BI_CullDistancePerViewNV : I32EnumAttrCase<"CullDistancePerViewNV", 5278> {
list<Availability> availability = [
Extension<[SPV_NV_mesh_shader]>,
Capability<[SPV_C_MeshShadingNV]>
];
}
def SPV_BI_LayerPerViewNV : I32EnumAttrCase<"LayerPerViewNV", 5279> {
list<Availability> availability = [
Extension<[SPV_NV_mesh_shader]>,
Capability<[SPV_C_MeshShadingNV]>
];
}
def SPV_BI_MeshViewCountNV : I32EnumAttrCase<"MeshViewCountNV", 5280> {
list<Availability> availability = [
Extension<[SPV_NV_mesh_shader]>,
Capability<[SPV_C_MeshShadingNV]>
];
}
def SPV_BI_MeshViewIndicesNV : I32EnumAttrCase<"MeshViewIndicesNV", 5281> {
list<Availability> availability = [
Extension<[SPV_NV_mesh_shader]>,
Capability<[SPV_C_MeshShadingNV]>
];
}
def SPV_BI_BaryCoordNV : I32EnumAttrCase<"BaryCoordNV", 5286> {
list<Availability> availability = [
Extension<[SPV_NV_fragment_shader_barycentric]>,
Capability<[SPV_C_FragmentBarycentricNV]>
];
}
def SPV_BI_BaryCoordNoPerspNV : I32EnumAttrCase<"BaryCoordNoPerspNV", 5287> {
list<Availability> availability = [
Extension<[SPV_NV_fragment_shader_barycentric]>,
Capability<[SPV_C_FragmentBarycentricNV]>
];
}
def SPV_BI_FragSizeEXT : I32EnumAttrCase<"FragSizeEXT", 5292> {
list<Availability> availability = [
Extension<[SPV_EXT_fragment_invocation_density, SPV_NV_shading_rate]>,
Capability<[SPV_C_FragmentDensityEXT]>
];
}
def SPV_BI_FragInvocationCountEXT : I32EnumAttrCase<"FragInvocationCountEXT", 5293> {
list<Availability> availability = [
Extension<[SPV_EXT_fragment_invocation_density, SPV_NV_shading_rate]>,
Capability<[SPV_C_FragmentDensityEXT]>
];
}
def SPV_BI_LaunchIdNV : I32EnumAttrCase<"LaunchIdNV", 5319> {
list<Availability> availability = [
Extension<[SPV_NV_ray_tracing]>,
Capability<[SPV_C_RayTracingNV]>
];
}
def SPV_BI_LaunchSizeNV : I32EnumAttrCase<"LaunchSizeNV", 5320> {
list<Availability> availability = [
Extension<[SPV_NV_ray_tracing]>,
Capability<[SPV_C_RayTracingNV]>
];
}
def SPV_BI_WorldRayOriginNV : I32EnumAttrCase<"WorldRayOriginNV", 5321> {
list<Availability> availability = [
Extension<[SPV_NV_ray_tracing]>,
Capability<[SPV_C_RayTracingNV]>
];
}
def SPV_BI_WorldRayDirectionNV : I32EnumAttrCase<"WorldRayDirectionNV", 5322> {
list<Availability> availability = [
Extension<[SPV_NV_ray_tracing]>,
Capability<[SPV_C_RayTracingNV]>
];
}
def SPV_BI_ObjectRayOriginNV : I32EnumAttrCase<"ObjectRayOriginNV", 5323> {
list<Availability> availability = [
Extension<[SPV_NV_ray_tracing]>,
Capability<[SPV_C_RayTracingNV]>
];
}
def SPV_BI_ObjectRayDirectionNV : I32EnumAttrCase<"ObjectRayDirectionNV", 5324> {
list<Availability> availability = [
Extension<[SPV_NV_ray_tracing]>,
Capability<[SPV_C_RayTracingNV]>
];
}
def SPV_BI_RayTminNV : I32EnumAttrCase<"RayTminNV", 5325> {
list<Availability> availability = [
Extension<[SPV_NV_ray_tracing]>,
Capability<[SPV_C_RayTracingNV]>
];
}
def SPV_BI_RayTmaxNV : I32EnumAttrCase<"RayTmaxNV", 5326> {
list<Availability> availability = [
Extension<[SPV_NV_ray_tracing]>,
Capability<[SPV_C_RayTracingNV]>
];
}
def SPV_BI_InstanceCustomIndexNV : I32EnumAttrCase<"InstanceCustomIndexNV", 5327> {
list<Availability> availability = [
Extension<[SPV_NV_ray_tracing]>,
Capability<[SPV_C_RayTracingNV]>
];
}
def SPV_BI_ObjectToWorldNV : I32EnumAttrCase<"ObjectToWorldNV", 5330> {
list<Availability> availability = [
Extension<[SPV_NV_ray_tracing]>,
Capability<[SPV_C_RayTracingNV]>
];
}
def SPV_BI_WorldToObjectNV : I32EnumAttrCase<"WorldToObjectNV", 5331> {
list<Availability> availability = [
Extension<[SPV_NV_ray_tracing]>,
Capability<[SPV_C_RayTracingNV]>
];
}
def SPV_BI_HitTNV : I32EnumAttrCase<"HitTNV", 5332> {
list<Availability> availability = [
Extension<[SPV_NV_ray_tracing]>,
Capability<[SPV_C_RayTracingNV]>
];
}
def SPV_BI_HitKindNV : I32EnumAttrCase<"HitKindNV", 5333> {
list<Availability> availability = [
Extension<[SPV_NV_ray_tracing]>,
Capability<[SPV_C_RayTracingNV]>
];
}
def SPV_BI_IncomingRayFlagsNV : I32EnumAttrCase<"IncomingRayFlagsNV", 5351> {
list<Availability> availability = [
Extension<[SPV_NV_ray_tracing]>,
Capability<[SPV_C_RayTracingNV]>
];
}
def SPV_BI_WarpsPerSMNV : I32EnumAttrCase<"WarpsPerSMNV", 5374> {
list<Availability> availability = [
Extension<[SPV_NV_shader_sm_builtins]>,
Capability<[SPV_C_ShaderSMBuiltinsNV]>
];
}
def SPV_BI_SMCountNV : I32EnumAttrCase<"SMCountNV", 5375> {
list<Availability> availability = [
Extension<[SPV_NV_shader_sm_builtins]>,
Capability<[SPV_C_ShaderSMBuiltinsNV]>
];
}
def SPV_BI_WarpIDNV : I32EnumAttrCase<"WarpIDNV", 5376> {
list<Availability> availability = [
Extension<[SPV_NV_shader_sm_builtins]>,
Capability<[SPV_C_ShaderSMBuiltinsNV]>
];
}
def SPV_BI_SMIDNV : I32EnumAttrCase<"SMIDNV", 5377> {
list<Availability> availability = [
Extension<[SPV_NV_shader_sm_builtins]>,
Capability<[SPV_C_ShaderSMBuiltinsNV]>
];
}
def SPV_BuiltInAttr :
SPV_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
]>;
def SPV_D_RelaxedPrecision : I32EnumAttrCase<"RelaxedPrecision", 0> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_D_SpecId : I32EnumAttrCase<"SpecId", 1> {
list<Availability> availability = [
Capability<[SPV_C_Kernel, SPV_C_Shader]>
];
}
def SPV_D_Block : I32EnumAttrCase<"Block", 2> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_D_BufferBlock : I32EnumAttrCase<"BufferBlock", 3> {
list<Availability> availability = [
MaxVersion<SPV_V_1_3>,
Capability<[SPV_C_Shader]>
];
}
def SPV_D_RowMajor : I32EnumAttrCase<"RowMajor", 4> {
list<Availability> availability = [
Capability<[SPV_C_Matrix]>
];
}
def SPV_D_ColMajor : I32EnumAttrCase<"ColMajor", 5> {
list<Availability> availability = [
Capability<[SPV_C_Matrix]>
];
}
def SPV_D_ArrayStride : I32EnumAttrCase<"ArrayStride", 6> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_D_MatrixStride : I32EnumAttrCase<"MatrixStride", 7> {
list<Availability> availability = [
Capability<[SPV_C_Matrix]>
];
}
def SPV_D_GLSLShared : I32EnumAttrCase<"GLSLShared", 8> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_D_GLSLPacked : I32EnumAttrCase<"GLSLPacked", 9> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_D_CPacked : I32EnumAttrCase<"CPacked", 10> {
list<Availability> availability = [
Capability<[SPV_C_Kernel]>
];
}
def SPV_D_BuiltIn : I32EnumAttrCase<"BuiltIn", 11>;
def SPV_D_NoPerspective : I32EnumAttrCase<"NoPerspective", 13> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_D_Flat : I32EnumAttrCase<"Flat", 14> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_D_Patch : I32EnumAttrCase<"Patch", 15> {
list<Availability> availability = [
Capability<[SPV_C_Tessellation]>
];
}
def SPV_D_Centroid : I32EnumAttrCase<"Centroid", 16> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_D_Sample : I32EnumAttrCase<"Sample", 17> {
list<Availability> availability = [
Capability<[SPV_C_SampleRateShading]>
];
}
def SPV_D_Invariant : I32EnumAttrCase<"Invariant", 18> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
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> {
list<Availability> availability = [
Capability<[SPV_C_Kernel]>
];
}
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> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_D_UniformId : I32EnumAttrCase<"UniformId", 27> {
list<Availability> availability = [
MinVersion<SPV_V_1_4>,
Capability<[SPV_C_Shader]>
];
}
def SPV_D_SaturatedConversion : I32EnumAttrCase<"SaturatedConversion", 28> {
list<Availability> availability = [
Capability<[SPV_C_Kernel]>
];
}
def SPV_D_Stream : I32EnumAttrCase<"Stream", 29> {
list<Availability> availability = [
Capability<[SPV_C_GeometryStreams]>
];
}
def SPV_D_Location : I32EnumAttrCase<"Location", 30> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_D_Component : I32EnumAttrCase<"Component", 31> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_D_Index : I32EnumAttrCase<"Index", 32> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_D_Binding : I32EnumAttrCase<"Binding", 33> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_D_DescriptorSet : I32EnumAttrCase<"DescriptorSet", 34> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_D_Offset : I32EnumAttrCase<"Offset", 35> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_D_XfbBuffer : I32EnumAttrCase<"XfbBuffer", 36> {
list<Availability> availability = [
Capability<[SPV_C_TransformFeedback]>
];
}
def SPV_D_XfbStride : I32EnumAttrCase<"XfbStride", 37> {
list<Availability> availability = [
Capability<[SPV_C_TransformFeedback]>
];
}
def SPV_D_FuncParamAttr : I32EnumAttrCase<"FuncParamAttr", 38> {
list<Availability> availability = [
Capability<[SPV_C_Kernel]>
];
}
def SPV_D_FPRoundingMode : I32EnumAttrCase<"FPRoundingMode", 39>;
def SPV_D_FPFastMathMode : I32EnumAttrCase<"FPFastMathMode", 40> {
list<Availability> availability = [
Capability<[SPV_C_Kernel]>
];
}
def SPV_D_LinkageAttributes : I32EnumAttrCase<"LinkageAttributes", 41> {
list<Availability> availability = [
Capability<[SPV_C_Linkage]>
];
}
def SPV_D_NoContraction : I32EnumAttrCase<"NoContraction", 42> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_D_InputAttachmentIndex : I32EnumAttrCase<"InputAttachmentIndex", 43> {
list<Availability> availability = [
Capability<[SPV_C_InputAttachment]>
];
}
def SPV_D_Alignment : I32EnumAttrCase<"Alignment", 44> {
list<Availability> availability = [
Capability<[SPV_C_Kernel]>
];
}
def SPV_D_MaxByteOffset : I32EnumAttrCase<"MaxByteOffset", 45> {
list<Availability> availability = [
MinVersion<SPV_V_1_1>,
Capability<[SPV_C_Addresses]>
];
}
def SPV_D_AlignmentId : I32EnumAttrCase<"AlignmentId", 46> {
list<Availability> availability = [
MinVersion<SPV_V_1_2>,
Capability<[SPV_C_Kernel]>
];
}
def SPV_D_MaxByteOffsetId : I32EnumAttrCase<"MaxByteOffsetId", 47> {
list<Availability> availability = [
MinVersion<SPV_V_1_2>,
Capability<[SPV_C_Addresses]>
];
}
def SPV_D_NoSignedWrap : I32EnumAttrCase<"NoSignedWrap", 4469> {
list<Availability> availability = [
Extension<[SPV_KHR_no_integer_wrap_decoration]>
];
}
def SPV_D_NoUnsignedWrap : I32EnumAttrCase<"NoUnsignedWrap", 4470> {
list<Availability> availability = [
Extension<[SPV_KHR_no_integer_wrap_decoration]>
];
}
def SPV_D_ExplicitInterpAMD : I32EnumAttrCase<"ExplicitInterpAMD", 4999> {
list<Availability> availability = [
Extension<[SPV_AMD_shader_explicit_vertex_parameter]>
];
}
def SPV_D_OverrideCoverageNV : I32EnumAttrCase<"OverrideCoverageNV", 5248> {
list<Availability> availability = [
Extension<[SPV_NV_sample_mask_override_coverage]>,
Capability<[SPV_C_SampleMaskOverrideCoverageNV]>
];
}
def SPV_D_PassthroughNV : I32EnumAttrCase<"PassthroughNV", 5250> {
list<Availability> availability = [
Extension<[SPV_NV_geometry_shader_passthrough]>,
Capability<[SPV_C_GeometryShaderPassthroughNV]>
];
}
def SPV_D_ViewportRelativeNV : I32EnumAttrCase<"ViewportRelativeNV", 5252> {
list<Availability> availability = [
Capability<[SPV_C_ShaderViewportMaskNV]>
];
}
def SPV_D_SecondaryViewportRelativeNV : I32EnumAttrCase<"SecondaryViewportRelativeNV", 5256> {
list<Availability> availability = [
Extension<[SPV_NV_stereo_view_rendering]>,
Capability<[SPV_C_ShaderStereoViewNV]>
];
}
def SPV_D_PerPrimitiveNV : I32EnumAttrCase<"PerPrimitiveNV", 5271> {
list<Availability> availability = [
Extension<[SPV_NV_mesh_shader]>,
Capability<[SPV_C_MeshShadingNV]>
];
}
def SPV_D_PerViewNV : I32EnumAttrCase<"PerViewNV", 5272> {
list<Availability> availability = [
Extension<[SPV_NV_mesh_shader]>,
Capability<[SPV_C_MeshShadingNV]>
];
}
def SPV_D_PerTaskNV : I32EnumAttrCase<"PerTaskNV", 5273> {
list<Availability> availability = [
Extension<[SPV_NV_mesh_shader]>,
Capability<[SPV_C_MeshShadingNV]>
];
}
def SPV_D_PerVertexNV : I32EnumAttrCase<"PerVertexNV", 5285> {
list<Availability> availability = [
Extension<[SPV_NV_fragment_shader_barycentric]>,
Capability<[SPV_C_FragmentBarycentricNV]>
];
}
def SPV_D_NonUniform : I32EnumAttrCase<"NonUniform", 5300> {
list<Availability> availability = [
MinVersion<SPV_V_1_5>,
Capability<[SPV_C_ShaderNonUniform]>
];
}
def SPV_D_RestrictPointer : I32EnumAttrCase<"RestrictPointer", 5355> {
list<Availability> availability = [
Extension<[SPV_EXT_physical_storage_buffer, SPV_KHR_physical_storage_buffer]>,
Capability<[SPV_C_PhysicalStorageBufferAddresses]>
];
}
def SPV_D_AliasedPointer : I32EnumAttrCase<"AliasedPointer", 5356> {
list<Availability> availability = [
Extension<[SPV_EXT_physical_storage_buffer, SPV_KHR_physical_storage_buffer]>,
Capability<[SPV_C_PhysicalStorageBufferAddresses]>
];
}
def SPV_D_CounterBuffer : I32EnumAttrCase<"CounterBuffer", 5634> {
list<Availability> availability = [
MinVersion<SPV_V_1_4>
];
}
def SPV_D_UserSemantic : I32EnumAttrCase<"UserSemantic", 5635> {
list<Availability> availability = [
MinVersion<SPV_V_1_4>
];
}
def SPV_D_UserTypeGOOGLE : I32EnumAttrCase<"UserTypeGOOGLE", 5636> {
list<Availability> availability = [
Extension<[SPV_GOOGLE_user_type]>
];
}
def SPV_DecorationAttr :
SPV_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
]>;
def SPV_D_1D : I32EnumAttrCase<"Dim1D", 0> {
list<Availability> availability = [
Capability<[SPV_C_Image1D, SPV_C_Sampled1D]>
];
}
def SPV_D_2D : I32EnumAttrCase<"Dim2D", 1> {
list<Availability> availability = [
Capability<[SPV_C_ImageMSArray, SPV_C_Kernel, SPV_C_Shader]>
];
}
def SPV_D_3D : I32EnumAttrCase<"Dim3D", 2>;
def SPV_D_Cube : I32EnumAttrCase<"Cube", 3> {
list<Availability> availability = [
Capability<[SPV_C_ImageCubeArray, SPV_C_Shader]>
];
}
def SPV_D_Rect : I32EnumAttrCase<"Rect", 4> {
list<Availability> availability = [
Capability<[SPV_C_ImageRect, SPV_C_SampledRect]>
];
}
def SPV_D_Buffer : I32EnumAttrCase<"Buffer", 5> {
list<Availability> availability = [
Capability<[SPV_C_ImageBuffer, SPV_C_SampledBuffer]>
];
}
def SPV_D_SubpassData : I32EnumAttrCase<"SubpassData", 6> {
list<Availability> availability = [
Capability<[SPV_C_InputAttachment]>
];
}
def SPV_DimAttr :
SPV_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
]>;
def SPV_EM_Invocations : I32EnumAttrCase<"Invocations", 0> {
list<Availability> availability = [
Capability<[SPV_C_Geometry]>
];
}
def SPV_EM_SpacingEqual : I32EnumAttrCase<"SpacingEqual", 1> {
list<Availability> availability = [
Capability<[SPV_C_Tessellation]>
];
}
def SPV_EM_SpacingFractionalEven : I32EnumAttrCase<"SpacingFractionalEven", 2> {
list<Availability> availability = [
Capability<[SPV_C_Tessellation]>
];
}
def SPV_EM_SpacingFractionalOdd : I32EnumAttrCase<"SpacingFractionalOdd", 3> {
list<Availability> availability = [
Capability<[SPV_C_Tessellation]>
];
}
def SPV_EM_VertexOrderCw : I32EnumAttrCase<"VertexOrderCw", 4> {
list<Availability> availability = [
Capability<[SPV_C_Tessellation]>
];
}
def SPV_EM_VertexOrderCcw : I32EnumAttrCase<"VertexOrderCcw", 5> {
list<Availability> availability = [
Capability<[SPV_C_Tessellation]>
];
}
def SPV_EM_PixelCenterInteger : I32EnumAttrCase<"PixelCenterInteger", 6> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_EM_OriginUpperLeft : I32EnumAttrCase<"OriginUpperLeft", 7> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_EM_OriginLowerLeft : I32EnumAttrCase<"OriginLowerLeft", 8> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_EM_EarlyFragmentTests : I32EnumAttrCase<"EarlyFragmentTests", 9> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_EM_PointMode : I32EnumAttrCase<"PointMode", 10> {
list<Availability> availability = [
Capability<[SPV_C_Tessellation]>
];
}
def SPV_EM_Xfb : I32EnumAttrCase<"Xfb", 11> {
list<Availability> availability = [
Capability<[SPV_C_TransformFeedback]>
];
}
def SPV_EM_DepthReplacing : I32EnumAttrCase<"DepthReplacing", 12> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_EM_DepthGreater : I32EnumAttrCase<"DepthGreater", 14> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_EM_DepthLess : I32EnumAttrCase<"DepthLess", 15> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_EM_DepthUnchanged : I32EnumAttrCase<"DepthUnchanged", 16> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_EM_LocalSize : I32EnumAttrCase<"LocalSize", 17>;
def SPV_EM_LocalSizeHint : I32EnumAttrCase<"LocalSizeHint", 18> {
list<Availability> availability = [
Capability<[SPV_C_Kernel]>
];
}
def SPV_EM_InputPoints : I32EnumAttrCase<"InputPoints", 19> {
list<Availability> availability = [
Capability<[SPV_C_Geometry]>
];
}
def SPV_EM_InputLines : I32EnumAttrCase<"InputLines", 20> {
list<Availability> availability = [
Capability<[SPV_C_Geometry]>
];
}
def SPV_EM_InputLinesAdjacency : I32EnumAttrCase<"InputLinesAdjacency", 21> {
list<Availability> availability = [
Capability<[SPV_C_Geometry]>
];
}
def SPV_EM_Triangles : I32EnumAttrCase<"Triangles", 22> {
list<Availability> availability = [
Capability<[SPV_C_Geometry, SPV_C_Tessellation]>
];
}
def SPV_EM_InputTrianglesAdjacency : I32EnumAttrCase<"InputTrianglesAdjacency", 23> {
list<Availability> availability = [
Capability<[SPV_C_Geometry]>
];
}
def SPV_EM_Quads : I32EnumAttrCase<"Quads", 24> {
list<Availability> availability = [
Capability<[SPV_C_Tessellation]>
];
}
def SPV_EM_Isolines : I32EnumAttrCase<"Isolines", 25> {
list<Availability> availability = [
Capability<[SPV_C_Tessellation]>
];
}
def SPV_EM_OutputVertices : I32EnumAttrCase<"OutputVertices", 26> {
list<Availability> availability = [
Capability<[SPV_C_Geometry, SPV_C_MeshShadingNV, SPV_C_Tessellation]>
];
}
def SPV_EM_OutputPoints : I32EnumAttrCase<"OutputPoints", 27> {
list<Availability> availability = [
Capability<[SPV_C_Geometry, SPV_C_MeshShadingNV]>
];
}
def SPV_EM_OutputLineStrip : I32EnumAttrCase<"OutputLineStrip", 28> {
list<Availability> availability = [
Capability<[SPV_C_Geometry]>
];
}
def SPV_EM_OutputTriangleStrip : I32EnumAttrCase<"OutputTriangleStrip", 29> {
list<Availability> availability = [
Capability<[SPV_C_Geometry]>
];
}
def SPV_EM_VecTypeHint : I32EnumAttrCase<"VecTypeHint", 30> {
list<Availability> availability = [
Capability<[SPV_C_Kernel]>
];
}
def SPV_EM_ContractionOff : I32EnumAttrCase<"ContractionOff", 31> {
list<Availability> availability = [
Capability<[SPV_C_Kernel]>
];
}
def SPV_EM_Initializer : I32EnumAttrCase<"Initializer", 33> {
list<Availability> availability = [
MinVersion<SPV_V_1_1>,
Capability<[SPV_C_Kernel]>
];
}
def SPV_EM_Finalizer : I32EnumAttrCase<"Finalizer", 34> {
list<Availability> availability = [
MinVersion<SPV_V_1_1>,
Capability<[SPV_C_Kernel]>
];
}
def SPV_EM_SubgroupSize : I32EnumAttrCase<"SubgroupSize", 35> {
list<Availability> availability = [
MinVersion<SPV_V_1_1>,
Capability<[SPV_C_SubgroupDispatch]>
];
}
def SPV_EM_SubgroupsPerWorkgroup : I32EnumAttrCase<"SubgroupsPerWorkgroup", 36> {
list<Availability> availability = [
MinVersion<SPV_V_1_1>,
Capability<[SPV_C_SubgroupDispatch]>
];
}
def SPV_EM_SubgroupsPerWorkgroupId : I32EnumAttrCase<"SubgroupsPerWorkgroupId", 37> {
list<Availability> availability = [
MinVersion<SPV_V_1_2>,
Capability<[SPV_C_SubgroupDispatch]>
];
}
def SPV_EM_LocalSizeId : I32EnumAttrCase<"LocalSizeId", 38> {
list<Availability> availability = [
MinVersion<SPV_V_1_2>
];
}
def SPV_EM_LocalSizeHintId : I32EnumAttrCase<"LocalSizeHintId", 39> {
list<Availability> availability = [
MinVersion<SPV_V_1_2>,
Capability<[SPV_C_Kernel]>
];
}
def SPV_EM_PostDepthCoverage : I32EnumAttrCase<"PostDepthCoverage", 4446> {
list<Availability> availability = [
Extension<[SPV_KHR_post_depth_coverage]>,
Capability<[SPV_C_SampleMaskPostDepthCoverage]>
];
}
def SPV_EM_DenormPreserve : I32EnumAttrCase<"DenormPreserve", 4459> {
list<Availability> availability = [
Extension<[SPV_KHR_float_controls]>,
Capability<[SPV_C_DenormPreserve]>
];
}
def SPV_EM_DenormFlushToZero : I32EnumAttrCase<"DenormFlushToZero", 4460> {
list<Availability> availability = [
Extension<[SPV_KHR_float_controls]>,
Capability<[SPV_C_DenormFlushToZero]>
];
}
def SPV_EM_SignedZeroInfNanPreserve : I32EnumAttrCase<"SignedZeroInfNanPreserve", 4461> {
list<Availability> availability = [
Extension<[SPV_KHR_float_controls]>,
Capability<[SPV_C_SignedZeroInfNanPreserve]>
];
}
def SPV_EM_RoundingModeRTE : I32EnumAttrCase<"RoundingModeRTE", 4462> {
list<Availability> availability = [
Extension<[SPV_KHR_float_controls]>,
Capability<[SPV_C_RoundingModeRTE]>
];
}
def SPV_EM_RoundingModeRTZ : I32EnumAttrCase<"RoundingModeRTZ", 4463> {
list<Availability> availability = [
Extension<[SPV_KHR_float_controls]>,
Capability<[SPV_C_RoundingModeRTZ]>
];
}
def SPV_EM_StencilRefReplacingEXT : I32EnumAttrCase<"StencilRefReplacingEXT", 5027> {
list<Availability> availability = [
Extension<[SPV_EXT_shader_stencil_export]>,
Capability<[SPV_C_StencilExportEXT]>
];
}
def SPV_EM_OutputLinesNV : I32EnumAttrCase<"OutputLinesNV", 5269> {
list<Availability> availability = [
Extension<[SPV_NV_mesh_shader]>,
Capability<[SPV_C_MeshShadingNV]>
];
}
def SPV_EM_OutputPrimitivesNV : I32EnumAttrCase<"OutputPrimitivesNV", 5270> {
list<Availability> availability = [
Extension<[SPV_NV_mesh_shader]>,
Capability<[SPV_C_MeshShadingNV]>
];
}
def SPV_EM_DerivativeGroupQuadsNV : I32EnumAttrCase<"DerivativeGroupQuadsNV", 5289> {
list<Availability> availability = [
Extension<[SPV_NV_compute_shader_derivatives]>,
Capability<[SPV_C_ComputeDerivativeGroupQuadsNV]>
];
}
def SPV_EM_DerivativeGroupLinearNV : I32EnumAttrCase<"DerivativeGroupLinearNV", 5290> {
list<Availability> availability = [
Extension<[SPV_NV_compute_shader_derivatives]>,
Capability<[SPV_C_ComputeDerivativeGroupLinearNV]>
];
}
def SPV_EM_OutputTrianglesNV : I32EnumAttrCase<"OutputTrianglesNV", 5298> {
list<Availability> availability = [
Extension<[SPV_NV_mesh_shader]>,
Capability<[SPV_C_MeshShadingNV]>
];
}
def SPV_EM_PixelInterlockOrderedEXT : I32EnumAttrCase<"PixelInterlockOrderedEXT", 5366> {
list<Availability> availability = [
Extension<[SPV_EXT_fragment_shader_interlock]>,
Capability<[SPV_C_FragmentShaderPixelInterlockEXT]>
];
}
def SPV_EM_PixelInterlockUnorderedEXT : I32EnumAttrCase<"PixelInterlockUnorderedEXT", 5367> {
list<Availability> availability = [
Extension<[SPV_EXT_fragment_shader_interlock]>,
Capability<[SPV_C_FragmentShaderPixelInterlockEXT]>
];
}
def SPV_EM_SampleInterlockOrderedEXT : I32EnumAttrCase<"SampleInterlockOrderedEXT", 5368> {
list<Availability> availability = [
Extension<[SPV_EXT_fragment_shader_interlock]>,
Capability<[SPV_C_FragmentShaderSampleInterlockEXT]>
];
}
def SPV_EM_SampleInterlockUnorderedEXT : I32EnumAttrCase<"SampleInterlockUnorderedEXT", 5369> {
list<Availability> availability = [
Extension<[SPV_EXT_fragment_shader_interlock]>,
Capability<[SPV_C_FragmentShaderSampleInterlockEXT]>
];
}
def SPV_EM_ShadingRateInterlockOrderedEXT : I32EnumAttrCase<"ShadingRateInterlockOrderedEXT", 5370> {
list<Availability> availability = [
Extension<[SPV_EXT_fragment_shader_interlock]>,
Capability<[SPV_C_FragmentShaderShadingRateInterlockEXT]>
];
}
def SPV_EM_ShadingRateInterlockUnorderedEXT : I32EnumAttrCase<"ShadingRateInterlockUnorderedEXT", 5371> {
list<Availability> availability = [
Extension<[SPV_EXT_fragment_shader_interlock]>,
Capability<[SPV_C_FragmentShaderShadingRateInterlockEXT]>
];
}
def SPV_ExecutionModeAttr :
SPV_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
]>;
def SPV_EM_Vertex : I32EnumAttrCase<"Vertex", 0> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_EM_TessellationControl : I32EnumAttrCase<"TessellationControl", 1> {
list<Availability> availability = [
Capability<[SPV_C_Tessellation]>
];
}
def SPV_EM_TessellationEvaluation : I32EnumAttrCase<"TessellationEvaluation", 2> {
list<Availability> availability = [
Capability<[SPV_C_Tessellation]>
];
}
def SPV_EM_Geometry : I32EnumAttrCase<"Geometry", 3> {
list<Availability> availability = [
Capability<[SPV_C_Geometry]>
];
}
def SPV_EM_Fragment : I32EnumAttrCase<"Fragment", 4> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_EM_GLCompute : I32EnumAttrCase<"GLCompute", 5> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_EM_Kernel : I32EnumAttrCase<"Kernel", 6> {
list<Availability> availability = [
Capability<[SPV_C_Kernel]>
];
}
def SPV_EM_TaskNV : I32EnumAttrCase<"TaskNV", 5267> {
list<Availability> availability = [
Capability<[SPV_C_MeshShadingNV]>
];
}
def SPV_EM_MeshNV : I32EnumAttrCase<"MeshNV", 5268> {
list<Availability> availability = [
Capability<[SPV_C_MeshShadingNV]>
];
}
def SPV_EM_RayGenerationNV : I32EnumAttrCase<"RayGenerationNV", 5313> {
list<Availability> availability = [
Capability<[SPV_C_RayTracingNV]>
];
}
def SPV_EM_IntersectionNV : I32EnumAttrCase<"IntersectionNV", 5314> {
list<Availability> availability = [
Capability<[SPV_C_RayTracingNV]>
];
}
def SPV_EM_AnyHitNV : I32EnumAttrCase<"AnyHitNV", 5315> {
list<Availability> availability = [
Capability<[SPV_C_RayTracingNV]>
];
}
def SPV_EM_ClosestHitNV : I32EnumAttrCase<"ClosestHitNV", 5316> {
list<Availability> availability = [
Capability<[SPV_C_RayTracingNV]>
];
}
def SPV_EM_MissNV : I32EnumAttrCase<"MissNV", 5317> {
list<Availability> availability = [
Capability<[SPV_C_RayTracingNV]>
];
}
def SPV_EM_CallableNV : I32EnumAttrCase<"CallableNV", 5318> {
list<Availability> availability = [
Capability<[SPV_C_RayTracingNV]>
];
}
def SPV_ExecutionModelAttr :
SPV_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
]>;
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 :
SPV_BitEnumAttr<"FunctionControl", "valid SPIR-V FunctionControl", [
SPV_FC_None, SPV_FC_Inline, SPV_FC_DontInline, SPV_FC_Pure, SPV_FC_Const
]>;
def SPV_GO_Reduce : I32EnumAttrCase<"Reduce", 0> {
list<Availability> availability = [
Capability<[SPV_C_GroupNonUniformArithmetic, SPV_C_GroupNonUniformBallot, SPV_C_Kernel]>
];
}
def SPV_GO_InclusiveScan : I32EnumAttrCase<"InclusiveScan", 1> {
list<Availability> availability = [
Capability<[SPV_C_GroupNonUniformArithmetic, SPV_C_GroupNonUniformBallot, SPV_C_Kernel]>
];
}
def SPV_GO_ExclusiveScan : I32EnumAttrCase<"ExclusiveScan", 2> {
list<Availability> availability = [
Capability<[SPV_C_GroupNonUniformArithmetic, SPV_C_GroupNonUniformBallot, SPV_C_Kernel]>
];
}
def SPV_GO_ClusteredReduce : I32EnumAttrCase<"ClusteredReduce", 3> {
list<Availability> availability = [
MinVersion<SPV_V_1_3>,
Capability<[SPV_C_GroupNonUniformClustered]>
];
}
def SPV_GO_PartitionedReduceNV : I32EnumAttrCase<"PartitionedReduceNV", 6> {
list<Availability> availability = [
Extension<[SPV_NV_shader_subgroup_partitioned]>,
Capability<[SPV_C_GroupNonUniformPartitionedNV]>
];
}
def SPV_GO_PartitionedInclusiveScanNV : I32EnumAttrCase<"PartitionedInclusiveScanNV", 7> {
list<Availability> availability = [
Extension<[SPV_NV_shader_subgroup_partitioned]>,
Capability<[SPV_C_GroupNonUniformPartitionedNV]>
];
}
def SPV_GO_PartitionedExclusiveScanNV : I32EnumAttrCase<"PartitionedExclusiveScanNV", 8> {
list<Availability> availability = [
Extension<[SPV_NV_shader_subgroup_partitioned]>,
Capability<[SPV_C_GroupNonUniformPartitionedNV]>
];
}
def SPV_GroupOperationAttr :
SPV_I32EnumAttr<"GroupOperation", "valid SPIR-V GroupOperation", [
SPV_GO_Reduce, SPV_GO_InclusiveScan, SPV_GO_ExclusiveScan,
SPV_GO_ClusteredReduce, SPV_GO_PartitionedReduceNV,
SPV_GO_PartitionedInclusiveScanNV, SPV_GO_PartitionedExclusiveScanNV
]>;
def SPV_IF_Unknown : I32EnumAttrCase<"Unknown", 0>;
def SPV_IF_Rgba32f : I32EnumAttrCase<"Rgba32f", 1> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_IF_Rgba16f : I32EnumAttrCase<"Rgba16f", 2> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_IF_R32f : I32EnumAttrCase<"R32f", 3> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_IF_Rgba8 : I32EnumAttrCase<"Rgba8", 4> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_IF_Rgba8Snorm : I32EnumAttrCase<"Rgba8Snorm", 5> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_IF_Rg32f : I32EnumAttrCase<"Rg32f", 6> {
list<Availability> availability = [
Capability<[SPV_C_StorageImageExtendedFormats]>
];
}
def SPV_IF_Rg16f : I32EnumAttrCase<"Rg16f", 7> {
list<Availability> availability = [
Capability<[SPV_C_StorageImageExtendedFormats]>
];
}
def SPV_IF_R11fG11fB10f : I32EnumAttrCase<"R11fG11fB10f", 8> {
list<Availability> availability = [
Capability<[SPV_C_StorageImageExtendedFormats]>
];
}
def SPV_IF_R16f : I32EnumAttrCase<"R16f", 9> {
list<Availability> availability = [
Capability<[SPV_C_StorageImageExtendedFormats]>
];
}
def SPV_IF_Rgba16 : I32EnumAttrCase<"Rgba16", 10> {
list<Availability> availability = [
Capability<[SPV_C_StorageImageExtendedFormats]>
];
}
def SPV_IF_Rgb10A2 : I32EnumAttrCase<"Rgb10A2", 11> {
list<Availability> availability = [
Capability<[SPV_C_StorageImageExtendedFormats]>
];
}
def SPV_IF_Rg16 : I32EnumAttrCase<"Rg16", 12> {
list<Availability> availability = [
Capability<[SPV_C_StorageImageExtendedFormats]>
];
}
def SPV_IF_Rg8 : I32EnumAttrCase<"Rg8", 13> {
list<Availability> availability = [
Capability<[SPV_C_StorageImageExtendedFormats]>
];
}
def SPV_IF_R16 : I32EnumAttrCase<"R16", 14> {
list<Availability> availability = [
Capability<[SPV_C_StorageImageExtendedFormats]>
];
}
def SPV_IF_R8 : I32EnumAttrCase<"R8", 15> {
list<Availability> availability = [
Capability<[SPV_C_StorageImageExtendedFormats]>
];
}
def SPV_IF_Rgba16Snorm : I32EnumAttrCase<"Rgba16Snorm", 16> {
list<Availability> availability = [
Capability<[SPV_C_StorageImageExtendedFormats]>
];
}
def SPV_IF_Rg16Snorm : I32EnumAttrCase<"Rg16Snorm", 17> {
list<Availability> availability = [
Capability<[SPV_C_StorageImageExtendedFormats]>
];
}
def SPV_IF_Rg8Snorm : I32EnumAttrCase<"Rg8Snorm", 18> {
list<Availability> availability = [
Capability<[SPV_C_StorageImageExtendedFormats]>
];
}
def SPV_IF_R16Snorm : I32EnumAttrCase<"R16Snorm", 19> {
list<Availability> availability = [
Capability<[SPV_C_StorageImageExtendedFormats]>
];
}
def SPV_IF_R8Snorm : I32EnumAttrCase<"R8Snorm", 20> {
list<Availability> availability = [
Capability<[SPV_C_StorageImageExtendedFormats]>
];
}
def SPV_IF_Rgba32i : I32EnumAttrCase<"Rgba32i", 21> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_IF_Rgba16i : I32EnumAttrCase<"Rgba16i", 22> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_IF_Rgba8i : I32EnumAttrCase<"Rgba8i", 23> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_IF_R32i : I32EnumAttrCase<"R32i", 24> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_IF_Rg32i : I32EnumAttrCase<"Rg32i", 25> {
list<Availability> availability = [
Capability<[SPV_C_StorageImageExtendedFormats]>
];
}
def SPV_IF_Rg16i : I32EnumAttrCase<"Rg16i", 26> {
list<Availability> availability = [
Capability<[SPV_C_StorageImageExtendedFormats]>
];
}
def SPV_IF_Rg8i : I32EnumAttrCase<"Rg8i", 27> {
list<Availability> availability = [
Capability<[SPV_C_StorageImageExtendedFormats]>
];
}
def SPV_IF_R16i : I32EnumAttrCase<"R16i", 28> {
list<Availability> availability = [
Capability<[SPV_C_StorageImageExtendedFormats]>
];
}
def SPV_IF_R8i : I32EnumAttrCase<"R8i", 29> {
list<Availability> availability = [
Capability<[SPV_C_StorageImageExtendedFormats]>
];
}
def SPV_IF_Rgba32ui : I32EnumAttrCase<"Rgba32ui", 30> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_IF_Rgba16ui : I32EnumAttrCase<"Rgba16ui", 31> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_IF_Rgba8ui : I32EnumAttrCase<"Rgba8ui", 32> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_IF_R32ui : I32EnumAttrCase<"R32ui", 33> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_IF_Rgb10a2ui : I32EnumAttrCase<"Rgb10a2ui", 34> {
list<Availability> availability = [
Capability<[SPV_C_StorageImageExtendedFormats]>
];
}
def SPV_IF_Rg32ui : I32EnumAttrCase<"Rg32ui", 35> {
list<Availability> availability = [
Capability<[SPV_C_StorageImageExtendedFormats]>
];
}
def SPV_IF_Rg16ui : I32EnumAttrCase<"Rg16ui", 36> {
list<Availability> availability = [
Capability<[SPV_C_StorageImageExtendedFormats]>
];
}
def SPV_IF_Rg8ui : I32EnumAttrCase<"Rg8ui", 37> {
list<Availability> availability = [
Capability<[SPV_C_StorageImageExtendedFormats]>
];
}
def SPV_IF_R16ui : I32EnumAttrCase<"R16ui", 38> {
list<Availability> availability = [
Capability<[SPV_C_StorageImageExtendedFormats]>
];
}
def SPV_IF_R8ui : I32EnumAttrCase<"R8ui", 39> {
list<Availability> availability = [
Capability<[SPV_C_StorageImageExtendedFormats]>
];
}
def SPV_ImageFormatAttr :
SPV_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
]>;
def SPV_LT_Export : I32EnumAttrCase<"Export", 0> {
list<Availability> availability = [
Capability<[SPV_C_Linkage]>
];
}
def SPV_LT_Import : I32EnumAttrCase<"Import", 1> {
list<Availability> availability = [
Capability<[SPV_C_Linkage]>
];
}
def SPV_LinkageTypeAttr :
SPV_I32EnumAttr<"LinkageType", "valid SPIR-V LinkageType", [
SPV_LT_Export, SPV_LT_Import
]>;
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> {
list<Availability> availability = [
MinVersion<SPV_V_1_1>
];
}
def SPV_LC_DependencyLength : BitEnumAttrCase<"DependencyLength", 0x0008> {
list<Availability> availability = [
MinVersion<SPV_V_1_1>
];
}
def SPV_LC_MinIterations : BitEnumAttrCase<"MinIterations", 0x0010> {
list<Availability> availability = [
MinVersion<SPV_V_1_4>
];
}
def SPV_LC_MaxIterations : BitEnumAttrCase<"MaxIterations", 0x0020> {
list<Availability> availability = [
MinVersion<SPV_V_1_4>
];
}
def SPV_LC_IterationMultiple : BitEnumAttrCase<"IterationMultiple", 0x0040> {
list<Availability> availability = [
MinVersion<SPV_V_1_4>
];
}
def SPV_LC_PeelCount : BitEnumAttrCase<"PeelCount", 0x0080> {
list<Availability> availability = [
MinVersion<SPV_V_1_4>
];
}
def SPV_LC_PartialCount : BitEnumAttrCase<"PartialCount", 0x0100> {
list<Availability> availability = [
MinVersion<SPV_V_1_4>
];
}
def SPV_LoopControlAttr :
SPV_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
]>;
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> {
list<Availability> availability = [
MinVersion<SPV_V_1_5>,
Capability<[SPV_C_VulkanMemoryModel]>
];
}
def SPV_MA_MakePointerVisible : BitEnumAttrCase<"MakePointerVisible", 0x0010> {
list<Availability> availability = [
MinVersion<SPV_V_1_5>,
Capability<[SPV_C_VulkanMemoryModel]>
];
}
def SPV_MA_NonPrivatePointer : BitEnumAttrCase<"NonPrivatePointer", 0x0020> {
list<Availability> availability = [
MinVersion<SPV_V_1_5>,
Capability<[SPV_C_VulkanMemoryModel]>
];
}
def SPV_MemoryAccessAttr :
SPV_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
]>;
def SPV_MM_Simple : I32EnumAttrCase<"Simple", 0> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_MM_GLSL450 : I32EnumAttrCase<"GLSL450", 1> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_MM_OpenCL : I32EnumAttrCase<"OpenCL", 2> {
list<Availability> availability = [
Capability<[SPV_C_Kernel]>
];
}
def SPV_MM_Vulkan : I32EnumAttrCase<"Vulkan", 3> {
list<Availability> availability = [
Extension<[SPV_KHR_vulkan_memory_model]>,
Capability<[SPV_C_VulkanMemoryModel]>
];
}
def SPV_MemoryModelAttr :
SPV_I32EnumAttr<"MemoryModel", "valid SPIR-V MemoryModel", [
SPV_MM_Simple, SPV_MM_GLSL450, SPV_MM_OpenCL, SPV_MM_Vulkan
]>;
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> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
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> {
list<Availability> availability = [
Capability<[SPV_C_AtomicStorage]>
];
}
def SPV_MS_ImageMemory : BitEnumAttrCase<"ImageMemory", 0x0800>;
def SPV_MS_OutputMemory : BitEnumAttrCase<"OutputMemory", 0x1000> {
list<Availability> availability = [
MinVersion<SPV_V_1_5>,
Capability<[SPV_C_VulkanMemoryModel]>
];
}
def SPV_MS_MakeAvailable : BitEnumAttrCase<"MakeAvailable", 0x2000> {
list<Availability> availability = [
MinVersion<SPV_V_1_5>,
Capability<[SPV_C_VulkanMemoryModel]>
];
}
def SPV_MS_MakeVisible : BitEnumAttrCase<"MakeVisible", 0x4000> {
list<Availability> availability = [
MinVersion<SPV_V_1_5>,
Capability<[SPV_C_VulkanMemoryModel]>
];
}
def SPV_MS_Volatile : BitEnumAttrCase<"Volatile", 0x8000> {
list<Availability> availability = [
Extension<[SPV_KHR_vulkan_memory_model]>,
Capability<[SPV_C_VulkanMemoryModel]>
];
}
def SPV_MemorySemanticsAttr :
SPV_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
]>;
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> {
list<Availability> availability = [
MinVersion<SPV_V_1_5>,
Capability<[SPV_C_VulkanMemoryModel]>
];
}
def SPV_ScopeAttr :
SPV_I32EnumAttr<"Scope", "valid SPIR-V Scope", [
SPV_S_CrossDevice, SPV_S_Device, SPV_S_Workgroup, SPV_S_Subgroup,
SPV_S_Invocation, SPV_S_QueueFamily
]>;
def SPV_SC_None : BitEnumAttrCase<"None", 0x0000>;
def SPV_SC_Flatten : BitEnumAttrCase<"Flatten", 0x0001>;
def SPV_SC_DontFlatten : BitEnumAttrCase<"DontFlatten", 0x0002>;
def SPV_SelectionControlAttr :
SPV_BitEnumAttr<"SelectionControl", "valid SPIR-V SelectionControl", [
SPV_SC_None, SPV_SC_Flatten, SPV_SC_DontFlatten
]>;
def SPV_SC_UniformConstant : I32EnumAttrCase<"UniformConstant", 0>;
def SPV_SC_Input : I32EnumAttrCase<"Input", 1>;
def SPV_SC_Uniform : I32EnumAttrCase<"Uniform", 2> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_SC_Output : I32EnumAttrCase<"Output", 3> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_SC_Workgroup : I32EnumAttrCase<"Workgroup", 4>;
def SPV_SC_CrossWorkgroup : I32EnumAttrCase<"CrossWorkgroup", 5>;
def SPV_SC_Private : I32EnumAttrCase<"Private", 6> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_SC_Function : I32EnumAttrCase<"Function", 7>;
def SPV_SC_Generic : I32EnumAttrCase<"Generic", 8> {
list<Availability> availability = [
Capability<[SPV_C_GenericPointer]>
];
}
def SPV_SC_PushConstant : I32EnumAttrCase<"PushConstant", 9> {
list<Availability> availability = [
Capability<[SPV_C_Shader]>
];
}
def SPV_SC_AtomicCounter : I32EnumAttrCase<"AtomicCounter", 10> {
list<Availability> availability = [
Capability<[SPV_C_AtomicStorage]>
];
}
def SPV_SC_Image : I32EnumAttrCase<"Image", 11>;
def SPV_SC_StorageBuffer : I32EnumAttrCase<"StorageBuffer", 12> {
list<Availability> availability = [
Extension<[SPV_KHR_storage_buffer_storage_class, SPV_KHR_variable_pointers]>,
Capability<[SPV_C_Shader]>
];
}
def SPV_SC_CallableDataNV : I32EnumAttrCase<"CallableDataNV", 5328> {
list<Availability> availability = [
Extension<[SPV_NV_ray_tracing]>,
Capability<[SPV_C_RayTracingNV]>
];
}
def SPV_SC_IncomingCallableDataNV : I32EnumAttrCase<"IncomingCallableDataNV", 5329> {
list<Availability> availability = [
Extension<[SPV_NV_ray_tracing]>,
Capability<[SPV_C_RayTracingNV]>
];
}
def SPV_SC_RayPayloadNV : I32EnumAttrCase<"RayPayloadNV", 5338> {
list<Availability> availability = [
Extension<[SPV_NV_ray_tracing]>,
Capability<[SPV_C_RayTracingNV]>
];
}
def SPV_SC_HitAttributeNV : I32EnumAttrCase<"HitAttributeNV", 5339> {
list<Availability> availability = [
Extension<[SPV_NV_ray_tracing]>,
Capability<[SPV_C_RayTracingNV]>
];
}
def SPV_SC_IncomingRayPayloadNV : I32EnumAttrCase<"IncomingRayPayloadNV", 5342> {
list<Availability> availability = [
Extension<[SPV_NV_ray_tracing]>,
Capability<[SPV_C_RayTracingNV]>
];
}
def SPV_SC_ShaderRecordBufferNV : I32EnumAttrCase<"ShaderRecordBufferNV", 5343> {
list<Availability> availability = [
Extension<[SPV_NV_ray_tracing]>,
Capability<[SPV_C_RayTracingNV]>
];
}
def SPV_SC_PhysicalStorageBuffer : I32EnumAttrCase<"PhysicalStorageBuffer", 5349> {
list<Availability> availability = [
Extension<[SPV_EXT_physical_storage_buffer, SPV_KHR_physical_storage_buffer]>,
Capability<[SPV_C_PhysicalStorageBufferAddresses]>
];
}
def SPV_StorageClassAttr :
SPV_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
]>;
// End enum section. Generated from SPIR-V spec; DO NOT MODIFY!
// Enums added manually that are not part of SPIR-V 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 :
SPV_I32EnumAttr<"ImageDepthInfo", "valid SPIR-V Image Depth specification",
[SPV_IDI_NoDepth, SPV_IDI_IsDepth, SPV_IDI_DepthUnknown]>;
def SPV_IAI_NonArrayed : I32EnumAttrCase<"NonArrayed", 0>;
def SPV_IAI_Arrayed : I32EnumAttrCase<"Arrayed", 1>;
def SPV_ArrayedAttr :
SPV_I32EnumAttr<
"ImageArrayedInfo", "valid SPIR-V Image Arrayed specification",
[SPV_IAI_NonArrayed, SPV_IAI_Arrayed]>;
def SPV_ISI_SingleSampled : I32EnumAttrCase<"SingleSampled", 0>;
def SPV_ISI_MultiSampled : I32EnumAttrCase<"MultiSampled", 1>;
def SPV_SamplingAttr:
SPV_I32EnumAttr<
"ImageSamplingInfo", "valid SPIR-V Image Sampling specification",
[SPV_ISI_SingleSampled, SPV_ISI_MultiSampled]>;
def SPV_ISUI_SamplerUnknown : I32EnumAttrCase<"SamplerUnknown", 0>;
def SPV_ISUI_NeedSampler : I32EnumAttrCase<"NeedSampler", 1>;
def SPV_ISUI_NoSampler : I32EnumAttrCase<"NoSampler", 2>;
def SPV_SamplerUseAttr:
SPV_I32EnumAttr<
"ImageSamplerUseInfo", "valid SPIR-V Sampler Use specification",
[SPV_ISUI_SamplerUnknown, SPV_ISUI_NeedSampler, SPV_ISUI_NoSampler]>;
//===----------------------------------------------------------------------===//
// SPIR-V attribute definitions
//===----------------------------------------------------------------------===//
def SPV_VerCapExtAttr : DialectAttr<
SPIRV_Dialect,
CPred<"$_self.isa<::mlir::spirv::VerCapExtAttr>()">,
"version-capability-extension attribute"> {
let storageType = "::mlir::spirv::VerCapExtAttr";
let returnType = "::mlir::spirv::VerCapExtAttr";
let convertFromStorage = "$_self";
}
//===----------------------------------------------------------------------===//
// SPIR-V type definitions
//===----------------------------------------------------------------------===//
class IOrUI<int width>
: Type<Or<[CPred<"$_self.isSignlessInteger(" # width # ")">,
CPred<"$_self.isUnsignedInteger(" # width # ")">]>,
width # "-bit signless/unsigned integer"> {
int bitwidth = width;
}
class SignlessOrUnsignedIntOfWidths<list<int> widths> :
AnyTypeOf<!foreach(w, widths, IOrUI<w>),
StrJoinInt<widths, "/">.result # "-bit signless/unsigned integer">;
def SPV_IsArrayType : CPred<"$_self.isa<::mlir::spirv::ArrayType>()">;
def SPV_IsCooperativeMatrixType :
CPred<"$_self.isa<::mlir::spirv::CooperativeMatrixNVType>()">;
def SPV_IsMatrixType : CPred<"$_self.isa<::mlir::spirv::MatrixType>()">;
def SPV_IsPtrType : CPred<"$_self.isa<::mlir::spirv::PointerType>()">;
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">;
def SPV_Bool : TypeAlias<I1, "bool">;
def SPV_Integer : AnyIntOfWidths<[8, 16, 32, 64]>;
def SPV_Int32 : TypeAlias<I32, "Int32">;
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 : DialectType<SPIRV_Dialect, SPV_IsPtrType,
"any SPIR-V pointer type">;
def SPV_AnyArray : DialectType<SPIRV_Dialect, SPV_IsArrayType,
"any SPIR-V array type">;
def SPV_AnyCooperativeMatrix : DialectType<SPIRV_Dialect,
SPV_IsCooperativeMatrixType,
"any SPIR-V cooperative matrix type">;
def SPV_AnyMatrix : DialectType<SPIRV_Dialect, SPV_IsMatrixType,
"any SPIR-V matrix type">;
def SPV_AnyRTArray : DialectType<SPIRV_Dialect, SPV_IsRTArrayType,
"any SPIR-V runtime array type">;
def SPV_AnyStruct : DialectType<SPIRV_Dialect, 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_AnyRTArray, SPV_AnyStruct]>;
def SPV_Composite :
AnyTypeOf<[SPV_Vector, SPV_AnyArray, SPV_AnyRTArray, SPV_AnyStruct,
SPV_AnyCooperativeMatrix, SPV_AnyMatrix]>;
def SPV_Type : AnyTypeOf<[
SPV_Void, SPV_Bool, SPV_Integer, SPV_Float, SPV_Vector,
SPV_AnyPtr, SPV_AnyArray, SPV_AnyRTArray, SPV_AnyStruct,
SPV_AnyCooperativeMatrix, SPV_AnyMatrix
]>;
def SPV_SignlessOrUnsignedInt : SignlessOrUnsignedIntOfWidths<[8, 16, 32, 64]>;
class SPV_CoopMatrixOfType<list<Type> allowedTypes> :
ContainerType<AnyTypeOf<allowedTypes>, SPV_IsCooperativeMatrixType,
"$_self.cast<::mlir::spirv::CooperativeMatrixNVType>().getElementType()",
"Cooperative Matrix">;
class SPV_ScalarOrVectorOf<Type type> :
AnyTypeOf<[type, VectorOfLengthAndType<[2, 3, 4], [type]>]>;
class SPV_ScalarOrVectorOrCoopMatrixOf<Type type> :
AnyTypeOf<[type, VectorOfLengthAndType<[2, 3, 4], [type]>,
SPV_CoopMatrixOfType<[type]>]>;
def SPV_ScalarOrVector : AnyTypeOf<[SPV_Scalar, SPV_Vector]>;
def SPV_ScalarOrVectorOrPtr : AnyTypeOf<[SPV_ScalarOrVector, SPV_AnyPtr]>;
class SPV_Vec4<Type type> : VectorOfLengthAndType<[4], [type]>;
def SPV_IntVec4 : SPV_Vec4<SPV_Integer>;
def SPV_IOrUIVec4 : SPV_Vec4<SPV_SignlessOrUnsignedInt>;
def SPV_Int32Vec4 : SPV_Vec4<AnyI32>;
// TODO: From 1.4, this should also include Composite type.
def SPV_SelectType : AnyTypeOf<[SPV_Scalar, SPV_Vector, SPV_AnyPtr]>;
//===----------------------------------------------------------------------===//
// SPIR-V OpTrait definitions
//===----------------------------------------------------------------------===//
// Check that an op can only be used within the scope of a function-like op.
def InFunctionScope : PredOpTrait<
"op must appear in a function-like op's block",
CPred<"isNestedInFunctionLikeOp($_op.getParentOp())">>;
// Check that an op can only be used within the scope of a module-like op.
def InModuleScope : PredOpTrait<
"op must appear in a module-like op's block",
CPred<"isDirectInModuleLikeOp($_op.getParentOp())">>;
//===----------------------------------------------------------------------===//
// 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_OpLine : I32EnumAttrCase<"OpLine", 8>;
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_OpTypeMatrix : I32EnumAttrCase<"OpTypeMatrix", 24>;
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_OpCopyMemory : I32EnumAttrCase<"OpCopyMemory", 63>;
def SPV_OC_OpAccessChain : I32EnumAttrCase<"OpAccessChain", 65>;
def SPV_OC_OpDecorate : I32EnumAttrCase<"OpDecorate", 71>;
def SPV_OC_OpMemberDecorate : I32EnumAttrCase<"OpMemberDecorate", 72>;
def SPV_OC_OpCompositeConstruct : I32EnumAttrCase<"OpCompositeConstruct", 80>;
def SPV_OC_OpCompositeExtract : I32EnumAttrCase<"OpCompositeExtract", 81>;
def SPV_OC_OpCompositeInsert : I32EnumAttrCase<"OpCompositeInsert", 82>;
def SPV_OC_OpTranspose : I32EnumAttrCase<"OpTranspose", 84>;
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_OpMatrixTimesScalar : I32EnumAttrCase<"OpMatrixTimesScalar", 143>;
def SPV_OC_OpMatrixTimesMatrix : I32EnumAttrCase<"OpMatrixTimesMatrix", 146>;
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_OpShiftRightLogical : I32EnumAttrCase<"OpShiftRightLogical", 194>;
def SPV_OC_OpShiftRightArithmetic : I32EnumAttrCase<"OpShiftRightArithmetic", 195>;
def SPV_OC_OpShiftLeftLogical : I32EnumAttrCase<"OpShiftLeftLogical", 196>;
def SPV_OC_OpBitwiseOr : I32EnumAttrCase<"OpBitwiseOr", 197>;
def SPV_OC_OpBitwiseXor : I32EnumAttrCase<"OpBitwiseXor", 198>;
def SPV_OC_OpBitwiseAnd : I32EnumAttrCase<"OpBitwiseAnd", 199>;
def SPV_OC_OpNot : I32EnumAttrCase<"OpNot", 200>;
def SPV_OC_OpBitFieldInsert : I32EnumAttrCase<"OpBitFieldInsert", 201>;
def SPV_OC_OpBitFieldSExtract : I32EnumAttrCase<"OpBitFieldSExtract", 202>;
def SPV_OC_OpBitFieldUExtract : I32EnumAttrCase<"OpBitFieldUExtract", 203>;
def SPV_OC_OpBitReverse : I32EnumAttrCase<"OpBitReverse", 204>;
def SPV_OC_OpBitCount : I32EnumAttrCase<"OpBitCount", 205>;
def SPV_OC_OpControlBarrier : I32EnumAttrCase<"OpControlBarrier", 224>;
def SPV_OC_OpMemoryBarrier : I32EnumAttrCase<"OpMemoryBarrier", 225>;
def SPV_OC_OpAtomicCompareExchangeWeak : I32EnumAttrCase<"OpAtomicCompareExchangeWeak", 231>;
def SPV_OC_OpAtomicIIncrement : I32EnumAttrCase<"OpAtomicIIncrement", 232>;
def SPV_OC_OpAtomicIDecrement : I32EnumAttrCase<"OpAtomicIDecrement", 233>;
def SPV_OC_OpAtomicIAdd : I32EnumAttrCase<"OpAtomicIAdd", 234>;
def SPV_OC_OpAtomicISub : I32EnumAttrCase<"OpAtomicISub", 235>;
def SPV_OC_OpAtomicSMin : I32EnumAttrCase<"OpAtomicSMin", 236>;
def SPV_OC_OpAtomicUMin : I32EnumAttrCase<"OpAtomicUMin", 237>;
def SPV_OC_OpAtomicSMax : I32EnumAttrCase<"OpAtomicSMax", 238>;
def SPV_OC_OpAtomicUMax : I32EnumAttrCase<"OpAtomicUMax", 239>;
def SPV_OC_OpAtomicAnd : I32EnumAttrCase<"OpAtomicAnd", 240>;
def SPV_OC_OpAtomicOr : I32EnumAttrCase<"OpAtomicOr", 241>;
def SPV_OC_OpAtomicXor : I32EnumAttrCase<"OpAtomicXor", 242>;
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_OpNoLine : I32EnumAttrCase<"OpNoLine", 317>;
def SPV_OC_OpModuleProcessed : I32EnumAttrCase<"OpModuleProcessed", 330>;
def SPV_OC_OpGroupNonUniformElect : I32EnumAttrCase<"OpGroupNonUniformElect", 333>;
def SPV_OC_OpGroupNonUniformBallot : I32EnumAttrCase<"OpGroupNonUniformBallot", 339>;
def SPV_OC_OpGroupNonUniformIAdd : I32EnumAttrCase<"OpGroupNonUniformIAdd", 349>;
def SPV_OC_OpGroupNonUniformFAdd : I32EnumAttrCase<"OpGroupNonUniformFAdd", 350>;
def SPV_OC_OpGroupNonUniformIMul : I32EnumAttrCase<"OpGroupNonUniformIMul", 351>;
def SPV_OC_OpGroupNonUniformFMul : I32EnumAttrCase<"OpGroupNonUniformFMul", 352>;
def SPV_OC_OpGroupNonUniformSMin : I32EnumAttrCase<"OpGroupNonUniformSMin", 353>;
def SPV_OC_OpGroupNonUniformUMin : I32EnumAttrCase<"OpGroupNonUniformUMin", 354>;
def SPV_OC_OpGroupNonUniformFMin : I32EnumAttrCase<"OpGroupNonUniformFMin", 355>;
def SPV_OC_OpGroupNonUniformSMax : I32EnumAttrCase<"OpGroupNonUniformSMax", 356>;
def SPV_OC_OpGroupNonUniformUMax : I32EnumAttrCase<"OpGroupNonUniformUMax", 357>;
def SPV_OC_OpGroupNonUniformFMax : I32EnumAttrCase<"OpGroupNonUniformFMax", 358>;
def SPV_OC_OpSubgroupBallotKHR : I32EnumAttrCase<"OpSubgroupBallotKHR", 4421>;
def SPV_OC_OpTypeCooperativeMatrixNV : I32EnumAttrCase<"OpTypeCooperativeMatrixNV", 5358>;
def SPV_OC_OpCooperativeMatrixLoadNV : I32EnumAttrCase<"OpCooperativeMatrixLoadNV", 5359>;
def SPV_OC_OpCooperativeMatrixStoreNV : I32EnumAttrCase<"OpCooperativeMatrixStoreNV", 5360>;
def SPV_OC_OpCooperativeMatrixMulAddNV : I32EnumAttrCase<"OpCooperativeMatrixMulAddNV", 5361>;
def SPV_OC_OpCooperativeMatrixLengthNV : I32EnumAttrCase<"OpCooperativeMatrixLengthNV", 5362>;
def SPV_OpcodeAttr :
SPV_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_OpLine, 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_OpTypeMatrix,
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_OpCopyMemory,
SPV_OC_OpAccessChain, SPV_OC_OpDecorate, SPV_OC_OpMemberDecorate,
SPV_OC_OpCompositeConstruct, SPV_OC_OpCompositeExtract,
SPV_OC_OpCompositeInsert, SPV_OC_OpTranspose, 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_OpMatrixTimesScalar, SPV_OC_OpMatrixTimesMatrix, 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_OpShiftRightLogical,
SPV_OC_OpShiftRightArithmetic, SPV_OC_OpShiftLeftLogical, SPV_OC_OpBitwiseOr,
SPV_OC_OpBitwiseXor, SPV_OC_OpBitwiseAnd, SPV_OC_OpNot,
SPV_OC_OpBitFieldInsert, SPV_OC_OpBitFieldSExtract, SPV_OC_OpBitFieldUExtract,
SPV_OC_OpBitReverse, SPV_OC_OpBitCount, SPV_OC_OpControlBarrier,
SPV_OC_OpMemoryBarrier, SPV_OC_OpAtomicCompareExchangeWeak,
SPV_OC_OpAtomicIIncrement, SPV_OC_OpAtomicIDecrement, SPV_OC_OpAtomicIAdd,
SPV_OC_OpAtomicISub, SPV_OC_OpAtomicSMin, SPV_OC_OpAtomicUMin,
SPV_OC_OpAtomicSMax, SPV_OC_OpAtomicUMax, SPV_OC_OpAtomicAnd,
SPV_OC_OpAtomicOr, SPV_OC_OpAtomicXor, 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_OpNoLine, SPV_OC_OpModuleProcessed,
SPV_OC_OpGroupNonUniformElect, SPV_OC_OpGroupNonUniformBallot,
SPV_OC_OpGroupNonUniformIAdd, SPV_OC_OpGroupNonUniformFAdd,
SPV_OC_OpGroupNonUniformIMul, SPV_OC_OpGroupNonUniformFMul,
SPV_OC_OpGroupNonUniformSMin, SPV_OC_OpGroupNonUniformUMin,
SPV_OC_OpGroupNonUniformFMin, SPV_OC_OpGroupNonUniformSMax,
SPV_OC_OpGroupNonUniformUMax, SPV_OC_OpGroupNonUniformFMax,
SPV_OC_OpSubgroupBallotKHR, SPV_OC_OpTypeCooperativeMatrixNV,
SPV_OC_OpCooperativeMatrixLoadNV, SPV_OC_OpCooperativeMatrixStoreNV,
SPV_OC_OpCooperativeMatrixMulAddNV, SPV_OC_OpCooperativeMatrixLengthNV
]>;
// End opcode section. Generated from SPIR-V spec; DO NOT MODIFY!
//===----------------------------------------------------------------------===//
// SPIR-V op definitions
//===----------------------------------------------------------------------===//
// Base class for all SPIR-V ops.
class SPV_Op<string mnemonic, list<OpTrait> traits = []> :
Op<SPIRV_Dialect, mnemonic, !listconcat(traits, [
// TODO: We don't need all of the following traits for every op; only
// the suitable ones should be added automatically after ODS supports
// dialect-specific contents.
DeclareOpInterfaceMethods<QueryMinVersionInterface>,
DeclareOpInterfaceMethods<QueryMaxVersionInterface>,
DeclareOpInterfaceMethods<QueryExtensionInterface>,
DeclareOpInterfaceMethods<QueryCapabilityInterface>
])> {
// Availability specification for this op itself.
list<Availability> availability = [
MinVersion<SPV_V_1_0>,
MaxVersion<SPV_V_1_5>,
Extension<[]>,
Capability<[]>
];
// 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