Fixing ref-counting memtables

main
Igor Canadi 11 years ago
parent 983fafa56c
commit e55b3c040c
  1. 10
      db/memtablelist.cc
  2. 2
      db/memtablelist.h

@ -76,17 +76,16 @@ void MemTableListVersion::AddIterators(const ReadOptions& options,
} }
} }
// caller is responsible for referencing m
void MemTableListVersion::Add(MemTable* m) { void MemTableListVersion::Add(MemTable* m) {
assert(refs_ == 1); // only when refs_ == 1 is MemTableListVersion mutable assert(refs_ == 1); // only when refs_ == 1 is MemTableListVersion mutable
m->Ref();
memlist_.push_front(m); memlist_.push_front(m);
++size_; ++size_;
} }
// caller is responsible for unreferencing m
void MemTableListVersion::Remove(MemTable* m) { void MemTableListVersion::Remove(MemTable* m) {
assert(refs_ == 1); // only when refs_ == 1 is MemTableListVersion mutable assert(refs_ == 1); // only when refs_ == 1 is MemTableListVersion mutable
MemTable* x __attribute__((unused)) = m->Unref();
assert(x == nullptr); // it still needs to be alive!
memlist_.remove(m); memlist_.remove(m);
--size_; --size_;
} }
@ -232,6 +231,11 @@ Status MemTableList::InstallMemtableFlushResults(
void MemTableList::Add(MemTable* m) { void MemTableList::Add(MemTable* m) {
assert(current_->size_ >= num_flush_not_started_); assert(current_->size_ >= num_flush_not_started_);
InstallNewVersion(); InstallNewVersion();
// this method is used to move mutable memtable into an immutable list.
// since mutable memtable is already refcounted by the DBImpl,
// and when moving to the imutable list we don't unref it,
// we don't have to ref the memtable here. we just take over the
// reference from the DBImpl.
current_->Add(m); current_->Add(m);
m->MarkImmutable(); m->MarkImmutable();
num_flush_not_started_++; num_flush_not_started_++;

@ -40,12 +40,12 @@ class MemTableListVersion {
void AddIterators(const ReadOptions& options, void AddIterators(const ReadOptions& options,
std::vector<Iterator*>* iterator_list); std::vector<Iterator*>* iterator_list);
private:
// REQUIRE: m is mutable memtable // REQUIRE: m is mutable memtable
void Add(MemTable* m); void Add(MemTable* m);
// REQUIRE: m is mutable memtable // REQUIRE: m is mutable memtable
void Remove(MemTable* m); void Remove(MemTable* m);
private:
friend class MemTableList; friend class MemTableList;
std::list<MemTable*> memlist_; std::list<MemTable*> memlist_;
int size_ = 0; int size_ = 0;

Loading…
Cancel
Save