xref: /llvm-project/flang/lib/Optimizer/Support/DataLayout.cpp (revision 27d9a479c09632db4fef8eac204764de97d52925)
1e59e8488SjeanPerier //===-- Optimizer/Support/DataLayout.cpp ----------------------------------===//
2e59e8488SjeanPerier //
3e59e8488SjeanPerier // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4e59e8488SjeanPerier // See https://llvm.org/LICENSE.txt for license information.
5e59e8488SjeanPerier // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6e59e8488SjeanPerier //
7e59e8488SjeanPerier //===----------------------------------------------------------------------===//
8e59e8488SjeanPerier 
9e59e8488SjeanPerier #include "flang/Optimizer/Support/DataLayout.h"
10e59e8488SjeanPerier #include "flang/Optimizer/Dialect/Support/FIRContext.h"
11e59e8488SjeanPerier #include "flang/Optimizer/Support/FatalError.h"
12e59e8488SjeanPerier #include "mlir/Dialect/DLTI/DLTI.h"
13e59e8488SjeanPerier #include "mlir/Dialect/LLVMIR/LLVMDialect.h"
14e59e8488SjeanPerier #include "mlir/IR/BuiltinOps.h"
15e59e8488SjeanPerier #include "mlir/Interfaces/DataLayoutInterfaces.h"
16e59e8488SjeanPerier #include "mlir/Support/LLVM.h"
17e59e8488SjeanPerier #include "mlir/Target/LLVMIR/Import.h"
18e59e8488SjeanPerier #include "llvm/IR/DataLayout.h"
19e59e8488SjeanPerier #include "llvm/MC/TargetRegistry.h"
20e59e8488SjeanPerier #include "llvm/Support/TargetSelect.h"
21e59e8488SjeanPerier #include "llvm/Target/TargetMachine.h"
22e59e8488SjeanPerier 
setMLIRDataLayout(mlir::ModuleOp mlirModule,const llvm::DataLayout & dl)23e59e8488SjeanPerier void fir::support::setMLIRDataLayout(mlir::ModuleOp mlirModule,
24e59e8488SjeanPerier                                      const llvm::DataLayout &dl) {
25e59e8488SjeanPerier   mlir::MLIRContext *context = mlirModule.getContext();
26e59e8488SjeanPerier   mlirModule->setAttr(
27e59e8488SjeanPerier       mlir::LLVM::LLVMDialect::getDataLayoutAttrName(),
28e59e8488SjeanPerier       mlir::StringAttr::get(context, dl.getStringRepresentation()));
29e59e8488SjeanPerier   mlir::DataLayoutSpecInterface dlSpec = mlir::translateDataLayout(dl, context);
30e59e8488SjeanPerier   mlirModule->setAttr(mlir::DLTIDialect::kDataLayoutAttrName, dlSpec);
31e59e8488SjeanPerier }
32e59e8488SjeanPerier 
setMLIRDataLayoutFromAttributes(mlir::ModuleOp mlirModule,bool allowDefaultLayout)33e59e8488SjeanPerier void fir::support::setMLIRDataLayoutFromAttributes(mlir::ModuleOp mlirModule,
34e59e8488SjeanPerier                                                    bool allowDefaultLayout) {
35e59e8488SjeanPerier   if (mlirModule.getDataLayoutSpec())
36e59e8488SjeanPerier     return; // Already set.
37e59e8488SjeanPerier   if (auto dataLayoutString = mlirModule->getAttrOfType<mlir::StringAttr>(
38e59e8488SjeanPerier           mlir::LLVM::LLVMDialect::getDataLayoutAttrName())) {
39e59e8488SjeanPerier     llvm::DataLayout llvmDataLayout(dataLayoutString);
40e59e8488SjeanPerier     fir::support::setMLIRDataLayout(mlirModule, llvmDataLayout);
41e59e8488SjeanPerier     return;
42e59e8488SjeanPerier   }
43e59e8488SjeanPerier   if (!allowDefaultLayout)
44e59e8488SjeanPerier     return;
45e59e8488SjeanPerier   llvm::DataLayout llvmDataLayout("");
46e59e8488SjeanPerier   fir::support::setMLIRDataLayout(mlirModule, llvmDataLayout);
47e59e8488SjeanPerier }
48*27d9a479SjeanPerier 
49*27d9a479SjeanPerier std::optional<mlir::DataLayout>
getOrSetDataLayout(mlir::ModuleOp mlirModule,bool allowDefaultLayout)50*27d9a479SjeanPerier fir::support::getOrSetDataLayout(mlir::ModuleOp mlirModule,
51*27d9a479SjeanPerier                                  bool allowDefaultLayout) {
52*27d9a479SjeanPerier   if (!mlirModule.getDataLayoutSpec()) {
53*27d9a479SjeanPerier     fir::support::setMLIRDataLayoutFromAttributes(mlirModule,
54*27d9a479SjeanPerier                                                   allowDefaultLayout);
55*27d9a479SjeanPerier     if (!mlirModule.getDataLayoutSpec()) {
56*27d9a479SjeanPerier       return std::nullopt;
57*27d9a479SjeanPerier     }
58*27d9a479SjeanPerier   }
59*27d9a479SjeanPerier   return mlir::DataLayout(mlirModule);
60*27d9a479SjeanPerier }
61