[Mlir-commits] [mlir] [mlir] Apply rule of five for Pass / OperationPass (PR #80998)
Andrei Golubev
llvmlistbot at llvm.org
Tue Feb 13 05:54:30 PST 2024
https://github.com/andrey-golubev updated https://github.com/llvm/llvm-project/pull/80998
>From 80c9a4e20ca30f99bb055e1c4c51cf8b812e290c Mon Sep 17 00:00:00 2001
From: "Golubev, Andrey" <andrey.golubev at intel.com>
Date: Wed, 7 Feb 2024 15:14:50 +0000
Subject: [PATCH] [mlir] Apply rule of five to *Pass classes
Define all special member functions for mlir::Pass, mlir::OperationPass
and PassGen types since mlir::Pass already provides a custom copy-ctor.
Given the nature of the types, however, mark other special member
functions deleted: the semantics of a Pass type object seems to be that
it is only ever created by being wrapped in a smart pointer.
The copy-ctor is special since this is the "delegating" ctor for derived
pass types to use during cloning.
Co-authored-by: Asya Pronina <anastasiya.pronina at intel.com>
Co-authored-by: Harald Rotuna <harald.razvan.rotuna at intel.com>
---
mlir/include/mlir/Pass/Pass.h | 9 +++++++++
mlir/tools/mlir-tblgen/PassGen.cpp | 8 ++++++++
2 files changed, 17 insertions(+)
diff --git a/mlir/include/mlir/Pass/Pass.h b/mlir/include/mlir/Pass/Pass.h
index 121b253eb83fea..d2d30a8a801cde 100644
--- a/mlir/include/mlir/Pass/Pass.h
+++ b/mlir/include/mlir/Pass/Pass.h
@@ -161,6 +161,9 @@ class Pass {
explicit Pass(TypeID passID, std::optional<StringRef> opName = std::nullopt)
: passID(passID), opName(opName) {}
Pass(const Pass &other) : Pass(other.passID, other.opName) {}
+ Pass &operator=(const Pass &) = delete;
+ Pass(Pass &&) = delete;
+ Pass &operator=(Pass &&) = delete;
/// Returns the current pass state.
detail::PassExecutionState &getPassState() {
@@ -352,6 +355,9 @@ class OperationPass : public Pass {
protected:
OperationPass(TypeID passID) : Pass(passID, OpT::getOperationName()) {}
OperationPass(const OperationPass &) = default;
+ OperationPass &operator=(const OperationPass &) = delete;
+ OperationPass(OperationPass &&) = delete;
+ OperationPass &operator=(OperationPass &&) = delete;
/// Support isa/dyn_cast functionality.
static bool classof(const Pass *pass) {
@@ -391,6 +397,9 @@ class OperationPass<void> : public Pass {
protected:
OperationPass(TypeID passID) : Pass(passID) {}
OperationPass(const OperationPass &) = default;
+ OperationPass &operator=(const OperationPass &) = delete;
+ OperationPass(OperationPass &&) = delete;
+ OperationPass &operator=(OperationPass &&) = delete;
/// Indicate if the current pass can be scheduled on the given operation type.
/// By default, generic operation passes can be scheduled on any operation.
diff --git a/mlir/tools/mlir-tblgen/PassGen.cpp b/mlir/tools/mlir-tblgen/PassGen.cpp
index 11af6497cecf50..90aa67115a4007 100644
--- a/mlir/tools/mlir-tblgen/PassGen.cpp
+++ b/mlir/tools/mlir-tblgen/PassGen.cpp
@@ -183,6 +183,10 @@ class {0}Base : public {1} {
{0}Base() : {1}(::mlir::TypeID::get<DerivedT>()) {{}
{0}Base(const {0}Base &other) : {1}(other) {{}
+ {0}Base& operator=(const {0}Base &) = delete;
+ {0}Base({0}Base &&) = delete;
+ {0}Base& operator=({0}Base &&) = delete;
+ ~{0}Base() = default;
/// Returns the command-line argument attached to this pass.
static constexpr ::llvm::StringLiteral getArgumentName() {
@@ -380,6 +384,10 @@ class {0}Base : public {1} {
{0}Base() : {1}(::mlir::TypeID::get<DerivedT>()) {{}
{0}Base(const {0}Base &other) : {1}(other) {{}
+ {0}Base& operator=(const {0}Base &) = delete;
+ {0}Base({0}Base &&) = delete;
+ {0}Base& operator=({0}Base &&) = delete;
+ ~{0}Base() = default;
/// Returns the command-line argument attached to this pass.
static constexpr ::llvm::StringLiteral getArgumentName() {
More information about the Mlir-commits
mailing list