[Mlir-commits] [mlir] Add DialectInlinerInterface to QuantDialect (PR #172509)
Jonas Rickert
llvmlistbot at llvm.org
Tue Dec 16 08:16:12 PST 2025
https://github.com/jorickert created https://github.com/llvm/llvm-project/pull/172509
None
>From 50ade49aaa61425a37a9179aa48a88dd8cca7a51 Mon Sep 17 00:00:00 2001
From: Jonas Rickert <jonas.rickert at amd.com>
Date: Tue, 16 Dec 2025 09:11:00 -0700
Subject: [PATCH] Add DialectInlinerInterface to QuantDialect
Signed-off-by: Jonas Rickert <jonas.rickert at amd.com>
---
mlir/lib/Dialect/Quant/IR/QuantOps.cpp | 10 ++++++
mlir/test/Dialect/Quant/inlining.mlir | 47 ++++++++++++++++++++++++++
2 files changed, 57 insertions(+)
create mode 100644 mlir/test/Dialect/Quant/inlining.mlir
diff --git a/mlir/lib/Dialect/Quant/IR/QuantOps.cpp b/mlir/lib/Dialect/Quant/IR/QuantOps.cpp
index e23a0d6aba825..060707437334e 100644
--- a/mlir/lib/Dialect/Quant/IR/QuantOps.cpp
+++ b/mlir/lib/Dialect/Quant/IR/QuantOps.cpp
@@ -14,6 +14,7 @@
#include "mlir/IR/BuiltinTypes.h"
#include "mlir/IR/PatternMatch.h"
#include "mlir/IR/TypeUtilities.h"
+#include "mlir/Transforms/InliningUtils.h"
#include "mlir/Dialect/Quant/IR/QuantOpsDialect.cpp.inc"
@@ -183,6 +184,14 @@ LogicalResult verifyQuantizationOp(Operation *op, QuantizedType quantizedType,
return success();
}
+struct QuantInlinerInterface : public DialectInlinerInterface {
+ using DialectInlinerInterface::DialectInlinerInterface;
+ /// All quant dialect ops can be inlined.
+ bool isLegalToInline(Operation *, Region *, bool, IRMapping &) const final {
+ return true;
+ }
+};
+
} // namespace
//===----------------------------------------------------------------------===//
@@ -197,6 +206,7 @@ void QuantDialect::initialize() {
#include "mlir/Dialect/Quant/IR/QuantOps.cpp.inc"
>();
detail::addBytecodeInterface(this);
+ addInterfaces<QuantInlinerInterface>();
}
//===----------------------------------------------------------------------===//
diff --git a/mlir/test/Dialect/Quant/inlining.mlir b/mlir/test/Dialect/Quant/inlining.mlir
new file mode 100644
index 0000000000000..6cb06efc8b633
--- /dev/null
+++ b/mlir/test/Dialect/Quant/inlining.mlir
@@ -0,0 +1,47 @@
+// RUN: mlir-opt %s -inline | FileCheck %s
+
+!qalias = !quant.uniform<i8:f32, 2.0:10>
+
+func.func @inner_dcast_inlinable(%arg0: !qalias) -> f32 {
+ %0 = quant.dcast %arg0 : !qalias to f32
+ return %0 : f32
+}
+
+// CHECK-LABEL: func.func @test_inline_dcast(
+// CHECK-NOT: func.call
+// CHECK-NEXT: quant.dcast
+func.func @test_inline_dcast(%v: !qalias) -> f32 {
+ %0 = call @inner_dcast_inlinable(%v) : (!qalias) -> f32
+ return %0 : f32
+}
+
+
+
+func.func @inner_qcast_inlinable(%v: f32) -> !qalias {
+ %1 = quant.qcast %v : f32 to !qalias
+ return %1 : !qalias
+}
+
+// CHECK-LABEL: func.func @test_inline_qcast(
+// CHECK-NOT: func.call
+// CHECK-NEXT: quant.qcast
+func.func @test_inline_qcast(%v: f32) -> !qalias {
+ %0 = call @inner_qcast_inlinable(%v) : (f32) -> !qalias
+ return %0 : !qalias
+}
+
+func.func @inner_scast_inlinable(%v: i8) -> !qalias {
+ %1 = quant.scast %v : i8 to !qalias
+ return %1 : !qalias
+}
+
+// CHECK-LABEL: func.func @test_inline_scast(
+// CHECK-NOT: func.call
+// CHECK-NEXT: quant.scast
+func.func @test_inline_scast(%v: i8) -> !qalias {
+ %0 = call @inner_scast_inlinable(%v) : (i8) -> !qalias
+ return %0 : !qalias
+}
+
+
+
More information about the Mlir-commits
mailing list