]> git-server-git.apps.pok.os.sepia.ceph.com Git - ceph.git/commitdiff
osd: fix send_failures() locking 6694/head
authorSage Weil <sage@redhat.com>
Fri, 18 Sep 2015 01:42:53 +0000 (21:42 -0400)
committerxiexingguo <xie.xingguo@zte.com.cn>
Fri, 27 Nov 2015 08:47:21 +0000 (16:47 +0800)
It is unsafe to check failure_queue.empty() without the lock.
Fixes: #13869
Signed-off-by: Sage Weil <sage@redhat.com>
(cherry picked from commit b3ca828ae8ebc9068073494c46faf3e8e1443ada)

src/osd/OSD.cc

index 413ad594c4f304e055cadfde954180ae76e422cf..e95dfb9515e3d23698b8743323bba464c66b5032 100644 (file)
@@ -4709,21 +4709,17 @@ void OSD::got_full_map(epoch_t e)
 void OSD::send_failures()
 {
   assert(osd_lock.is_locked());
-  bool locked = false;
-  if (!failure_queue.empty()) {
-    heartbeat_lock.Lock();
-    locked = true;
-  }
+  Mutex::Locker l(heartbeat_lock);
   utime_t now = ceph_clock_now(cct);
   while (!failure_queue.empty()) {
     int osd = failure_queue.begin()->first;
     int failed_for = (int)(double)(now - failure_queue.begin()->second);
     entity_inst_t i = osdmap->get_inst(osd);
-    monc->send_mon_message(new MOSDFailure(monc->get_fsid(), i, failed_for, osdmap->get_epoch()));
+    monc->send_mon_message(new MOSDFailure(monc->get_fsid(), i, failed_for,
+                                          osdmap->get_epoch()));
     failure_pending[osd] = i;
     failure_queue.erase(osd);
   }
-  if (locked) heartbeat_lock.Unlock();
 }
 
 void OSD::send_still_alive(epoch_t epoch, const entity_inst_t &i)