mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-04 09:18:36 +03:00
vdo: allow resize of VDO and VDO pool volumes
Now with newer VDO kvdo target we can start to use standard mechanism to enable resize of VDO volumes. VDO pool can be grown. Virtual volume grows on top of VDO pool when is not big enough. Reduced VDOLV is calling discard for reduced areas - this can take long time! TODO: implement some pollable mechanism for out-of-lock TRIM.
This commit is contained in:
parent
bd6709cec6
commit
08cabe9b83
@ -1,5 +1,6 @@
|
|||||||
Version 2.03.02 -
|
Version 2.03.02 -
|
||||||
===================================
|
===================================
|
||||||
|
Support reszing for VDOPoolLV and VDOLV.
|
||||||
Improve -lXXX%VG modifier which improves cache segment estimation.
|
Improve -lXXX%VG modifier which improves cache segment estimation.
|
||||||
Ensure migration_threshold for cache is at least 8 chunks.
|
Ensure migration_threshold for cache is at least 8 chunks.
|
||||||
Restore missing man info lvcreate --zero for thin-pools.
|
Restore missing man info lvcreate --zero for thin-pools.
|
||||||
|
@ -1857,7 +1857,8 @@ static int _setup_lv_size(struct logical_volume *lv, uint32_t extents)
|
|||||||
lv->le_count = extents;
|
lv->le_count = extents;
|
||||||
lv->size = (uint64_t) extents * lv->vg->extent_size;
|
lv->size = (uint64_t) extents * lv->vg->extent_size;
|
||||||
|
|
||||||
if (lv_is_thin_pool_data(lv)) {
|
if (lv_is_thin_pool_data(lv) ||
|
||||||
|
lv_is_vdo_pool_data(lv)) {
|
||||||
if (!(thin_pool_seg = get_only_segment_using_this_lv(lv)))
|
if (!(thin_pool_seg = get_only_segment_using_this_lv(lv)))
|
||||||
return_0;
|
return_0;
|
||||||
|
|
||||||
@ -4902,12 +4903,6 @@ static int _lvresize_check(struct logical_volume *lv,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (lv_is_vdo_type(lv)) {
|
|
||||||
log_error("Resize of VDO type volume %s is not yet supported.",
|
|
||||||
display_lvname(lv));
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (lv_is_raid(lv) &&
|
if (lv_is_raid(lv) &&
|
||||||
lp->resize == LV_REDUCE) {
|
lp->resize == LV_REDUCE) {
|
||||||
unsigned attrs;
|
unsigned attrs;
|
||||||
@ -4934,6 +4929,7 @@ static int _lvresize_check(struct logical_volume *lv,
|
|||||||
|
|
||||||
if (!lv_is_visible(lv) &&
|
if (!lv_is_visible(lv) &&
|
||||||
!lv_is_thin_pool_metadata(lv) &&
|
!lv_is_thin_pool_metadata(lv) &&
|
||||||
|
!lv_is_vdo_pool_data(lv) &&
|
||||||
!lv_is_lockd_sanlock_lv(lv)) {
|
!lv_is_lockd_sanlock_lv(lv)) {
|
||||||
log_error("Can't resize internal logical volume %s.", display_lvname(lv));
|
log_error("Can't resize internal logical volume %s.", display_lvname(lv));
|
||||||
return 0;
|
return 0;
|
||||||
@ -4967,6 +4963,8 @@ static int _lvresize_check(struct logical_volume *lv,
|
|||||||
(lv_is_thin_pool(lv) ||
|
(lv_is_thin_pool(lv) ||
|
||||||
lv_is_thin_pool_data(lv) ||
|
lv_is_thin_pool_data(lv) ||
|
||||||
lv_is_thin_pool_metadata(lv) ||
|
lv_is_thin_pool_metadata(lv) ||
|
||||||
|
lv_is_vdo_pool(lv) ||
|
||||||
|
lv_is_vdo_pool_data(lv) ||
|
||||||
lv_is_pool_metadata_spare(lv) ||
|
lv_is_pool_metadata_spare(lv) ||
|
||||||
lv_is_lockd_sanlock_lv(lv))) {
|
lv_is_lockd_sanlock_lv(lv))) {
|
||||||
log_print_unless_silent("Ignoring --resizefs as volume %s does not have a filesystem.",
|
log_print_unless_silent("Ignoring --resizefs as volume %s does not have a filesystem.",
|
||||||
@ -5457,6 +5455,11 @@ static int _lvresize_check_type(const struct logical_volume *lv,
|
|||||||
log_error("Thin pool metadata volumes cannot be reduced.");
|
log_error("Thin pool metadata volumes cannot be reduced.");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
if (lv_is_vdo_pool_data(lv)) {
|
||||||
|
log_error("Cannot reduce VDO pool data volume %s.",
|
||||||
|
display_lvname(lv));
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
} else if (lp->resize == LV_EXTEND) {
|
} else if (lp->resize == LV_EXTEND) {
|
||||||
if (lv_is_thin_pool_metadata(lv) &&
|
if (lv_is_thin_pool_metadata(lv) &&
|
||||||
(!(seg = find_pool_seg(first_seg(lv))) ||
|
(!(seg = find_pool_seg(first_seg(lv))) ||
|
||||||
@ -5529,7 +5532,7 @@ static int _lvresize_prepare(struct logical_volume **lv,
|
|||||||
{
|
{
|
||||||
struct volume_group *vg = (*lv)->vg;
|
struct volume_group *vg = (*lv)->vg;
|
||||||
|
|
||||||
if (lv_is_thin_pool(*lv))
|
if (lv_is_thin_pool(*lv) || lv_is_vdo_pool(*lv))
|
||||||
*lv = seg_lv(first_seg(*lv), 0); /* switch to data LV */
|
*lv = seg_lv(first_seg(*lv), 0); /* switch to data LV */
|
||||||
|
|
||||||
/* Resolve extents from size */
|
/* Resolve extents from size */
|
||||||
|
Loading…
Reference in New Issue
Block a user