1
0
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:
David Teigland 2018-12-04 12:44:43 -06:00
parent c1b2de936c
commit 89c11a2b49
2 changed files with 16 additions and 39 deletions

View File

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

View File

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