diff options
| author | Dan Engelbrecht <[email protected]> | 2025-06-19 09:29:50 +0200 |
|---|---|---|
| committer | GitHub Enterprise <[email protected]> | 2025-06-19 09:29:50 +0200 |
| commit | 583e98fc49a4c3ebe24208d082ce5fe71ccef0ef (patch) | |
| tree | 2b39bf5f346512c03a897e89b473ee4513247031 /src/zenstore/cache/cachedisklayer.cpp | |
| parent | symbol gen hack-fix for linux (#442) (diff) | |
| download | zen-583e98fc49a4c3ebe24208d082ce5fe71ccef0ef.tar.xz zen-583e98fc49a4c3ebe24208d082ce5fe71ccef0ef.zip | |
make sure we unregister from GC before we drop bucket/namespaces (#443)
Diffstat (limited to 'src/zenstore/cache/cachedisklayer.cpp')
| -rw-r--r-- | src/zenstore/cache/cachedisklayer.cpp | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/src/zenstore/cache/cachedisklayer.cpp b/src/zenstore/cache/cachedisklayer.cpp index 0d2aef612..15a1c9650 100644 --- a/src/zenstore/cache/cachedisklayer.cpp +++ b/src/zenstore/cache/cachedisklayer.cpp @@ -2004,6 +2004,8 @@ ZenCacheDiskLayer::CacheBucket::Drop() { ZEN_TRACE_CPU("Z$::Bucket::Drop"); + m_Gc.RemoveGcReferencer(*this); + RwLock::ExclusiveLockScope _(m_IndexLock); std::vector<std::unique_ptr<RwLock::ExclusiveLockScope>> ShardLocks; @@ -3165,7 +3167,7 @@ ZenCacheDiskLayer::CacheBucket::RemoveExpiredData(GcCtx& Ctx, GcStats& Stats) return nullptr; } - if (Ctx.Settings.IsDeleteMode) + if (Ctx.Settings.IsDeleteMode && !ExpiredEntries.empty()) { for (const DiskIndexEntry& Entry : ExpiredEntries) { |