27#ifndef FORTRAN_LOWER_CALLINTERFACE_H
28#define FORTRAN_LOWER_CALLINTERFACE_H
30#include "flang/Common/reference.h"
31#include "flang/Evaluate/characteristics.h"
32#include "mlir/Dialect/Func/IR/FuncOps.h"
33#include "mlir/IR/BuiltinOps.h"
37namespace Fortran::semantics {
46class FortranProcedureFlagsEnumAttr;
50class AbstractConverter;
52class HostAssociations;
54struct FunctionLikeUnit;
74 std::optional<common::Reference<const semantics::Symbol>>;
75 using FirValue = mlir::Value;
115 CharBoxValueAttribute,
151 static constexpr int resultEntityPosition = -1;
169 bool testTKR(Fortran::common::IgnoreTKR flag)
const;
193 FirValue firArgument;
206 std::size_t getNumFIRResults()
const {
return outputs.size(); }
213 return passedArguments;
244 fir::FortranProcedureFlagsEnumAttr
250 T &
side() {
return *
static_cast<T *
>(
this); }
251 const T &
side()
const {
return *
static_cast<const T *
>(
this); }
258 void mapBackInputToPassedEntity(
const FirPlaceHolder &, FirValue);
262 mlir::func::FuncOp func;
264 std::optional<PassedEntity> passedResult;
265 bool saveResult =
false;
294 std::string getMangledName()
const;
295 mlir::Location getCalleeLocation()
const;
306 bool isMainProgram()
const {
return false; }
337 void placeInput(
const PassedEntity &passedEntity, mlir::Value arg);
338 void placeAddressAndLengthInput(
const PassedEntity &passedEntity,
339 mlir::Value addr, mlir::Value len);
342 mlir::Value
getInput(
const PassedEntity &passedEntity);
350 if (!verifyActualInputs())
351 llvm::report_fatal_error(
"lowered arguments are incomplete");
399 static constexpr bool hasHostAssociated() {
return false; }
400 mlir::Type getHostAssociatedTy()
const {
401 llvm_unreachable(
"getting host associated type in CallerInterface");
406 bool verifyActualInputs()
const;
425 bool hasAlternateReturns()
const;
426 std::string getMangledName()
const;
427 mlir::Location getCalleeLocation()
const;
429 bool isMainProgram()
const;
451 bool hasHostAssociated()
const;
452 mlir::Type getHostAssociatedTy()
const;
453 mlir::Value getHostAssociatedTuple()
const;
Definition: AbstractConverter.h:82
Implementation helper.
Definition: CallInterface.cpp:811
Definition: CallInterface.h:97
void declare()
Definition: CallInterface.cpp:681
bool mustPassResult() const
Is the Fortran result passed as an extra MLIR argument ?
Definition: CallInterface.h:233
llvm::SmallVector< mlir::Type > getResultType() const
Return the MLIR output types.
Definition: CallInterface.cpp:1542
llvm::ArrayRef< PassedEntity > getPassedArguments() const
Definition: CallInterface.h:212
bool callerAllocateResult() const
Does the caller need to allocate storage for the result ?
Definition: CallInterface.h:228
std::size_t getNumFIRArguments() const
Number of MLIR inputs/outputs of the created FuncOp.
Definition: CallInterface.h:205
std::optional< Fortran::evaluate::characteristics::Procedure > characteristic
Definition: CallInterface.h:270
void mapPassedEntities()
Definition: CallInterface.cpp:726
mlir::func::FuncOp getFuncOp() const
Definition: CallInterface.h:203
T & side()
CRTP handle.
Definition: CallInterface.h:250
bool canBeCalledViaImplicitInterface() const
Can the associated procedure be called via an implicit interface?
Definition: CallInterface.h:238
void determineInterface(bool isImplicit, const Fortran::evaluate::characteristics::Procedure &)
Definition: CallInterface.cpp:1511
PassEntityBy
Enum the different ways an entity can be passed-by.
Definition: CallInterface.h:102
@ BaseAddressValueAttribute
ValueAttribute means dummy has the Fortran VALUE attribute.
mlir::FunctionType genFunctionType()
Returns the mlir function type.
Definition: CallInterface.cpp:1529
bool mustSaveResult() const
Must the MLIR result be saved with a fir.save_result ?
Definition: CallInterface.h:235
Property
Definition: CallInterface.h:124
std::optional< PassedEntity > getPassedResult() const
Definition: CallInterface.h:217
fir::FortranProcedureFlagsEnumAttr getProcedureAttrs(mlir::MLIRContext *) const
Definition: CallInterface.cpp:1551
Definition: CallInterface.h:417
mlir::func::FuncOp addEntryBlockAndMapArguments()
Definition: CallInterface.cpp:551
const Fortran::semantics::Symbol * getProcedureSymbol() const
Definition: CallInterface.cpp:523
bool isIndirectCall() const
Definition: CallInterface.h:437
bool requireDispatchCall() const
Definition: CallInterface.h:441
Definition: CallInterface.h:282
const Fortran::semantics::SubprogramDetails * getInterfaceDetails() const
Definition: CallInterface.cpp:499
mlir::Value getIfPassedArg() const
Definition: CallInterface.cpp:137
std::function< void(evaluate::Expr< evaluate::SomeType >, bool)> ExprVisitor
Definition: CallInterface.h:367
bool mustMapInterfaceSymbolsForResult() const
Definition: CallInterface.cpp:413
mlir::Type getDummyArgumentType(const PassedEntity &) const
Return FIR type of argument.
Definition: CallInterface.cpp:482
mlir::Value getInput(const PassedEntity &passedEntity)
Get lowered FIR argument given the Fortran argument.
Definition: CallInterface.cpp:315
void walkDummyArgumentExtents(const PassedEntity &, const ExprVisitor &) const
Walk non-deferred extent specification expressions of a dummy argument.
Definition: CallInterface.cpp:402
void walkDummyArgumentLengths(const PassedEntity &, const ExprVisitor &) const
Walk non-deferred length specification expressions of a dummy argument.
Definition: CallInterface.cpp:350
bool requireDispatchCall() const
Definition: CallInterface.cpp:91
const Fortran::evaluate::ProcedureDesignator * getIfIndirectCall() const
Definition: CallInterface.cpp:147
bool mustMapInterfaceSymbolsForDummyArgument(const PassedEntity &) const
Definition: CallInterface.cpp:429
const Fortran::semantics::Symbol * getProcedureSymbol() const
Definition: CallInterface.cpp:80
bool isIndirectCall() const
Definition: CallInterface.cpp:84
void placeInput(const PassedEntity &passedEntity, mlir::Value arg)
Definition: CallInterface.cpp:284
const Fortran::semantics::Symbol * getDummySymbol(const PassedEntity &entity) const
Definition: CallInterface.cpp:458
void walkResultExtents(const ExprVisitor &) const
Walk the result non-deferred extent specification expressions.
Definition: CallInterface.cpp:386
std::optional< unsigned > getPassArgIndex() const
Definition: CallInterface.cpp:113
mlir::Type getResultStorageType() const
Definition: CallInterface.cpp:475
const Fortran::semantics::Symbol & getResultSymbol() const
Definition: CallInterface.cpp:488
mlir::Value getArgumentValue(const semantics::Symbol &sym) const
Definition: CallInterface.cpp:440
void walkResultLengths(const ExprVisitor &) const
Walk the result non-deferred length specification expressions.
Definition: CallInterface.cpp:339
bool hasAlternateReturns() const
CRTP callbacks.
Definition: CallInterface.cpp:59
llvm::ArrayRef< mlir::Value > getInputs() const
Get the input vector once it is complete.
Definition: CallInterface.h:349
Definition: AbstractConverter.h:59
bool mustPassLengthWithDummyProcedure(const Fortran::evaluate::ProcedureDesignator &proc, Fortran::lower::AbstractConverter &)
Is it required to pass proc as a tuple<function address, result length> ?
Definition: CallInterface.cpp:1742
mlir::FunctionType translateSignature(const Fortran::evaluate::ProcedureDesignator &, Fortran::lower::AbstractConverter &)
Translate a procedure characteristics to an mlir::FunctionType signature.
Definition: CallInterface.cpp:1710
bool isCPtrArgByValueType(mlir::Type ty)
Definition: CallInterface.cpp:1764
mlir::func::FuncOp getOrDeclareFunction(const Fortran::evaluate::ProcedureDesignator &, Fortran::lower::AbstractConverter &)
Definition: CallInterface.cpp:1716
mlir::Type getUntypedBoxProcType(mlir::MLIRContext *context)
Return !fir.boxproc<() -> ()> type.
Definition: CallInterface.cpp:32
mlir::Type getDummyProcedureType(const Fortran::semantics::Symbol &dummyProc, Fortran::lower::AbstractConverter &)
Definition: CallInterface.cpp:1751
Definition: AbstractConverter.h:31
Definition: AbstractConverter.h:27
Definition: characteristics.h:282
Definition: characteristics.h:355
Definition: CallInterface.h:141
int passedEntityPosition
Definition: CallInterface.h:150
Property property
Definition: CallInterface.h:154
llvm::SmallVector< mlir::NamedAttribute > attributes
MLIR attributes for this argument.
Definition: CallInterface.h:156
mlir::Type type
Type for this input/output.
Definition: CallInterface.h:147
Definition: CallInterface.h:161
FortranEntity entity
Definition: CallInterface.h:192
bool testTKR(Fortran::common::IgnoreTKR flag) const
Does the argument have the specified IgnoreTKR flag?
Definition: CallInterface.cpp:1396
bool mayRequireIntentoutFinalization() const
Definition: CallInterface.cpp:1462
bool mayBeModifiedByCall() const
Can the argument be modified by the callee?
Definition: CallInterface.cpp:1380
bool mayBeReadByCall() const
Can the argument be read by the callee?
Definition: CallInterface.cpp:1389
bool hasValueAttribute() const
Does the dummy argument have the VALUE attribute?
Definition: CallInterface.cpp:1437
bool isIntentOut() const
Is the argument INTENT(OUT)
Definition: CallInterface.cpp:1409
bool hasAllocatableAttribute() const
Does the dummy argument have the ALLOCATABLE attribute?
Definition: CallInterface.cpp:1449
const Fortran::evaluate::characteristics::DummyArgument * characteristics
Pointer to the argument characteristics. Nullptr for results.
Definition: CallInterface.h:197
bool isSequenceAssociatedDescriptor() const
Definition: CallInterface.cpp:1501
PassEntityBy passBy
How entity is passed by.
Definition: CallInterface.h:188
bool mustBeMadeContiguous() const
Does the argument have the CONTIGUOUS attribute or have explicit shape?
Definition: CallInterface.cpp:1415
bool isOptional() const
Is the dummy argument optional?
Definition: CallInterface.cpp:1374
Definition: CallInterface.h:65
Definition: PFTBuilder.h:605