diff options
author | David Teigland <teigland@redhat.com> | 2021-10-29 14:49:36 -0500 |
---|---|---|
committer | David Teigland <teigland@redhat.com> | 2021-12-20 14:22:17 -0600 |
commit | f732f3d53faee3732d0f4a666c378709e6c2f5e9 (patch) | |
tree | 8a33edfe7e8b3afc9527e21b29289fdebde043ed | |
parent | f73be4480a5dd104a77e3ef84d7dcc80b834e593 (diff) | |
download | lvm2-f732f3d53faee3732d0f4a666c378709e6c2f5e9.tar.gz |
lvmdevices: increase open file limit
-rw-r--r-- | lib/label/label.c | 4 | ||||
-rw-r--r-- | lib/label/label.h | 2 | ||||
-rw-r--r-- | tools/lvmdevices.c | 3 |
3 files changed, 7 insertions, 2 deletions
diff --git a/lib/label/label.c b/lib/label/label.c index 479a5037a..9fac3e464 100644 --- a/lib/label/label.c +++ b/lib/label/label.c @@ -891,7 +891,7 @@ static int _setup_bcache(void) #define BASE_FD_COUNT 32 /* Number of open files we want apart from devs */ -static void _prepare_open_file_limit(struct cmd_context *cmd, unsigned int num_devs) +void prepare_open_file_limit(struct cmd_context *cmd, unsigned int num_devs) { #ifdef HAVE_PRLIMIT struct rlimit old = { 0 }, new; @@ -1165,7 +1165,7 @@ int label_scan(struct cmd_context *cmd) * which we want to keep open) is higher than the current * soft limit. */ - _prepare_open_file_limit(cmd, dm_list_size(&scan_devs)); + prepare_open_file_limit(cmd, dm_list_size(&scan_devs)); /* * Do the main scan. diff --git a/lib/label/label.h b/lib/label/label.h index 8b510eb79..34563efd0 100644 --- a/lib/label/label.h +++ b/lib/label/label.h @@ -134,4 +134,6 @@ void dev_invalidate(struct device *dev); void dev_set_last_byte(struct device *dev, uint64_t offset); void dev_unset_last_byte(struct device *dev); +void prepare_open_file_limit(struct cmd_context *cmd, unsigned int num_devs); + #endif diff --git a/tools/lvmdevices.c b/tools/lvmdevices.c index 8d9634848..3f104f7de 100644 --- a/tools/lvmdevices.c +++ b/tools/lvmdevices.c @@ -176,6 +176,9 @@ int lvmdevices(struct cmd_context *cmd, int argc, char **argv) log_error("Failed to read the devices file."); return ECMD_FAILED; } + + prepare_open_file_limit(cmd, dm_list_size(&cmd->use_devices)); + dev_cache_scan(cmd); device_ids_match(cmd); |