[Mlir-commits] [mlir] [mlir][GPU] Implement ValueBoundsOpInterface for GPU ID operations (PR #122190)
Matthias Springer
llvmlistbot at llvm.org
Thu Jan 9 00:45:59 PST 2025
================
@@ -0,0 +1,150 @@
+// RUN: mlir-opt %s -pass-pipeline='builtin.module( \
+// RUN: func.func(test-affine-reify-value-bounds), \
+// RUN: gpu.module(llvm.func(test-affine-reify-value-bounds)), \
+// RUN: gpu.module(gpu.func(test-affine-reify-value-bounds)))' \
+// RUN: -verify-diagnostics \
+// RUN: -split-input-file | FileCheck %s
+
+// CHECK-LABEL: func @launch_func
+func.func @launch_func(%arg0 : index) {
+ %c0 = arith.constant 0 : index
+ %c1 = arith.constant 1 : index
+ %c2 = arith.constant 2 : index
+ %c4 = arith.constant 4 : index
+ %c64 = arith.constant 64 : index
+ gpu.launch blocks(%block_id_x, %block_id_y, %block_id_z) in (%grid_dim_x = %arg0, %grid_dim_y = %c4, %grid_dim_z = %c2)
+ threads(%thread_id_x, %thread_id_y, %thread_id_z) in (%block_dim_x = %c64, %block_dim_y = %c4, %block_dim_z = %c2) {
+
+ // Sanity checks:
+ // expected-error @below{{unknown}}
+ "test.compare" (%thread_id_x, %c1) {cmp = "EQ"} : (index, index) -> ()
+ // expected-remark @below{{false}}
+ "test.compare" (%thread_id_x, %c64) {cmp = "GE"} : (index, index) -> ()
+
+ // expected-remark @below{{true}}
+ "test.compare" (%grid_dim_x, %c1) {cmp = "GE"} : (index, index) -> ()
+ // expected-remark @below{{true}}
+ "test.compare" (%grid_dim_x, %arg0) {cmp = "EQ"} : (index, index) -> ()
+ // expected-remark @below{{true}}
+ "test.compare" (%grid_dim_y, %c4) {cmp = "EQ"} : (index, index) -> ()
+ // expected-remark @below{{true}}
+ "test.compare" (%grid_dim_z, %c2) {cmp = "EQ"} : (index, index) -> ()
+
+ // expected-remark @below{{true}}
+ "test.compare"(%block_id_x, %c0) {cmp = "GE"} : (index, index) -> ()
+ // expected-remark @below{{true}}
+ "test.compare"(%block_id_x, %arg0) {cmp = "LT"} : (index, index) -> ()
+ // expected-remark @below{{true}}
+ "test.compare"(%block_id_y, %c0) {cmp = "GE"} : (index, index) -> ()
+ // expected-remark @below{{true}}
+ "test.compare"(%block_id_y, %c4) {cmp = "LT"} : (index, index) -> ()
+ // expected-remark @below{{true}}
+ "test.compare"(%block_id_z, %c0) {cmp = "GE"} : (index, index) -> ()
+ // expected-remark @below{{true}}
+ "test.compare"(%block_id_z, %c2) {cmp = "LT"} : (index, index) -> ()
+
+ // expected-remark @below{{true}}
+ "test.compare" (%block_dim_x, %c64) {cmp = "EQ"} : (index, index) -> ()
+ // expected-remark @below{{true}}
+ "test.compare" (%block_dim_y, %c4) {cmp = "EQ"} : (index, index) -> ()
+ // expected-remark @below{{true}}
+ "test.compare" (%block_dim_z, %c2) {cmp = "EQ"} : (index, index) -> ()
+
+ // expected-remark @below{{true}}
+ "test.compare"(%thread_id_x, %c0) {cmp = "GE"} : (index, index) -> ()
+ // expected-remark @below{{true}}
+ "test.compare"(%thread_id_x, %c64) {cmp = "LT"} : (index, index) -> ()
+ // expected-remark @below{{true}}
+ "test.compare"(%thread_id_y, %c0) {cmp = "GE"} : (index, index) -> ()
+ // expected-remark @below{{true}}
+ "test.compare"(%thread_id_y, %c4) {cmp = "LT"} : (index, index) -> ()
+ // expected-remark @below{{true}}
+ "test.compare"(%thread_id_z, %c0) {cmp = "GE"} : (index, index) -> ()
+ // expected-remark @below{{true}}
+ "test.compare"(%thread_id_z, %c2) {cmp = "LT"} : (index, index) -> ()
+ gpu.terminator
----------------
matthias-springer wrote:
Can you add another check for `%thread_id_y < %block_dim_y` etc?
https://github.com/llvm/llvm-project/pull/122190
More information about the Mlir-commits
mailing list