From: Xuehan Xu Date: Wed, 6 Sep 2023 06:56:51 +0000 (+0800) Subject: crimson/os/seastore/onode_manager: populate value recorders of onodes to X-Git-Tag: v19.0.0~498^2 X-Git-Url: http://git-server-git.apps.pok.os.sepia.ceph.com/?a=commitdiff_plain;h=refs%2Fpull%2F53305%2Fhead;p=ceph.git crimson/os/seastore/onode_manager: populate value recorders of onodes to be erased Otherwise, the following modification sequence with the same transaction might lead to onode extents' crc inconsistency during journal replay: 1. modify the last mapping in an onode extent; 2. erase the last mapping in that onode extent. During journal replay, if the first modification is not recorded in the delta, the onode extent's content would be inconsistent with that before the system reboot Signed-off-by: Xuehan Xu --- diff --git a/src/crimson/os/seastore/onode_manager/staged-fltree/fltree_onode_manager.cc b/src/crimson/os/seastore/onode_manager/staged-fltree/fltree_onode_manager.cc index ba78cbf0b0b3..bff27ab65178 100644 --- a/src/crimson/os/seastore/onode_manager/staged-fltree/fltree_onode_manager.cc +++ b/src/crimson/os/seastore/onode_manager/staged-fltree/fltree_onode_manager.cc @@ -120,6 +120,10 @@ FLTreeOnodeManager::erase_onode_ret FLTreeOnodeManager::erase_onode( OnodeRef &onode) { auto &flonode = static_cast(*onode); + assert(flonode.is_alive()); + if (flonode.status == FLTreeOnode::status_t::MUTATED) { + flonode.populate_recorder(trans); + } flonode.mark_delete(); return tree.erase(trans, flonode); }