9#ifndef FORTRAN_OPTIMIZER_DIALECT_FIROPS_H
10#define FORTRAN_OPTIMIZER_DIALECT_FIROPS_H
12#include "flang/Optimizer/Dialect/CUF/Attributes/CUFAttr.h"
13#include "flang/Optimizer/Dialect/FIRAttr.h"
14#include "flang/Optimizer/Dialect/FIRType.h"
15#include "flang/Optimizer/Dialect/FirAliasTagOpInterface.h"
16#include "flang/Optimizer/Dialect/FortranVariableInterface.h"
17#include "flang/Optimizer/Dialect/SafeTempArrayCopyAttrInterface.h"
18#include "mlir/Dialect/Arith/IR/Arith.h"
19#include "mlir/Dialect/Func/IR/FuncOps.h"
20#include "mlir/Dialect/LLVMIR/LLVMAttrs.h"
21#include "mlir/Interfaces/LoopLikeInterface.h"
22#include "mlir/Interfaces/SideEffectInterfaces.h"
23#include "mlir/Interfaces/ViewLikeInterface.h"
31void buildCmpCOp(mlir::OpBuilder &builder, mlir::OperationState &result,
32 mlir::arith::CmpFPredicate predicate, mlir::Value lhs,
34unsigned getCaseArgumentOffset(llvm::ArrayRef<mlir::Attribute> cases,
36DoLoopOp getForInductionVarOwner(mlir::Value val);
37mlir::ParseResult isValidCaseAttr(mlir::Attribute attr);
38mlir::ParseResult parseCmpcOp(mlir::OpAsmParser &parser,
39 mlir::OperationState &result);
40mlir::ParseResult parseSelector(mlir::OpAsmParser &parser,
41 mlir::OperationState &result,
42 mlir::OpAsmParser::UnresolvedOperand &selector,
44bool useStrictVolatileVerification();
46static constexpr llvm::StringRef getNormalizedLowerBoundAttrName() {
47 return "normalized.lb";
52 :
public mlir::SideEffects::Resource::Base<DebuggingResource> {
53 mlir::StringRef getName()
final {
return "DebuggingResource"; }
58 :
public mlir::SideEffects::Resource::Base<VolatileMemoryResource> {
59 mlir::StringRef getName()
final {
return "VolatileMemoryResource"; }
63using IntOrValue = llvm::PointerUnion<mlir::IntegerAttr, mlir::Value>;
68#include "flang/Optimizer/Dialect/FIROps.h.inc"
71class CoordinateIndicesAdaptor {
73 using value_type = IntOrValue;
75 CoordinateIndicesAdaptor(mlir::DenseI32ArrayAttr fieldIndices,
76 mlir::ValueRange values)
77 : fieldIndices(fieldIndices), values(values) {}
79 value_type operator[](
size_t index)
const {
80 assert(index < size() &&
"index out of bounds");
81 return *std::next(begin(), index);
85 return fieldIndices ? fieldIndices.size() : values.size();
89 return values.empty() && (!fieldIndices || fieldIndices.empty());
93 :
public llvm::iterator_facade_base<iterator, std::forward_iterator_tag,
94 value_type, std::ptrdiff_t,
95 value_type *, value_type> {
97 iterator(
const CoordinateIndicesAdaptor *base,
99 llvm::detail::IterOfRange<const mlir::ValueRange> valuesIter)
100 : base(base), fieldIter(fieldIter), valuesIter(valuesIter) {}
102 value_type operator*()
const {
103 if (fieldIter && **fieldIter != fir::CoordinateOp::kDynamicIndex) {
104 return mlir::IntegerAttr::get(base->fieldIndices.getElementType(),
110 iterator &operator++() {
112 if (**fieldIter == fir::CoordinateOp::kDynamicIndex)
121 bool operator==(
const iterator &rhs)
const {
122 return base == rhs.base && fieldIter == rhs.fieldIter &&
123 valuesIter == rhs.valuesIter;
127 const CoordinateIndicesAdaptor *base;
128 std::optional<llvm::ArrayRef<int32_t>::const_iterator> fieldIter;
129 llvm::detail::IterOfRange<const mlir::ValueRange> valuesIter;
133 std::optional<llvm::ArrayRef<int32_t>::const_iterator> fieldIter;
135 fieldIter = fieldIndices.asArrayRef().begin();
136 return iterator(
this, fieldIter, values.begin());
139 iterator end()
const {
140 std::optional<llvm::ArrayRef<int32_t>::const_iterator> fieldIter;
142 fieldIter = fieldIndices.asArrayRef().end();
143 return iterator(
this, fieldIter, values.end());
147 mlir::DenseI32ArrayAttr fieldIndices;
148 mlir::ValueRange values;
Definition AbstractConverter.h:34
Model operations which affect global debugging information.
Definition FIROps.h:52
Model operations which read from/write to volatile memory.
Definition FIROps.h:58