[mlir][PDL] Use ODS for defining PDL types

This removes the need to define these classes and their parser/printers in C++.

Differential Revision: https://reviews.llvm.org/D94135
This commit is contained in:
River Riddle 2021-01-08 12:29:47 -08:00
parent 0386f3d4f4
commit e45840f4af
11 changed files with 156 additions and 105 deletions

View File

@ -13,11 +13,7 @@
#ifndef MLIR_DIALECT_PDL_IR_PDL_H_ #ifndef MLIR_DIALECT_PDL_IR_PDL_H_
#define MLIR_DIALECT_PDL_IR_PDL_H_ #define MLIR_DIALECT_PDL_IR_PDL_H_
#include "mlir/IR/Builders.h"
#include "mlir/IR/Dialect.h" #include "mlir/IR/Dialect.h"
#include "mlir/IR/OpImplementation.h"
#include "mlir/IR/SymbolTable.h"
#include "mlir/Interfaces/SideEffectInterfaces.h"
//===----------------------------------------------------------------------===// //===----------------------------------------------------------------------===//
// PDL Dialect // PDL Dialect
@ -25,12 +21,4 @@
#include "mlir/Dialect/PDL/IR/PDLOpsDialect.h.inc" #include "mlir/Dialect/PDL/IR/PDLOpsDialect.h.inc"
//===----------------------------------------------------------------------===//
// PDL Dialect Operations
//===----------------------------------------------------------------------===//
#define GET_OP_CLASSES
#include "mlir/Dialect/PDL/IR/PDLOps.h.inc"
#endif // MLIR_DIALECT_PDL_IR_PDL_H_ #endif // MLIR_DIALECT_PDL_IR_PDL_H_

View File

@ -1,4 +1,4 @@
//===- PDLBase.td - PDL base definitions -------------------*- tablegen -*-===// //===- PDLDialect.td - PDL dialect definition --------------*- tablegen -*-===//
// //
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information. // See https://llvm.org/LICENSE.txt for license information.
@ -6,12 +6,12 @@
// //
//===----------------------------------------------------------------------===// //===----------------------------------------------------------------------===//
// //
// Defines base support for MLIR PDL operations. // Defines the MLIR PDL dialect.
// //
//===----------------------------------------------------------------------===// //===----------------------------------------------------------------------===//
#ifndef MLIR_DIALECT_PDL_IR_PDLBASE #ifndef MLIR_DIALECT_PDL_IR_PDLDIALECT
#define MLIR_DIALECT_PDL_IR_PDLBASE #define MLIR_DIALECT_PDL_IR_PDLDIALECT
include "mlir/IR/OpBase.td" include "mlir/IR/OpBase.td"
@ -66,31 +66,4 @@ def PDL_Dialect : Dialect {
let cppNamespace = "::mlir::pdl"; let cppNamespace = "::mlir::pdl";
} }
//===----------------------------------------------------------------------===// #endif // MLIR_DIALECT_PDL_IR_PDLDIALECT
// PDL Types
//===----------------------------------------------------------------------===//
class PDL_Handle<string underlying> :
DialectType<PDL_Dialect, CPred<"$_self.isa<" # underlying # ">()">,
underlying>,
BuildableType<"$_builder.getType<" # underlying # ">()">;
// Handle for `mlir::Attribute`.
def PDL_Attribute : PDL_Handle<"mlir::pdl::AttributeType">;
// Handle for `mlir::Operation*`.
def PDL_Operation : PDL_Handle<"mlir::pdl::OperationType">;
// Handle for `mlir::Type`.
def PDL_Type : PDL_Handle<"mlir::pdl::TypeType">;
// Handle for `mlir::Value`.
def PDL_Value : PDL_Handle<"mlir::pdl::ValueType">;
// A positional value is a location on a pattern DAG, which may be an operation,
// an attribute, or an operand/result.
def PDL_PositionalValue :
AnyTypeOf<[PDL_Attribute, PDL_Operation, PDL_Type, PDL_Value],
"Positional Value">;
#endif // MLIR_DIALECT_PDL_IR_PDLBASE

View File

@ -0,0 +1,29 @@
//===- PDLOps.h - Pattern Descriptor Language Operations --------*- C++ -*-===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
//
// This file defines the operations for the Pattern Descriptor Language dialect.
//
//===----------------------------------------------------------------------===//
#ifndef MLIR_DIALECT_PDL_IR_PDLOPS_H_
#define MLIR_DIALECT_PDL_IR_PDLOPS_H_
#include "mlir/Dialect/PDL/IR/PDLTypes.h"
#include "mlir/IR/Builders.h"
#include "mlir/IR/OpImplementation.h"
#include "mlir/IR/SymbolTable.h"
#include "mlir/Interfaces/SideEffectInterfaces.h"
//===----------------------------------------------------------------------===//
// PDL Dialect Operations
//===----------------------------------------------------------------------===//
#define GET_OP_CLASSES
#include "mlir/Dialect/PDL/IR/PDLOps.h.inc"
#endif // MLIR_DIALECT_PDL_IR_PDLOPS_H_

View File

@ -13,7 +13,7 @@
#ifndef MLIR_DIALECT_PDL_IR_PDLOPS #ifndef MLIR_DIALECT_PDL_IR_PDLOPS
#define MLIR_DIALECT_PDL_IR_PDLOPS #define MLIR_DIALECT_PDL_IR_PDLOPS
include "mlir/Dialect/PDL/IR/PDLBase.td" include "mlir/Dialect/PDL/IR/PDLTypes.td"
include "mlir/Interfaces/SideEffectInterfaces.td" include "mlir/Interfaces/SideEffectInterfaces.td"
include "mlir/IR/SymbolInterfaces.td" include "mlir/IR/SymbolInterfaces.td"

View File

@ -1,4 +1,4 @@
//===- PDL.h - Pattern Descriptor Language Types ----------------*- C++ -*-===// //===- PDLTypes.h - Pattern Descriptor Language Types -----------*- C++ -*-===//
// //
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information. // See https://llvm.org/LICENSE.txt for license information.
@ -15,33 +15,11 @@
#include "mlir/IR/Types.h" #include "mlir/IR/Types.h"
namespace mlir {
namespace pdl {
//===----------------------------------------------------------------------===// //===----------------------------------------------------------------------===//
// PDL Dialect Types // PDL Dialect Types
//===----------------------------------------------------------------------===// //===----------------------------------------------------------------------===//
/// This type represents a handle to an `mlir::Attribute`. #define GET_TYPEDEF_CLASSES
struct AttributeType : public Type::TypeBase<AttributeType, Type, TypeStorage> { #include "mlir/Dialect/PDL/IR/PDLOpsTypes.h.inc"
using Base::Base;
};
/// This type represents a handle to an `mlir::Operation*`.
struct OperationType : public Type::TypeBase<OperationType, Type, TypeStorage> {
using Base::Base;
};
/// This type represents a handle to an `mlir::Type`.
struct TypeType : public Type::TypeBase<TypeType, Type, TypeStorage> {
using Base::Base;
};
/// This type represents a handle to an `mlir::Value`.
struct ValueType : public Type::TypeBase<ValueType, Type, TypeStorage> {
using Base::Base;
};
} // end namespace pdl
} // end namespace mlir
#endif // MLIR_DIALECT_PDL_IR_PDLTYPES_H_ #endif // MLIR_DIALECT_PDL_IR_PDLTYPES_H_

View File

@ -0,0 +1,84 @@
//===- PDLTypes.td - Pattern descriptor types --------------*- tablegen -*-===//
//
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
// See https://llvm.org/LICENSE.txt for license information.
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
//
//===----------------------------------------------------------------------===//
//
// This file declares the Pattern Descriptor Language dialect types.
//
//===----------------------------------------------------------------------===//
#ifndef MLIR_DIALECT_PDL_IR_PDLTYPES
#define MLIR_DIALECT_PDL_IR_PDLTYPES
include "mlir/Dialect/PDL/IR/PDLDialect.td"
//===----------------------------------------------------------------------===//
// PDL Types
//===----------------------------------------------------------------------===//
class PDL_Type<string name, string typeMnemonic> : TypeDef<PDL_Dialect, name> {
let mnemonic = typeMnemonic;
}
//===----------------------------------------------------------------------===//
// pdl::AttributeType
//===----------------------------------------------------------------------===//
def PDL_Attribute : PDL_Type<"Attribute", "attribute"> {
let summary = "PDL handle to an `mlir::Attribute`";
let description = [{
This type represents a handle to an instance of an `mlir::Attribute`, bound
to a value that is usable within a PDL pattern or rewrite.
}];
}
//===----------------------------------------------------------------------===//
// pdl::OperationType
//===----------------------------------------------------------------------===//
def PDL_Operation : PDL_Type<"Operation", "operation"> {
let summary = "PDL handle to an `mlir::Operation *`";
let description = [{
This type represents a handle to an instance of an `mlir::Operation *`,
bound to a value that is usable within a PDL pattern or rewrite.
}];
}
//===----------------------------------------------------------------------===//
// pdl::TypeType
//===----------------------------------------------------------------------===//
def PDL_Type : PDL_Type<"Type", "type"> {
let summary = "PDL handle to an `mlir::Type`";
let description = [{
This type represents a handle to an instance of an `mlir::Type`, bound to a
value that is usable within a PDL pattern or rewrite.
}];
}
//===----------------------------------------------------------------------===//
// pdl::ValueType
//===----------------------------------------------------------------------===//
def PDL_Value : PDL_Type<"Value", "value"> {
let summary = "PDL handle for an `mlir::Value`";
let description = [{
This type represents a handle to an instance of an `mlir::Value`, bound to a
value that is usable within a PDL pattern or rewrite.
}];
}
//===----------------------------------------------------------------------===//
// Additional Type Constraints
//===----------------------------------------------------------------------===//
// A positional value is a location on a pattern DAG, which may be an attribute,
// operation, or operand/result.
def PDL_PositionalValue :
AnyTypeOf<[PDL_Attribute, PDL_Operation, PDL_Type, PDL_Value],
"Positional Value">;
#endif // MLIR_DIALECT_PDL_IR_PDLTYPES

View File

@ -15,6 +15,7 @@
#define MLIR_DIALECT_PDLINTERP_IR_PDLINTERP_H_ #define MLIR_DIALECT_PDLINTERP_IR_PDLINTERP_H_
#include "mlir/Dialect/PDL/IR/PDL.h" #include "mlir/Dialect/PDL/IR/PDL.h"
#include "mlir/Dialect/PDL/IR/PDLTypes.h"
#include "mlir/Interfaces/InferTypeOpInterface.h" #include "mlir/Interfaces/InferTypeOpInterface.h"
#include "mlir/Interfaces/SideEffectInterfaces.h" #include "mlir/Interfaces/SideEffectInterfaces.h"

View File

@ -13,7 +13,7 @@
#ifndef MLIR_DIALECT_PDLINTERP_IR_PDLINTERPOPS #ifndef MLIR_DIALECT_PDLINTERP_IR_PDLINTERPOPS
#define MLIR_DIALECT_PDLINTERP_IR_PDLINTERPOPS #define MLIR_DIALECT_PDLINTERP_IR_PDLINTERPOPS
include "mlir/Dialect/PDL/IR/PDLBase.td" include "mlir/Dialect/PDL/IR/PDLTypes.td"
include "mlir/Interfaces/SideEffectInterfaces.td" include "mlir/Interfaces/SideEffectInterfaces.td"
//===----------------------------------------------------------------------===// //===----------------------------------------------------------------------===//

View File

@ -15,7 +15,7 @@
#define MLIR_LIB_CONVERSION_PDLTOPDLINTERP_PREDICATETREE_H_ #define MLIR_LIB_CONVERSION_PDLTOPDLINTERP_PREDICATETREE_H_
#include "Predicate.h" #include "Predicate.h"
#include "mlir/Dialect/PDL/IR/PDL.h" #include "mlir/Dialect/PDL/IR/PDLOps.h"
#include "llvm/ADT/MapVector.h" #include "llvm/ADT/MapVector.h"
namespace mlir { namespace mlir {

View File

@ -7,11 +7,13 @@
//===----------------------------------------------------------------------===// //===----------------------------------------------------------------------===//
#include "mlir/Dialect/PDL/IR/PDL.h" #include "mlir/Dialect/PDL/IR/PDL.h"
#include "mlir/Dialect/PDL/IR/PDLOps.h"
#include "mlir/Dialect/PDL/IR/PDLTypes.h" #include "mlir/Dialect/PDL/IR/PDLTypes.h"
#include "mlir/IR/BuiltinTypes.h" #include "mlir/IR/BuiltinTypes.h"
#include "mlir/IR/DialectImplementation.h" #include "mlir/IR/DialectImplementation.h"
#include "mlir/Interfaces/InferTypeOpInterface.h" #include "mlir/Interfaces/InferTypeOpInterface.h"
#include "llvm/ADT/StringSwitch.h" #include "llvm/ADT/StringSwitch.h"
#include "llvm/ADT/TypeSwitch.h"
using namespace mlir; using namespace mlir;
using namespace mlir::pdl; using namespace mlir::pdl;
@ -25,38 +27,10 @@ void PDLDialect::initialize() {
#define GET_OP_LIST #define GET_OP_LIST
#include "mlir/Dialect/PDL/IR/PDLOps.cpp.inc" #include "mlir/Dialect/PDL/IR/PDLOps.cpp.inc"
>(); >();
addTypes<AttributeType, OperationType, TypeType, ValueType>(); addTypes<
} #define GET_TYPEDEF_LIST
#include "mlir/Dialect/PDL/IR/PDLOpsTypes.cpp.inc"
Type PDLDialect::parseType(DialectAsmParser &parser) const { >();
StringRef keyword;
if (parser.parseKeyword(&keyword))
return Type();
Builder &builder = parser.getBuilder();
Type result = StringSwitch<Type>(keyword)
.Case("attribute", builder.getType<AttributeType>())
.Case("operation", builder.getType<OperationType>())
.Case("type", builder.getType<TypeType>())
.Case("value", builder.getType<ValueType>())
.Default(Type());
if (!result)
parser.emitError(parser.getNameLoc(), "invalid 'pdl' type: `")
<< keyword << "'";
return result;
}
void PDLDialect::printType(Type type, DialectAsmPrinter &printer) const {
if (type.isa<AttributeType>())
printer << "attribute";
else if (type.isa<OperationType>())
printer << "operation";
else if (type.isa<TypeType>())
printer << "type";
else if (type.isa<ValueType>())
printer << "value";
else
llvm_unreachable("unknown 'pdl' type");
} }
/// Returns true if the given operation is used by a "binding" pdl operation /// Returns true if the given operation is used by a "binding" pdl operation
@ -456,3 +430,27 @@ static LogicalResult verify(TypeOp op) {
#define GET_OP_CLASSES #define GET_OP_CLASSES
#include "mlir/Dialect/PDL/IR/PDLOps.cpp.inc" #include "mlir/Dialect/PDL/IR/PDLOps.cpp.inc"
//===----------------------------------------------------------------------===//
// TableGen'd type method definitions
//===----------------------------------------------------------------------===//
#define GET_TYPEDEF_CLASSES
#include "mlir/Dialect/PDL/IR/PDLOpsTypes.cpp.inc"
Type PDLDialect::parseType(DialectAsmParser &parser) const {
StringRef keyword;
if (parser.parseKeyword(&keyword))
return Type();
if (Type type = generatedTypeParser(getContext(), parser, keyword))
return type;
parser.emitError(parser.getNameLoc(), "invalid 'pdl' type: `")
<< keyword << "'";
return Type();
}
void PDLDialect::printType(Type type, DialectAsmPrinter &printer) const {
if (failed(generatedTypePrinter(type, printer)))
llvm_unreachable("unknown 'pdl' type");
}

View File

@ -9,7 +9,7 @@
#include "mlir/Rewrite/FrozenRewritePatternList.h" #include "mlir/Rewrite/FrozenRewritePatternList.h"
#include "ByteCode.h" #include "ByteCode.h"
#include "mlir/Conversion/PDLToPDLInterp/PDLToPDLInterp.h" #include "mlir/Conversion/PDLToPDLInterp/PDLToPDLInterp.h"
#include "mlir/Dialect/PDL/IR/PDL.h" #include "mlir/Dialect/PDL/IR/PDLOps.h"
#include "mlir/Interfaces/SideEffectInterfaces.h" #include "mlir/Interfaces/SideEffectInterfaces.h"
#include "mlir/Pass/Pass.h" #include "mlir/Pass/Pass.h"
#include "mlir/Pass/PassManager.h" #include "mlir/Pass/PassManager.h"