1
0
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:
Peter Rajnoha 2015-07-08 11:22:24 +02:00
parent 67a61cce1b
commit 3b6840e099
14 changed files with 44 additions and 71 deletions

View File

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

View File

@ -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.");

View File

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

View File

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

View File

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

View File

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

View File

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

View File

@ -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: "

View 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);

View File

@ -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) {

View File

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

View File

@ -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.",

View File

@ -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) {

View File

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