| //===- ConvertStandardToLLVM.h - Convert to the LLVM dialect ----*- 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 |
| // |
| //===----------------------------------------------------------------------===// |
| // |
| // Provides a dialect conversion targeting the LLVM IR dialect. By default, it |
| // converts Standard ops and types and provides hooks for dialect-specific |
| // extensions to the conversion. |
| // |
| //===----------------------------------------------------------------------===// |
| |
| #ifndef MLIR_CONVERSION_STANDARDTOLLVM_CONVERTSTANDARDTOLLVM_H |
| #define MLIR_CONVERSION_STANDARDTOLLVM_CONVERTSTANDARDTOLLVM_H |
| |
| namespace mlir { |
| |
| class MLIRContext; |
| class LLVMTypeConverter; |
| class RewritePatternSet; |
| |
| /// Collect the default pattern to convert a FuncOp to the LLVM dialect. If |
| /// `emitCWrappers` is set, the pattern will also produce functions |
| /// that pass memref descriptors by pointer-to-structure in addition to the |
| /// default unpacked form. |
| void populateStdToLLVMFuncOpConversionPattern(LLVMTypeConverter &converter, |
| RewritePatternSet &patterns); |
| |
| /// Collect the patterns to convert from the Standard dialect to LLVM. The |
| /// conversion patterns capture the LLVMTypeConverter and the LowerToLLVMOptions |
| /// by reference meaning the references have to remain alive during the entire |
| /// pattern lifetime. |
| void populateStdToLLVMConversionPatterns(LLVMTypeConverter &converter, |
| RewritePatternSet &patterns); |
| |
| } // namespace mlir |
| |
| #endif // MLIR_CONVERSION_STANDARDTOLLVM_CONVERTSTANDARDTOLLVM_H |