mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-05 13:18:20 +03:00
lvconvert: remove unused calls for snapshots
snapshot commands are no longer called from the monolithic lvconvert code, so remove the unused code.
This commit is contained in:
parent
24e69e5feb
commit
72c9735e01
@ -41,20 +41,17 @@ typedef enum {
|
|||||||
/* Merge:
|
/* Merge:
|
||||||
* If merge_snapshot is also set:
|
* If merge_snapshot is also set:
|
||||||
* merge thin snapshot LV into its origin
|
* merge thin snapshot LV into its origin
|
||||||
* merge old snapshot COW into its origin
|
|
||||||
* or if merge_mirror is also set
|
* or if merge_mirror is also set
|
||||||
* merge LV previously split from mirror back into mirror
|
* merge LV previously split from mirror back into mirror
|
||||||
*/
|
*/
|
||||||
CONV_MERGE = 1,
|
CONV_MERGE = 1,
|
||||||
|
|
||||||
/* Split:
|
/* Split:
|
||||||
* For a snapshot, split it apart into COW and origin for future recombination
|
|
||||||
* For a cached LV, split it apart into the cached LV and its pool
|
* For a cached LV, split it apart into the cached LV and its pool
|
||||||
* For a mirrored or raid LV, split mirror into two mirrors, optionally tracking
|
* For a mirrored or raid LV, split mirror into two mirrors, optionally tracking
|
||||||
* future changes to the main mirror to allow future recombination.
|
* future changes to the main mirror to allow future recombination.
|
||||||
*/
|
*/
|
||||||
CONV_SPLIT = 2,
|
CONV_SPLIT = 2,
|
||||||
CONV_SPLIT_SNAPSHOT = 3,
|
|
||||||
CONV_SPLIT_CACHE = 4,
|
CONV_SPLIT_CACHE = 4,
|
||||||
CONV_SPLIT_MIRRORS = 5,
|
CONV_SPLIT_MIRRORS = 5,
|
||||||
|
|
||||||
@ -64,9 +61,6 @@ typedef enum {
|
|||||||
/* Destroy the cache attached to a cached LV */
|
/* Destroy the cache attached to a cached LV */
|
||||||
CONV_UNCACHE = 7,
|
CONV_UNCACHE = 7,
|
||||||
|
|
||||||
/* Reconstruct a snapshot from its origin and COW */
|
|
||||||
CONV_SNAPSHOT = 8,
|
|
||||||
|
|
||||||
/* Convert normal LV into one in a thin pool */
|
/* Convert normal LV into one in a thin pool */
|
||||||
CONV_THIN = 11,
|
CONV_THIN = 11,
|
||||||
|
|
||||||
@ -78,19 +72,16 @@ struct lvconvert_params {
|
|||||||
/* Exactly one of these 12 command categories is determined */
|
/* Exactly one of these 12 command categories is determined */
|
||||||
int merge; /* 1 */
|
int merge; /* 1 */
|
||||||
int split; /* 2 */
|
int split; /* 2 */
|
||||||
int splitsnapshot; /* 3 */
|
|
||||||
int splitcache; /* 4 */
|
int splitcache; /* 4 */
|
||||||
int keep_mimages; /* 5 */ /* --splitmirrors */
|
int keep_mimages; /* 5 */ /* --splitmirrors */
|
||||||
int cache; /* 6 */
|
int cache; /* 6 */
|
||||||
int uncache; /* 7 */
|
int uncache; /* 7 */
|
||||||
int snapshot; /* 8 */
|
|
||||||
int thin; /* 11 */
|
int thin; /* 11 */
|
||||||
/* other */ /* 12 */
|
/* other */ /* 12 */
|
||||||
|
|
||||||
/* FIXME Eliminate all cases where more than one of the above are set then use conv_type instead */
|
/* FIXME Eliminate all cases where more than one of the above are set then use conv_type instead */
|
||||||
conversion_type_t conv_type;
|
conversion_type_t conv_type;
|
||||||
|
|
||||||
int merge_snapshot; /* CONV_MERGE is set */
|
|
||||||
int merge_mirror; /* CONV_MERGE is set */
|
int merge_mirror; /* CONV_MERGE is set */
|
||||||
|
|
||||||
int track_changes; /* CONV_SPLIT_MIRRORS is set */
|
int track_changes; /* CONV_SPLIT_MIRRORS is set */
|
||||||
@ -202,13 +193,6 @@ static int _lvconvert_name_params(struct lvconvert_params *lp,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!strstr((*pargv)[0], "_rimage_")) { /* Snapshot */
|
|
||||||
lp->type_str = SEG_TYPE_NAME_SNAPSHOT;
|
|
||||||
lp->merge_snapshot = 1;
|
|
||||||
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Mirror */
|
/* Mirror */
|
||||||
lp->merge_mirror = 1;
|
lp->merge_mirror = 1;
|
||||||
}
|
}
|
||||||
@ -223,11 +207,6 @@ static int _lvconvert_name_params(struct lvconvert_params *lp,
|
|||||||
"the external origin.");
|
"the external origin.");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
if (lp->snapshot) {
|
|
||||||
log_error("Please specify a logical volume to act as "
|
|
||||||
"the snapshot exception store.");
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
if (lp->split) {
|
if (lp->split) {
|
||||||
log_error("Logical volume for split is missing.");
|
log_error("Logical volume for split is missing.");
|
||||||
return 0;
|
return 0;
|
||||||
@ -296,14 +275,6 @@ static int _lvconvert_name_params(struct lvconvert_params *lp,
|
|||||||
return_0;
|
return_0;
|
||||||
|
|
||||||
if (*pargc) {
|
if (*pargc) {
|
||||||
if (lp->snapshot) {
|
|
||||||
log_error("Too many arguments provided for snapshots.");
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
if (lp->splitsnapshot) {
|
|
||||||
log_error("Too many arguments provided with --splitsnapshot.");
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
if (lp->splitcache) {
|
if (lp->splitcache) {
|
||||||
log_error("Too many arguments provided with --splitcache.");
|
log_error("Too many arguments provided with --splitcache.");
|
||||||
return 0;
|
return 0;
|
||||||
@ -328,12 +299,6 @@ static int _lvconvert_name_params(struct lvconvert_params *lp,
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* -s/--snapshot and --type snapshot are synonyms */
|
|
||||||
static int _snapshot_type_requested(struct cmd_context *cmd, const char *type_str)
|
|
||||||
{
|
|
||||||
return (arg_is_set(cmd, snapshot_ARG) || !strcmp(type_str, SEG_TYPE_NAME_SNAPSHOT));
|
|
||||||
}
|
|
||||||
|
|
||||||
static int _raid0_type_requested(const char *type_str)
|
static int _raid0_type_requested(const char *type_str)
|
||||||
{
|
{
|
||||||
return (!strcmp(type_str, SEG_TYPE_NAME_RAID0) || !strcmp(type_str, SEG_TYPE_NAME_RAID0_META));
|
return (!strcmp(type_str, SEG_TYPE_NAME_RAID0) || !strcmp(type_str, SEG_TYPE_NAME_RAID0_META));
|
||||||
@ -531,14 +496,6 @@ static int _read_params(struct cmd_context *cmd, int argc, char **argv,
|
|||||||
return_0;
|
return_0;
|
||||||
lp->splitcache = 1;
|
lp->splitcache = 1;
|
||||||
_set_conv_type(lp, CONV_SPLIT_CACHE);
|
_set_conv_type(lp, CONV_SPLIT_CACHE);
|
||||||
} else if (arg_is_set(cmd, splitsnapshot_ARG)) {
|
|
||||||
if (arg_outside_list_is_set(cmd, "cannot be used with --splitsnapshot",
|
|
||||||
splitsnapshot_ARG,
|
|
||||||
force_ARG, noudevsync_ARG, test_ARG,
|
|
||||||
-1))
|
|
||||||
return_0;
|
|
||||||
lp->splitsnapshot = 1;
|
|
||||||
_set_conv_type(lp, CONV_SPLIT_SNAPSHOT);
|
|
||||||
} else if (arg_is_set(cmd, uncache_ARG)) {
|
} else if (arg_is_set(cmd, uncache_ARG)) {
|
||||||
if (arg_outside_list_is_set(cmd, "cannot be used with --uncache",
|
if (arg_outside_list_is_set(cmd, "cannot be used with --uncache",
|
||||||
uncache_ARG,
|
uncache_ARG,
|
||||||
@ -585,15 +542,6 @@ static int _read_params(struct cmd_context *cmd, int argc, char **argv,
|
|||||||
if (!_read_pool_params(cmd, &argc, &argv, lp))
|
if (!_read_pool_params(cmd, &argc, &argv, lp))
|
||||||
return_0;
|
return_0;
|
||||||
|
|
||||||
if (_snapshot_type_requested(cmd, lp->type_str)) {
|
|
||||||
if (lp->merge) {
|
|
||||||
log_error("--snapshot and --merge are mutually exclusive.");
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
lp->snapshot = 1;
|
|
||||||
_set_conv_type(lp, CONV_SNAPSHOT);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (lp->split) {
|
if (lp->split) {
|
||||||
lp->lv_split_name = arg_str_value(cmd, name_ARG, NULL);
|
lp->lv_split_name = arg_str_value(cmd, name_ARG, NULL);
|
||||||
|
|
||||||
@ -632,17 +580,17 @@ static int _read_params(struct cmd_context *cmd, int argc, char **argv,
|
|||||||
}
|
}
|
||||||
|
|
||||||
/* If no other case was identified, then use of --stripes means --type striped */
|
/* If no other case was identified, then use of --stripes means --type striped */
|
||||||
if (!arg_is_set(cmd, type_ARG) && !*lp->type_str && !lp->merge && !lp->splitsnapshot &&
|
if (!arg_is_set(cmd, type_ARG) && !*lp->type_str && !lp->merge &&
|
||||||
!lp->splitcache && !lp->split && !lp->snapshot && !lp->uncache && !lp->cache && !lp->thin &&
|
!lp->splitcache && !lp->split && !lp->uncache && !lp->cache && !lp->thin &&
|
||||||
!lp->mirrorlog && !lp->corelog &&
|
!lp->mirrorlog && !lp->corelog &&
|
||||||
(arg_is_set(cmd, stripes_long_ARG) || arg_is_set(cmd, stripesize_ARG)))
|
(arg_is_set(cmd, stripes_long_ARG) || arg_is_set(cmd, stripesize_ARG)))
|
||||||
lp->type_str = SEG_TYPE_NAME_STRIPED;
|
lp->type_str = SEG_TYPE_NAME_STRIPED;
|
||||||
|
|
||||||
if ((_snapshot_type_requested(cmd, lp->type_str) || lp->merge) &&
|
if (lp->merge &&
|
||||||
(lp->mirrorlog || _mirror_or_raid_type_requested(cmd, lp->type_str) ||
|
(lp->mirrorlog || _mirror_or_raid_type_requested(cmd, lp->type_str) ||
|
||||||
arg_is_set(cmd, thinpool_ARG) || _raid0_type_requested(lp->type_str) ||
|
arg_is_set(cmd, thinpool_ARG) || _raid0_type_requested(lp->type_str) ||
|
||||||
_striped_type_requested(lp->type_str))) {
|
_striped_type_requested(lp->type_str))) {
|
||||||
log_error("--snapshot/--type snapshot or --merge argument "
|
log_error("--merge argument "
|
||||||
"cannot be mixed with --mirrors/--type mirror/--type raid*/--stripes/--type striped/--type linear, "
|
"cannot be mixed with --mirrors/--type mirror/--type raid*/--stripes/--type striped/--type linear, "
|
||||||
"--mirrorlog, --repair or --thinpool.");
|
"--mirrorlog, --repair or --thinpool.");
|
||||||
return 0;
|
return 0;
|
||||||
@ -666,8 +614,8 @@ static int _read_params(struct cmd_context *cmd, int argc, char **argv,
|
|||||||
lp->alloc = (alloc_policy_t) arg_uint_value(cmd, alloc_ARG, ALLOC_INHERIT);
|
lp->alloc = (alloc_policy_t) arg_uint_value(cmd, alloc_ARG, ALLOC_INHERIT);
|
||||||
|
|
||||||
/* We should have caught all these cases already. */
|
/* We should have caught all these cases already. */
|
||||||
if (lp->merge + lp->splitsnapshot + lp->splitcache + lp->split + lp->uncache +
|
if (lp->merge + lp->splitcache + lp->split + lp->uncache +
|
||||||
lp->cache + lp->thin + lp->keep_mimages + lp->snapshot > 1) {
|
lp->cache + lp->thin + lp->keep_mimages > 1) {
|
||||||
log_error(INTERNAL_ERROR "Unexpected combination of incompatible options selected.");
|
log_error(INTERNAL_ERROR "Unexpected combination of incompatible options selected.");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -676,14 +624,12 @@ static int _read_params(struct cmd_context *cmd, int argc, char **argv,
|
|||||||
/*
|
/*
|
||||||
* Final checking of each case:
|
* Final checking of each case:
|
||||||
* lp->merge
|
* lp->merge
|
||||||
* lp->splitsnapshot
|
|
||||||
* lp->splitcache
|
* lp->splitcache
|
||||||
* lp->split
|
* lp->split
|
||||||
* lp->uncache
|
* lp->uncache
|
||||||
* lp->cache
|
* lp->cache
|
||||||
* lp->thin
|
* lp->thin
|
||||||
* lp->keep_mimages
|
* lp->keep_mimages
|
||||||
* lp->snapshot
|
|
||||||
* --type mirror|raid lp->mirrorlog lp->corelog
|
* --type mirror|raid lp->mirrorlog lp->corelog
|
||||||
* --type raid0|striped
|
* --type raid0|striped
|
||||||
*/
|
*/
|
||||||
@ -692,46 +638,10 @@ static int _read_params(struct cmd_context *cmd, int argc, char **argv,
|
|||||||
case CONV_SPLIT:
|
case CONV_SPLIT:
|
||||||
case CONV_SPLIT_CACHE:
|
case CONV_SPLIT_CACHE:
|
||||||
case CONV_SPLIT_MIRRORS:
|
case CONV_SPLIT_MIRRORS:
|
||||||
case CONV_SPLIT_SNAPSHOT: /* Destroy snapshot retaining cow as separate LV */
|
|
||||||
case CONV_CACHE:
|
case CONV_CACHE:
|
||||||
case CONV_UNCACHE:
|
case CONV_UNCACHE:
|
||||||
case CONV_THIN:
|
case CONV_THIN:
|
||||||
break;
|
break;
|
||||||
case CONV_SNAPSHOT: /* Snapshot creation from pre-existing cow */
|
|
||||||
if (!argc) {
|
|
||||||
log_error("Please provide logical volume path for snapshot origin.");
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
lp->origin_name = argv[0];
|
|
||||||
argv++, argc--;
|
|
||||||
|
|
||||||
if (arg_is_set(cmd, regionsize_ARG)) {
|
|
||||||
log_error("--regionsize is only available with mirrors");
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (arg_is_set(cmd, stripesize_ARG) || arg_is_set(cmd, stripes_long_ARG)) {
|
|
||||||
log_error("--stripes and --stripesize are only available with striped mirrors");
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (arg_is_set(cmd, chunksize_ARG) &&
|
|
||||||
(arg_sign_value(cmd, chunksize_ARG, SIGN_NONE) == SIGN_MINUS)) {
|
|
||||||
log_error("Negative chunk size is invalid.");
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
lp->chunk_size = arg_uint_value(cmd, chunksize_ARG, 8);
|
|
||||||
if (lp->chunk_size < 8 || lp->chunk_size > 1024 ||
|
|
||||||
!is_power_of_2(lp->chunk_size)) {
|
|
||||||
log_error("Chunk size must be a power of 2 in the "
|
|
||||||
"range 4K to 512K");
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
log_verbose("Setting chunk size to %s.", display_size(cmd, lp->chunk_size));
|
|
||||||
|
|
||||||
lp->type_str = SEG_TYPE_NAME_SNAPSHOT;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case CONV_OTHER:
|
case CONV_OTHER:
|
||||||
if (_mirror_or_raid_type_requested(cmd, lp->type_str) ||
|
if (_mirror_or_raid_type_requested(cmd, lp->type_str) ||
|
||||||
@ -3363,26 +3273,6 @@ static int _lvconvert_cache(struct cmd_context *cmd,
|
|||||||
* moved into the _convert_lvtype_operation() functions below.
|
* moved into the _convert_lvtype_operation() functions below.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/*
|
|
||||||
* Separate a COW snapshot LV from its origin.
|
|
||||||
* lvconvert --splitsnapshot LV
|
|
||||||
*/
|
|
||||||
static int _convert_cow_snapshot_splitsnapshot(struct cmd_context *cmd, struct logical_volume *lv,
|
|
||||||
struct lvconvert_params *lp)
|
|
||||||
{
|
|
||||||
return _lvconvert_splitsnapshot(cmd, lv);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Merge a COW snapshot LV into its origin.
|
|
||||||
* lvconvert --merge LV
|
|
||||||
*/
|
|
||||||
static int _convert_cow_snapshot_merge(struct cmd_context *cmd, struct logical_volume *lv,
|
|
||||||
struct lvconvert_params *lp)
|
|
||||||
{
|
|
||||||
/* return _lvconvert_merge_old_snapshot(cmd, lv, lp); */
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Merge a snapshot thin LV into its origin.
|
* Merge a snapshot thin LV into its origin.
|
||||||
* lvconvert --merge LV
|
* lvconvert --merge LV
|
||||||
@ -3663,20 +3553,6 @@ static int _convert_raid_merge(struct cmd_context *cmd, struct logical_volume *l
|
|||||||
return _lvconvert_raid(lv, lp);
|
return _lvconvert_raid(lv, lp);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* Combine a raid* LV with a snapshot LV that was previously
|
|
||||||
* split from the raid* LV using --splitsnapshot.
|
|
||||||
* lvconvert --type snapshot LV SnapshotLV
|
|
||||||
*
|
|
||||||
* Alternate syntax:
|
|
||||||
* lvconvert --snapshot LV SnapshotLV
|
|
||||||
*/
|
|
||||||
static int _convert_raid_snapshot(struct cmd_context *cmd, struct logical_volume *lv,
|
|
||||||
struct lvconvert_params *lp)
|
|
||||||
{
|
|
||||||
return _lvconvert_snapshot(cmd, lv, lp->origin_name);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Convert a raid* LV to a thin LV with an external origin.
|
* Convert a raid* LV to a thin LV with an external origin.
|
||||||
* lvconvert --type thin LV
|
* lvconvert --type thin LV
|
||||||
@ -3802,20 +3678,6 @@ static int _convert_striped_merge(struct cmd_context *cmd, struct logical_volume
|
|||||||
return _lvconvert_raid(lv, lp);
|
return _lvconvert_raid(lv, lp);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
|
||||||
* Combine a linear/striped LV with a snapshot LV that was previously
|
|
||||||
* split from the linear/striped LV using --splitsnapshot.
|
|
||||||
* lvconvert --type snapshot LV SnapshotLV
|
|
||||||
*
|
|
||||||
* Alternate syntax:
|
|
||||||
* lvconvert --snapshot LV SnapshotLV
|
|
||||||
*/
|
|
||||||
static int _convert_striped_snapshot(struct cmd_context *cmd, struct logical_volume *lv,
|
|
||||||
struct lvconvert_params *lp)
|
|
||||||
{
|
|
||||||
return _lvconvert_snapshot(cmd, lv, lp->origin_name);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Convert a striped/linear LV to a thin LV with an external origin.
|
* Convert a striped/linear LV to a thin LV with an external origin.
|
||||||
* lvconvert --type thin LV
|
* lvconvert --type thin LV
|
||||||
@ -3930,22 +3792,6 @@ static int _convert_striped_raid(struct cmd_context *cmd, struct logical_volume
|
|||||||
*
|
*
|
||||||
* _convert_<lvtype>
|
* _convert_<lvtype>
|
||||||
*/
|
*/
|
||||||
static int _convert_cow_snapshot(struct cmd_context *cmd, struct logical_volume *lv,
|
|
||||||
struct lvconvert_params *lp)
|
|
||||||
{
|
|
||||||
if (lp->splitsnapshot)
|
|
||||||
return _convert_cow_snapshot_splitsnapshot(cmd, lv, lp);
|
|
||||||
|
|
||||||
/* FIXME: add --merge-snapshot to make this distinct from --merge-mirror. */
|
|
||||||
if (lp->merge)
|
|
||||||
return _convert_cow_snapshot_merge(cmd, lv, lp);
|
|
||||||
|
|
||||||
log_error("Operation not permitted on COW snapshot LV %s.", display_lvname(lv));
|
|
||||||
log_error("Operations permitted on a COW snapshot LV are:\n"
|
|
||||||
" --splitsnapshot\n"
|
|
||||||
" --merge\n");
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
static int _convert_thin_volume(struct cmd_context *cmd, struct logical_volume *lv,
|
static int _convert_thin_volume(struct cmd_context *cmd, struct logical_volume *lv,
|
||||||
struct lvconvert_params *lp)
|
struct lvconvert_params *lp)
|
||||||
@ -4147,9 +3993,6 @@ static int _convert_raid(struct cmd_context *cmd, struct logical_volume *lv,
|
|||||||
if (lp->merge)
|
if (lp->merge)
|
||||||
return _convert_raid_merge(cmd, lv, lp);
|
return _convert_raid_merge(cmd, lv, lp);
|
||||||
|
|
||||||
if (!strcmp(lp->type_str, SEG_TYPE_NAME_SNAPSHOT) || arg_is_set(cmd, snapshot_ARG))
|
|
||||||
return _convert_raid_snapshot(cmd, lv, lp);
|
|
||||||
|
|
||||||
if (lp->thin)
|
if (lp->thin)
|
||||||
return _convert_raid_thin(cmd, lv, lp);
|
return _convert_raid_thin(cmd, lv, lp);
|
||||||
|
|
||||||
@ -4181,9 +4024,6 @@ static int _convert_striped(struct cmd_context *cmd, struct logical_volume *lv,
|
|||||||
if (lp->merge)
|
if (lp->merge)
|
||||||
return _convert_striped_merge(cmd, lv, lp);
|
return _convert_striped_merge(cmd, lv, lp);
|
||||||
|
|
||||||
if (lp->snapshot || !strcmp(lp->type_str, SEG_TYPE_NAME_SNAPSHOT))
|
|
||||||
return _convert_striped_snapshot(cmd, lv, lp);
|
|
||||||
|
|
||||||
if (lp->thin)
|
if (lp->thin)
|
||||||
return _convert_striped_thin(cmd, lv, lp);
|
return _convert_striped_thin(cmd, lv, lp);
|
||||||
|
|
||||||
@ -4322,18 +4162,10 @@ static int _lvconvert(struct cmd_context *cmd, struct logical_volume *lv,
|
|||||||
lp->stripes = 0;
|
lp->stripes = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (lp->snapshot)
|
|
||||||
lp->zero = (lp->segtype->flags & SEG_CANNOT_BE_ZEROED) ? 0 : arg_int_value(cmd, zero_ARG, 1);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Each LV type that can be converted.
|
* Each LV type that can be converted.
|
||||||
* (The existing type of the LV, not a requested type.)
|
* (The existing type of the LV, not a requested type.)
|
||||||
*/
|
*/
|
||||||
if (lv_is_cow(lv)) {
|
|
||||||
ret = _convert_cow_snapshot(cmd, lv, lp);
|
|
||||||
goto out;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (lv_is_thin_volume(lv)) {
|
if (lv_is_thin_volume(lv)) {
|
||||||
ret = _convert_thin_volume(cmd, lv, lp);
|
ret = _convert_thin_volume(cmd, lv, lp);
|
||||||
goto out;
|
goto out;
|
||||||
|
Loading…
Reference in New Issue
Block a user