mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-03 05:18:29 +03:00
lvconvert: share function for cache params
Reuse same code for getting/setting cache parameters with lvcreate. So there is single one place how to get vars from profiles and configs. Variables declarations are moved to start of function and there is no need to initialize them as they are always defined by functions get_cache_params() and get_pool_params().
This commit is contained in:
parent
298d12c459
commit
46820bfff3
@ -1,5 +1,6 @@
|
|||||||
Version 2.02.169 -
|
Version 2.02.169 -
|
||||||
=====================================
|
=====================================
|
||||||
|
Use function cache_set_params() for both lvcreate and lvconvert.
|
||||||
Skip rounding on cache chunk size boudary when create cache LV.
|
Skip rounding on cache chunk size boudary when create cache LV.
|
||||||
Improve cache_set_params support for chunk_size selection.
|
Improve cache_set_params support for chunk_size selection.
|
||||||
Fix metadata profile allocation/cache_[mode|policy] setting.
|
Fix metadata profile allocation/cache_[mode|policy] setting.
|
||||||
|
@ -2680,7 +2680,12 @@ static int _lvconvert_to_pool(struct cmd_context *cmd,
|
|||||||
uint32_t meta_extents;
|
uint32_t meta_extents;
|
||||||
uint32_t chunk_size;
|
uint32_t chunk_size;
|
||||||
int chunk_calc;
|
int chunk_calc;
|
||||||
|
cache_mode_t cache_mode;
|
||||||
|
const char *policy_name;
|
||||||
struct dm_config_tree *policy_settings = NULL;
|
struct dm_config_tree *policy_settings = NULL;
|
||||||
|
int pool_metadata_spare;
|
||||||
|
thin_discards_t discards;
|
||||||
|
thin_zero_t zero_new_blocks;
|
||||||
int r = 0;
|
int r = 0;
|
||||||
|
|
||||||
/* for handling lvmlockd cases */
|
/* for handling lvmlockd cases */
|
||||||
@ -2692,7 +2697,6 @@ static int _lvconvert_to_pool(struct cmd_context *cmd,
|
|||||||
struct id lockd_meta_id;
|
struct id lockd_meta_id;
|
||||||
const char *str_seg_type = to_cachepool ? SEG_TYPE_NAME_CACHE_POOL : SEG_TYPE_NAME_THIN_POOL;
|
const char *str_seg_type = to_cachepool ? SEG_TYPE_NAME_CACHE_POOL : SEG_TYPE_NAME_THIN_POOL;
|
||||||
|
|
||||||
|
|
||||||
if (lv_is_thin_pool(lv) || lv_is_cache_pool(lv)) {
|
if (lv_is_thin_pool(lv) || lv_is_cache_pool(lv)) {
|
||||||
log_error(INTERNAL_ERROR "LV %s is already a pool.", display_lvname(lv));
|
log_error(INTERNAL_ERROR "LV %s is already a pool.", display_lvname(lv));
|
||||||
return 0;
|
return 0;
|
||||||
@ -2786,34 +2790,21 @@ static int _lvconvert_to_pool(struct cmd_context *cmd,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
if (!get_pool_params(cmd, pool_segtype, &passed_args,
|
||||||
* Determine the size of the metadata LV and the chunk size. When an
|
&meta_size, &pool_metadata_spare,
|
||||||
* existing LV is to be used for metadata, this introduces some
|
&chunk_size, &discards, &zero_new_blocks))
|
||||||
* constraints/defaults. When chunk_size=0 and/or meta_extents=0 are
|
goto_bad;
|
||||||
* passed to the "update params" function, defaults are calculated and
|
|
||||||
* returned.
|
|
||||||
*/
|
|
||||||
|
|
||||||
if (arg_is_set(cmd, chunksize_ARG)) {
|
if (to_cachepool &&
|
||||||
passed_args |= PASS_ARG_CHUNK_SIZE;
|
!get_cache_params(cmd, &chunk_size, &cache_mode, &policy_name, &policy_settings))
|
||||||
chunk_size = arg_uint_value(cmd, chunksize_ARG, 0);
|
goto_bad;
|
||||||
if (!validate_pool_chunk_size(cmd, pool_segtype, chunk_size))
|
|
||||||
return_0;
|
|
||||||
} else /* A default will be chosen by the "update" function. */
|
|
||||||
chunk_size = 0;
|
|
||||||
|
|
||||||
if (arg_is_set(cmd, poolmetadatasize_ARG)) {
|
if (metadata_lv)
|
||||||
meta_size = arg_uint64_value(cmd, poolmetadatasize_ARG, UINT64_C(0));
|
|
||||||
meta_extents = extents_from_size(cmd, meta_size, vg->extent_size);
|
|
||||||
passed_args |= PASS_ARG_POOL_METADATA_SIZE;
|
|
||||||
} else if (metadata_lv) {
|
|
||||||
meta_extents = metadata_lv->le_count;
|
meta_extents = metadata_lv->le_count;
|
||||||
passed_args |= PASS_ARG_POOL_METADATA_SIZE;
|
else if (meta_size)
|
||||||
} else /* A default will be chosen by the "update" function. */
|
meta_extents = extents_from_size(cmd, meta_size, vg->extent_size);
|
||||||
meta_extents = 0;
|
else
|
||||||
|
meta_extents = 0; /* A default will be chosen by the "update" function. */
|
||||||
/* Tell the "update" function to ignore these, they are handled below. */
|
|
||||||
passed_args |= PASS_ARG_DISCARDS | PASS_ARG_ZERO;
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Validate and/or choose defaults for meta_extents and chunk_size,
|
* Validate and/or choose defaults for meta_extents and chunk_size,
|
||||||
@ -2833,18 +2824,10 @@ static int _lvconvert_to_pool(struct cmd_context *cmd,
|
|||||||
&meta_extents,
|
&meta_extents,
|
||||||
&chunk_calc,
|
&chunk_calc,
|
||||||
&chunk_size,
|
&chunk_size,
|
||||||
NULL, NULL))
|
&discards, &zero_new_blocks))
|
||||||
goto_bad;
|
goto_bad;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((uint64_t)chunk_size > ((uint64_t)lv->le_count * vg->extent_size)) {
|
|
||||||
log_error("Pool data LV %s is too small (%s) for specified chunk size (%s).",
|
|
||||||
display_lvname(lv),
|
|
||||||
display_size(cmd, (uint64_t)lv->le_count * vg->extent_size),
|
|
||||||
display_size(cmd, chunk_size));
|
|
||||||
goto bad;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (metadata_lv && (meta_extents > metadata_lv->le_count)) {
|
if (metadata_lv && (meta_extents > metadata_lv->le_count)) {
|
||||||
log_error("Pool metadata LV %s is too small (%u extents) for required metadata (%u extents).",
|
log_error("Pool metadata LV %s is too small (%u extents) for required metadata (%u extents).",
|
||||||
display_lvname(metadata_lv), metadata_lv->le_count, meta_extents);
|
display_lvname(metadata_lv), metadata_lv->le_count, meta_extents);
|
||||||
@ -3034,44 +3017,15 @@ static int _lvconvert_to_pool(struct cmd_context *cmd,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/* Apply settings to the new pool seg */
|
||||||
* Apply settings to the new pool seg, from command line, from
|
|
||||||
* defaults, sometimes adjusted.
|
|
||||||
*/
|
|
||||||
|
|
||||||
seg->transaction_id = 0;
|
|
||||||
seg->chunk_size = chunk_size;
|
|
||||||
|
|
||||||
if (to_cachepool) {
|
if (to_cachepool) {
|
||||||
cache_mode_t cache_mode = 0;
|
if (!cache_set_params(seg, chunk_size, cache_mode, policy_name, policy_settings))
|
||||||
const char *policy_name = NULL;
|
|
||||||
|
|
||||||
if (!get_cache_params(cmd, &chunk_size, &cache_mode, &policy_name, &policy_settings))
|
|
||||||
goto_bad;
|
|
||||||
|
|
||||||
if (cache_mode &&
|
|
||||||
!cache_set_cache_mode(seg, cache_mode))
|
|
||||||
goto_bad;
|
|
||||||
|
|
||||||
if ((policy_name || policy_settings) &&
|
|
||||||
!cache_set_policy(seg, policy_name, policy_settings))
|
|
||||||
goto_bad;
|
goto_bad;
|
||||||
} else {
|
} else {
|
||||||
const char *discards_name;
|
seg->transaction_id = 0;
|
||||||
|
seg->chunk_size = chunk_size;
|
||||||
if (arg_is_set(cmd, zero_ARG))
|
seg->discards = discards;
|
||||||
seg->zero_new_blocks = arg_int_value(cmd, zero_ARG, 0) ? THIN_ZERO_YES : THIN_ZERO_NO;
|
seg->zero_new_blocks = zero_new_blocks;
|
||||||
else
|
|
||||||
seg->zero_new_blocks = find_config_tree_bool(cmd, allocation_thin_pool_zero_CFG, vg->profile) ? THIN_ZERO_YES : THIN_ZERO_NO;
|
|
||||||
|
|
||||||
if (arg_is_set(cmd, discards_ARG))
|
|
||||||
seg->discards = (thin_discards_t) arg_uint_value(cmd, discards_ARG, THIN_DISCARDS_PASSDOWN);
|
|
||||||
else {
|
|
||||||
if (!(discards_name = find_config_tree_str(cmd, allocation_thin_pool_discards_CFG, vg->profile)))
|
|
||||||
goto_bad;
|
|
||||||
if (!set_pool_discards(&seg->discards, discards_name))
|
|
||||||
goto_bad;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -3087,8 +3041,7 @@ static int _lvconvert_to_pool(struct cmd_context *cmd,
|
|||||||
|
|
||||||
if (!handle_pool_metadata_spare(vg,
|
if (!handle_pool_metadata_spare(vg,
|
||||||
metadata_lv->le_count,
|
metadata_lv->le_count,
|
||||||
use_pvh,
|
use_pvh, pool_metadata_spare))
|
||||||
arg_int_value(cmd, poolmetadataspare_ARG, DEFAULT_POOL_METADATA_SPARE)))
|
|
||||||
goto_bad;
|
goto_bad;
|
||||||
|
|
||||||
if (!vg_write(vg) || !vg_commit(vg))
|
if (!vg_write(vg) || !vg_commit(vg))
|
||||||
@ -3173,8 +3126,8 @@ static int _lvconvert_to_cache_vol(struct cmd_context *cmd,
|
|||||||
{
|
{
|
||||||
struct logical_volume *cache_lv;
|
struct logical_volume *cache_lv;
|
||||||
uint32_t chunk_size = 0;
|
uint32_t chunk_size = 0;
|
||||||
cache_mode_t cache_mode = 0;
|
cache_mode_t cache_mode;
|
||||||
const char *policy_name = NULL;
|
const char *policy_name;
|
||||||
struct dm_config_tree *policy_settings = NULL;
|
struct dm_config_tree *policy_settings = NULL;
|
||||||
int r = 0;
|
int r = 0;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user