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/SymbolMap.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/SymbolMap.cpp')
| -rw-r--r-- | flang/lib/Lower/SymbolMap.cpp | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/flang/lib/Lower/SymbolMap.cpp b/flang/lib/Lower/SymbolMap.cpp index b929dfbd5aec..080f21ec6740 100644 --- a/flang/lib/Lower/SymbolMap.cpp +++ b/flang/lib/Lower/SymbolMap.cpp @@ -82,6 +82,23 @@ Fortran::lower::SymMap::lookupImpliedDo(Fortran::lower::SymMap::AcDoVar var) { return {}; } +void Fortran::lower::SymMap::registerStorage( + semantics::SymbolRef symRef, Fortran::lower::SymMap::StorageDesc storage) { + auto *sym = symRef->HasLocalLocality() ? &*symRef : &symRef->GetUltimate(); + assert(storage.first && "registerting storage without an address"); + storageMapStack.back().insert_or_assign(sym, std::move(storage)); +} + +Fortran::lower::SymMap::StorageDesc +Fortran::lower::SymMap::lookupStorage(Fortran::semantics::SymbolRef symRef) { + auto *sym = symRef->HasLocalLocality() ? &*symRef : &symRef->GetUltimate(); + auto &map = storageMapStack.back(); + auto iter = map.find(sym); + if (iter != map.end()) + return iter->second; + return {nullptr, 0}; +} + void Fortran::lower::SymbolBox::dump() const { llvm::errs() << *this << '\n'; } void Fortran::lower::SymMap::dump() const { llvm::errs() << *this << '\n'; } |
