From 31e60e2a773559139181917d7590ea29ff6bcf08 Mon Sep 17 00:00:00 2001 From: Islam AbdelRahman Date: Fri, 5 Jun 2015 11:06:14 -0700 Subject: [PATCH] Unlock mutex in ReFitLevel Summary: I encountered an issue where the database hang, it looks like the mutex is not unlocked on return in ReFitLevel function Test Plan: make -j64 check Reviewers: yhchiang, sdong Reviewed By: sdong Subscribers: dhruba Differential Revision: https://reviews.facebook.net/D39609 --- db/db_impl.cc | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/db/db_impl.cc b/db/db_impl.cc index 747175c0f..2fd97d6ba 100644 --- a/db/db_impl.cc +++ b/db/db_impl.cc @@ -1707,11 +1707,10 @@ Status DBImpl::ReFitLevel(ColumnFamilyData* cfd, int level, int target_level) { SuperVersion* superversion_to_free = nullptr; SuperVersion* new_superversion = new SuperVersion(); - mutex_.Lock(); + InstrumentedMutexLock guard_lock(&mutex_); // only allow one thread refitting if (refitting_level_) { - mutex_.Unlock(); Log(InfoLogLevel::INFO_LEVEL, db_options_.info_log, "[ReFitLevel] another thread is refitting"); delete new_superversion; @@ -1743,12 +1742,14 @@ Status DBImpl::ReFitLevel(ColumnFamilyData* cfd, int level, int target_level) { auto* vstorage = cfd->current()->storage_info(); if (to_level > level) { if (level == 0) { + delete new_superversion; return Status::NotSupported( "Cannot change from level 0 to other levels."); } // Check levels are empty for a trivial move for (int l = level + 1; l <= to_level; l++) { if (vstorage->NumLevelFiles(l) > 0) { + delete new_superversion; return Status::NotSupported( "Levels between source and target are not empty for a move."); } @@ -1791,7 +1792,6 @@ Status DBImpl::ReFitLevel(ColumnFamilyData* cfd, int level, int target_level) { refitting_level_ = false; bg_work_gate_closed_ = false; - mutex_.Unlock(); delete superversion_to_free; delete new_superversion; return status;