mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-02 01:18:26 +03:00
toolcontext: add switches to create_toolcontext for connections and filters init
Make it possible to decide whether we want to initialize connections and filters together with toolcontext creation. Add "filters" and "connections" fields to struct cmd_context_initialized_parts and set these in cmd_context.initialized instance accordingly. (For now, all create_toolcontext calls do initialize connections and filters, we'll change that in subsequent patch appropriately.)
This commit is contained in:
parent
3e343ba5ef
commit
f6473baffc
@ -899,7 +899,7 @@ int init_clvm(struct dm_hash_table *excl_uuid)
|
|||||||
if (!get_initial_state(excl_uuid))
|
if (!get_initial_state(excl_uuid))
|
||||||
log_error("Cannot load initial lock states.");
|
log_error("Cannot load initial lock states.");
|
||||||
|
|
||||||
if (!(cmd = create_toolcontext(1, NULL, 0, 1))) {
|
if (!(cmd = create_toolcontext(1, NULL, 0, 1, 1, 1))) {
|
||||||
log_error("Failed to allocate command context");
|
log_error("Failed to allocate command context");
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -124,7 +124,7 @@ int main(int argc, char **argv) {
|
|||||||
|
|
||||||
if (argc > 1) {
|
if (argc > 1) {
|
||||||
int i;
|
int i;
|
||||||
struct cmd_context *cmd = create_toolcontext(0, NULL, 0, 0);
|
struct cmd_context *cmd = create_toolcontext(0, NULL, 0, 0, 1, 1);
|
||||||
for (i = 1; i < argc; ++i) {
|
for (i = 1; i < argc; ++i) {
|
||||||
const char *uuid = NULL;
|
const char *uuid = NULL;
|
||||||
scan(h, argv[i]);
|
scan(h, argv[i]);
|
||||||
|
@ -55,7 +55,6 @@
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
static const size_t linebuffer_size = 4096;
|
static const size_t linebuffer_size = 4096;
|
||||||
static int _init_connections(struct cmd_context *cmd);
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Copy the input string, removing invalid characters.
|
* Copy the input string, removing invalid characters.
|
||||||
@ -675,9 +674,6 @@ static int _process_config(struct cmd_context *cmd)
|
|||||||
init_detect_internal_vg_cache_corruption
|
init_detect_internal_vg_cache_corruption
|
||||||
(find_config_tree_bool(cmd, global_detect_internal_vg_cache_corruption_CFG, NULL));
|
(find_config_tree_bool(cmd, global_detect_internal_vg_cache_corruption_CFG, NULL));
|
||||||
|
|
||||||
if (!_init_connections(cmd))
|
|
||||||
return_0;
|
|
||||||
|
|
||||||
if (!_init_system_id(cmd))
|
if (!_init_system_id(cmd))
|
||||||
return_0;
|
return_0;
|
||||||
|
|
||||||
@ -1165,7 +1161,7 @@ bad:
|
|||||||
* md component filter -> fw raid filter
|
* md component filter -> fw raid filter
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
static int _init_filters(struct cmd_context *cmd, unsigned load_persistent_cache)
|
int init_filters(struct cmd_context *cmd, unsigned load_persistent_cache)
|
||||||
{
|
{
|
||||||
const char *dev_cache;
|
const char *dev_cache;
|
||||||
struct dev_filter *filter = NULL, *filter_components[2] = {0};
|
struct dev_filter *filter = NULL, *filter_components[2] = {0};
|
||||||
@ -1173,6 +1169,11 @@ static int _init_filters(struct cmd_context *cmd, unsigned load_persistent_cache
|
|||||||
const struct dm_config_node *cn;
|
const struct dm_config_node *cn;
|
||||||
struct timespec ts, cts;
|
struct timespec ts, cts;
|
||||||
|
|
||||||
|
if (!cmd->initialized.connections) {
|
||||||
|
log_error(INTERNAL_ERROR "connections must be initialized before filters");
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
cmd->dump_filter = 0;
|
cmd->dump_filter = 0;
|
||||||
|
|
||||||
cmd->lvmetad_filter = _init_lvmetad_filter_chain(cmd);
|
cmd->lvmetad_filter = _init_lvmetad_filter_chain(cmd);
|
||||||
@ -1253,6 +1254,7 @@ static int _init_filters(struct cmd_context *cmd, unsigned load_persistent_cache
|
|||||||
dev_cache);
|
dev_cache);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
cmd->initialized.filters = 1;
|
||||||
return 1;
|
return 1;
|
||||||
bad:
|
bad:
|
||||||
if (!filter) {
|
if (!filter) {
|
||||||
@ -1276,6 +1278,7 @@ bad:
|
|||||||
if (cmd->lvmetad_filter)
|
if (cmd->lvmetad_filter)
|
||||||
cmd->lvmetad_filter->destroy(cmd->lvmetad_filter);
|
cmd->lvmetad_filter->destroy(cmd->lvmetad_filter);
|
||||||
|
|
||||||
|
cmd->initialized.filters = 0;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1696,26 +1699,33 @@ static int _init_lvmpolld(struct cmd_context *cmd)
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
static int _init_connections(struct cmd_context *cmd)
|
int init_connections(struct cmd_context *cmd)
|
||||||
{
|
{
|
||||||
|
|
||||||
if (!_init_lvmetad(cmd)) {
|
if (!_init_lvmetad(cmd)) {
|
||||||
log_error("Failed to initialize lvmetad connection.");
|
log_error("Failed to initialize lvmetad connection.");
|
||||||
return 0;
|
goto bad;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!_init_lvmpolld(cmd)) {
|
if (!_init_lvmpolld(cmd)) {
|
||||||
log_error("Failed to initialize lvmpolld connection.");
|
log_error("Failed to initialize lvmpolld connection.");
|
||||||
return 0;
|
goto bad;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
cmd->initialized.connections = 1;
|
||||||
return 1;
|
return 1;
|
||||||
|
bad:
|
||||||
|
cmd->initialized.connections = 0;
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Entry point */
|
/* Entry point */
|
||||||
struct cmd_context *create_toolcontext(unsigned is_long_lived,
|
struct cmd_context *create_toolcontext(unsigned is_long_lived,
|
||||||
const char *system_dir,
|
const char *system_dir,
|
||||||
unsigned set_buffering,
|
unsigned set_buffering,
|
||||||
unsigned threaded)
|
unsigned threaded,
|
||||||
|
unsigned set_connections,
|
||||||
|
unsigned set_filters)
|
||||||
{
|
{
|
||||||
struct cmd_context *cmd;
|
struct cmd_context *cmd;
|
||||||
FILE *new_stream;
|
FILE *new_stream;
|
||||||
@ -1859,9 +1869,6 @@ struct cmd_context *create_toolcontext(unsigned is_long_lived,
|
|||||||
if (!_init_dev_cache(cmd))
|
if (!_init_dev_cache(cmd))
|
||||||
goto_out;
|
goto_out;
|
||||||
|
|
||||||
if (!_init_filters(cmd, 1))
|
|
||||||
goto_out;
|
|
||||||
|
|
||||||
memlock_init(cmd);
|
memlock_init(cmd);
|
||||||
|
|
||||||
if (!_init_formats(cmd))
|
if (!_init_formats(cmd))
|
||||||
@ -1880,6 +1887,12 @@ struct cmd_context *create_toolcontext(unsigned is_long_lived,
|
|||||||
|
|
||||||
_init_globals(cmd);
|
_init_globals(cmd);
|
||||||
|
|
||||||
|
if (set_connections && !init_connections(cmd))
|
||||||
|
return_0;
|
||||||
|
|
||||||
|
if (set_filters && !init_filters(cmd, 1))
|
||||||
|
goto_out;
|
||||||
|
|
||||||
cmd->default_settings.cache_vgmetadata = 1;
|
cmd->default_settings.cache_vgmetadata = 1;
|
||||||
cmd->current_settings = cmd->default_settings;
|
cmd->current_settings = cmd->default_settings;
|
||||||
|
|
||||||
@ -1957,14 +1970,19 @@ static void _destroy_filters(struct cmd_context *cmd)
|
|||||||
cmd->full_filter->destroy(cmd->full_filter);
|
cmd->full_filter->destroy(cmd->full_filter);
|
||||||
cmd->lvmetad_filter = cmd->filter = cmd->full_filter = NULL;
|
cmd->lvmetad_filter = cmd->filter = cmd->full_filter = NULL;
|
||||||
}
|
}
|
||||||
|
cmd->initialized.filters = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int refresh_filters(struct cmd_context *cmd)
|
int refresh_filters(struct cmd_context *cmd)
|
||||||
{
|
{
|
||||||
int r, saved_ignore_suspended_devices = ignore_suspended_devices();
|
int r, saved_ignore_suspended_devices = ignore_suspended_devices();
|
||||||
|
|
||||||
|
if (!cmd->initialized.filters)
|
||||||
|
/* if filters not initialized, there's nothing to refresh */
|
||||||
|
return 1;
|
||||||
|
|
||||||
_destroy_filters(cmd);
|
_destroy_filters(cmd);
|
||||||
if (!(r = _init_filters(cmd, 0)))
|
if (!(r = init_filters(cmd, 0)))
|
||||||
stack;
|
stack;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -2074,9 +2092,6 @@ int refresh_toolcontext(struct cmd_context *cmd)
|
|||||||
if (!_init_dev_cache(cmd))
|
if (!_init_dev_cache(cmd))
|
||||||
return_0;
|
return_0;
|
||||||
|
|
||||||
if (!_init_filters(cmd, 0))
|
|
||||||
return_0;
|
|
||||||
|
|
||||||
if (!_init_formats(cmd))
|
if (!_init_formats(cmd))
|
||||||
return_0;
|
return_0;
|
||||||
|
|
||||||
@ -2091,6 +2106,12 @@ int refresh_toolcontext(struct cmd_context *cmd)
|
|||||||
|
|
||||||
cmd->initialized.config = 1;
|
cmd->initialized.config = 1;
|
||||||
|
|
||||||
|
if (cmd->initialized.connections && !init_connections(cmd))
|
||||||
|
return_0;
|
||||||
|
|
||||||
|
if (cmd->initialized.filters && !init_filters(cmd, 0))
|
||||||
|
return_0;
|
||||||
|
|
||||||
reset_lvm_errno(1);
|
reset_lvm_errno(1);
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
@ -2159,6 +2180,7 @@ void destroy_toolcontext(struct cmd_context *cmd)
|
|||||||
lvmetad_release_token();
|
lvmetad_release_token();
|
||||||
lvmetad_disconnect();
|
lvmetad_disconnect();
|
||||||
lvmpolld_disconnect();
|
lvmpolld_disconnect();
|
||||||
|
cmd->initialized.connections = 0;
|
||||||
|
|
||||||
release_log_memory();
|
release_log_memory();
|
||||||
activation_exit();
|
activation_exit();
|
||||||
|
@ -62,6 +62,8 @@ struct config_tree_list {
|
|||||||
|
|
||||||
struct cmd_context_initialized_parts {
|
struct cmd_context_initialized_parts {
|
||||||
unsigned config:1; /* used to reinitialize config if previous init was not successful */
|
unsigned config:1; /* used to reinitialize config if previous init was not successful */
|
||||||
|
unsigned filters:1;
|
||||||
|
unsigned connections:1;
|
||||||
};
|
};
|
||||||
|
|
||||||
/* FIXME Split into tool & library contexts */
|
/* FIXME Split into tool & library contexts */
|
||||||
@ -171,13 +173,17 @@ struct cmd_context {
|
|||||||
struct cmd_context *create_toolcontext(unsigned is_long_lived,
|
struct cmd_context *create_toolcontext(unsigned is_long_lived,
|
||||||
const char *system_dir,
|
const char *system_dir,
|
||||||
unsigned set_buffering,
|
unsigned set_buffering,
|
||||||
unsigned threaded);
|
unsigned threaded,
|
||||||
|
unsigned set_connections,
|
||||||
|
unsigned set_filters);
|
||||||
void destroy_toolcontext(struct cmd_context *cmd);
|
void destroy_toolcontext(struct cmd_context *cmd);
|
||||||
int refresh_toolcontext(struct cmd_context *cmd);
|
int refresh_toolcontext(struct cmd_context *cmd);
|
||||||
int refresh_filters(struct cmd_context *cmd);
|
int refresh_filters(struct cmd_context *cmd);
|
||||||
int process_profilable_config(struct cmd_context *cmd);
|
int process_profilable_config(struct cmd_context *cmd);
|
||||||
int config_files_changed(struct cmd_context *cmd);
|
int config_files_changed(struct cmd_context *cmd);
|
||||||
int init_lvmcache_orphans(struct cmd_context *cmd);
|
int init_lvmcache_orphans(struct cmd_context *cmd);
|
||||||
|
int init_filters(struct cmd_context *cmd, unsigned load_persistent_cache);
|
||||||
|
int init_connections(struct cmd_context *cmd);
|
||||||
|
|
||||||
struct format_type *get_format_by_name(struct cmd_context *cmd, const char *format);
|
struct format_type *get_format_by_name(struct cmd_context *cmd, const char *format);
|
||||||
|
|
||||||
|
@ -45,7 +45,7 @@ static lvm_t _lvm_init(const char *system_dir)
|
|||||||
/* create context */
|
/* create context */
|
||||||
/* FIXME: split create_toolcontext */
|
/* FIXME: split create_toolcontext */
|
||||||
/* FIXME: make all globals configurable */
|
/* FIXME: make all globals configurable */
|
||||||
cmd = create_toolcontext(0, system_dir, 0, 0);
|
cmd = create_toolcontext(0, system_dir, 0, 0, 1, 1);
|
||||||
if (!cmd)
|
if (!cmd)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
|
@ -31,7 +31,7 @@ int lvm2_main(int argc, char **argv);
|
|||||||
void *cmdlib_lvm2_init(unsigned static_compile);
|
void *cmdlib_lvm2_init(unsigned static_compile);
|
||||||
void lvm_fin(struct cmd_context *cmd);
|
void lvm_fin(struct cmd_context *cmd);
|
||||||
|
|
||||||
struct cmd_context *init_lvm(void);
|
struct cmd_context *init_lvm(unsigned set_connections, unsigned set_filters);
|
||||||
void lvm_register_commands(void);
|
void lvm_register_commands(void);
|
||||||
int lvm_split(char *str, int *argc, char **argv, int max);
|
int lvm_split(char *str, int *argc, char **argv, int max);
|
||||||
int lvm_run_command(struct cmd_context *cmd, int argc, char **argv);
|
int lvm_run_command(struct cmd_context *cmd, int argc, char **argv);
|
||||||
|
@ -33,7 +33,7 @@ void *cmdlib_lvm2_init(unsigned static_compile)
|
|||||||
lvm_register_commands();
|
lvm_register_commands();
|
||||||
|
|
||||||
init_is_static(static_compile);
|
init_is_static(static_compile);
|
||||||
if (!(cmd = init_lvm()))
|
if (!(cmd = init_lvm(1, 1)))
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
return (void *) cmd;
|
return (void *) cmd;
|
||||||
|
@ -1873,7 +1873,7 @@ static int _close_stray_fds(const char *command)
|
|||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
struct cmd_context *init_lvm(void)
|
struct cmd_context *init_lvm(unsigned set_connections, unsigned set_filters)
|
||||||
{
|
{
|
||||||
struct cmd_context *cmd;
|
struct cmd_context *cmd;
|
||||||
|
|
||||||
@ -1887,7 +1887,8 @@ struct cmd_context *init_lvm(void)
|
|||||||
*/
|
*/
|
||||||
dm_set_name_mangling_mode(DM_STRING_MANGLING_NONE);
|
dm_set_name_mangling_mode(DM_STRING_MANGLING_NONE);
|
||||||
|
|
||||||
if (!(cmd = create_toolcontext(0, NULL, 1, 0))) {
|
if (!(cmd = create_toolcontext(0, NULL, 1, 0,
|
||||||
|
set_connections, set_filters))) {
|
||||||
udev_fin_library_context();
|
udev_fin_library_context();
|
||||||
return_NULL;
|
return_NULL;
|
||||||
}
|
}
|
||||||
@ -2055,7 +2056,7 @@ int lvm2_main(int argc, char **argv)
|
|||||||
if (!alias && argc > 1 && !strcmp(argv[1], "version"))
|
if (!alias && argc > 1 && !strcmp(argv[1], "version"))
|
||||||
return lvm_return_code(version(NULL, argc, argv));
|
return lvm_return_code(version(NULL, argc, argv));
|
||||||
|
|
||||||
if (!(cmd = init_lvm()))
|
if (!(cmd = init_lvm(1, 1)))
|
||||||
return -1;
|
return -1;
|
||||||
|
|
||||||
cmd->argv = argv;
|
cmd->argv = argv;
|
||||||
|
Loading…
Reference in New Issue
Block a user