mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-04 09:18:36 +03:00
thin: send messages to active pool
If the thin pool is known to be active, messages can be passed to the pool even when the created thin volume is not going to be activated. So we do not need to stack large list of message and validate and catch creation errors earlier in this case. Replace the test for valid activation combination with simpler list of deactivation combinations.
This commit is contained in:
parent
5658ec2bdc
commit
42881c8877
@ -1,5 +1,6 @@
|
|||||||
Version 2.02.99 -
|
Version 2.02.99 -
|
||||||
===================================
|
===================================
|
||||||
|
Send thin messages also for active thin pool and inactive thin volume.
|
||||||
Add activation/auto_set_activation_skip to control activation skip flagging.
|
Add activation/auto_set_activation_skip to control activation skip flagging.
|
||||||
Add 's(k)ip activation' bit to lvs -o lv_attr to indicate skip flag attached.
|
Add 's(k)ip activation' bit to lvs -o lv_attr to indicate skip flag attached.
|
||||||
Add --ignoreactivationskip to lvcreate/vgchange/lvchange to ignore skip flag.
|
Add --ignoreactivationskip to lvcreate/vgchange/lvchange to ignore skip flag.
|
||||||
|
@ -5548,18 +5548,17 @@ static struct logical_volume *_lv_create_an_lv(struct volume_group *vg, struct l
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (seg_is_thin_volume(lp) &&
|
if (seg_is_thin_volume(lp)) {
|
||||||
((lp->activate == CHANGE_AY) ||
|
|
||||||
(lp->activate == CHANGE_AE) ||
|
|
||||||
(lp->activate == CHANGE_ALY))) {
|
|
||||||
/* Ensure all stacked messages are submitted */
|
/* Ensure all stacked messages are submitted */
|
||||||
if (!(lvl = find_lv_in_vg(vg, lp->pool))) {
|
if (!(lvl = find_lv_in_vg(vg, lp->pool))) {
|
||||||
log_error("Unable to find existing pool LV %s in VG %s.",
|
log_error("Unable to find existing pool LV %s in VG %s.",
|
||||||
lp->pool, vg->name);
|
lp->pool, vg->name);
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
if (!update_pool_lv(lvl->lv, 1))
|
if (lv_is_active(lvl->lv) ||
|
||||||
return_NULL;
|
((lp->activate != CHANGE_AN) && (lp->activate != CHANGE_ALN)))
|
||||||
|
if (!update_pool_lv(lvl->lv, 1))
|
||||||
|
return_NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (vg_is_clustered(vg) && segtype_is_raid(lp->segtype)) {
|
if (vg_is_clustered(vg) && segtype_is_raid(lp->segtype)) {
|
||||||
|
Loading…
Reference in New Issue
Block a user