[mlir][sparse] add test that combines sparse codegen and lowering to llvm struct
authorAart Bik <ajcbik@google.com>
Wed, 4 Jan 2023 19:33:51 +0000 (11:33 -0800)
committerAart Bik <ajcbik@google.com>
Wed, 4 Jan 2023 20:12:31 +0000 (12:12 -0800)
Reviewed By: bixia

Differential Revision: https://reviews.llvm.org/D141006

mlir/test/Dialect/SparseTensor/codegen_to_llvm.mlir [new file with mode: 0644]

diff --git a/mlir/test/Dialect/SparseTensor/codegen_to_llvm.mlir b/mlir/test/Dialect/SparseTensor/codegen_to_llvm.mlir
new file mode 100644 (file)
index 0000000..50e3a44
--- /dev/null
@@ -0,0 +1,14 @@
+// RUN: mlir-opt %s --sparse-tensor-codegen --sparse-storage-specifier-to-llvm | FileCheck %s
+
+#SparseVector = #sparse_tensor.encoding<{ dimLevelType = ["compressed"] }>
+
+// CHECK-LABEL: func @sparse_nop(
+//  CHECK-SAME: %[[A0:.*0]]: memref<?xindex>,
+//  CHECK-SAME: %[[A1:.*1]]: memref<?xindex>,
+//  CHECK-SAME: %[[A2:.*2]]: memref<?xf64>,
+//  CHECK-SAME: %[[A3:.*3]]: !llvm.struct<(array<1 x i64>, array<3 x i64>)>)
+//       CHECK: return %[[A0]], %[[A1]], %[[A2]], %[[A3]] :
+//  CHECK-SAME: memref<?xindex>, memref<?xindex>, memref<?xf64>, !llvm.struct<(array<1 x i64>, array<3 x i64>)>
+func.func @sparse_nop(%arg0: tensor<?xf64, #SparseVector>) -> tensor<?xf64, #SparseVector> {
+  return %arg0 : tensor<?xf64, #SparseVector>
+}