mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-03 05:18:29 +03:00
remove unused lvmetad filter
This commit is contained in:
parent
c1b2de936c
commit
89c11a2b49
@ -1034,7 +1034,7 @@ static int _init_dev_cache(struct cmd_context *cmd)
|
|||||||
|
|
||||||
#define MAX_FILTERS 10
|
#define MAX_FILTERS 10
|
||||||
|
|
||||||
static struct dev_filter *_init_lvmetad_filter_chain(struct cmd_context *cmd)
|
static struct dev_filter *_init_filter_chain(struct cmd_context *cmd)
|
||||||
{
|
{
|
||||||
int nr_filt = 0;
|
int nr_filt = 0;
|
||||||
const struct dm_config_node *cn;
|
const struct dm_config_node *cn;
|
||||||
@ -1143,27 +1143,9 @@ bad:
|
|||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* The way the filtering is initialized depends on whether lvmetad is uesd or not.
|
* cmd->filter ==
|
||||||
*
|
* persistent(cache) filter -> sysfs filter -> internal filter -> global regex filter ->
|
||||||
* If lvmetad is used, there are three filter chains:
|
* regex_filter -> type filter -> usable device filter ->
|
||||||
*
|
|
||||||
* - cmd->lvmetad_filter - the lvmetad filter chain used when scanning devs for lvmetad update:
|
|
||||||
* sysfs filter -> internal filter -> global regex filter -> type filter ->
|
|
||||||
* usable device filter(FILTER_MODE_PRE_LVMETAD) ->
|
|
||||||
* mpath component filter -> partitioned filter ->
|
|
||||||
* md component filter -> fw raid filter
|
|
||||||
*
|
|
||||||
* - cmd->filter - the filter chain used for lvmetad responses:
|
|
||||||
* persistent filter -> regex_filter -> usable device filter(FILTER_MODE_POST_LVMETAD)
|
|
||||||
*
|
|
||||||
* - cmd->full_filter - the filter chain used for all the remaining situations:
|
|
||||||
* cmd->lvmetad_filter -> cmd->filter
|
|
||||||
*
|
|
||||||
* If lvmetad is not used, there's just one filter chain:
|
|
||||||
*
|
|
||||||
* - cmd->filter == cmd->full_filter:
|
|
||||||
* persistent filter -> sysfs filter -> internal filter -> global regex filter ->
|
|
||||||
* regex_filter -> type filter -> usable device filter(FILTER_MODE_NO_LVMETAD) ->
|
|
||||||
* mpath component filter -> partitioned filter -> md component filter -> fw raid filter
|
* mpath component filter -> partitioned filter -> md component filter -> fw raid filter
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
@ -1176,24 +1158,24 @@ int init_filters(struct cmd_context *cmd, unsigned load_persistent_cache)
|
|||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
cmd->lvmetad_filter = _init_lvmetad_filter_chain(cmd);
|
filter = _init_filter_chain(cmd);
|
||||||
if (!cmd->lvmetad_filter)
|
if (!filter)
|
||||||
goto_bad;
|
goto_bad;
|
||||||
|
|
||||||
init_ignore_suspended_devices(find_config_tree_bool(cmd, devices_ignore_suspended_devices_CFG, NULL));
|
init_ignore_suspended_devices(find_config_tree_bool(cmd, devices_ignore_suspended_devices_CFG, NULL));
|
||||||
init_ignore_lvm_mirrors(find_config_tree_bool(cmd, devices_ignore_lvm_mirrors_CFG, NULL));
|
init_ignore_lvm_mirrors(find_config_tree_bool(cmd, devices_ignore_lvm_mirrors_CFG, NULL));
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* If lvmetad is used, there's a separation between pre-lvmetad filter chain
|
* persisent filter is a cache of the previous result real filter result.
|
||||||
* ("cmd->lvmetad_filter") applied only if scanning for lvmetad update and
|
* If a dev is found in persistent filter, the pass/fail result saved by
|
||||||
* post-lvmetad filter chain ("filter") applied on each lvmetad response.
|
* the pfilter is used. If a dev does not existing in the persistent
|
||||||
* However, if lvmetad is not used, these two chains are not separated
|
* filter, the dev is passed on to the real filter, and when the result
|
||||||
* and we use exactly one filter chain during device scanning ("filter"
|
* of the real filter is saved in the persistent filter.
|
||||||
* that includes also "cmd->lvmetad_filter" chain).
|
*
|
||||||
|
* FIXME: we should apply the filter once at the start of the command,
|
||||||
|
* and not call the filters repeatedly. In that case we would not need
|
||||||
|
* the persistent/caching filter layer.
|
||||||
*/
|
*/
|
||||||
filter = cmd->lvmetad_filter;
|
|
||||||
cmd->lvmetad_filter = NULL;
|
|
||||||
|
|
||||||
if (!(pfilter = persistent_filter_create(cmd->dev_types, filter))) {
|
if (!(pfilter = persistent_filter_create(cmd->dev_types, filter))) {
|
||||||
log_verbose("Failed to create persistent device filter.");
|
log_verbose("Failed to create persistent device filter.");
|
||||||
goto bad;
|
goto bad;
|
||||||
@ -1223,10 +1205,6 @@ bad:
|
|||||||
filter->destroy(filter);
|
filter->destroy(filter);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* if lvmetad is used, the cmd->lvmetad_filter is separate */
|
|
||||||
if (cmd->lvmetad_filter)
|
|
||||||
cmd->lvmetad_filter->destroy(cmd->lvmetad_filter);
|
|
||||||
|
|
||||||
cmd->initialized.filters = 0;
|
cmd->initialized.filters = 0;
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -1858,7 +1836,7 @@ static void _destroy_filters(struct cmd_context *cmd)
|
|||||||
{
|
{
|
||||||
if (cmd->full_filter) {
|
if (cmd->full_filter) {
|
||||||
cmd->full_filter->destroy(cmd->full_filter);
|
cmd->full_filter->destroy(cmd->full_filter);
|
||||||
cmd->lvmetad_filter = cmd->filter = cmd->full_filter = NULL;
|
cmd->filter = cmd->full_filter = NULL;
|
||||||
}
|
}
|
||||||
cmd->initialized.filters = 0;
|
cmd->initialized.filters = 0;
|
||||||
}
|
}
|
||||||
|
@ -176,7 +176,6 @@ struct cmd_context {
|
|||||||
/*
|
/*
|
||||||
* Filtering.
|
* Filtering.
|
||||||
*/
|
*/
|
||||||
struct dev_filter *lvmetad_filter; /* pre-lvmetad filter chain */
|
|
||||||
struct dev_filter *filter; /* post-lvmetad filter chain */
|
struct dev_filter *filter; /* post-lvmetad filter chain */
|
||||||
struct dev_filter *full_filter; /* lvmetad_filter + filter */
|
struct dev_filter *full_filter; /* lvmetad_filter + filter */
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user