[Openmp-commits] [PATCH] D105947: [libomptarget] Keep the Shadow Pointer Map up-to-date
George Rokos via Phabricator via Openmp-commits
openmp-commits at lists.llvm.org
Wed Jul 14 15:24:42 PDT 2021
This revision was automatically updated to reflect the committed changes.
Closed by commit rG0c7a4870c5b6: [libomptarget] Keep the Shadow Pointer Map up-to-date (authored by grokos).
Repository:
rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
https://reviews.llvm.org/D105947/new/
https://reviews.llvm.org/D105947
Files:
openmp/libomptarget/src/omptarget.cpp
Index: openmp/libomptarget/src/omptarget.cpp
===================================================================
--- openmp/libomptarget/src/omptarget.cpp
+++ openmp/libomptarget/src/omptarget.cpp
@@ -564,9 +564,20 @@
Device.ShadowMtx.lock();
auto Entry = Device.ShadowPtrMap.find(Pointer_HstPtrBegin);
- // If this pointer is not in the map we need to insert it.
- if (Entry == Device.ShadowPtrMap.end()) {
- // create shadow pointers for this entry
+ // If this pointer is not in the map we need to insert it. If the map
+ // contains a stale entry, we need to update it (e.g. if the pointee was
+ // deallocated and later on is reallocated at another device address). The
+ // latter scenario is the subject of LIT test env/base_ptr_ref_count.c. An
+ // entry is removed from ShadowPtrMap only when the PTR of a PTR_AND_OBJ
+ // pair is deallocated, not when the OBJ is deallocated. In
+ // env/base_ptr_ref_count.c the PTR is a global "declare target" pointer,
+ // so it stays in the map for the lifetime of the application. When the
+ // OBJ is deallocated and later on allocated again (at a different device
+ // address), ShadowPtrMap still contains an entry for Pointer_HstPtrBegin
+ // which is stale, pointing to the old ExpectedTgtPtrBase of the OBJ.
+ if (Entry == Device.ShadowPtrMap.end() ||
+ Entry->second.TgtPtrVal != ExpectedTgtPtrBase) {
+ // create or update shadow pointers for this entry
Device.ShadowPtrMap[Pointer_HstPtrBegin] = {
HstPtrBase, PointerTgtPtrBegin, ExpectedTgtPtrBase};
UpdateDevPtr = true;
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D105947.358767.patch
Type: text/x-patch
Size: 1670 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/openmp-commits/attachments/20210714/b92bfd41/attachment.bin>
More information about the Openmp-commits
mailing list