[Mlir-commits] [mlir] 38fcf62 - [MLIR] Import LLVM add flag to disable loadalldialects (#122574)
llvmlistbot at llvm.org
llvmlistbot at llvm.org
Sat Jan 11 06:11:26 PST 2025
Author: William Moses
Date: 2025-01-11T09:11:22-05:00
New Revision: 38fcf62483907aa48325e60d1f685805e846c6ea
URL: https://github.com/llvm/llvm-project/commit/38fcf62483907aa48325e60d1f685805e846c6ea
DIFF: https://github.com/llvm/llvm-project/commit/38fcf62483907aa48325e60d1f685805e846c6ea.diff
LOG: [MLIR] Import LLVM add flag to disable loadalldialects (#122574)
Co-authored-by: Oleksandr "Alex" Zinenko <ftynse at gmail.com>
Added:
Modified:
mlir/include/mlir/Target/LLVMIR/Import.h
mlir/lib/Target/LLVMIR/ModuleImport.cpp
Removed:
################################################################################
diff --git a/mlir/include/mlir/Target/LLVMIR/Import.h b/mlir/include/mlir/Target/LLVMIR/Import.h
index 4a1242a8eb0590..4aa8f2ab7d8ce7 100644
--- a/mlir/include/mlir/Target/LLVMIR/Import.h
+++ b/mlir/include/mlir/Target/LLVMIR/Import.h
@@ -39,10 +39,13 @@ class ModuleOp;
/// be imported without elements. If set, the option avoids the recursive
/// traversal of composite type debug information, which can be expensive for
/// adversarial inputs.
+/// The `loadAllDialects` flag (default on) will load all dialects in the
+/// context.
OwningOpRef<ModuleOp>
translateLLVMIRToModule(std::unique_ptr<llvm::Module> llvmModule,
MLIRContext *context, bool emitExpensiveWarnings = true,
- bool dropDICompositeTypeElements = false);
+ bool dropDICompositeTypeElements = false,
+ bool loadAllDialects = true);
/// Translate the given LLVM data layout into an MLIR equivalent using the DLTI
/// dialect.
diff --git a/mlir/lib/Target/LLVMIR/ModuleImport.cpp b/mlir/lib/Target/LLVMIR/ModuleImport.cpp
index 2d8d7745eca9bb..eba86f06d09056 100644
--- a/mlir/lib/Target/LLVMIR/ModuleImport.cpp
+++ b/mlir/lib/Target/LLVMIR/ModuleImport.cpp
@@ -2325,7 +2325,8 @@ ModuleImport::translateLoopAnnotationAttr(const llvm::MDNode *node,
OwningOpRef<ModuleOp>
mlir::translateLLVMIRToModule(std::unique_ptr<llvm::Module> llvmModule,
MLIRContext *context, bool emitExpensiveWarnings,
- bool dropDICompositeTypeElements) {
+ bool dropDICompositeTypeElements,
+ bool loadAllDialects) {
// Preload all registered dialects to allow the import to iterate the
// registered LLVMImportDialectInterface implementations and query the
// supported LLVM IR constructs before starting the translation. Assumes the
@@ -2335,7 +2336,8 @@ mlir::translateLLVMIRToModule(std::unique_ptr<llvm::Module> llvmModule,
LLVMDialect::getDialectNamespace()));
assert(llvm::is_contained(context->getAvailableDialects(),
DLTIDialect::getDialectNamespace()));
- context->loadAllAvailableDialects();
+ if (loadAllDialects)
+ context->loadAllAvailableDialects();
OwningOpRef<ModuleOp> module(ModuleOp::create(FileLineColLoc::get(
StringAttr::get(context, llvmModule->getSourceFileName()), /*line=*/0,
/*column=*/0)));
More information about the Mlir-commits
mailing list