mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-19 14:04:17 +03:00
vdo: refactor code
Shuffle code to use prepare_exec_args(). Simplify generation of options string within a single char buffer.
This commit is contained in:
parent
4d2311655b
commit
409a79621a
@ -243,21 +243,22 @@ static int _format_vdo_pool_data_lv(struct logical_volume *data_lv,
|
|||||||
uint64_t *logical_size)
|
uint64_t *logical_size)
|
||||||
{
|
{
|
||||||
char *dpath, *c;
|
char *dpath, *c;
|
||||||
const struct dm_config_node *cn;
|
|
||||||
const struct dm_config_value *cv;
|
|
||||||
struct pipe_data pdata;
|
struct pipe_data pdata;
|
||||||
uint64_t logical_size_aligned = 1;
|
uint64_t logical_size_aligned = 1;
|
||||||
FILE *f;
|
FILE *f;
|
||||||
uint64_t lb;
|
uint64_t lb;
|
||||||
unsigned slabbits;
|
unsigned slabbits;
|
||||||
unsigned reformatting = 0;
|
unsigned reformatting = 0;
|
||||||
int args = 1;
|
int args = 0;
|
||||||
char buf_args[5][128];
|
|
||||||
char buf[256]; /* buffer for short disk header (64B) */
|
char buf[256]; /* buffer for short disk header (64B) */
|
||||||
const char *argv[19] = { /* Max supported args */
|
char *buf_pos = buf;
|
||||||
|
const char *argv[DEFAULT_MAX_EXEC_ARGS + 9] = { /* Max supported args */
|
||||||
find_config_tree_str_allow_empty(data_lv->vg->cmd, global_vdo_format_executable_CFG, NULL)
|
find_config_tree_str_allow_empty(data_lv->vg->cmd, global_vdo_format_executable_CFG, NULL)
|
||||||
};
|
};
|
||||||
|
|
||||||
|
if (!prepare_exec_args(data_lv->vg->cmd, argv, &args, global_vdo_format_options_CFG))
|
||||||
|
return_0;
|
||||||
|
|
||||||
if (!(dpath = lv_path_dup(data_lv->vg->cmd->mem, data_lv))) {
|
if (!(dpath = lv_path_dup(data_lv->vg->cmd->mem, data_lv))) {
|
||||||
log_error("Failed to build device path for VDO formatting of data volume %s.",
|
log_error("Failed to build device path for VDO formatting of data volume %s.",
|
||||||
display_lvname(data_lv));
|
display_lvname(data_lv));
|
||||||
@ -266,59 +267,31 @@ static int _format_vdo_pool_data_lv(struct logical_volume *data_lv,
|
|||||||
|
|
||||||
if (*logical_size) {
|
if (*logical_size) {
|
||||||
logical_size_aligned = 0;
|
logical_size_aligned = 0;
|
||||||
if (dm_snprintf(buf_args[args], sizeof(buf_args[0]), "--logical-size=" FMTu64 "K",
|
|
||||||
(*logical_size / 2)) < 0)
|
|
||||||
return_0;
|
|
||||||
|
|
||||||
argv[args] = buf_args[args];
|
argv[++args] = buf_pos;
|
||||||
args++;
|
buf_pos += 1 + dm_snprintf(buf_pos, 30, "--logical-size=" FMTu64 "K",
|
||||||
|
(*logical_size / 2));
|
||||||
}
|
}
|
||||||
|
|
||||||
slabbits = 31 - clz(vtp->slab_size_mb / DM_VDO_BLOCK_SIZE * 2 * 1024); /* to KiB / block_size */
|
slabbits = 31 - clz(vtp->slab_size_mb / DM_VDO_BLOCK_SIZE * 2 * 1024); /* to KiB / block_size */
|
||||||
log_debug("Slab size %s converted to %u bits.",
|
log_debug("Slab size %s converted to %u bits.",
|
||||||
display_size(data_lv->vg->cmd, vtp->slab_size_mb * UINT64_C(2 * 1024)), slabbits);
|
display_size(data_lv->vg->cmd, vtp->slab_size_mb * UINT64_C(2 * 1024)), slabbits);
|
||||||
if (dm_snprintf(buf_args[args], sizeof(buf_args[0]), "--slab-bits=%u", slabbits) < 0)
|
|
||||||
return_0;
|
|
||||||
|
|
||||||
argv[args] = buf_args[args];
|
argv[++args] = buf_pos;
|
||||||
args++;
|
buf_pos += 1 + dm_snprintf(buf_pos, 30, "--slab-bits=%u", slabbits);
|
||||||
|
|
||||||
/* Convert size to GiB units or one of these strings: 0.25, 0.50, 0.75 */
|
/* Convert size to GiB units or one of these strings: 0.25, 0.50, 0.75 */
|
||||||
if (vtp->index_memory_size_mb >= 1024) {
|
argv[++args] = buf_pos;
|
||||||
if (dm_snprintf(buf_args[args], sizeof(buf_args[0]), "--uds-memory-size=%u",
|
if (vtp->index_memory_size_mb >= 1024)
|
||||||
vtp->index_memory_size_mb / 1024) < 0)
|
buf_pos += 1 + dm_snprintf(buf_pos, 30, "--uds-memory-size=%u",
|
||||||
return_0;
|
vtp->index_memory_size_mb / 1024);
|
||||||
} else if (dm_snprintf(buf_args[args], sizeof(buf_args[0]), "--uds-memory-size=0.%u",
|
else
|
||||||
|
buf_pos += 1 + dm_snprintf(buf_pos, 30, "--uds-memory-size=0.%2u",
|
||||||
(vtp->index_memory_size_mb < 512) ? 25 :
|
(vtp->index_memory_size_mb < 512) ? 25 :
|
||||||
(vtp->index_memory_size_mb < 768) ? 50 : 75) < 0)
|
(vtp->index_memory_size_mb < 768) ? 50 : 75);
|
||||||
return_0;
|
|
||||||
|
|
||||||
argv[args] = buf_args[args];
|
if (vtp->use_sparse_index)
|
||||||
args++;
|
argv[++args] = "--uds-sparse";
|
||||||
|
|
||||||
if (vtp->use_sparse_index) {
|
|
||||||
if (dm_snprintf(buf_args[args], sizeof(buf_args[0]), "--uds-sparse") < 0)
|
|
||||||
return_0;
|
|
||||||
|
|
||||||
argv[args] = buf_args[args];
|
|
||||||
args++;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Any other user opts add here */
|
|
||||||
if (!(cn = find_config_tree_array(data_lv->vg->cmd, global_vdo_format_options_CFG, NULL))) {
|
|
||||||
log_error(INTERNAL_ERROR "Unable to find configuration for vdoformat command options.");
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
for (cv = cn->v; cv && args < 16; cv = cv->next) {
|
|
||||||
if (cv->type != DM_CFG_STRING) {
|
|
||||||
log_error("Invalid string in config file: "
|
|
||||||
"global/vdoformat_options.");
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
if (cv->v.str[0])
|
|
||||||
argv[++args] = cv->v.str;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Only unused VDO data LV could be activated and wiped */
|
/* Only unused VDO data LV could be activated and wiped */
|
||||||
if (!dm_list_empty(&data_lv->segs_using_this_lv)) {
|
if (!dm_list_empty(&data_lv->segs_using_this_lv)) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user