[mlir] Finish removing Identifier from the C++ API

There have been a few API pieces remaining to allow for a smooth transition for
downstream users, but these have been up for a few months now. After this only
the C API will have reference to "Identifier", but those will be reworked in a followup.

The main updates are:
* Identifier -> StringAttr
* StringAttr::get requires the context as the first parameter
  - i.e. `Identifier::get("...", ctx)` -> `StringAttr::get(ctx, "...")`

Reviewed By: mehdi_amini

Differential Revision: https://reviews.llvm.org/D116626
This commit is contained in:
River Riddle 2022-01-12 11:20:18 -08:00
parent be1aeb818c
commit 56f62fbf73
13 changed files with 16 additions and 52 deletions

View File

@ -1,13 +1,12 @@
#include "mlir/IR/BuiltinAttributes.h" #include "mlir/IR/BuiltinAttributes.h"
#include "mlir/IR/BuiltinTypes.h" #include "mlir/IR/BuiltinTypes.h"
#include "mlir/IR/Identifier.h"
#include "mlir/IR/Location.h" #include "mlir/IR/Location.h"
#include "mlir/IR/MLIRContext.h" #include "mlir/IR/MLIRContext.h"
#include "mlir/IR/OperationSupport.h" #include "mlir/IR/OperationSupport.h"
mlir::MLIRContext Context; mlir::MLIRContext Context;
auto Identifier = mlir::Identifier::get("foo", &Context); auto Identifier = mlir::StringAttr::get(&Context, "foo");
mlir::OperationName OperationName("FooOp", &Context); mlir::OperationName OperationName("FooOp", &Context);
mlir::Type Type(nullptr); mlir::Type Type(nullptr);

View File

@ -81,7 +81,7 @@ mlir::Value Fortran::lower::FirOpBuilder::allocateLocal(
}); });
llvm::SmallVector<mlir::NamedAttribute, 2> attrs; llvm::SmallVector<mlir::NamedAttribute, 2> attrs;
if (asTarget) if (asTarget)
attrs.emplace_back(mlir::Identifier::get("target", getContext()), attrs.emplace_back(mlir::StringAttr::get(getContext(), "target"),
getUnitAttr()); getUnitAttr());
return create<fir::AllocaOp>(loc, ty, nm, llvm::None, indices, attrs); return create<fir::AllocaOp>(loc, ty, nm, llvm::None, indices, attrs);
} }
@ -175,9 +175,9 @@ mlir::Value Fortran::lower::FirOpBuilder::createConvert(mlir::Location loc,
fir::StringLitOp Fortran::lower::FirOpBuilder::createStringLit( fir::StringLitOp Fortran::lower::FirOpBuilder::createStringLit(
mlir::Location loc, mlir::Type eleTy, llvm::StringRef data) { mlir::Location loc, mlir::Type eleTy, llvm::StringRef data) {
auto strAttr = mlir::StringAttr::get(getContext(), data); auto strAttr = mlir::StringAttr::get(getContext(), data);
auto valTag = mlir::Identifier::get(fir::StringLitOp::value(), getContext()); auto valTag = mlir::StringAttr::get(getContext(), fir::StringLitOp::value());
mlir::NamedAttribute dataAttr(valTag, strAttr); mlir::NamedAttribute dataAttr(valTag, strAttr);
auto sizeTag = mlir::Identifier::get(fir::StringLitOp::size(), getContext()); auto sizeTag = mlir::StringAttr::get(getContext(), fir::StringLitOp::size());
mlir::NamedAttribute sizeAttr(sizeTag, getI64IntegerAttr(data.size())); mlir::NamedAttribute sizeAttr(sizeTag, getI64IntegerAttr(data.size()));
llvm::SmallVector<mlir::NamedAttribute, 2> attrs{dataAttr, sizeAttr}; llvm::SmallVector<mlir::NamedAttribute, 2> attrs{dataAttr, sizeAttr};
auto arrTy = auto arrTy =

View File

@ -162,7 +162,7 @@ mlir::Value fir::FirOpBuilder::allocateLocal(
llvm::SmallVector<mlir::NamedAttribute> attrs; llvm::SmallVector<mlir::NamedAttribute> attrs;
if (asTarget) if (asTarget)
attrs.emplace_back( attrs.emplace_back(
mlir::Identifier::get(fir::getTargetAttrName(), getContext()), mlir::StringAttr::get(getContext(), fir::getTargetAttrName()),
getUnitAttr()); getUnitAttr());
// Create the local variable. // Create the local variable.
if (name.empty()) { if (name.empty()) {
@ -298,9 +298,9 @@ fir::StringLitOp fir::FirOpBuilder::createStringLitOp(mlir::Location loc,
llvm::StringRef data) { llvm::StringRef data) {
auto type = fir::CharacterType::get(getContext(), 1, data.size()); auto type = fir::CharacterType::get(getContext(), 1, data.size());
auto strAttr = mlir::StringAttr::get(getContext(), data); auto strAttr = mlir::StringAttr::get(getContext(), data);
auto valTag = mlir::Identifier::get(fir::StringLitOp::value(), getContext()); auto valTag = mlir::StringAttr::get(getContext(), fir::StringLitOp::value());
mlir::NamedAttribute dataAttr(valTag, strAttr); mlir::NamedAttribute dataAttr(valTag, strAttr);
auto sizeTag = mlir::Identifier::get(fir::StringLitOp::size(), getContext()); auto sizeTag = mlir::StringAttr::get(getContext(), fir::StringLitOp::size());
mlir::NamedAttribute sizeAttr(sizeTag, getI64IntegerAttr(data.size())); mlir::NamedAttribute sizeAttr(sizeTag, getI64IntegerAttr(data.size()));
llvm::SmallVector<mlir::NamedAttribute> attrs{dataAttr, sizeAttr}; llvm::SmallVector<mlir::NamedAttribute> attrs{dataAttr, sizeAttr};
return create<fir::StringLitOp>(loc, llvm::ArrayRef<mlir::Type>{type}, return create<fir::StringLitOp>(loc, llvm::ArrayRef<mlir::Type>{type},

View File

@ -238,7 +238,7 @@ TEST_F(FIRBuilderTest, uniqueCFIdent) {
TEST_F(FIRBuilderTest, locationToLineNo) { TEST_F(FIRBuilderTest, locationToLineNo) {
auto builder = getBuilder(); auto builder = getBuilder();
auto loc = mlir::FileLineColLoc::get(builder.getIdentifier("file1"), 10, 5); auto loc = mlir::FileLineColLoc::get(builder.getStringAttr("file1"), 10, 5);
mlir::Value line = mlir::Value line =
fir::factory::locationToLineNo(builder, loc, builder.getI64Type()); fir::factory::locationToLineNo(builder, loc, builder.getI64Type());
checkIntegerConstant(line, builder.getI64Type(), 10); checkIntegerConstant(line, builder.getI64Type(), 10);
@ -260,7 +260,7 @@ TEST_F(FIRBuilderTest, hasDynamicSize) {
TEST_F(FIRBuilderTest, locationToFilename) { TEST_F(FIRBuilderTest, locationToFilename) {
auto builder = getBuilder(); auto builder = getBuilder();
auto loc = auto loc =
mlir::FileLineColLoc::get(builder.getIdentifier("file1.f90"), 10, 5); mlir::FileLineColLoc::get(builder.getStringAttr("file1.f90"), 10, 5);
mlir::Value locToFile = fir::factory::locationToFilename(builder, loc); mlir::Value locToFile = fir::factory::locationToFilename(builder, loc);
auto addrOp = dyn_cast<fir::AddrOfOp>(locToFile.getDefiningOp()); auto addrOp = dyn_cast<fir::AddrOfOp>(locToFile.getDefiningOp());
auto symbol = addrOp.symbol().getRootReference().getValue(); auto symbol = addrOp.symbol().getRootReference().getValue();

View File

@ -15,9 +15,6 @@
namespace mlir { namespace mlir {
class StringAttr; class StringAttr;
// TODO: Remove this when all usages have been replaced with StringAttr.
using Identifier = StringAttr;
/// Attributes are known-constant values of operations. /// Attributes are known-constant values of operations.
/// ///
/// Instances of the Attribute class are references to immortal key-value pairs /// Instances of the Attribute class are references to immortal key-value pairs

View File

@ -53,8 +53,6 @@ public:
MLIRContext *getContext() const { return context; } MLIRContext *getContext() const { return context; }
StringAttr getIdentifier(const Twine &str);
// Locations. // Locations.
Location getUnknownLoc(); Location getUnknownLoc();
Location getFusedLoc(ArrayRef<Location> locs, Location getFusedLoc(ArrayRef<Location> locs,

View File

@ -949,12 +949,6 @@ def Builtin_StringAttr : Builtin_Attr<"String"> {
return getValue().compare(rhs.getValue()); return getValue().compare(rhs.getValue());
} }
/// FIXME: Defined as part of transition of Identifier->StringAttr. Prefer
/// using the other `get` methods instead.
static StringAttr get(const Twine &str, MLIRContext *context) {
return get(context, str);
}
private: private:
/// Return an empty StringAttr with NoneType type. This is a special variant /// Return an empty StringAttr with NoneType type. This is a special variant
/// of the `get` method that is used by the MLIRContext to cache the /// of the `get` method that is used by the MLIRContext to cache the

View File

@ -1,20 +0,0 @@
//===- Identifier.h - MLIR Identifier Class ---------------------*- 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
//
//===----------------------------------------------------------------------===//
#ifndef MLIR_IR_IDENTIFIER_H
#define MLIR_IR_IDENTIFIER_H
#include "mlir/IR/BuiltinAttributes.h"
namespace mlir {
/// NOTICE: Identifier is deprecated and usages of it should be replaced with
/// StringAttr.
using Identifier = StringAttr;
} // namespace mlir
#endif

View File

@ -820,8 +820,8 @@ MlirLogicalResult mlirSymbolTableReplaceAllSymbolUses(MlirStringRef oldSymbol,
MlirOperation from) { MlirOperation from) {
auto *cppFrom = unwrap(from); auto *cppFrom = unwrap(from);
auto *context = cppFrom->getContext(); auto *context = cppFrom->getContext();
auto oldSymbolAttr = StringAttr::get(unwrap(oldSymbol), context); auto oldSymbolAttr = StringAttr::get(context, unwrap(oldSymbol));
auto newSymbolAttr = StringAttr::get(unwrap(newSymbol), context); auto newSymbolAttr = StringAttr::get(context, unwrap(newSymbol));
return wrap(SymbolTable::replaceAllSymbolUses(oldSymbolAttr, newSymbolAttr, return wrap(SymbolTable::replaceAllSymbolUses(oldSymbolAttr, newSymbolAttr,
unwrap(from))); unwrap(from)));
} }

View File

@ -1182,12 +1182,12 @@ static void populateVectorizationPatterns(
ConvOp::getOperationName(), context, ConvOp::getOperationName(), context,
LinalgTilingOptions().setTileSizes(tileSizes), LinalgTilingOptions().setTileSizes(tileSizes),
LinalgTransformationFilter(ArrayRef<StringAttr>{}, LinalgTransformationFilter(ArrayRef<StringAttr>{},
StringAttr::get(kTiledMarker, context))); StringAttr::get(context, kTiledMarker)));
promotionPatterns.add<LinalgPromotionPattern<ConvOp>>( promotionPatterns.add<LinalgPromotionPattern<ConvOp>>(
context, LinalgPromotionOptions().setUseFullTileBuffersByDefault(true), context, LinalgPromotionOptions().setUseFullTileBuffersByDefault(true),
LinalgTransformationFilter(StringAttr::get(kTiledMarker, context), LinalgTransformationFilter(StringAttr::get(context, kTiledMarker),
StringAttr::get(kPromotedMarker, context))); StringAttr::get(context, kPromotedMarker)));
SmallVector<bool, 4> mask(N); SmallVector<bool, 4> mask(N);
int offset = tileSizes.size() - N; int offset = tileSizes.size() - N;

View File

@ -19,10 +19,6 @@
using namespace mlir; using namespace mlir;
StringAttr Builder::getIdentifier(const Twine &str) {
return getStringAttr(str);
}
//===----------------------------------------------------------------------===// //===----------------------------------------------------------------------===//
// Locations. // Locations.
//===----------------------------------------------------------------------===// //===----------------------------------------------------------------------===//

View File

@ -109,7 +109,7 @@ struct OpPassManagerImpl {
/// Return the operation name of this pass manager as an identifier. /// Return the operation name of this pass manager as an identifier.
StringAttr getOpName(MLIRContext &context) { StringAttr getOpName(MLIRContext &context) {
if (!identifier) if (!identifier)
identifier = StringAttr::get(name, &context); identifier = StringAttr::get(&context, name);
return *identifier; return *identifier;
} }

View File

@ -59,7 +59,7 @@ void TestLinalgDistribution::runOnFunction() {
distributeTiledLoopsPatterns, getDistributionOptions(), distributeTiledLoopsPatterns, getDistributionOptions(),
LinalgTransformationFilter( LinalgTransformationFilter(
ArrayRef<StringAttr>{}, ArrayRef<StringAttr>{},
{StringAttr::get("distributed", funcOp.getContext())}) {StringAttr::get(funcOp.getContext(), "distributed")})
.addFilter([](Operation *op) { .addFilter([](Operation *op) {
return success(!op->getParentOfType<linalg::TiledLoopOp>()); return success(!op->getParentOfType<linalg::TiledLoopOp>());
})); }));