Skip to content

Commit 43bcf94

Browse files
committed
osd: share curmap in handle_osd_ping
We just took the curmap ref above; do not call get_osdmap() again. I think it may explain a weird segv I saw here in ~shared_ptr, although I'm not quite certain. Regardless, this change is correct and better. (gdb) bt #0 raise (sig=sig@entry=11) at ../sysdeps/unix/sysv/linux/raise.c:51 #1 0x00005596e5a98261 in reraise_fatal (signum=11) at ./src/global/signal_handler.cc:326 #2 handle_fatal_signal(int) () at ./src/global/signal_handler.cc:326 #3 <signal handler called> #4 0x00005596f4fe80e0 in ?? () #5 0x00005596e5464068 in std::_Sp_counted_base<(__gnu_cxx::_Lock_policy)2>::_M_release (this=0x5596f4b7cf60) at /usr/include/c++/9/bits/shared_ptr_base.h:148 #6 std::_Sp_counted_base<(__gnu_cxx::_Lock_policy)2>::_M_release (this=0x5596f4b7cf60) at /usr/include/c++/9/bits/shared_ptr_base.h:148 #7 0x00005596e543377f in std::__shared_count<(__gnu_cxx::_Lock_policy)2>::~__shared_count (this=0x7f2b25044e28, __in_chrg=<optimized out>) at /usr/include/c++/9/bits/shared_ptr_base.h:1169 #8 std::__shared_ptr<OSDMap const, (__gnu_cxx::_Lock_policy)2>::~__shared_ptr (this=0x7f2b25044e20, __in_chrg=<optimized out>) at /usr/include/c++/9/bits/shared_ptr_base.h:1169 #9 std::shared_ptr<OSDMap const>::~shared_ptr (this=0x7f2b25044e20, __in_chrg=<optimized out>) at /usr/include/c++/9/bits/shared_ptr.h:103 #10 OSD::handle_osd_ping(MOSDPing*) () at ./src/osd/OSD.cc:4662 Signed-off-by: Sage Weil <[email protected]>
1 parent 8d44d03 commit 43bcf94

File tree

1 file changed

+2
-2
lines changed

1 file changed

+2
-2
lines changed

src/osd/OSD.cc

Lines changed: 2 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -4565,7 +4565,7 @@ void OSD::handle_osd_ping(MOSDPing *m)
45654565
if (is_active()) {
45664566
ConnectionRef con = service.get_con_osd_cluster(from, curmap->get_epoch());
45674567
if (con) {
4568-
service.maybe_share_map(con.get(), get_osdmap(), m->map_epoch);
4568+
service.maybe_share_map(con.get(), curmap, m->map_epoch);
45694569
}
45704570
}
45714571
} else if (!curmap->exists(from) ||
@@ -4659,7 +4659,7 @@ void OSD::handle_osd_ping(MOSDPing *m)
46594659
if (is_active()) {
46604660
ConnectionRef con = service.get_con_osd_cluster(from, curmap->get_epoch());
46614661
if (con) {
4662-
service.maybe_share_map(con.get(), get_osdmap(), m->map_epoch);
4662+
service.maybe_share_map(con.get(), curmap, m->map_epoch);
46634663
}
46644664
}
46654665
}

0 commit comments

Comments
 (0)