mirror of
https://github.com/ceph/ceph
synced 2025-01-23 11:33:20 +00:00
librbd: review: add helper for 'scanning snapshots for this parent'
This commit is contained in:
parent
2ca8fb210a
commit
53868a96e9
@ -411,6 +411,25 @@ namespace librbd {
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int scan_for_parents(ImageCtx *ictx, parent_spec &pspec,
|
||||
snapid_t oursnap_id)
|
||||
{
|
||||
if (pspec.pool_id != -1) {
|
||||
map<string, SnapInfo>::iterator it;
|
||||
for (it = ictx->snaps_by_name.begin();
|
||||
it != ictx->snaps_by_name.end(); ++it) {
|
||||
// skip our snap id (if checking base image, CEPH_NOSNAP won't match)
|
||||
if (it->second.id == oursnap_id)
|
||||
continue;
|
||||
if (it->second.parent.spec == pspec)
|
||||
break;
|
||||
}
|
||||
if (it == ictx->snaps_by_name.end())
|
||||
return -ENOENT;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
||||
int snap_remove(ImageCtx *ictx, const char *snap_name)
|
||||
{
|
||||
ldout(ictx->cct, 20) << "snap_remove " << ictx << " " << snap_name << dendl;
|
||||
@ -432,24 +451,12 @@ namespace librbd {
|
||||
parent_spec our_pspec;
|
||||
r = ictx->get_parent_spec(snap_id, &our_pspec);
|
||||
if (r < 0) {
|
||||
lderr(ictx->cct) << "snap_remove: can't get snapinfo" << dendl;
|
||||
lderr(ictx->cct) << "snap_remove: can't get parent spec" << dendl;
|
||||
return r;
|
||||
}
|
||||
|
||||
// scan base image and snapshots, and if this snapshot contains the
|
||||
// only remaining reference to its parent, remove the child from that
|
||||
// parent's list
|
||||
map<string, SnapInfo>::iterator it;
|
||||
for (it = ictx->snaps_by_name.begin();
|
||||
it != ictx->snaps_by_name.end(); ++it) {
|
||||
// skip our own snap
|
||||
if (it->second.id == snap_id)
|
||||
continue;
|
||||
if (it->second.parent.spec == our_pspec)
|
||||
break;
|
||||
}
|
||||
if ((ictx->parent_md.spec != our_pspec) &&
|
||||
(it == ictx->snaps_by_name.end())) {
|
||||
if (ictx->parent_md.spec != our_pspec &&
|
||||
(scan_for_parents(ictx, our_pspec, snap_id) == -ENOENT)) {
|
||||
r = cls_client::remove_child(&ictx->md_ctx, RBD_CHILDREN,
|
||||
our_pspec, ictx->id);
|
||||
if (r < 0)
|
||||
@ -993,16 +1000,7 @@ namespace librbd {
|
||||
parent_info parent_info = ictx->parent_md;
|
||||
ictx->parent_lock.Unlock();
|
||||
|
||||
// scan snapshots; if none of them refer to this parent,
|
||||
// remove the child from parent's list
|
||||
if (parent_info.spec.pool_id != -1) {
|
||||
map<string, SnapInfo>::iterator it;
|
||||
for (it = ictx->snaps_by_name.begin();
|
||||
it != ictx->snaps_by_name.end(); ++it) {
|
||||
if (it->second.parent.spec == parent_info.spec)
|
||||
break;
|
||||
}
|
||||
if (it == ictx->snaps_by_name.end()) {
|
||||
if (scan_for_parents(ictx, parent_info.spec, CEPH_NOSNAP) == -ENOENT) {
|
||||
r = cls_client::remove_child(&ictx->md_ctx, RBD_CHILDREN,
|
||||
parent_info.spec, id);
|
||||
if (r < 0) {
|
||||
@ -1010,7 +1008,6 @@ namespace librbd {
|
||||
return r;
|
||||
}
|
||||
}
|
||||
}
|
||||
close_image(ictx);
|
||||
|
||||
ldout(cct, 2) << "removing header..." << dendl;
|
||||
|
Loading…
Reference in New Issue
Block a user