From: Sage Weil Date: Sun, 28 Jul 2013 15:55:38 +0000 (-0700) Subject: osd: fix off-by-one in map gap logic X-Git-Tag: v0.67-rc3~14 X-Git-Url: http://git.apps.os.sepia.ceph.com/?a=commitdiff_plain;h=e24b50225c841a650d9303041bbe811e04bdd668;p=ceph.git osd: fix off-by-one in map gap logic If we have map 250, and monitor's first is 251, but sends 260, we can request the intervening range. Fixes: #5784 Signed-off-by: Sage Weil Reviewed-by: Samuel Just --- diff --git a/src/osd/OSD.cc b/src/osd/OSD.cc index e3a7c227e1553..3fd818e04e3d6 100644 --- a/src/osd/OSD.cc +++ b/src/osd/OSD.cc @@ -4958,7 +4958,7 @@ void OSD::handle_osd_map(MOSDMap *m) dout(10) << "handle_osd_map message skips epochs " << osdmap->get_epoch() + 1 << ".." << (first-1) << dendl; if ((m->oldest_map < first && osdmap->get_epoch() == 0) || - m->oldest_map <= osdmap->get_epoch()) { + m->oldest_map <= osdmap->get_epoch() + 1) { monc->sub_want("osdmap", osdmap->get_epoch()+1, CEPH_SUBSCRIBE_ONETIME); monc->renew_subs(); m->put();