1
0
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:
David Teigland 2016-11-21 15:03:27 -06:00
parent 24e69e5feb
commit 72c9735e01

View File

@ -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;