mirror of
git://sourceware.org/git/lvm2.git
synced 2025-01-21 22:04:19 +03:00
filters: better message for excluding LV
Make the generic "device is not usable" message from filter-usable more specific in case the device is not usable because it's an LV. (i.e. when scan_lvs=0)
This commit is contained in:
parent
d0b0c20077
commit
e9d10f3711
@ -392,7 +392,7 @@ int add_areas_line(struct dev_manager *dm, struct lv_segment *seg,
|
|||||||
{
|
{
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
int device_is_usable(struct device *dev, struct dev_usable_check_params check)
|
int device_is_usable(struct device *dev, struct dev_usable_check_params check, int *is_lv)
|
||||||
{
|
{
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -253,7 +253,7 @@ struct dev_usable_check_params {
|
|||||||
* Returns 1 if mapped device is not suspended, blocked or
|
* Returns 1 if mapped device is not suspended, blocked or
|
||||||
* is using a reserved name.
|
* is using a reserved name.
|
||||||
*/
|
*/
|
||||||
int device_is_usable(struct device *dev, struct dev_usable_check_params check);
|
int device_is_usable(struct device *dev, struct dev_usable_check_params check, int *is_lv);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Declaration moved here from fs.h to keep header fs.h hidden
|
* Declaration moved here from fs.h to keep header fs.h hidden
|
||||||
|
@ -405,7 +405,7 @@ static int _ignore_blocked_mirror_devices(struct device *dev,
|
|||||||
.check_blocked = 1,
|
.check_blocked = 1,
|
||||||
.check_suspended = ignore_suspended_devices(),
|
.check_suspended = ignore_suspended_devices(),
|
||||||
.check_error_target = 1,
|
.check_error_target = 1,
|
||||||
.check_reserved = 0 }))
|
.check_reserved = 0 }, NULL))
|
||||||
goto out; /* safe to use */
|
goto out; /* safe to use */
|
||||||
stack;
|
stack;
|
||||||
}
|
}
|
||||||
@ -620,7 +620,7 @@ static int _ignore_frozen_raid(struct device *dev, const char *params)
|
|||||||
*
|
*
|
||||||
* Returns: 1 if usable, 0 otherwise
|
* Returns: 1 if usable, 0 otherwise
|
||||||
*/
|
*/
|
||||||
int device_is_usable(struct device *dev, struct dev_usable_check_params check)
|
int device_is_usable(struct device *dev, struct dev_usable_check_params check, int *is_lv)
|
||||||
{
|
{
|
||||||
struct dm_task *dmt;
|
struct dm_task *dmt;
|
||||||
struct dm_info info;
|
struct dm_info info;
|
||||||
@ -675,6 +675,8 @@ int device_is_usable(struct device *dev, struct dev_usable_check_params check)
|
|||||||
|
|
||||||
if (check.check_lv && uuid && !strncmp(uuid, "LVM-", 4)) {
|
if (check.check_lv && uuid && !strncmp(uuid, "LVM-", 4)) {
|
||||||
/* Skip LVs */
|
/* Skip LVs */
|
||||||
|
if (is_lv)
|
||||||
|
*is_lv = 1;
|
||||||
goto out;
|
goto out;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
2
lib/cache/lvmcache.c
vendored
2
lib/cache/lvmcache.c
vendored
@ -2909,6 +2909,8 @@ const char *dev_filtered_reason(struct device *dev)
|
|||||||
return "device is not in devices file";
|
return "device is not in devices file";
|
||||||
if (dev->filtered_flags & DEV_FILTERED_DEVICES_LIST)
|
if (dev->filtered_flags & DEV_FILTERED_DEVICES_LIST)
|
||||||
return "device is not in devices list";
|
return "device is not in devices list";
|
||||||
|
if (dev->filtered_flags & DEV_FILTERED_IS_LV)
|
||||||
|
return "device is an LV";
|
||||||
|
|
||||||
/* flag has not been added here */
|
/* flag has not been added here */
|
||||||
if (dev->filtered_flags)
|
if (dev->filtered_flags)
|
||||||
|
@ -111,6 +111,7 @@ static int _passes_usable_filter(struct cmd_context *cmd, struct dev_filter *f,
|
|||||||
filter_mode_t mode = data->mode;
|
filter_mode_t mode = data->mode;
|
||||||
int skip_lvs = data->skip_lvs;
|
int skip_lvs = data->skip_lvs;
|
||||||
struct dev_usable_check_params ucp = {0};
|
struct dev_usable_check_params ucp = {0};
|
||||||
|
int is_lv = 0;
|
||||||
int r = 1;
|
int r = 1;
|
||||||
|
|
||||||
dev->filtered_flags &= ~DEV_FILTERED_MINSIZE;
|
dev->filtered_flags &= ~DEV_FILTERED_MINSIZE;
|
||||||
@ -145,8 +146,11 @@ static int _passes_usable_filter(struct cmd_context *cmd, struct dev_filter *f,
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!(r = device_is_usable(dev, ucp))) {
|
if (!(r = device_is_usable(dev, ucp, &is_lv))) {
|
||||||
dev->filtered_flags |= DEV_FILTERED_UNUSABLE;
|
if (is_lv)
|
||||||
|
dev->filtered_flags |= DEV_FILTERED_IS_LV;
|
||||||
|
else
|
||||||
|
dev->filtered_flags |= DEV_FILTERED_UNUSABLE;
|
||||||
log_debug_devs("%s: Skipping unusable device.", dev_name(dev));
|
log_debug_devs("%s: Skipping unusable device.", dev_name(dev));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -66,5 +66,6 @@ struct dev_filter *usable_filter_create(struct cmd_context *cmd, struct dev_type
|
|||||||
#define DEV_FILTERED_UNUSABLE 0x00000400
|
#define DEV_FILTERED_UNUSABLE 0x00000400
|
||||||
#define DEV_FILTERED_DEVICES_FILE 0x00000800
|
#define DEV_FILTERED_DEVICES_FILE 0x00000800
|
||||||
#define DEV_FILTERED_DEVICES_LIST 0x00001000
|
#define DEV_FILTERED_DEVICES_LIST 0x00001000
|
||||||
|
#define DEV_FILTERED_IS_LV 0x00002000
|
||||||
|
|
||||||
#endif /* _LVM_FILTER_H */
|
#endif /* _LVM_FILTER_H */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user