[Mlir-commits] [mlir] [mlir][spirv] Propagate alignment requirements from vector to spirv (PR #155278)
Jakub Kuderski
llvmlistbot at llvm.org
Thu Aug 28 08:25:05 PDT 2025
================
@@ -0,0 +1,43 @@
+// RUN: mlir-opt --split-input-file --verify-diagnostics %s
+
+//===----------------------------------------------------------------------===//
+// spirv.LoadOp
+//===----------------------------------------------------------------------===//
+
+func.func @aligned_load_non_positive() -> () {
+ %0 = spirv.Variable : !spirv.ptr<f32, Function>
+ // expected-error at below {{'spirv.Load' op attribute 'alignment' failed to satisfy constraint: 32-bit signless integer attribute whose value is positive and whose value is a power of two > 0}}
+ %1 = spirv.Load "Function" %0 ["Aligned", 0] : f32
+ return
+}
+
+// -----
+
+func.func @aligned_load_non_power_of_two() -> () {
+ %0 = spirv.Variable : !spirv.ptr<f32, Function>
+ // expected-error at below {{'spirv.Load' op attribute 'alignment' failed to satisfy constraint: 32-bit signless integer attribute whose value is positive and whose value is a power of two > 0}}
+ %1 = spirv.Load "Function" %0 ["Aligned", 3] : f32
+ return
+}
+
+// -----
+
+//===----------------------------------------------------------------------===//
+// spirv.StoreOp
+//===----------------------------------------------------------------------===//
+
+func.func @aligned_store_non_positive(%arg0 : f32) -> () {
+ %0 = spirv.Variable : !spirv.ptr<f32, Function>
+ // expected-error at below {{'spirv.Store' op attribute 'alignment' failed to satisfy constraint: 32-bit signless integer attribute whose value is positive and whose value is a power of two > 0}}
+ spirv.Store "Function" %0, %arg0 ["Aligned", 0] : f32
+ return
+}
+
+// -----
+
+func.func @aligned_store_non_power_of_two(%arg0 : f32) -> () {
+ %0 = spirv.Variable : !spirv.ptr<f32, Function>
+ // expected-error at below {{'spirv.Store' op attribute 'alignment' failed to satisfy constraint: 32-bit signless integer attribute whose value is positive and whose value is a power of two > 0}}
+ spirv.Store "Function" %0, %arg0 ["Aligned", 3] : f32
----------------
kuhar wrote:
```suggestion
spirv.Store "Function" %0, %arg0 ["Aligned", 3] : f32
```
https://github.com/llvm/llvm-project/pull/155278
More information about the Mlir-commits
mailing list