summaryrefslogtreecommitdiffstats
path: root/src/os
diff options
context:
space:
mode:
authorSage Weil <sage@newdream.net>2008-10-08 18:47:37 +0200
committerSage Weil <sage@newdream.net>2008-10-08 18:47:48 +0200
commitb3d6eef6a9da15ef33fc9949779bf8ec03a84b64 (patch)
tree67022690e8b55578ef17beded86e98887b7ce9e4 /src/os
parentdebian: include crun in osd, mds, mon packages (diff)
downloadceph-b3d6eef6a9da15ef33fc9949779bf8ec03a84b64.tar.xz
ceph-b3d6eef6a9da15ef33fc9949779bf8ec03a84b64.zip
journal: protect journal access (namely, completions) with mutex
The commit_waiters map was getting corrupted occasionally.
Diffstat (limited to '')
-rw-r--r--src/os/JournalingObjectStore.h9
1 files changed, 9 insertions, 0 deletions
diff --git a/src/os/JournalingObjectStore.h b/src/os/JournalingObjectStore.h
index b4f1c661f46..4b70ef9e482 100644
--- a/src/os/JournalingObjectStore.h
+++ b/src/os/JournalingObjectStore.h
@@ -28,6 +28,7 @@ protected:
map<version_t, vector<Context*> > commit_waiters;
RWLock op_lock;
Mutex journal_lock;
+ Mutex lock;
void journal_start() {
finisher.start();
@@ -58,12 +59,16 @@ protected:
op_lock.get_write();
}
void commit_started() {
+ Mutex::Locker l(lock);
+
// allow new ops
// (underlying fs should now be committing all prior ops)
committing_op_seq = op_seq;
op_lock.put_write();
}
void commit_finish() {
+ Mutex::Locker l(lock);
+
if (journal)
journal->committed_thru(committing_op_seq);
@@ -76,11 +81,15 @@ protected:
}
void queue_commit_waiter(Context *oncommit) {
+ Mutex::Locker l(lock);
+
if (oncommit)
commit_waiters[op_seq].push_back(oncommit);
}
void journal_transaction(bufferlist& tbl, Context *onsafe) {
+ Mutex::Locker l(lock);
+
++op_seq;
if (journal && journal->is_writeable()) {
journal->submit_entry(op_seq, tbl, onsafe);