mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-02 01:18:26 +03:00
config: replace find_config_tree_node with find_config_tree_array where appropriate
This commit is contained in:
parent
67a61cce1b
commit
3b6840e099
@ -180,7 +180,7 @@ int lv_passes_auto_activation_filter(struct cmd_context *cmd, struct logical_vol
|
|||||||
{
|
{
|
||||||
const struct dm_config_node *cn;
|
const struct dm_config_node *cn;
|
||||||
|
|
||||||
if (!(cn = find_config_tree_node(cmd, activation_auto_activation_volume_list_CFG, NULL))) {
|
if (!(cn = find_config_tree_array(cmd, activation_auto_activation_volume_list_CFG, NULL))) {
|
||||||
log_verbose("activation/auto_activation_volume_list configuration setting "
|
log_verbose("activation/auto_activation_volume_list configuration setting "
|
||||||
"not defined: All logical volumes will be auto-activated.");
|
"not defined: All logical volumes will be auto-activated.");
|
||||||
return 1;
|
return 1;
|
||||||
@ -467,7 +467,7 @@ static int _passes_activation_filter(struct cmd_context *cmd,
|
|||||||
{
|
{
|
||||||
const struct dm_config_node *cn;
|
const struct dm_config_node *cn;
|
||||||
|
|
||||||
if (!(cn = find_config_tree_node(cmd, activation_volume_list_CFG, NULL))) {
|
if (!(cn = find_config_tree_array(cmd, activation_volume_list_CFG, NULL))) {
|
||||||
log_verbose("activation/volume_list configuration setting "
|
log_verbose("activation/volume_list configuration setting "
|
||||||
"not defined: Checking only host tags for %s/%s",
|
"not defined: Checking only host tags for %s/%s",
|
||||||
lv->vg->name, lv->name);
|
lv->vg->name, lv->name);
|
||||||
@ -496,7 +496,7 @@ static int _passes_readonly_filter(struct cmd_context *cmd,
|
|||||||
{
|
{
|
||||||
const struct dm_config_node *cn;
|
const struct dm_config_node *cn;
|
||||||
|
|
||||||
if (!(cn = find_config_tree_node(cmd, activation_read_only_volume_list_CFG, NULL)))
|
if (!(cn = find_config_tree_array(cmd, activation_read_only_volume_list_CFG, NULL)))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
return _lv_passes_volumes_filter(cmd, lv, cn, activation_read_only_volume_list_CFG);
|
return _lv_passes_volumes_filter(cmd, lv, cn, activation_read_only_volume_list_CFG);
|
||||||
|
@ -1918,7 +1918,6 @@ struct pool_cb_data {
|
|||||||
int skip_zero; /* to skip zeroed device header (check first 64B) */
|
int skip_zero; /* to skip zeroed device header (check first 64B) */
|
||||||
int exec; /* which binary to call */
|
int exec; /* which binary to call */
|
||||||
int opts;
|
int opts;
|
||||||
const char *defaults;
|
|
||||||
const char *global;
|
const char *global;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -1926,7 +1925,6 @@ static int _pool_callback(struct dm_tree_node *node,
|
|||||||
dm_node_callback_t type, void *cb_data)
|
dm_node_callback_t type, void *cb_data)
|
||||||
{
|
{
|
||||||
int ret, status, fd;
|
int ret, status, fd;
|
||||||
char *split;
|
|
||||||
const struct dm_config_node *cn;
|
const struct dm_config_node *cn;
|
||||||
const struct dm_config_value *cv;
|
const struct dm_config_value *cv;
|
||||||
const struct pool_cb_data *data = cb_data;
|
const struct pool_cb_data *data = cb_data;
|
||||||
@ -1941,23 +1939,17 @@ static int _pool_callback(struct dm_tree_node *node,
|
|||||||
if (!*argv[0])
|
if (!*argv[0])
|
||||||
return 1; /* Checking disabled */
|
return 1; /* Checking disabled */
|
||||||
|
|
||||||
if ((cn = find_config_tree_node(mlv->vg->cmd, data->opts, NULL))) {
|
if (!(cn = find_config_tree_array(mlv->vg->cmd, data->opts, NULL)))
|
||||||
for (cv = cn->v; cv && args < 16; cv = cv->next) {
|
return_0;
|
||||||
if (cv->type != DM_CFG_STRING) {
|
|
||||||
log_error("Invalid string in config file: "
|
for (cv = cn->v; cv && args < 16; cv = cv->next) {
|
||||||
"global/%s_check_options",
|
if (cv->type != DM_CFG_STRING) {
|
||||||
data->global);
|
log_error("Invalid string in config file: "
|
||||||
return 0;
|
"global/%s_check_options",
|
||||||
}
|
data->global);
|
||||||
argv[++args] = cv->v.str;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
/* Use default options (no support for options with spaces) */
|
|
||||||
if (!(split = dm_pool_strdup(data->dm->mem, data->defaults))) {
|
|
||||||
log_error("Failed to duplicate defaults.");
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
args = dm_split_words(split, 16, 0, (char**) argv + 1);
|
argv[++args] = cv->v.str;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (args == 16) {
|
if (args == 16) {
|
||||||
@ -2048,14 +2040,12 @@ static int _pool_register_callback(struct dev_manager *dm,
|
|||||||
data->skip_zero = 1;
|
data->skip_zero = 1;
|
||||||
data->exec = global_thin_check_executable_CFG;
|
data->exec = global_thin_check_executable_CFG;
|
||||||
data->opts = global_thin_check_options_CFG;
|
data->opts = global_thin_check_options_CFG;
|
||||||
data->defaults = DEFAULT_THIN_CHECK_OPTION1 " " DEFAULT_THIN_CHECK_OPTION2;
|
|
||||||
data->global = "thin";
|
data->global = "thin";
|
||||||
} else if (lv_is_cache(lv)) { /* cache pool */
|
} else if (lv_is_cache(lv)) { /* cache pool */
|
||||||
data->pool_lv = first_seg(lv)->pool_lv;
|
data->pool_lv = first_seg(lv)->pool_lv;
|
||||||
data->skip_zero = dm->activation;
|
data->skip_zero = dm->activation;
|
||||||
data->exec = global_cache_check_executable_CFG;
|
data->exec = global_cache_check_executable_CFG;
|
||||||
data->opts = global_cache_check_options_CFG;
|
data->opts = global_cache_check_options_CFG;
|
||||||
data->defaults = DEFAULT_CACHE_CHECK_OPTION1 " " DEFAULT_CACHE_CHECK_OPTION2;
|
|
||||||
data->global = "cache";
|
data->global = "cache";
|
||||||
} else {
|
} else {
|
||||||
log_error(INTERNAL_ERROR "Registering unsupported pool callback.");
|
log_error(INTERNAL_ERROR "Registering unsupported pool callback.");
|
||||||
|
@ -245,8 +245,8 @@ static int _parse_debug_classes(struct cmd_context *cmd)
|
|||||||
const struct dm_config_value *cv;
|
const struct dm_config_value *cv;
|
||||||
int debug_classes = 0;
|
int debug_classes = 0;
|
||||||
|
|
||||||
if (!(cn = find_config_tree_node(cmd, log_debug_classes_CFG, NULL)))
|
if (!(cn = find_config_tree_array(cmd, log_debug_classes_CFG, NULL)))
|
||||||
return DEFAULT_LOGGED_DEBUG_CLASSES;
|
return -1;
|
||||||
|
|
||||||
for (cv = cn->v; cv; cv = cv->next) {
|
for (cv = cn->v; cv; cv = cv->next) {
|
||||||
if (cv->type != DM_CFG_STRING) {
|
if (cv->type != DM_CFG_STRING) {
|
||||||
@ -652,7 +652,7 @@ static int _process_config(struct cmd_context *cmd)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((cn = find_config_tree_node(cmd, activation_mlock_filter_CFG, NULL)))
|
if ((cn = find_config_tree_array(cmd, activation_mlock_filter_CFG, NULL)))
|
||||||
for (cv = cn->v; cv; cv = cv->next)
|
for (cv = cn->v; cv; cv = cv->next)
|
||||||
if ((cv->type != DM_CFG_STRING) || !cv->v.str[0])
|
if ((cv->type != DM_CFG_STRING) || !cv->v.str[0])
|
||||||
log_error("Ignoring invalid activation/mlock_filter entry in config file");
|
log_error("Ignoring invalid activation/mlock_filter entry in config file");
|
||||||
@ -1016,14 +1016,10 @@ static int _init_dev_cache(struct cmd_context *cmd)
|
|||||||
init_obtain_device_list_from_udev(device_list_from_udev);
|
init_obtain_device_list_from_udev(device_list_from_udev);
|
||||||
|
|
||||||
if (!(cn = find_config_tree_node(cmd, devices_scan_CFG, NULL))) {
|
if (!(cn = find_config_tree_node(cmd, devices_scan_CFG, NULL))) {
|
||||||
if (!dev_cache_add_dir("/dev")) {
|
log_verbose("device/scan not in config file, "
|
||||||
log_error("Failed to add /dev to internal "
|
"using defaults.");
|
||||||
"device cache");
|
if (!(cn = find_config_tree_array(cmd, devices_scan_CFG, NULL)))
|
||||||
return 0;
|
return_0;
|
||||||
}
|
|
||||||
log_verbose("device/scan not in config file: "
|
|
||||||
"Defaulting to /dev");
|
|
||||||
return 1;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
for (cv = cn->v; cv; cv = cv->next) {
|
for (cv = cn->v; cv; cv = cv->next) {
|
||||||
@ -1061,7 +1057,7 @@ static int _init_dev_cache(struct cmd_context *cmd)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!(cn = find_config_tree_node(cmd, devices_loopfiles_CFG, NULL)))
|
if (!(cn = find_config_tree_array(cmd, devices_loopfiles_CFG, NULL)))
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
for (cv = cn->v; cv; cv = cv->next) {
|
for (cv = cn->v; cv; cv = cv->next) {
|
||||||
@ -1235,8 +1231,6 @@ static int _init_filters(struct cmd_context *cmd, unsigned load_persistent_cache
|
|||||||
cmd->lvmetad_filter = NULL;
|
cmd->lvmetad_filter = NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
cn = find_config_tree_array(cmd, devices_filter_CFG, NULL);
|
|
||||||
|
|
||||||
/* filter component 1 */
|
/* filter component 1 */
|
||||||
if ((cn = find_config_tree_node(cmd, devices_filter_CFG, NULL))) {
|
if ((cn = find_config_tree_node(cmd, devices_filter_CFG, NULL))) {
|
||||||
if (!(filter_components[1] = regex_filter_create(cn->v)))
|
if (!(filter_components[1] = regex_filter_create(cn->v)))
|
||||||
@ -1355,7 +1349,7 @@ static int _init_formats(struct cmd_context *cmd)
|
|||||||
#ifdef HAVE_LIBDL
|
#ifdef HAVE_LIBDL
|
||||||
/* Load any formats in shared libs if not static */
|
/* Load any formats in shared libs if not static */
|
||||||
if (!is_static() &&
|
if (!is_static() &&
|
||||||
(cn = find_config_tree_node(cmd, global_format_libraries_CFG, NULL))) {
|
(cn = find_config_tree_array(cmd, global_format_libraries_CFG, NULL))) {
|
||||||
|
|
||||||
const struct dm_config_value *cv;
|
const struct dm_config_value *cv;
|
||||||
struct format_type *(*init_format_fn) (struct cmd_context *);
|
struct format_type *(*init_format_fn) (struct cmd_context *);
|
||||||
@ -1521,7 +1515,7 @@ static int _init_segtypes(struct cmd_context *cmd)
|
|||||||
#ifdef HAVE_LIBDL
|
#ifdef HAVE_LIBDL
|
||||||
/* Load any formats in shared libs unless static */
|
/* Load any formats in shared libs unless static */
|
||||||
if (!is_static() &&
|
if (!is_static() &&
|
||||||
(cn = find_config_tree_node(cmd, global_segment_libraries_CFG, NULL))) {
|
(cn = find_config_tree_array(cmd, global_segment_libraries_CFG, NULL))) {
|
||||||
|
|
||||||
const struct dm_config_value *cv;
|
const struct dm_config_value *cv;
|
||||||
int (*init_multiple_segtypes_fn) (struct cmd_context *,
|
int (*init_multiple_segtypes_fn) (struct cmd_context *,
|
||||||
@ -1827,7 +1821,7 @@ struct cmd_context *create_toolcontext(unsigned is_long_lived,
|
|||||||
goto_out;
|
goto_out;
|
||||||
|
|
||||||
if (!(cmd->dev_types = create_dev_types(cmd->proc_dir,
|
if (!(cmd->dev_types = create_dev_types(cmd->proc_dir,
|
||||||
find_config_tree_node(cmd, devices_types_CFG, NULL))))
|
find_config_tree_array(cmd, devices_types_CFG, NULL))))
|
||||||
goto_out;
|
goto_out;
|
||||||
|
|
||||||
if (!_init_dev_cache(cmd))
|
if (!_init_dev_cache(cmd))
|
||||||
@ -2042,7 +2036,7 @@ int refresh_toolcontext(struct cmd_context *cmd)
|
|||||||
return_0;
|
return_0;
|
||||||
|
|
||||||
if (!(cmd->dev_types = create_dev_types(cmd->proc_dir,
|
if (!(cmd->dev_types = create_dev_types(cmd->proc_dir,
|
||||||
find_config_tree_node(cmd, devices_types_CFG, NULL))))
|
find_config_tree_array(cmd, devices_types_CFG, NULL))))
|
||||||
return_0;
|
return_0;
|
||||||
|
|
||||||
if (!_init_dev_cache(cmd))
|
if (!_init_dev_cache(cmd))
|
||||||
|
@ -1386,12 +1386,12 @@ static struct dm_config_node *_get_array_def_node(struct cmd_context *cmd,
|
|||||||
return cn;
|
return cn;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct dm_config_node *find_config_tree_array(struct cmd_context *cmd, int id, struct profile *profile)
|
const struct dm_config_node *find_config_tree_array(struct cmd_context *cmd, int id, struct profile *profile)
|
||||||
{
|
{
|
||||||
cfg_def_item_t *item = cfg_def_get_item_p(id);
|
cfg_def_item_t *item = cfg_def_get_item_p(id);
|
||||||
char path[CFG_PATH_MAX_LEN];
|
char path[CFG_PATH_MAX_LEN];
|
||||||
int profile_applied;
|
int profile_applied;
|
||||||
struct dm_config_node *cn;
|
const struct dm_config_node *cn;
|
||||||
|
|
||||||
profile_applied = _apply_local_profile(cmd, profile);
|
profile_applied = _apply_local_profile(cmd, profile);
|
||||||
_cfg_def_make_path(path, sizeof(path), item->id, item, 0);
|
_cfg_def_make_path(path, sizeof(path), item->id, item, 0);
|
||||||
@ -1400,7 +1400,7 @@ struct dm_config_node *find_config_tree_array(struct cmd_context *cmd, int id, s
|
|||||||
log_error(INTERNAL_ERROR "%s cfg tree element not declared as array.", path);
|
log_error(INTERNAL_ERROR "%s cfg tree element not declared as array.", path);
|
||||||
|
|
||||||
if (_config_disabled(cmd, item, path) ||
|
if (_config_disabled(cmd, item, path) ||
|
||||||
!(cn = dm_config_find_node(cmd->cft->root, path)))
|
!(cn = find_config_tree_node(cmd, id, profile)))
|
||||||
cn = _get_array_def_node(cmd, item, profile);
|
cn = _get_array_def_node(cmd, item, profile);
|
||||||
|
|
||||||
if (profile_applied)
|
if (profile_applied)
|
||||||
|
@ -272,7 +272,7 @@ int find_config_tree_int(struct cmd_context *cmd, int id, struct profile *profil
|
|||||||
int64_t find_config_tree_int64(struct cmd_context *cmd, int id, struct profile *profile);
|
int64_t find_config_tree_int64(struct cmd_context *cmd, int id, struct profile *profile);
|
||||||
float find_config_tree_float(struct cmd_context *cmd, int id, struct profile *profile);
|
float find_config_tree_float(struct cmd_context *cmd, int id, struct profile *profile);
|
||||||
int find_config_tree_bool(struct cmd_context *cmd, int id, struct profile *profile);
|
int find_config_tree_bool(struct cmd_context *cmd, int id, struct profile *profile);
|
||||||
struct dm_config_node *find_config_tree_array(struct cmd_context *cmd, int id, struct profile *profile);
|
const struct dm_config_node *find_config_tree_array(struct cmd_context *cmd, int id, struct profile *profile);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Functions for configuration settings for which the default
|
* Functions for configuration settings for which the default
|
||||||
|
@ -152,11 +152,6 @@
|
|||||||
# define DEFAULT_LOG_FACILITY LOG_USER
|
# define DEFAULT_LOG_FACILITY LOG_USER
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#define DEFAULT_LOGGED_DEBUG_CLASSES (LOG_CLASS_MEM | LOG_CLASS_DEVS | \
|
|
||||||
LOG_CLASS_ACTIVATION | LOG_CLASS_ALLOC | LOG_CLASS_LVMETAD | \
|
|
||||||
LOG_CLASS_METADATA | LOG_CLASS_CACHE | LOG_CLASS_LOCKING | \
|
|
||||||
LOG_CLASS_LVMPOLLD)
|
|
||||||
|
|
||||||
#define DEFAULT_SYSLOG 1
|
#define DEFAULT_SYSLOG 1
|
||||||
#define DEFAULT_VERBOSE 0
|
#define DEFAULT_VERBOSE 0
|
||||||
#define DEFAULT_SILENT 0
|
#define DEFAULT_SILENT 0
|
||||||
|
@ -681,7 +681,7 @@ static int _init_preferred_names(struct cmd_context *cmd)
|
|||||||
|
|
||||||
_cache.preferred_names_matcher = NULL;
|
_cache.preferred_names_matcher = NULL;
|
||||||
|
|
||||||
if (!(cn = find_config_tree_node(cmd, devices_preferred_names_CFG, NULL)) ||
|
if (!(cn = find_config_tree_array(cmd, devices_preferred_names_CFG, NULL)) ||
|
||||||
cn->v->type == DM_CFG_EMPTY_ARRAY) {
|
cn->v->type == DM_CFG_EMPTY_ARRAY) {
|
||||||
log_very_verbose("devices/preferred_names not found in config file: "
|
log_very_verbose("devices/preferred_names not found in config file: "
|
||||||
"using built-in preferences");
|
"using built-in preferences");
|
||||||
|
@ -2491,7 +2491,7 @@ struct format_type *create_text_format(struct cmd_context *cmd)
|
|||||||
goto bad;
|
goto bad;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((cn = find_config_tree_node(cmd, metadata_dirs_CFG, NULL))) {
|
if ((cn = find_config_tree_array(cmd, metadata_dirs_CFG, NULL))) {
|
||||||
for (cv = cn->v; cv; cv = cv->next) {
|
for (cv = cn->v; cv; cv = cv->next) {
|
||||||
if (cv->type != DM_CFG_STRING) {
|
if (cv->type != DM_CFG_STRING) {
|
||||||
log_error("Invalid string in config file: "
|
log_error("Invalid string in config file: "
|
||||||
|
@ -3255,7 +3255,7 @@ static struct alloc_handle *_alloc_init(struct cmd_context *cmd,
|
|||||||
|
|
||||||
ah->parallel_areas = parallel_areas;
|
ah->parallel_areas = parallel_areas;
|
||||||
|
|
||||||
if ((ah->cling_tag_list_cn = find_config_tree_node(cmd, allocation_cling_tag_list_CFG, NULL)))
|
if ((ah->cling_tag_list_cn = find_config_tree_array(cmd, allocation_cling_tag_list_CFG, NULL)))
|
||||||
(void) _validate_tag_list(ah->cling_tag_list_cn);
|
(void) _validate_tag_list(ah->cling_tag_list_cn);
|
||||||
|
|
||||||
ah->maximise_cling = find_config_tree_bool(cmd, allocation_maximise_cling_CFG, NULL);
|
ah->maximise_cling = find_config_tree_bool(cmd, allocation_maximise_cling_CFG, NULL);
|
||||||
|
@ -4602,7 +4602,7 @@ static int _allow_system_id(struct cmd_context *cmd, const char *system_id)
|
|||||||
const struct dm_config_value *cv;
|
const struct dm_config_value *cv;
|
||||||
const char *str;
|
const char *str;
|
||||||
|
|
||||||
if (!(cn = find_config_tree_node(cmd, local_extra_system_ids_CFG, NULL)))
|
if (!(cn = find_config_tree_array(cmd, local_extra_system_ids_CFG, NULL)))
|
||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
for (cv = cn->v; cv; cv = cv->next) {
|
for (cv = cn->v; cv; cv = cv->next) {
|
||||||
|
@ -33,7 +33,7 @@ static int _obtain_device_list_from_udev = DEFAULT_OBTAIN_DEVICE_LIST_FROM_UDEV;
|
|||||||
static unsigned _external_device_info_source = DEV_EXT_NONE;
|
static unsigned _external_device_info_source = DEV_EXT_NONE;
|
||||||
static int _trust_cache = 0; /* Don't scan when incomplete VGs encountered */
|
static int _trust_cache = 0; /* Don't scan when incomplete VGs encountered */
|
||||||
static int _debug_level = 0;
|
static int _debug_level = 0;
|
||||||
static int _debug_classes_logged = DEFAULT_LOGGED_DEBUG_CLASSES;
|
static int _debug_classes_logged = 0;
|
||||||
static int _log_cmd_name = 0;
|
static int _log_cmd_name = 0;
|
||||||
static int _ignorelockingfailure = 0;
|
static int _ignorelockingfailure = 0;
|
||||||
static int _security_level = SECURITY_LEVEL;
|
static int _security_level = SECURITY_LEVEL;
|
||||||
|
@ -687,7 +687,7 @@ static int _thin_target_present(struct cmd_context *cmd,
|
|||||||
if (attributes) {
|
if (attributes) {
|
||||||
if (!_feature_mask) {
|
if (!_feature_mask) {
|
||||||
/* Support runtime lvm.conf changes, N.B. avoid 32 feature */
|
/* Support runtime lvm.conf changes, N.B. avoid 32 feature */
|
||||||
if ((cn = find_config_tree_node(cmd, global_thin_disabled_features_CFG, NULL))) {
|
if ((cn = find_config_tree_array(cmd, global_thin_disabled_features_CFG, NULL))) {
|
||||||
for (cv = cn->v; cv; cv = cv->next) {
|
for (cv = cn->v; cv; cv = cv->next) {
|
||||||
if (cv->type != DM_CFG_STRING) {
|
if (cv->type != DM_CFG_STRING) {
|
||||||
log_error("Ignoring invalid string in config file %s.",
|
log_error("Ignoring invalid string in config file %s.",
|
||||||
|
@ -2299,7 +2299,7 @@ static int _lvconvert_pool_repair(struct cmd_context *cmd,
|
|||||||
int ret = 0, status;
|
int ret = 0, status;
|
||||||
int args = 0;
|
int args = 0;
|
||||||
const char *argv[19]; /* Max supported 10 args */
|
const char *argv[19]; /* Max supported 10 args */
|
||||||
char *split, *dm_name, *trans_id_str;
|
char *dm_name, *trans_id_str;
|
||||||
char meta_path[PATH_MAX];
|
char meta_path[PATH_MAX];
|
||||||
char pms_path[PATH_MAX];
|
char pms_path[PATH_MAX];
|
||||||
uint64_t trans_id;
|
uint64_t trans_id;
|
||||||
@ -2339,22 +2339,16 @@ static int _lvconvert_pool_repair(struct cmd_context *cmd,
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ((cn = find_config_tree_node(cmd, global_thin_repair_options_CFG, NULL))) {
|
if (!(cn = find_config_tree_array(cmd, global_thin_repair_options_CFG, NULL)))
|
||||||
for (cv = cn->v; cv && args < 16; cv = cv->next) {
|
return_0;
|
||||||
if (cv->type != DM_CFG_STRING) {
|
|
||||||
log_error("Invalid string in config file: "
|
for (cv = cn->v; cv && args < 16; cv = cv->next) {
|
||||||
"global/thin_repair_options");
|
if (cv->type != DM_CFG_STRING) {
|
||||||
return 0;
|
log_error("Invalid string in config file: "
|
||||||
}
|
"global/thin_repair_options");
|
||||||
argv[++args] = cv->v.str;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
/* Use default options (no support for options with spaces) */
|
|
||||||
if (!(split = dm_pool_strdup(cmd->mem, DEFAULT_THIN_REPAIR_OPTIONS))) {
|
|
||||||
log_error("Failed to duplicate thin repair string.");
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
args = dm_split_words(split, 16, 0, (char**) argv + 1);
|
argv[++args] = cv->v.str;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (args == 10) {
|
if (args == 10) {
|
||||||
|
@ -818,7 +818,7 @@ static int _passes_lock_start_filter(struct cmd_context *cmd,
|
|||||||
|
|
||||||
/* undefined list means no restrictions, all vg names pass */
|
/* undefined list means no restrictions, all vg names pass */
|
||||||
|
|
||||||
cn = find_config_tree_node(cmd, cfg_id, NULL);
|
cn = find_config_tree_array(cmd, cfg_id, NULL);
|
||||||
if (!cn)
|
if (!cn)
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user