14 #ifndef MLIR_TARGET_LLVMIR_MODULEIMPORT_H
15 #define MLIR_TARGET_LLVMIR_MODULEIMPORT_H
26 class DbgVariableIntrinsic;
36 class DataLayoutImporter;
38 class LoopAnnotationImporter;
49 ModuleImport(ModuleOp mlirModule, std::unique_ptr<llvm::Module> llvmModule,
50 bool emitExpensiveWarnings,
bool importEmptyDICompositeTypes);
81 assert(
mlir ==
nullptr &&
82 "attempting to map a value that is already mapped");
102 assert(inst->getType()->isVoidTy() &&
103 "attempting to map an operation that returns a result");
104 assert(
mlir ==
nullptr &&
105 "attempting to map an operation that is already mapped");
114 return value.getDefiningOp();
115 return noResultOpMapping.lookup(inst);
120 auto result = blockMapping.try_emplace(
llvm,
mlir);
122 assert(result.second &&
"attempting to map a block that is already mapped");
127 return blockMapping.lookup(block);
167 FailureOr<SmallVector<AliasScopeAttr>>
230 return tbaaMapping.lookup(node);
236 FailureOr<SmallVector<AccessGroupAttr>>
247 FailureOr<SmallVector<AliasScopeAttr>>
262 bool requiresOpBundles,
270 void clearRegionState() {
271 valueMapping.clear();
272 noResultOpMapping.clear();
273 blockMapping.clear();
274 debugIntrinsics.clear();
277 void setConstantInsertionPointToStart(
Block *block) {
278 constantInsertionBlock = block;
279 constantInsertionOp =
nullptr;
284 LogicalResult convertGlobal(llvm::GlobalVariable *globalVar);
286 LogicalResult convertGlobalCtorsAndDtors(llvm::GlobalVariable *globalVar);
288 FlatSymbolRefAttr getPersonalityAsAttr(llvm::Function *func);
290 LogicalResult processBasicBlock(llvm::BasicBlock *bb, Block *block);
293 LogicalResult processDebugIntrinsics();
295 LogicalResult processDebugIntrinsic(llvm::DbgVariableIntrinsic *dbgIntr,
296 DominanceInfo &domInfo);
299 LogicalResult convertIntrinsic(llvm::CallInst *inst);
302 LogicalResult convertInstruction(llvm::Instruction *inst);
307 void setNonDebugMetadataAttrs(llvm::Instruction *inst, Operation *op);
311 LogicalResult processInstruction(llvm::Instruction *inst);
316 LogicalResult convertBranchArgs(llvm::Instruction *branch,
317 llvm::BasicBlock *target,
318 SmallVectorImpl<Value> &blockArguments);
322 LogicalResult convertCallTypeAndOperands(llvm::CallBase *callInst,
323 SmallVectorImpl<Type> &types,
324 SmallVectorImpl<Value> &operands);
327 void convertParameterAttributes(llvm::Function *func, LLVMFuncOp funcOp,
331 DictionaryAttr convertParameterAttribute(llvm::AttributeSet llvmParamAttrs,
336 Type getBuiltinTypeForAttr(Type type);
340 Attribute getConstantAsAttr(llvm::Constant *constant);
343 SetVector<llvm::Constant *> getConstantsToConvert(llvm::Constant *constant);
348 FailureOr<Value> convertConstant(llvm::Constant *constant);
354 FailureOr<Value> convertConstantExpr(llvm::Constant *constant);
358 ComdatOp getGlobalComdatOp();
364 LogicalResult processTBAAMetadata(
const llvm::MDNode *node);
369 LogicalResult processAccessGroupMetadata(
const llvm::MDNode *node);
374 LogicalResult processAliasScopeMetadata(
const llvm::MDNode *node);
378 void processComdat(
const llvm::Comdat *comdat);
382 getOrCreateNamelessSymbolName(llvm::GlobalVariable *globalVar);
387 Block *constantInsertionBlock =
nullptr;
389 Operation *constantInsertionOp =
nullptr;
391 Operation *globalInsertionOp =
nullptr;
393 ComdatOp globalComdatOp =
nullptr;
395 MLIRContext *context;
399 std::unique_ptr<llvm::Module> llvmModule;
401 DenseMap<llvm::GlobalVariable *, FlatSymbolRefAttr> namelessGlobals;
403 unsigned namelessGlobalId = 0;
407 LLVMImportInterface iface;
410 DenseMap<llvm::BasicBlock *, Block *> blockMapping;
412 DenseMap<llvm::Value *, Value> valueMapping;
416 DenseMap<llvm::Instruction *, Operation *> noResultOpMapping;
419 SetVector<llvm::Instruction *> debugIntrinsics;
422 DenseMap<const llvm::MDNode *, Attribute> aliasScopeMapping;
425 DenseMap<const llvm::MDNode *, Attribute> tbaaMapping;
428 DenseMap<const llvm::Comdat *, SymbolRefAttr> comdatMapping;
430 LLVM::TypeFromLLVMIRTranslator typeTranslator;
432 std::unique_ptr<detail::DebugImporter> debugImporter;
434 std::unique_ptr<detail::LoopAnnotationImporter> loopAnnotationImporter;
439 bool emitExpensiveWarnings;
Attributes are known-constant values of operations.
Block represents an ordered list of Operations.
LogicalResult initializeImport(llvm::LLVMContext &llvmContext)
Queries all registered dialect interfaces for the supported LLVM IR intrinsic and metadata kinds and ...
Module import implementation class that provides methods to import globals and functions from an LLVM...
LogicalResult convertIntrinsicArguments(ArrayRef< llvm::Value * > values, ArrayRef< llvm::OperandBundleUse > opBundles, bool requiresOpBundles, ArrayRef< unsigned > immArgPositions, ArrayRef< StringLiteral > immArgAttrNames, SmallVectorImpl< Value > &valuesOut, SmallVectorImpl< NamedAttribute > &attrsOut)
Converts the LLVM values for an intrinsic to mixed MLIR values and attributes for LLVM_IntrOpBase.
Location translateLoc(llvm::DILocation *loc)
Translates the debug location.
LogicalResult convertComdats()
Converts all comdat selectors of the LLVM module to MLIR comdat operations.
LogicalResult convertFunctions()
Converts all functions of the LLVM module to MLIR functions.
FailureOr< SmallVector< Value > > convertValues(ArrayRef< llvm::Value * > values)
Converts a range of LLVM values to a range of MLIR values using the convertValue method,...
Attribute lookupTBAAAttr(const llvm::MDNode *node) const
Returns the MLIR attribute mapped to the given LLVM TBAA metadata node.
DILocalVariableAttr matchLocalVariableAttr(llvm::Value *value)
Converts value to a local variable attribute.
LogicalResult convertLinkerOptionsMetadata()
Converts !llvm.linker.options metadata to the llvm.linker.options LLVM dialect operation.
void mapBlock(llvm::BasicBlock *llvm, Block *mlir)
Stores the mapping between an LLVM block and its MLIR counterpart.
void processFunctionAttributes(llvm::Function *func, LLVMFuncOp funcOp)
Converts function attributes of LLVM Function func into LLVM dialect attributes of LLVMFuncOp funcOp.
LogicalResult convertMetadata()
Converts all LLVM metadata nodes that translate to attributes such as alias analysis or access group ...
Value & mapValue(llvm::Value *value)
Provides write-once access to store the MLIR value corresponding to the given LLVM value.
FailureOr< Value > convertValue(llvm::Value *value)
Converts an LLVM value to an MLIR value, or returns failure if the conversion fails.
LogicalResult initializeImportInterface()
Calls the LLVMImportInterface initialization that queries the registered dialect interfaces for the s...
void addDebugIntrinsic(llvm::CallInst *intrinsic)
Adds a debug intrinsics to the list of intrinsics that should be converted after the function convers...
LogicalResult convertIdentMetadata()
Converts !llvm.ident metadata to the llvm.ident LLVM ModuleOp attribute.
Block * lookupBlock(llvm::BasicBlock *block) const
Returns the MLIR block mapped to the given LLVM block.
FailureOr< Value > convertMetadataValue(llvm::Value *value)
Converts an LLVM metadata value to an MLIR value, or returns failure if the conversion fails.
FailureOr< SmallVector< AliasScopeAttr > > lookupAliasScopeAttrs(const llvm::MDNode *node) const
Returns the alias scope attributes that map to the alias scope nodes starting from the metadata node.
void setDisjointFlag(llvm::Instruction *inst, Operation *op) const
Sets the disjoint flag attribute for the imported operation op given the original instruction inst.
void mapNoResultOp(llvm::Instruction *llvm, Operation *mlir)
Stores a mapping between an LLVM instruction and the imported MLIR operation if the operation returns...
void setExactFlag(llvm::Instruction *inst, Operation *op) const
Sets the exact flag attribute for the imported operation op given the original instruction inst.
Type convertType(llvm::Type *type)
Converts the type from LLVM to MLIR LLVM dialect.
Operation * lookupOperation(llvm::Instruction *inst)
Returns the MLIR operation mapped to the given LLVM instruction.
DILabelAttr matchLabelAttr(llvm::Value *value)
Converts value to a label attribute. Asserts if the matching fails.
FloatAttr matchFloatAttr(llvm::Value *value)
Converts value to a float attribute. Asserts if the matching fails.
LoopAnnotationAttr translateLoopAnnotationAttr(const llvm::MDNode *node, Location loc) const
Returns the loop annotation attribute that corresponds to the given LLVM loop metadata node.
void setFastmathFlagsAttr(llvm::Instruction *inst, Operation *op) const
Sets the fastmath flags attribute for the imported operation op given the original instruction inst.
FailureOr< SmallVector< AliasScopeAttr > > matchAliasScopeAttrs(llvm::Value *value)
Converts value to an array of alias scopes or returns failure if the conversion fails.
Value lookupValue(llvm::Value *value)
Returns the MLIR value mapped to the given LLVM value.
LogicalResult processFunction(llvm::Function *func)
Imports func into the current module.
RoundingModeAttr matchRoundingModeAttr(llvm::Value *value)
Converts value to a rounding mode attribute.
Operation *& mapNoResultOp(llvm::Instruction *inst)
Provides write-once access to store the MLIR operation corresponding to the given LLVM instruction if...
void mapValue(llvm::Value *llvm, Value mlir)
Stores the mapping between an LLVM value and its MLIR counterpart.
ModuleImport(ModuleOp mlirModule, std::unique_ptr< llvm::Module > llvmModule, bool emitExpensiveWarnings, bool importEmptyDICompositeTypes)
FailureOr< SmallVector< AccessGroupAttr > > lookupAccessGroupAttrs(const llvm::MDNode *node) const
Returns the access group attributes that map to the access group nodes starting from the access group...
LogicalResult convertGlobals()
Converts all global variables of the LLVM module to MLIR global variables.
void setIntegerOverflowFlags(llvm::Instruction *inst, Operation *op) const
Sets the integer overflow flags (nsw/nuw) attribute for the imported operation op given the original ...
LogicalResult convertCommandlineMetadata()
Converts !llvm.commandline metadata to the llvm.commandline LLVM ModuleOp attribute.
FPExceptionBehaviorAttr matchFPExceptionBehaviorAttr(llvm::Value *value)
Converts value to a FP exception behavior attribute.
void setNonNegFlag(llvm::Instruction *inst, Operation *op) const
Sets the nneg flag attribute for the imported operation op given the original instruction inst.
LogicalResult convertDataLayout()
Converts the data layout of the LLVM module to an MLIR data layout specification.
IntegerAttr matchIntegerAttr(llvm::Value *value)
Converts value to an integer attribute. Asserts if the matching fails.
Type translateType(llvm::Type *type)
Translates the given LLVM IR type to the MLIR LLVM dialect.
This class defines the main interface for locations in MLIR and acts as a non-nullable wrapper around...
Operation is the basic unit of execution within MLIR.
Instances of the Type class are uniqued, have an immutable identifier and an optional mutable compone...
This class represents an instance of an SSA value in the MLIR system, representing a computable value...
The OpAsmOpInterface, see OpAsmInterface.td for more details.
Include the generated interface declarations.