diff options
| author | Mingming Liu <mingmingl@google.com> | 2025-09-10 15:25:31 -0700 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2025-09-10 15:25:31 -0700 |
| commit | 1417dafa1db9cb1b2b09438aa9f53ea5ab6e36e2 (patch) | |
| tree | 57f4b1f313c8cf74eed8819870f39c36ea263c68 /flang/lib/Lower/CallInterface.cpp | |
| parent | 898b813bc8a6d0276bf0f4769f5f2f64b34e632d (diff) | |
| parent | b8cefcb601ddaa18482555c4ff363c01a270c2fe (diff) | |
Merge branch 'main' into users/mingmingl-llvm/samplefdo-profile-formatusers/mingmingl-llvm/samplefdo-profile-format
Diffstat (limited to 'flang/lib/Lower/CallInterface.cpp')
| -rw-r--r-- | flang/lib/Lower/CallInterface.cpp | 11 |
1 files changed, 11 insertions, 0 deletions
diff --git a/flang/lib/Lower/CallInterface.cpp b/flang/lib/Lower/CallInterface.cpp index 72431a9cfacc..c3284cd936f8 100644 --- a/flang/lib/Lower/CallInterface.cpp +++ b/flang/lib/Lower/CallInterface.cpp @@ -1766,6 +1766,17 @@ mlir::Type Fortran::lower::getDummyProcedureType( return procType; } +mlir::Type Fortran::lower::getDummyProcedurePointerType( + const Fortran::semantics::Symbol &dummyProcPtr, + Fortran::lower::AbstractConverter &converter) { + std::optional<Fortran::evaluate::characteristics::Procedure> iface = + Fortran::evaluate::characteristics::Procedure::Characterize( + dummyProcPtr, converter.getFoldingContext()); + mlir::Type procPtrType = getProcedureDesignatorType( + iface.has_value() ? &*iface : nullptr, converter); + return fir::ReferenceType::get(procPtrType); +} + bool Fortran::lower::isCPtrArgByValueType(mlir::Type ty) { return mlir::isa<fir::ReferenceType>(ty) && fir::isa_integer(fir::unwrapRefType(ty)); |
