mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-03 05:18:29 +03:00
filters: swap device_is_usable test
Fix regression introduced with commit:
2fc126b00d
This commit has moved pv_min_size() test in front
of device_is_usable(). However pv_min_size needs to open device,
so it may have actually get blocked.
So restore the original order and first validate
dm device to be usable for open.
It's worth to note that such check is not 'race-free',
but it usually eliminates 99.99% of problems ;).
This commit is contained in:
parent
a3c7e326c3
commit
81a9da8f61
@ -1,5 +1,7 @@
|
|||||||
Version 2.02.130 -
|
Version 2.02.130 -
|
||||||
===================================
|
===================================
|
||||||
|
Check if dm device is usable before checking its size (2.02.116).
|
||||||
|
Extend parsing of cache_check version in configure.
|
||||||
Make lvpoll error messages visible in lvmpolld's stderr and in syslog.
|
Make lvpoll error messages visible in lvmpolld's stderr and in syslog.
|
||||||
Add 'make install_full_man' to install all man pages regardless of config.
|
Add 'make install_full_man' to install all man pages regardless of config.
|
||||||
|
|
||||||
|
@ -112,25 +112,10 @@ static int _passes_usable_filter(struct dev_filter *f, struct device *dev)
|
|||||||
{
|
{
|
||||||
filter_mode_t mode = *((filter_mode_t *) f->private);
|
filter_mode_t mode = *((filter_mode_t *) f->private);
|
||||||
struct dev_usable_check_params ucp = {0};
|
struct dev_usable_check_params ucp = {0};
|
||||||
int r;
|
int r = 1;
|
||||||
|
|
||||||
/* check if the device is not too small to hold a PV */
|
|
||||||
switch (mode) {
|
|
||||||
case FILTER_MODE_NO_LVMETAD:
|
|
||||||
/* fall through */
|
|
||||||
case FILTER_MODE_PRE_LVMETAD:
|
|
||||||
if (!_check_pv_min_size(dev))
|
|
||||||
return 0;
|
|
||||||
break;
|
|
||||||
case FILTER_MODE_POST_LVMETAD:
|
|
||||||
/* nothing to do here */
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* further checks are done on dm devices only */
|
/* further checks are done on dm devices only */
|
||||||
if (!dm_is_dm_major(MAJOR(dev->dev)))
|
if (dm_is_dm_major(MAJOR(dev->dev))) {
|
||||||
return 1;
|
|
||||||
|
|
||||||
switch (mode) {
|
switch (mode) {
|
||||||
case FILTER_MODE_NO_LVMETAD:
|
case FILTER_MODE_NO_LVMETAD:
|
||||||
ucp.check_empty = 1;
|
ucp.check_empty = 1;
|
||||||
@ -163,7 +148,22 @@ static int _passes_usable_filter(struct dev_filter *f, struct device *dev)
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (!(r = device_is_usable(dev, ucp)))
|
if (!(r = device_is_usable(dev, ucp)))
|
||||||
log_debug_devs("%s: Skipping unusable device", dev_name(dev));
|
log_debug_devs("%s: Skipping unusable device.", dev_name(dev));
|
||||||
|
}
|
||||||
|
|
||||||
|
if (r) {
|
||||||
|
/* check if the device is not too small to hold a PV */
|
||||||
|
switch (mode) {
|
||||||
|
case FILTER_MODE_NO_LVMETAD:
|
||||||
|
/* fall through */
|
||||||
|
case FILTER_MODE_PRE_LVMETAD:
|
||||||
|
r = _check_pv_min_size(dev);
|
||||||
|
break;
|
||||||
|
case FILTER_MODE_POST_LVMETAD:
|
||||||
|
/* nothing to do here */
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return r;
|
return r;
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user