cppgc: Check AssignUnsafe use cases

Assert that the lock is help whenever AssignUnsafe is called.
LazyMutex::AssertHeld resolves to a DCHECK so this should not
regress production performance (other than the call itself
that might not be inlined).

Bug: chromium:1056170
Change-Id: Ic2005d180e6960c24dff7743aa3e0d5e57a63d80
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2716286
Reviewed-by: Michael Lippautz <mlippautz@chromium.org>
Commit-Queue: Omer Katz <omerkatz@chromium.org>
Cr-Commit-Position: refs/heads/master@{#73000}
This commit is contained in:
Omer Katz 2021-02-24 12:10:00 +01:00 committed by Commit Bot
parent 8cc862ed79
commit e18591dfb4
3 changed files with 8 additions and 0 deletions

View File

@ -271,6 +271,7 @@ class BasicCrossThreadPersistent final : public PersistentBase,
} }
void AssignUnsafe(T* ptr) { void AssignUnsafe(T* ptr) {
PersistentRegionLock::AssertLocked();
const void* old_value = GetValue(); const void* old_value = GetValue();
if (IsValid(old_value)) { if (IsValid(old_value)) {
PersistentRegion& region = this->GetPersistentRegion(old_value); PersistentRegion& region = this->GetPersistentRegion(old_value);

View File

@ -121,6 +121,8 @@ class V8_EXPORT PersistentRegionLock final {
public: public:
PersistentRegionLock(); PersistentRegionLock();
~PersistentRegionLock(); ~PersistentRegionLock();
static void AssertLocked();
}; };
} // namespace internal } // namespace internal

View File

@ -90,5 +90,10 @@ PersistentRegionLock::~PersistentRegionLock() {
g_process_mutex.Pointer()->Unlock(); g_process_mutex.Pointer()->Unlock();
} }
// static
void PersistentRegionLock::AssertLocked() {
return g_process_mutex.Pointer()->AssertHeld();
}
} // namespace internal } // namespace internal
} // namespace cppgc } // namespace cppgc