From: Mykola Golub Date: Fri, 31 Jul 2020 15:05:10 +0000 (+0100) Subject: os/bluestore: fix collection_list properly set next if end reached X-Git-Tag: v14.2.12~81^2~6 X-Git-Url: http://git-server-git.apps.pok.os.sepia.ceph.com/?a=commitdiff_plain;h=107aff0c8131549f09364d7057ea155adbeea03e;p=ceph.git os/bluestore: fix collection_list properly set next if end reached Previously it was setting it to GMAX (happened when one had end set to not GMAX and max set to INT_MAX). Signed-off-by: Mykola Golub (cherry picked from commit 46d73a806c90b944c8596ad3d9dae3f5cf78d915) --- diff --git a/src/os/bluestore/BlueStore.cc b/src/os/bluestore/BlueStore.cc index 6b2ea1628e19..f57b9ff05bf5 100644 --- a/src/os/bluestore/BlueStore.cc +++ b/src/os/bluestore/BlueStore.cc @@ -9978,6 +9978,10 @@ int BlueStore::_collection_list( dout(20) << __func__ << " oid " << it->oid() << " >= " << pend << dendl; if (temp) { if (end.hobj.is_temp()) { + if (it->valid() && it->key() < temp_end_key) { + *pnext = it->oid(); + set_next = true; + } break; } dout(30) << __func__ << " switch to non-temp namespace" << dendl; @@ -9990,6 +9994,10 @@ int BlueStore::_collection_list( dout(30) << __func__ << " pend " << pend << dendl; continue; } + if (it->valid() && it->key() < end_key) { + *pnext = it->oid(); + set_next = true; + } break; } dout(30) << __func__ << " key " << pretty_binary_string(it->key()) << dendl;