MLIR  20.0.0git
ToLLVMInterface.h
Go to the documentation of this file.
1 //===- ToLLVMInterface.h - Conversion to LLVM iface ---*- C++ -*-=============//
2 //
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6 //
7 //===----------------------------------------------------------------------===//
8 
9 #ifndef MLIR_CONVERSION_CONVERTTOLLVM_TOLLVMINTERFACE_H
10 #define MLIR_CONVERSION_CONVERTTOLLVM_TOLLVMINTERFACE_H
11 
13 #include "mlir/IR/MLIRContext.h"
14 #include "mlir/IR/OpDefinition.h"
15 
16 namespace mlir {
17 class ConversionTarget;
18 class LLVMTypeConverter;
19 class MLIRContext;
20 class Operation;
21 class RewritePatternSet;
22 class AnalysisManager;
23 
24 /// Base class for dialect interfaces providing translation to LLVM IR.
25 /// Dialects that can be translated should provide an implementation of this
26 /// interface for the supported operations. The interface may be implemented in
27 /// a separate library to avoid the "main" dialect library depending on LLVM IR.
28 /// The interface can be attached using the delayed registration mechanism
29 /// available in DialectRegistry.
31  : public DialectInterface::Base<ConvertToLLVMPatternInterface> {
32 public:
33  ConvertToLLVMPatternInterface(Dialect *dialect) : Base(dialect) {}
34 
35  /// Hook for derived dialect interface to load the dialects they
36  /// target. The LLVMDialect is implicitly already loaded, but this
37  /// method allows to load other intermediate dialects used in the
38  /// conversion, or target dialects like NVVM for example.
39  virtual void loadDependentDialects(MLIRContext *context) const {}
40 
41  /// Hook for derived dialect interface to provide conversion patterns
42  /// and mark dialect legal for the conversion target.
44  ConversionTarget &target, LLVMTypeConverter &typeConverter,
45  RewritePatternSet &patterns) const = 0;
46 };
47 
48 /// Recursively walk the IR and collect all dialects implementing the interface,
49 /// and populate the conversion patterns.
51  ConversionTarget &target,
52  LLVMTypeConverter &typeConverter,
54 
55 /// Helper function for populating LLVM conversion patterns. If `op` implements
56 /// the `ConvertToLLVMOpInterface` interface, then the LLVM conversion pattern
57 /// attributes provided by the interface will be used to configure the
58 /// conversion target, type converter, and the pattern set.
60  ConversionTarget &target,
61  LLVMTypeConverter &typeConverter,
63 } // namespace mlir
64 
65 #include "mlir/Conversion/ConvertToLLVM/ToLLVMAttrInterface.h.inc"
66 
67 #include "mlir/Conversion/ConvertToLLVM/ToLLVMOpInterface.h.inc"
68 
69 #endif // MLIR_CONVERSION_CONVERTTOLLVM_TOLLVMINTERFACE_H
This class describes a specific conversion target.
Base class for dialect interfaces providing translation to LLVM IR.
virtual void populateConvertToLLVMConversionPatterns(ConversionTarget &target, LLVMTypeConverter &typeConverter, RewritePatternSet &patterns) const =0
Hook for derived dialect interface to provide conversion patterns and mark dialect legal for the conv...
virtual void loadDependentDialects(MLIRContext *context) const
Hook for derived dialect interface to load the dialects they target.
ConvertToLLVMPatternInterface(Dialect *dialect)
Dialects are groups of MLIR operations, types and attributes, as well as behavior associated with the...
Definition: Dialect.h:38
Conversion from types to the LLVM IR dialect.
Definition: TypeConverter.h:35
MLIRContext is the top-level object for a collection of MLIR operations.
Definition: MLIRContext.h:60
Operation is the basic unit of execution within MLIR.
Definition: Operation.h:88
The base class used for all derived interface types.
Include the generated interface declarations.
void populateConversionTargetFromOperation(Operation *op, ConversionTarget &target, LLVMTypeConverter &typeConverter, RewritePatternSet &patterns)
Recursively walk the IR and collect all dialects implementing the interface, and populate the convers...
const FrozenRewritePatternSet & patterns
void populateOpConvertToLLVMConversionPatterns(Operation *op, ConversionTarget &target, LLVMTypeConverter &typeConverter, RewritePatternSet &patterns)
Helper function for populating LLVM conversion patterns.