From 6e83cfecfbd0d4ffe4657146ad72bba2b5d4a43e Mon Sep 17 00:00:00 2001 From: Sage Weil Date: Mon, 19 Jun 2017 22:57:43 -0400 Subject: [PATCH] os/bluestore: fix unsharing blob dirty_range args Fixes: http://tracker.ceph.com/issues/20227 Signed-off-by: Sage Weil --- src/os/bluestore/BlueStore.cc | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/os/bluestore/BlueStore.cc b/src/os/bluestore/BlueStore.cc index 2d34799662213..498c8bb50df48 100644 --- a/src/os/bluestore/BlueStore.cc +++ b/src/os/bluestore/BlueStore.cc @@ -10353,7 +10353,7 @@ int BlueStore::_do_remove( if (b.is_shared() && std::find(unshared_blobs.begin(), unshared_blobs.end(), sb) != unshared_blobs.end()) { - dout(20) << __func__ << " " << e << dendl; + dout(20) << __func__ << " unsharing " << e << dendl; bluestore_blob_t& blob = e.blob->dirty_blob(); blob.clear_flag(bluestore_blob_t::FLAG_SHARED); if (e.logical_offset < b_start) { @@ -10365,7 +10365,7 @@ int BlueStore::_do_remove( } } - h->extent_map.dirty_range(b_start, b_end); + h->extent_map.dirty_range(b_start, b_end - b_start); txc->write_onode(h); } } -- 2.39.5