diff --git a/mlir/include/mlir/IR/Builders.h b/mlir/include/mlir/IR/Builders.h --- a/mlir/include/mlir/IR/Builders.h +++ b/mlir/include/mlir/IR/Builders.h @@ -373,6 +373,10 @@ template OpTy create(Location location, Args &&... args) { OperationState state(location, OpTy::getOperationName()); + if (!state.name.getAbstractOperation()) + llvm::report_fatal_error("Building op `" + + state.name.getStringRef().str() + + "` but it isn't registered in this MLIRContext"); OpTy::build(*this, state, std::forward(args)...); auto *op = createOperation(state); auto result = dyn_cast(op); @@ -389,6 +393,10 @@ // Create the operation without using 'createOperation' as we don't want to // insert it yet. OperationState state(location, OpTy::getOperationName()); + if (!state.name.getAbstractOperation()) + llvm::report_fatal_error("Building op `" + + state.name.getStringRef().str() + + "` but it isn't registered in this MLIRContext"); OpTy::build(*this, state, std::forward(args)...); Operation *op = Operation::create(state); diff --git a/mlir/lib/IR/MLIRContext.cpp b/mlir/lib/IR/MLIRContext.cpp --- a/mlir/lib/IR/MLIRContext.cpp +++ b/mlir/lib/IR/MLIRContext.cpp @@ -621,8 +621,9 @@ static Dialect &lookupDialectForSymbol(MLIRContext *ctx, TypeID typeID) { auto &impl = ctx->getImpl(); auto it = impl.registeredDialectSymbols.find(typeID); - assert(it != impl.registeredDialectSymbols.end() && - "symbol is not registered."); + if (it == impl.registeredDialectSymbols.end()) + llvm::report_fatal_error( + "Trying to create a type that was not registered in this MLIRContext."); return *it->second; }