From fa91dcbefd7d9f16b2c6d624b14a1c023745b78a Mon Sep 17 00:00:00 2001 From: Igor Wodiany Date: Wed, 6 Aug 2025 14:40:03 +0100 Subject: [PATCH] [mlir][spirv] Add support for Invariant and Patch decorations (#152301) New tests were validated with `spriv-val`. --- .../Target/SPIRV/Deserialization/Deserializer.cpp | 2 ++ mlir/lib/Target/SPIRV/Serialization/Serializer.cpp | 2 ++ mlir/test/Target/SPIRV/decorations.mlir | 14 ++++++++++++++ 3 files changed, 18 insertions(+) diff --git a/mlir/lib/Target/SPIRV/Deserialization/Deserializer.cpp b/mlir/lib/Target/SPIRV/Deserialization/Deserializer.cpp index 750821833224..c967e863554f 100644 --- a/mlir/lib/Target/SPIRV/Deserialization/Deserializer.cpp +++ b/mlir/lib/Target/SPIRV/Deserialization/Deserializer.cpp @@ -344,6 +344,8 @@ LogicalResult spirv::Deserializer::processDecoration(ArrayRef words) { case spirv::Decoration::RestrictPointer: case spirv::Decoration::NoContraction: case spirv::Decoration::Constant: + case spirv::Decoration::Invariant: + case spirv::Decoration::Patch: if (words.size() != 2) { return emitError(unknownLoc, "OpDecoration with ") << decorationName << "needs a single target "; diff --git a/mlir/lib/Target/SPIRV/Serialization/Serializer.cpp b/mlir/lib/Target/SPIRV/Serialization/Serializer.cpp index 30536638b56f..c049574fbc9e 100644 --- a/mlir/lib/Target/SPIRV/Serialization/Serializer.cpp +++ b/mlir/lib/Target/SPIRV/Serialization/Serializer.cpp @@ -338,6 +338,8 @@ LogicalResult Serializer::processDecorationAttr(Location loc, uint32_t resultID, case spirv::Decoration::NoContraction: case spirv::Decoration::Constant: case spirv::Decoration::Block: + case spirv::Decoration::Invariant: + case spirv::Decoration::Patch: // For unit attributes and decoration attributes, the args list // has no values so we do nothing. if (isa(attr)) diff --git a/mlir/test/Target/SPIRV/decorations.mlir b/mlir/test/Target/SPIRV/decorations.mlir index ee7ad814ea0c..90ba690e50b7 100644 --- a/mlir/test/Target/SPIRV/decorations.mlir +++ b/mlir/test/Target/SPIRV/decorations.mlir @@ -58,6 +58,20 @@ spirv.module Logical GLSL450 requires #spirv.vce { // ----- +spirv.module Logical GLSL450 requires #spirv.vce { + // CHECK: patch + spirv.GlobalVariable @var {patch} : !spirv.ptr, Input> +} + +// ----- + +spirv.module Logical GLSL450 requires #spirv.vce { + // CHECK: invariant + spirv.GlobalVariable @var {invariant} : !spirv.ptr, Output> +} + +// ----- + spirv.module Logical GLSL450 requires #spirv.vce { // CHECK: linkage_attributes = #spirv.linkage_attributes> spirv.GlobalVariable @var1 {