16#include "llvm/ADT/SmallVectorExtras.h"
17#include "llvm/Support/DebugLog.h"
28 return FusedLoc::get(locs, metadata,
context);
72 return IntegerType::get(
context, width);
76 return IntegerType::get(
77 context, width, isSigned ? IntegerType::Signed : IntegerType::Unsigned);
81 return FunctionType::get(
context, inputs, results);
85 return GraphType::get(
context, inputs, results);
89 return TupleType::get(
context, elementTypes);
109 return DictionaryAttr::get(
context, value);
113 return IntegerAttr::get(
getIndexType(), APInt(64, value));
146 VectorType::get(
static_cast<float>(values.size()),
getF32Type()), values);
151 VectorType::get(
static_cast<double>(values.size()),
getF64Type()),
185 RankedTensorType::get(
static_cast<int64_t>(values.size()),
192 RankedTensorType::get(
static_cast<int64_t>(values.size()),
199 RankedTensorType::get(
static_cast<int64_t>(values.size()),
208 APInt(32, value,
true));
213 APInt(32, value,
true));
218 APInt(32, (uint64_t)value,
false));
229 APInt(8, value,
true));
234 return IntegerAttr::get(type, APInt(64, value));
243 return IntegerAttr::get(type, value);
247 return FloatAttr::get(
getF64Type(), APFloat(value));
251 return FloatAttr::get(
getF32Type(), APFloat(value));
259 return FloatAttr::get(type, value);
263 return FloatAttr::get(type, value);
267 return StringAttr::get(
context, bytes);
271 return ArrayAttr::get(
context, value);
275 auto attrs = llvm::map_to_vector<8>(
281 auto attrs = llvm::map_to_vector<8>(
286 auto attrs = llvm::map_to_vector<8>(
292 auto attrs = llvm::map_to_vector<8>(values, [
this](
int64_t v) ->
Attribute {
299 auto attrs = llvm::map_to_vector<8>(
305 auto attrs = llvm::map_to_vector<8>(
311 auto attrs = llvm::map_to_vector<8>(
317 auto attrs = llvm::map_to_vector<8>(
318 values, [](
Type v) ->
Attribute {
return TypeAttr::get(v); });
323 auto attrs = llvm::map_to_vector<8>(
329 if (llvm::isa<FloatType>(type))
331 if (llvm::isa<IndexType>(type))
333 if (llvm::dyn_cast<IntegerType>(type))
335 APInt(llvm::cast<IntegerType>(type).getWidth(), 0));
336 if (llvm::isa<RankedTensorType, VectorType>(type)) {
337 auto vtType = llvm::cast<ShapedType>(type);
338 auto element =
getZeroAttr(vtType.getElementType());
347 if (llvm::isa<FloatType>(type))
349 if (llvm::isa<IndexType>(type))
351 if (llvm::dyn_cast<IntegerType>(type))
353 APInt(llvm::cast<IntegerType>(type).getWidth(), 1));
354 if (llvm::isa<RankedTensorType, VectorType>(type)) {
355 auto vtType = llvm::cast<ShapedType>(type);
356 auto element =
getOneAttr(vtType.getElementType());
393 dimExprs.reserve(rank);
394 for (
unsigned i = 0; i < rank; ++i)
415 shiftedResults.push_back(resultExpr + shift);
427 block->getOperations().insert(insertPoint, op);
429 listener->notifyOperationInserted(op, {});
436 assert(parent &&
"expected valid parent region");
437 assert(argTypes.size() == locs.size() &&
"argument location mismatch");
439 insertPt = parent->
end();
442 b->addArguments(argTypes, locs);
447 listener->notifyBlockInserted(
b,
nullptr, {});
455 assert(insertBefore &&
"expected valid insertion block");
471 OperationState state(loc, opName, operands, types, attributes, successors,
479 assert(results.empty() &&
"expected empty results");
482 results.reserve(opResults.size());
483 auto cleanupFailure = [&] {
490 return cleanupFailure();
494 LDBG() <<
"Trying to fold: "
496 if (failed(op->
fold(foldResults)))
497 return cleanupFailure();
501 LDBG() <<
"Folded in place #" << count
504 }
while (foldResults.empty() && succeeded(op->
fold(foldResults)));
507 if (foldResults.empty())
516 for (
auto [foldResult, expectedType] :
517 llvm::zip_equal(foldResults, opResults.
getTypes())) {
520 if (
auto value = llvm::dyn_cast_if_present<Value>(foldResult)) {
521 results.push_back(value);
527 return cleanupFailure();
530 Attribute attr = cast<Attribute>(foldResult);
535 for (Operation *cst : generatedConstants)
537 return cleanupFailure();
541 generatedConstants.push_back(constOp);
542 results.push_back(constOp->getResult(0));
546 for (Operation *cst : generatedConstants)
550 if (materializedConstants)
551 *materializedConstants = std::move(generatedConstants);
561 for (
Block &
b : r.getBlocks())
578 listener->notifyOperationInserted(walkedOp, {});
590 return clone(op, mapper);
595 region.
cloneInto(&parent, before, mapping);
602 for (
auto it = mapping.
lookup(®ion.
front())->getIterator(); it != before;
604 listener->notifyBlockInserted(&*it,
nullptr,
607 listener->notifyOperationInserted(walkedOp, {});
static void notifyBlockInsertions(Operation *op, OpBuilder::Listener *listener)
Helper function that sends block insertion notifications for every block that is directly nested in t...
Base type for affine expression.
A multi-dimensional affine map Affine map's are immutable like Type's, and they are uniqued.
static AffineMap get(MLIRContext *context)
Returns a zero result affine map with no dimensions or symbols: () -> ().
unsigned getNumSymbols() const
unsigned getNumDims() const
ArrayRef< AffineExpr > getResults() const
unsigned getNumResults() const
Attributes are known-constant values of operations.
This class provides an abstraction over the different types of ranges over Blocks.
Block represents an ordered list of Operations.
Region * getParent() const
Provide a 'getParent' method for ilist_node_with_parent methods.
Special case of IntegerAttr to represent boolean integers, i.e., signless i1 integers.
static BoolAttr get(MLIRContext *context, bool value)
IntegerAttr getIndexAttr(int64_t value)
AffineMap getSingleDimShiftAffineMap(int64_t shift)
Returns a map that shifts its (single) input dimension by 'shift'.
ArrayAttr getIndexArrayAttr(ArrayRef< int64_t > values)
DenseF64ArrayAttr getDenseF64ArrayAttr(ArrayRef< double > values)
DenseI8ArrayAttr getDenseI8ArrayAttr(ArrayRef< int8_t > values)
IntegerAttr getI32IntegerAttr(int32_t value)
DenseI32ArrayAttr getDenseI32ArrayAttr(ArrayRef< int32_t > values)
DenseIntElementsAttr getBoolVectorAttr(ArrayRef< bool > values)
Vector-typed DenseIntElementsAttr getters. values must not be empty.
TupleType getTupleType(TypeRange elementTypes)
IntegerAttr getIntegerAttr(Type type, int64_t value)
FloatAttr getF64FloatAttr(double value)
AffineMap getShiftedAffineMap(AffineMap map, int64_t shift)
Returns an affine map that is a translation (shift) of all result expressions in 'map' by 'shift'.
ArrayAttr getI32ArrayAttr(ArrayRef< int32_t > values)
DenseI64ArrayAttr getDenseI64ArrayAttr(ArrayRef< int64_t > values)
FloatAttr getF16FloatAttr(float value)
FloatType getF8E5M2Type()
AffineMap getDimIdentityMap()
AffineMap getMultiDimIdentityMap(unsigned rank)
IntegerAttr getI16IntegerAttr(int16_t value)
DenseI16ArrayAttr getDenseI16ArrayAttr(ArrayRef< int16_t > values)
AffineExpr getAffineSymbolExpr(unsigned position)
DenseFPElementsAttr getF32VectorAttr(ArrayRef< float > values)
FloatAttr getFloatAttr(Type type, double value)
AffineExpr getAffineConstantExpr(int64_t constant)
DenseIntElementsAttr getI32TensorAttr(ArrayRef< int32_t > values)
Tensor-typed DenseIntElementsAttr getters.
FunctionType getFunctionType(TypeRange inputs, TypeRange results)
IntegerAttr getI64IntegerAttr(int64_t value)
IntegerType getIntegerType(unsigned width)
DenseIntElementsAttr getI64TensorAttr(ArrayRef< int64_t > values)
BoolAttr getBoolAttr(bool value)
StringAttr getStringAttr(const Twine &bytes)
AffineMap getEmptyAffineMap()
Returns a zero result affine map with no dimensions or symbols: () -> ().
IntegerAttr getSI32IntegerAttr(int32_t value)
Signed and unsigned integer attribute getters.
GraphType getGraphType(TypeRange inputs, TypeRange results)
TypedAttr getZeroAttr(Type type)
Location getFusedLoc(ArrayRef< Location > locs, Attribute metadata=Attribute())
AffineExpr getAffineDimExpr(unsigned position)
DenseIntElementsAttr getIndexTensorAttr(ArrayRef< int64_t > values)
AffineMap getConstantAffineMap(int64_t val)
Returns a single constant result affine map with 0 dimensions and 0 symbols.
ArrayAttr getTypeArrayAttr(TypeRange values)
FloatType getF8E8M0Type()
DenseIntElementsAttr getI32VectorAttr(ArrayRef< int32_t > values)
DenseF32ArrayAttr getDenseF32ArrayAttr(ArrayRef< float > values)
DenseIntElementsAttr getI64VectorAttr(ArrayRef< int64_t > values)
AffineMap getSymbolIdentityMap()
ArrayAttr getF64ArrayAttr(ArrayRef< double > values)
DenseFPElementsAttr getF64VectorAttr(ArrayRef< double > values)
ArrayAttr getArrayAttr(ArrayRef< Attribute > value)
MLIRContext * getContext() const
DenseBoolArrayAttr getDenseBoolArrayAttr(ArrayRef< bool > values)
Tensor-typed DenseArrayAttr getters.
ArrayAttr getI64ArrayAttr(ArrayRef< int64_t > values)
FloatAttr getF32FloatAttr(float value)
DictionaryAttr getDictionaryAttr(ArrayRef< NamedAttribute > value)
FloatType getF8E4M3FNType()
NamedAttribute getNamedAttr(StringRef name, Attribute val)
IntegerAttr getUI32IntegerAttr(uint32_t value)
IntegerAttr getI8IntegerAttr(int8_t value)
ArrayAttr getF32ArrayAttr(ArrayRef< float > values)
ArrayAttr getBoolArrayAttr(ArrayRef< bool > values)
ArrayAttr getStrArrayAttr(ArrayRef< StringRef > values)
DenseIntElementsAttr getIndexVectorAttr(ArrayRef< int64_t > values)
ArrayAttr getAffineMapArrayAttr(ArrayRef< AffineMap > values)
TypedAttr getOneAttr(Type type)
static DenseElementsAttr get(ShapedType type, ArrayRef< Attribute > values)
Constructs a dense elements attribute from an array of element values.
An attribute that represents a reference to a dense float vector or tensor object.
static DenseFPElementsAttr get(const ShapedType &type, Arg &&arg)
Get an instance of a DenseFPElementsAttr with the given arguments.
An attribute that represents a reference to a dense integer vector or tensor object.
static DenseIntElementsAttr get(const ShapedType &type, Arg &&arg)
Get an instance of a DenseIntElementsAttr with the given arguments.
Dialects are groups of MLIR operations, types and attributes, as well as behavior associated with the...
virtual Operation * materializeConstant(OpBuilder &builder, Attribute value, Type type, Location loc)
Registered hook to materialize a single constant operation from a given attribute value with the desi...
This is a utility class for mapping one set of IR entities to another.
auto lookup(T from) const
Lookup a mapped value within the map.
This class defines the main interface for locations in MLIR and acts as a non-nullable wrapper around...
NamedAttribute represents a combination of a name and an Attribute value.
This class helps build Operations.
Block * createBlock(Region *parent, Region::iterator insertPt={}, TypeRange argTypes={}, ArrayRef< Location > locs={})
Add new block with 'argTypes' arguments and set the insertion point to the end of it.
Operation * clone(Operation &op, IRMapping &mapper)
Creates a deep copy of the specified operation, remapping any operands that use values outside of the...
void setInsertionPointToEnd(Block *block)
Sets the insertion point to the end of the specified block.
void cloneRegionBefore(Region ®ion, Region &parent, Region::iterator before, IRMapping &mapping)
Clone the blocks that belong to "region" before the given position in another region "parent".
LogicalResult tryFold(Operation *op, SmallVectorImpl< Value > &results, SmallVectorImpl< Operation * > *materializedConstants=nullptr)
Attempts to fold the given operation and places new results within results.
Listener * listener
The optional listener for events of this builder.
Operation * create(const OperationState &state)
Creates an operation given the fields represented as an OperationState.
Operation * insert(Operation *op)
Insert the given operation at the current insertion point and return it.
Set of flags used to control the behavior of the various IR print methods (e.g.
A wrapper class that allows for printing an operation with a set of flags, useful to act as a "stream...
Operation is the basic unit of execution within MLIR.
Dialect * getDialect()
Return the dialect this operation is associated with, or nullptr if the associated dialect is not loa...
LogicalResult fold(ArrayRef< Attribute > operands, SmallVectorImpl< OpFoldResult > &results)
Attempt to fold this operation with the specified constant operand values.
Operation * clone(IRMapping &mapper, CloneOptions options=CloneOptions::all())
Create a deep copy of this operation, remapping any operands that use values outside of the operation...
Location getLoc()
The source location the operation was defined or derived from.
static Operation * create(Location location, OperationName name, TypeRange resultTypes, ValueRange operands, NamedAttrList &&attributes, OpaqueProperties properties, BlockRange successors, unsigned numRegions)
Create a new Operation with the specific fields.
MutableArrayRef< Region > getRegions()
Returns the regions held by this operation.
result_range getResults()
This class contains a list of basic blocks and a link to the parent operation it is attached to.
void cloneInto(Region *dest, IRMapping &mapper)
Clone the internal blocks from this region into dest.
BlockListType & getBlocks()
BlockListType::iterator iterator
This class implements the result iterators for the Operation class.
type_range getTypes() const
This class provides an abstraction over the various different ranges of value types.
Instances of the Type class are uniqued, have an immutable identifier and an optional mutable compone...
bool isSignedInteger() const
Return true if this is a signed integer type (with the specified width).
unsigned getIntOrFloatBitWidth() const
Return the bit width of an integer or a float type, assert failure on other types.
This class provides an abstraction over the different types of ranges over Values.
static DenseArrayAttrImpl get(MLIRContext *context, ArrayRef< bool > content)
Include the generated interface declarations.
bool matchPattern(Value value, const Pattern &pattern)
Entry point for matching a pattern over a Value.
detail::DenseArrayAttrImpl< int64_t > DenseI64ArrayAttr
detail::DenseArrayAttrImpl< int8_t > DenseI8ArrayAttr
detail::DenseArrayAttrImpl< int32_t > DenseI32ArrayAttr
AffineExpr getAffineConstantExpr(int64_t constant, MLIRContext *context)
detail::DenseArrayAttrImpl< double > DenseF64ArrayAttr
detail::DenseArrayAttrImpl< bool > DenseBoolArrayAttr
detail::DenseArrayAttrImpl< float > DenseF32ArrayAttr
detail::constant_op_matcher m_Constant()
Matches a constant foldable operation.
AffineExpr getAffineDimExpr(unsigned position, MLIRContext *context)
These free functions allow clients of the API to not use classes in detail.
detail::DenseArrayAttrImpl< int16_t > DenseI16ArrayAttr
AffineExpr getAffineSymbolExpr(unsigned position, MLIRContext *context)
This class represents a listener that may be used to hook into various actions within an OpBuilder.
virtual void notifyBlockInserted(Block *block, Region *previous, Region::iterator previousIt)
Notify the listener that the specified block was inserted.
This represents an operation in an abstracted form, suitable for use with the builder APIs.