FLANG
FIROpenACCTypeInterfaces.h
1//===- FIROpenACCTypeInterfaces.h -------------------------------*- 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// This file contains external dialect interfaces for FIR.
10//
11//===----------------------------------------------------------------------===//
12
13#ifndef FLANG_OPTIMIZER_OPENACC_FIROPENACCTYPEINTERFACES_H_
14#define FLANG_OPTIMIZER_OPENACC_FIROPENACCTYPEINTERFACES_H_
15
16#include "flang/Optimizer/Dialect/FIRType.h"
17#include "mlir/Dialect/OpenACC/OpenACC.h"
18
19namespace fir::acc {
20
21template <typename T>
23 : public mlir::acc::PointerLikeType::ExternalModel<
24 OpenACCPointerLikeModel<T>, T> {
25 mlir::Type getElementType(mlir::Type pointer) const {
26 return mlir::cast<T>(pointer).getElementType();
27 }
28 mlir::acc::VariableTypeCategory
29 getPointeeTypeCategory(mlir::Type pointer,
30 mlir::TypedValue<mlir::acc::PointerLikeType> varPtr,
31 mlir::Type varType) const;
32
33 mlir::Value genAllocate(mlir::Type pointer, mlir::OpBuilder &builder,
34 mlir::Location loc, llvm::StringRef varName,
35 mlir::Type varType, mlir::Value originalVar,
36 bool &needsFree) const;
37
38 bool genFree(mlir::Type pointer, mlir::OpBuilder &builder, mlir::Location loc,
39 mlir::TypedValue<mlir::acc::PointerLikeType> varToFree,
40 mlir::Value allocRes, mlir::Type varType) const;
41
42 bool genCopy(mlir::Type pointer, mlir::OpBuilder &builder, mlir::Location loc,
43 mlir::TypedValue<mlir::acc::PointerLikeType> destination,
44 mlir::TypedValue<mlir::acc::PointerLikeType> source,
45 mlir::Type varType) const;
46
47 mlir::Value genLoad(mlir::Type pointer, mlir::OpBuilder &builder,
48 mlir::Location loc,
49 mlir::TypedValue<mlir::acc::PointerLikeType> srcPtr,
50 mlir::Type valueType) const;
51
52 bool genStore(mlir::Type pointer, mlir::OpBuilder &builder,
53 mlir::Location loc, mlir::Value valueToStore,
54 mlir::TypedValue<mlir::acc::PointerLikeType> destPtr) const;
55
56 mlir::Value genCast(mlir::Type pointer, mlir::OpBuilder &builder,
57 mlir::Location loc, mlir::Value value,
58 mlir::Type resultType) const;
59
60 mlir::MemRefType getAsMemRefType(mlir::Type pointer,
61 mlir::ModuleOp module) const;
62
63 bool isDeviceData(mlir::Type pointer, mlir::Value var) const;
64};
65
66template <typename T>
68 : public mlir::acc::MappableType::ExternalModel<OpenACCMappableModel<T>,
69 T> {
70 mlir::TypedValue<mlir::acc::PointerLikeType> getVarPtr(::mlir::Type type,
71 mlir::Value var) const;
72
73 std::optional<llvm::TypeSize>
74 getSizeInBytes(mlir::Type type, mlir::Value var, mlir::ValueRange accBounds,
75 const mlir::DataLayout &dataLayout) const;
76
77 std::optional<int64_t>
78 getOffsetInBytes(mlir::Type type, mlir::Value var, mlir::ValueRange accBounds,
79 const mlir::DataLayout &dataLayout) const;
80
81 bool hasUnknownDimensions(mlir::Type type) const;
82
84 generateAccBounds(mlir::Type type, mlir::Value var,
85 mlir::OpBuilder &builder) const;
86
87 mlir::acc::VariableTypeCategory getTypeCategory(mlir::Type type,
88 mlir::Value var) const;
89
90 mlir::acc::VariableInfoAttr
91 genPrivateVariableInfo(mlir::Type type,
92 mlir::TypedValue<mlir::acc::MappableType> var) const;
93
94 mlir::Value generatePrivateInit(mlir::Type type, mlir::OpBuilder &builder,
95 mlir::Location loc,
96 mlir::TypedValue<mlir::acc::MappableType> var,
97 llvm::StringRef varName,
98 mlir::ValueRange extents, mlir::Value initVal,
99 mlir::acc::VariableInfoAttr varInfo,
100 bool &needsDestroy) const;
101
102 bool generatePrivateDestroy(mlir::Type type, mlir::OpBuilder &builder,
103 mlir::Location loc, mlir::Value privatized,
104 mlir::ValueRange bounds,
105 mlir::acc::VariableInfoAttr varInfo) const;
106
107 bool generateCopy(mlir::Type type, mlir::OpBuilder &mlirBuilder,
108 mlir::Location loc,
109 mlir::TypedValue<mlir::acc::MappableType> source,
110 mlir::TypedValue<mlir::acc::MappableType> dest,
111 mlir::ValueRange bounds,
112 mlir::acc::VariableInfoAttr varInfo) const;
113
114 bool generateCombiner(mlir::Type type, mlir::OpBuilder &mlirBuilder,
115 mlir::Location loc,
116 mlir::TypedValue<mlir::acc::MappableType> dest,
117 mlir::TypedValue<mlir::acc::MappableType> source,
118 mlir::ValueRange bounds,
119 mlir::acc::ReductionOperator op,
120 mlir::Attribute fastmathFlags) const;
121
122 bool isDeviceData(mlir::Type type, mlir::Value var) const;
123};
124
126 : public mlir::acc::ReducibleType::ExternalModel<
127 OpenACCReducibleLogicalModel, fir::LogicalType> {
128 std::optional<mlir::arith::AtomicRMWKind>
129 getAtomicRMWKind(mlir::Type type, mlir::acc::ReductionOperator redOp) const;
130};
131
132} // namespace fir::acc
133
134#endif // FLANG_OPTIMIZER_OPENACC_FIROPENACCTYPEINTERFACES_H_
Definition OpenACC.h:20
Definition FIROpenACCTypeInterfaces.h:69
Definition FIROpenACCTypeInterfaces.h:24
Definition FIROpenACCTypeInterfaces.h:127