mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-03 05:18:29 +03:00
Thin add support for origin_only suspend of thin volumes
Pass in the origin_only flag also for thin volumes - but curently the flag is not used to its best. FIXME: achieve the state where only thin volume snapshot origin is suspended without its childrens - let's explore whether this may happen automatically inside libdm (might be generic for other targets). So the code would not need to annotate the node for this.
This commit is contained in:
parent
78c3b21bfa
commit
efc8ca105d
@ -1344,7 +1344,7 @@ static int _lv_suspend(struct cmd_context *cmd, const char *lvid_s,
|
|||||||
goto_out;
|
goto_out;
|
||||||
|
|
||||||
/* Ignore origin_only unless LV is origin in both old and new metadata */
|
/* Ignore origin_only unless LV is origin in both old and new metadata */
|
||||||
if (!lv_is_origin(lv) || !lv_is_origin(lv_pre))
|
if (!lv_is_thin_volume(lv) && !(lv_is_origin(lv) && lv_is_origin(lv_pre)))
|
||||||
laopts->origin_only = 0;
|
laopts->origin_only = 0;
|
||||||
|
|
||||||
if (test_mode()) {
|
if (test_mode()) {
|
||||||
|
@ -1201,8 +1201,13 @@ static int _add_lv_to_dtree(struct dev_manager *dm, struct dm_tree *dtree,
|
|||||||
uint32_t s;
|
uint32_t s;
|
||||||
struct seg_list *sl;
|
struct seg_list *sl;
|
||||||
struct lv_segment *seg = first_seg(lv);
|
struct lv_segment *seg = first_seg(lv);
|
||||||
|
/* FIXME: Resolve skip_childrens
|
||||||
|
struct dm_tree_node *thin_node;
|
||||||
|
const char *uuid;
|
||||||
|
*/
|
||||||
|
|
||||||
if (!origin_only && !_add_dev_to_dtree(dm, dtree, lv, NULL))
|
if ((!origin_only || lv_is_thin_volume(lv)) &&
|
||||||
|
!_add_dev_to_dtree(dm, dtree, lv, NULL))
|
||||||
return_0;
|
return_0;
|
||||||
|
|
||||||
/* FIXME Can we avoid doing this every time? */
|
/* FIXME Can we avoid doing this every time? */
|
||||||
@ -1233,17 +1238,29 @@ static int _add_lv_to_dtree(struct dev_manager *dm, struct dm_tree *dtree,
|
|||||||
!_add_partial_replicator_to_dtree(dm, dtree, lv))
|
!_add_partial_replicator_to_dtree(dm, dtree, lv))
|
||||||
return_0;
|
return_0;
|
||||||
|
|
||||||
|
if (lv_is_thin_volume(lv)) {
|
||||||
|
/* FIXME: Resolve skip_childrens
|
||||||
|
if (origin_only) {
|
||||||
|
if (!(uuid = build_dm_uuid(dm->mem, lv->lvid.s, NULL)))
|
||||||
|
return_0;
|
||||||
|
if ((thin_node = dm_tree_find_node_by_uuid(dtree, uuid)))
|
||||||
|
dm_tree_node_skip_childrens(thin_node, 1);
|
||||||
|
}
|
||||||
|
*/
|
||||||
|
/* Add thin pool LV layer */
|
||||||
|
lv = seg->pool_lv;
|
||||||
|
seg = first_seg(lv);
|
||||||
|
}
|
||||||
|
|
||||||
if (lv_is_thin_pool(lv)) {
|
if (lv_is_thin_pool(lv)) {
|
||||||
if (!_add_lv_to_dtree(dm, dtree, seg->metadata_lv, origin_only))
|
if (!_add_lv_to_dtree(dm, dtree, seg->metadata_lv, 0))
|
||||||
return_0;
|
return_0;
|
||||||
/* FIXME code from _create_partial_dtree() should be moved here */
|
/* FIXME code from _create_partial_dtree() should be moved here */
|
||||||
if (!_add_lv_to_dtree(dm, dtree, seg_lv(seg, 0), origin_only))
|
if (!_add_lv_to_dtree(dm, dtree, seg_lv(seg, 0), 0))
|
||||||
return_0;
|
return_0;
|
||||||
if (!_add_dev_to_dtree(dm, dtree, lv, _thin_layer))
|
if (!_add_dev_to_dtree(dm, dtree, lv, _thin_layer))
|
||||||
return_0;
|
return_0;
|
||||||
} else if (lv_is_thin_volume(lv) &&
|
}
|
||||||
!_add_lv_to_dtree(dm, dtree, seg->pool_lv, origin_only))
|
|
||||||
return_0;
|
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
@ -1260,7 +1277,7 @@ static struct dm_tree *_create_partial_dtree(struct dev_manager *dm, struct logi
|
|||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!_add_lv_to_dtree(dm, dtree, lv, lv_is_origin(lv) ? origin_only : 0))
|
if (!_add_lv_to_dtree(dm, dtree, lv, (lv_is_origin(lv) || lv_is_thin_volume(lv)) ? origin_only : 0))
|
||||||
goto_bad;
|
goto_bad;
|
||||||
|
|
||||||
/* Add any snapshots of this LV */
|
/* Add any snapshots of this LV */
|
||||||
|
Loading…
Reference in New Issue
Block a user