FLANG
Allocatable.h
1//===-- Allocatable.h -- Allocatable statements lowering ------------------===//
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// Coding style: https://mlir.llvm.org/getting_started/DeveloperGuide/
10//
11//===----------------------------------------------------------------------===//
12
13#ifndef FORTRAN_LOWER_ALLOCATABLE_H
14#define FORTRAN_LOWER_ALLOCATABLE_H
15
16#include "flang/Lower/AbstractConverter.h"
17#include "flang/Optimizer/Builder/MutableBox.h"
18#include "flang/Runtime/allocator-registry-consts.h"
19#include "llvm/ADT/StringRef.h"
20
21namespace mlir {
22class Value;
23class ValueRange;
24class Location;
25} // namespace mlir
26
27namespace fir {
28class FirOpBuilder;
29} // namespace fir
30
31namespace Fortran {
32namespace parser {
33struct AllocateStmt;
34struct DeallocateStmt;
35} // namespace parser
36
37namespace semantics {
38class Symbol;
39class DerivedTypeSpec;
40} // namespace semantics
41
42namespace lower {
43struct SymbolBox;
44
46
47bool isArraySectionWithoutVectorSubscript(const SomeExpr &expr);
48
51 const parser::AllocateStmt &stmt, mlir::Location loc);
52
55 const parser::DeallocateStmt &stmt, mlir::Location loc);
56
57void genDeallocateBox(AbstractConverter &converter,
58 const fir::MutableBoxValue &box, mlir::Location loc,
59 const Fortran::semantics::Symbol *sym = nullptr,
60 mlir::Value declaredTypeDesc = {});
61
64 const fir::MutableBoxValue &box,
65 mlir::Location loc,
66 const Fortran::semantics::Symbol *sym = nullptr);
67
71fir::MutableBoxValue createMutableBox(AbstractConverter &converter,
72 mlir::Location loc,
73 const pft::Variable &var,
74 mlir::Value boxAddr,
75 mlir::ValueRange nonDeferredParams,
76 unsigned allocator = kDefaultAllocator);
77
82void associateMutableBox(AbstractConverter &converter, mlir::Location loc,
83 const fir::MutableBoxValue &box,
84 const SomeExpr &source, mlir::ValueRange lbounds,
85 StatementContext &stmtCtx);
86
88bool isWholeAllocatable(const SomeExpr &expr);
89
91bool isWholePointer(const SomeExpr &expr);
92
96 fir::FirOpBuilder &builder, mlir::Location loc,
97 const Fortran::semantics::Symbol &sym, mlir::Value box);
98
100mlir::Value
101getTypeDescAddr(AbstractConverter &converter, mlir::Location loc,
102 const Fortran::semantics::DerivedTypeSpec &typeSpec);
103
104} // namespace lower
105} // namespace Fortran
106
107#endif // FORTRAN_LOWER_ALLOCATABLE_H
Definition AbstractConverter.h:87
Definition StatementContext.h:46
Definition symbol.h:832
Definition FIRBuilder.h:58
Definition ParserActions.h:24
void associateMutableBox(AbstractConverter &converter, mlir::Location loc, const fir::MutableBoxValue &box, const SomeExpr &source, mlir::ValueRange lbounds, StatementContext &stmtCtx)
Definition Allocatable.cpp:1035
mlir::Value getTypeDescAddr(AbstractConverter &converter, mlir::Location loc, const Fortran::semantics::DerivedTypeSpec &typeSpec)
Retrieve the address of a type descriptor from its derived type spec.
Definition Allocatable.cpp:1097
bool isWholePointer(const SomeExpr &expr)
Is expr a reference to an entity with the POINTER attribute?
Definition Allocatable.cpp:1057
void genDeallocateStmt(AbstractConverter &converter, const parser::DeallocateStmt &stmt, mlir::Location loc)
Lower a deallocate statement to fir.
Definition Allocatable.cpp:963
void genDeallocateIfAllocated(AbstractConverter &converter, const fir::MutableBoxValue &box, mlir::Location loc, const Fortran::semantics::Symbol *sym=nullptr)
Deallocate an allocatable if it is allocated at the end of its lifetime.
Definition Allocatable.cpp:942
bool isWholeAllocatable(const SomeExpr &expr)
Is expr a reference to an entity with the ALLOCATABLE attribute?
Definition Allocatable.cpp:1050
mlir::Value getAssumedCharAllocatableOrPointerLen(fir::FirOpBuilder &builder, mlir::Location loc, const Fortran::semantics::Symbol &sym, mlir::Value box)
Definition Allocatable.cpp:1064
fir::MutableBoxValue createMutableBox(AbstractConverter &converter, mlir::Location loc, const pft::Variable &var, mlir::Value boxAddr, mlir::ValueRange nonDeferredParams, unsigned allocator=kDefaultAllocator)
Definition Allocatable.cpp:1010
void genAllocateStmt(AbstractConverter &converter, const parser::AllocateStmt &stmt, mlir::Location loc)
Lower an allocate statement to fir.
Definition Allocatable.cpp:829
Definition check-expression.h:19
Definition bit-population-count.h:20
Definition AbstractConverter.h:37
Definition AbstractConverter.h:32
Definition SymbolMap.h:53
Definition PFTBuilder.h:410
Definition parse-tree.h:1979
Definition parse-tree.h:1999