Files
clang-p2996/mlir/lib/Conversion/ShapeToStandard/ShapeToStandard.td
River Riddle 1d7120c69a [mlir] Split out AttrDef/TypeDef and pattern constructs from OpBase.td
OpBase.td has formed into a huge monolith of all ODS constructs. This
commits starts to rectify that by splitting out some constructs to their
own .td files.

Differential Revision: https://reviews.llvm.org/D118636
2022-03-15 00:18:03 -07:00

36 lines
1.2 KiB
TableGen

//==-- ShapeToStandard.td - Shape to Standard Patterns -------*- 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
//
//===----------------------------------------------------------------------===//
//
// Defines Patterns to lower Shape ops to Std.
//
//===----------------------------------------------------------------------===//
#ifndef MLIR_CONVERSION_SHAPETOSTANDARD_TD
#define MLIR_CONVERSION_SHAPETOSTANDARD_TD
include "mlir/IR/PatternBase.td"
include "mlir/Dialect/Shape/IR/ShapeOps.td"
def BroadcastableStringAttr : NativeCodeCall<[{
$_builder.getStringAttr("required broadcastable shapes")
}]>;
def CstrBroadcastableToRequire : Pat<(Shape_CstrBroadcastableOp $shapes),
(Shape_CstrRequireOp
(Shape_IsBroadcastableOp $shapes),
(BroadcastableStringAttr))>;
def EqStringAttr : NativeCodeCall<[{
$_builder.getStringAttr("required equal shapes")
}]>;
def CstrEqToRequire : Pat<(Shape_CstrEqOp $shapes),
(Shape_CstrRequireOp (Shape_ShapeEqOp $shapes), (EqStringAttr))>;
#endif // MLIR_CONVERSION_SHAPETOSTANDARD_TD