Mercurial > hg > CbC > CbC_llvm
view mlir/lib/Target/LLVMIR/ConvertToLLVMIR.cpp @ 266:00f31e85ec16 default tip
Added tag current for changeset 31d058e83c98
author | Shinji KONO <kono@ie.u-ryukyu.ac.jp> |
---|---|
date | Sat, 14 Oct 2023 10:13:55 +0900 |
parents | 1f2b6ac9f198 |
children |
line wrap: on
line source
//===- ConvertToLLVMIR.cpp - MLIR to LLVM IR conversion -------------------===// // // 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 // //===----------------------------------------------------------------------===// // // This file implements a translation between the MLIR LLVM dialect and LLVM IR. // //===----------------------------------------------------------------------===// #include "mlir/Dialect/DLTI/DLTI.h" #include "mlir/Dialect/Func/IR/FuncOps.h" #include "mlir/IR/BuiltinOps.h" #include "mlir/Target/LLVM/NVVM/Target.h" #include "mlir/Target/LLVM/ROCDL/Target.h" #include "mlir/Target/LLVMIR/Dialect/All.h" #include "mlir/Target/LLVMIR/Export.h" #include "mlir/Tools/mlir-translate/Translation.h" #include "llvm/IR/LLVMContext.h" #include "llvm/IR/Module.h" using namespace mlir; namespace mlir { void registerToLLVMIRTranslation() { TranslateFromMLIRRegistration registration( "mlir-to-llvmir", "Translate MLIR to LLVMIR", [](Operation *op, raw_ostream &output) { llvm::LLVMContext llvmContext; auto llvmModule = translateModuleToLLVMIR(op, llvmContext); if (!llvmModule) return failure(); llvmModule->print(output, nullptr); return success(); }, [](DialectRegistry ®istry) { registry.insert<DLTIDialect, func::FuncDialect>(); registerNVVMTarget(registry); registerROCDLTarget(registry); registerAllToLLVMIRTranslations(registry); }); } } // namespace mlir