]> sourceware.org Git - lvm2.git/commitdiff
dev-cache: move global variables into cmd struct 1359579497
authorDavid Teigland <teigland@redhat.com>
Tue, 2 Jul 2024 21:43:34 +0000 (16:43 -0500)
committerDavid Teigland <teigland@redhat.com>
Wed, 3 Jul 2024 16:52:32 +0000 (11:52 -0500)
The cmd struct is now required in many more functions, and
it's added as a function arg for most direct dev-cache function
calls.  The cmd struct is added to struct device (dev->cmd) so
that it can be accessed in many other cases where dev-cache
functions are being called from places where getting the cmd
struct is too difficult.

22 files changed:
lib/activate/dev_manager.c
lib/cache/lvmcache.c
lib/cache/lvmcache.h
lib/commands/toolcontext.c
lib/commands/toolcontext.h
lib/device/dev-cache.c
lib/device/dev-cache.h
lib/device/dev-mpath.c
lib/device/device.h
lib/device/device_id.c
lib/filters/filter-mpath.c
lib/filters/filter-regex.c
lib/label/hints.c
lib/label/label.c
lib/locking/locking.c
lib/metadata/metadata.c
tools/lvmdevices.c
tools/lvmdiskscan.c
tools/pvck.c
tools/pvscan.c
tools/toollib.c
tools/vgimportclone.c

index c2d857231f90eda00bdf36d4ab532861b2340702..26233f70e69ccf9bd95863efcc3c9cfe733660c5 100644 (file)
@@ -771,7 +771,7 @@ int dm_device_is_usable(struct cmd_context *cmd, struct device *dev, struct dev_
        int only_error_or_zero_target = 1;
        int r = 0;
 
-       if (dm_devs_cache_use() &&
+       if (dm_devs_cache_use(cmd) &&
            /* With cache we can avoid status calls for unusable UUIDs */
            (dm_dev = dm_devs_cache_get_by_devno(cmd, dev->dev)) &&
            !_is_usable_uuid(dev, dm_dev->name, dm_dev->uuid, check.check_reserved, check.check_lv, is_lv))
@@ -902,7 +902,7 @@ int devno_dm_uuid(struct cmd_context *cmd, int major, int minor,
        const char *uuid;
        int r = 0;
 
-       if (dm_devs_cache_use()) {
+       if (dm_devs_cache_use(cmd)) {
                if ((dm_dev = dm_devs_cache_get_by_devno(cmd, MKDEV(major, minor)))) {
                        dm_strncpy(uuid_buf, dm_dev->uuid, uuid_buf_size);
                        return 1;
@@ -1090,7 +1090,7 @@ int dev_manager_info(struct cmd_context *cmd,
 
        dm_strncpy(old_style_dlid, dlid, sizeof(old_style_dlid));
 
-       if (dm_devs_cache_use() &&
+       if (dm_devs_cache_use(cmd) &&
            !dm_devs_cache_get_by_uuid(cmd, dlid) &&
            !dm_devs_cache_get_by_uuid(cmd, old_style_dlid)) {
                log_debug("Cached as inactive %s.", name);
@@ -2464,7 +2464,7 @@ static int _add_dev_to_dtree(struct dev_manager *dm, struct dm_tree *dtree,
        if (!(dlid = build_dm_uuid(dm->track_pending_delete ? dm->cmd->pending_delete_mem : dm->mem, lv, layer)))
                return_0;
 
-       if (dm_devs_cache_use()) {
+       if (dm_devs_cache_use(dm->cmd)) {
                if (!(dm_dev = dm_devs_cache_get_by_uuid(dm->cmd, dlid))) {
                        log_debug("Cached as not present %s.", name);
                        return 1;
@@ -2619,7 +2619,7 @@ static int _pool_callback(struct dm_tree_node *node,
                }
        }
 
-       dm_devs_cache_destroy();
+       dm_devs_cache_destroy(cmd);
 
        log_debug("Running check command on %s", mpath);
 
@@ -4003,7 +4003,7 @@ static int _tree_action(struct dev_manager *dm, const struct logical_volume *lv,
 
        /* Drop any cache before DM table manipulation within locked section
         * TODO: check if it makes sense to manage cache within lock */
-       dm_devs_cache_destroy();
+       dm_devs_cache_destroy(dm->cmd);
 
        dtree = _create_partial_dtree(dm, lv, laopts->origin_only);
 
index e965903ef354ee514ee261b5b8c3f1069f82ac2c..fdbed34adab37e0d1a708d1f68d5206793da0a39 100644 (file)
@@ -3237,11 +3237,11 @@ const char *dev_filtered_reason(struct device *dev)
        return "device cannot be used";
 }
 
-const char *devname_error_reason(const char *devname)
+const char *devname_error_reason(struct cmd_context *cmd, const char *devname)
 {
        struct device *dev;
 
-       if ((dev = dev_cache_get_dev_by_name(devname))) {
+       if ((dev = dev_cache_get_by_name(cmd, devname))) {
                if (dev->filtered_flags)
                        return dev_filtered_reason(dev);
                if (lvmcache_dev_is_unused_duplicate(dev))
index 760ff6ba1ef4056bf52f6201dc0ff447cc4a5bb9..f1852d289ad222593e08a3bf1a29efc47c39e437 100644 (file)
@@ -218,7 +218,7 @@ void lvmcache_get_mdas(struct cmd_context *cmd,
                        struct dm_list *mda_list);
 
 const char *dev_filtered_reason(struct device *dev);
-const char *devname_error_reason(const char *devname);
+const char *devname_error_reason(struct cmd_context *cmd, const char *devname);
 
 struct metadata_area *lvmcache_get_dev_mda(struct device *dev, int mda_num);
 
index 56dc1f8564d702832a1e1b3d7a3f2af5caadaf6d..a8ff9f99fb83edc16f2c56e3ea0027fa763d2b77 100644 (file)
@@ -1167,7 +1167,7 @@ static int _init_dev_cache(struct cmd_context *cmd)
                        }
                }
 
-               if (!dev_cache_add_dir(cv->v.str)) {
+               if (!dev_cache_add_dir(cmd, cv->v.str)) {
                        log_error("Failed to add %s to internal device cache",
                                  cv->v.str);
                        return 0;
@@ -1899,7 +1899,7 @@ int refresh_toolcontext(struct cmd_context *cmd)
        _destroy_segtypes(&cmd->segtypes);
        _destroy_formats(cmd, &cmd->formats);
 
-       if (!dev_cache_exit())
+       if (!dev_cache_exit(cmd))
                stack;
        _destroy_dev_types(cmd);
        _destroy_tags(cmd);
@@ -2028,7 +2028,7 @@ void destroy_toolcontext(struct cmd_context *cmd)
        _destroy_segtypes(&cmd->segtypes);
        _destroy_formats(cmd, &cmd->formats);
        _destroy_filters(cmd);
-       dev_cache_exit();
+       dev_cache_exit(cmd);
        _destroy_dev_types(cmd);
        _destroy_tags(cmd);
 
index b405bbf000800634c7f4dc2f29482395fdd23bd7..be637b82c6953158650a9f141b15c401fedb8d85 100644 (file)
@@ -19,6 +19,7 @@
 #include "lib/device/dev-cache.h"
 #include "lib/device/dev-type.h"
 #include "lib/commands/cmd_enum.h"
+#include "base/data-struct/radix-tree.h"
 
 #include <limits.h>
 
@@ -222,6 +223,11 @@ struct cmd_context {
        /*
         * Devices and filtering.
         */
+       struct dm_list dev_dirs;     /* paths, like /dev, to look for devnames */
+       struct radix_tree *devnames; /* path names in dev_dirs, get struct device from path name */
+       struct radix_tree *devnos;   /* devnos found in dev_dirs, get struct device from devno */
+       struct dm_regex *preferred_names_matcher; /* preferred dev names to display from lvm.conf */
+
        struct dev_filter *filter;
        struct dm_list use_devices;             /* struct dev_use for each entry in devices file */
        const char *md_component_checks;
@@ -230,6 +236,22 @@ struct cmd_context {
        const char *devicesfile;                /* from --devicesfile option */
        struct dm_list deviceslist;             /* from --devices option, struct dm_str_list */
 
+       /*
+        * LV dev index.
+        */
+       struct dm_hash_table *vgid_index;
+       struct dm_hash_table *lvid_index;
+       struct radix_tree *sysfs_only_devices;
+
+       /*
+        * Cache of DM devices.
+        * Look up struct dm_active_device from devno or dm uuid.
+        */
+       int use_dm_devs_cache;       /* use this cache or not */
+       struct dm_list *dm_devs;     /* list of dm_active_device */
+       struct radix_tree *dm_uuids; /* dm uuids of dm devices, get entry from dm_devs */
+       struct radix_tree *dm_devnos; /* devnos of dm devices, get entry from dm_devs */
+
        /*
         * Configuration.
         */
index 602d9cd0eec4658f611f431d5bb0a91dc3076bf2..0f1bebd3f87d36bb8771c0c8580b08df98d4b393 100644 (file)
@@ -48,33 +48,9 @@ struct dir_list {
        char dir[0];
 };
 
-static struct {
-       struct dm_pool *mem;
-       struct radix_tree *names;
-       struct dm_hash_table *vgid_index;
-       struct dm_hash_table *lvid_index;
-       struct dm_list *dm_devs; /* dm_active_device structs with dm UUIDs from DM_DEVICE_LIST (when available) */
-       struct radix_tree *dm_uuids; /* references dm_devs entries */
-       struct radix_tree *dm_devnos; /* references dm_devs entries */
-       struct radix_tree *sysfs_only_devices; /* see comments in _get_device_for_sysfs_dev_name_using_devno */
-       struct radix_tree *devices;
-       struct dm_regex *preferred_names_matcher;
-       const char *dev_dir;
-       int use_dm_devs_cache;
-
-       size_t dev_dir_len;
-       int has_scanned;
-       dev_t st_dev;
-       struct dm_list dirs;
-       struct dm_list files;
-
-} _cache;
-
-#define _zalloc(x) dm_pool_zalloc(_cache.mem, (x))
-#define _free(x) dm_pool_free(_cache.mem, (x))
-#define _strdup(x) dm_pool_strdup(_cache.mem, (x))
-
-static int _insert(const char *path, const struct stat *info,
+static dev_t _dev_cache_st_dev;
+
+static int _insert_any(struct cmd_context *cmd, const char *path, const struct stat *info,
                   int rec, int check_with_udev_db);
 
 /* Setup non-zero members of passed zeroed 'struct device' */
@@ -94,27 +70,28 @@ void dev_init(struct device *dev)
        dm_list_init(&dev->wwids);
 }
 
-static struct device *_dev_create(dev_t d)
+static struct device *_dev_create(struct cmd_context *cmd, dev_t d)
 {
        struct device *dev;
 
-       if (!(dev = _zalloc(sizeof(*dev)))) {
+       if (!(dev = dm_pool_zalloc(cmd->mem, sizeof(*dev)))) {
                log_error("struct device allocation failed");
                return NULL;
        }
 
        dev_init(dev);
        dev->dev = d;
+       dev->cmd = cmd;
 
        return dev;
 }
 
-void dev_set_preferred_name(struct dm_str_list *sl, struct device *dev)
+void dev_set_preferred_name(struct cmd_context *cmd, struct dm_str_list *sl, struct device *dev)
 {
        /*
         * Don't interfere with ordering specified in config file.
         */
-       if (_cache.preferred_names_matcher)
+       if (cmd->preferred_names_matcher)
                return;
 
        log_debug_devs("%s: New preferred name", sl->str);
@@ -153,29 +130,28 @@ static int _builtin_preference(const char *path0, const char *path1,
        return -2;
 }
 
-static int _apply_builtin_path_preference_rules(const char *path0, const char *path1)
+static int _apply_builtin_path_preference_rules(struct cmd_context *cmd, const char *path0, const char *path1)
 {
-       size_t devdir_len = _cache.dev_dir_len;
+       size_t dev_dir_len = strlen(cmd->dev_dir);
        int r;
 
-
-       if (!strncmp(path0, _cache.dev_dir, devdir_len) &&
-           !strncmp(path1, _cache.dev_dir, devdir_len)) {
+       if (!strncmp(path0, cmd->dev_dir, dev_dir_len) &&
+           !strncmp(path1, cmd->dev_dir, dev_dir_len)) {
                /*
                 * We're trying to achieve the ordering:
                 *      /dev/block/ < /dev/dm-* < /dev/disk/ < /dev/mapper/ < anything else
                 */
 
                /* Prefer any other path over /dev/block/ path. */
-               if ((r = _builtin_preference(path0, path1, devdir_len, "block/")) >= -1)
+               if ((r = _builtin_preference(path0, path1, dev_dir_len, "block/")) >= -1)
                        return r;
 
                /* Prefer any other path over /dev/dm-* path. */
-               if ((r = _builtin_preference(path0, path1, devdir_len, "dm-")) >= -1)
+               if ((r = _builtin_preference(path0, path1, dev_dir_len, "dm-")) >= -1)
                        return r;
 
                /* Prefer any other path over /dev/disk/ path. */
-               if ((r = _builtin_preference(path0, path1, devdir_len, "disk/")) >= -1)
+               if ((r = _builtin_preference(path0, path1, dev_dir_len, "disk/")) >= -1)
                        return r;
 
                /* Prefer any other path over /dev/mapper/ path. */
@@ -187,7 +163,7 @@ static int _apply_builtin_path_preference_rules(const char *path0, const char *p
 }
 
 /* Return 1 if we prefer path1 else return 0 */
-static int _compare_paths(const char *path0, const char *path1)
+static int _compare_paths(struct cmd_context *cmd, const char *path0, const char *path1)
 {
        int slash0 = 0, slash1 = 0;
        int m0, m1;
@@ -200,9 +176,9 @@ static int _compare_paths(const char *path0, const char *path1)
        /*
         * FIXME Better to compare patterns one-at-a-time against all names.
         */
-       if (_cache.preferred_names_matcher) {
-               m0 = dm_regex_match(_cache.preferred_names_matcher, path0);
-               m1 = dm_regex_match(_cache.preferred_names_matcher, path1);
+       if (cmd->preferred_names_matcher) {
+               m0 = dm_regex_match(cmd->preferred_names_matcher, path0);
+               m1 = dm_regex_match(cmd->preferred_names_matcher, path1);
 
                if (m0 != m1) {
                        if (m0 < 0)
@@ -217,7 +193,7 @@ static int _compare_paths(const char *path0, const char *path1)
        }
 
        /* Apply built-in preference rules first. */
-       if ((r = _apply_builtin_path_preference_rules(path0, path1)) >= 0)
+       if ((r = _apply_builtin_path_preference_rules(cmd, path0, path1)) >= 0)
                return r;
 
        /* Return the path with fewer slashes */
@@ -285,7 +261,7 @@ enum add_hash {
        REHASH
 };
 
-static int _add_alias(struct device *dev, const char *path, enum add_hash hash)
+static int _add_alias(struct cmd_context *cmd, struct device *dev, const char *path, enum add_hash hash)
 {
        struct dm_str_list *sl;
        struct dm_str_list *strl;
@@ -294,7 +270,7 @@ static int _add_alias(struct device *dev, const char *path, enum add_hash hash)
        size_t path_len = strlen(path);
 
        if (hash == REHASH)
-               radix_tree_remove(_cache.names, path, path_len);
+               radix_tree_remove(cmd->devnames, path, path_len);
 
        /* Is name already there? */
        dm_list_iterate_items(strl, &dev->aliases)
@@ -303,8 +279,8 @@ static int _add_alias(struct device *dev, const char *path, enum add_hash hash)
                        goto out;
                }
 
-       if (!(path = _strdup(path)) ||
-           !(sl = _zalloc(sizeof(*sl)))) {
+       if (!(path = dm_pool_strdup(cmd->mem, path)) ||
+           !(sl = dm_pool_zalloc(cmd->mem, sizeof(*sl)))) {
                log_error("Failed to add allias to dev cache.");
                return 0;
        }
@@ -316,7 +292,7 @@ static int _add_alias(struct device *dev, const char *path, enum add_hash hash)
 
        if (!dm_list_empty(&dev->aliases)) {
                oldpath = dm_list_item(dev->aliases.n, struct dm_str_list)->str;
-               prefer_old = _compare_paths(path, oldpath);
+               prefer_old = _compare_paths(cmd, path, oldpath);
        }
 
        if (prefer_old)
@@ -325,7 +301,7 @@ static int _add_alias(struct device *dev, const char *path, enum add_hash hash)
                dm_list_add_h(&dev->aliases, &sl->list);
 out:
        if ((hash != NO_HASH) &&
-           !radix_tree_insert_ptr(_cache.names, path, path_len, dev)) {
+           !radix_tree_insert_ptr(cmd->devnames, path, path_len, dev)) {
                log_error("Couldn't add name to hash in dev cache.");
                return 0;
        }
@@ -412,14 +388,15 @@ static inline uint32_t _shuffle_devno(dev_t d)
        //return (uint32_t) d;
 }
 
-static struct dm_list *_get_or_add_list_by_index_key(struct dm_hash_table *idx, const char *key)
+static struct dm_list *_get_or_add_list_by_index_key(struct cmd_context *cmd,
+                               struct dm_hash_table *idx, const char *key)
 {
        struct dm_list *list;
 
        if ((list = dm_hash_lookup(idx, key)))
                return list;
 
-       if (!(list = _zalloc(sizeof(*list)))) {
+       if (!(list = dm_pool_zalloc(cmd->mem, sizeof(*list)))) {
                log_error("%s: failed to allocate device list for device cache index.", key);
                return NULL;
        }
@@ -434,7 +411,7 @@ static struct dm_list *_get_or_add_list_by_index_key(struct dm_hash_table *idx,
        return list;
 }
 
-static bool _dev_cache_insert_devno(struct radix_tree *rt, dev_t devno, void *dev)
+static bool _insert_devno(struct radix_tree *rt, dev_t devno, void *dev)
 {
        union radix_value v = { .ptr = dev };
        uint32_t key = _shuffle_devno(devno);
@@ -442,21 +419,28 @@ static bool _dev_cache_insert_devno(struct radix_tree *rt, dev_t devno, void *de
        return radix_tree_insert(rt, &key, sizeof(key), v);
 }
 
-static struct device *_dev_cache_get_dev_by_devno(struct radix_tree *rt, dev_t devno)
+static struct device *_get_dev_by_devno(struct radix_tree *rt, dev_t devno)
 {
        uint32_t key = _shuffle_devno(devno);
 
        return radix_tree_lookup_ptr(rt, &key, sizeof(key));
 }
 
-static struct device *_insert_sysfs_dev(dev_t devno, const char *devname)
+struct device *dev_cache_get_by_devno(struct cmd_context *cmd, dev_t devno)
+{
+       uint32_t key = _shuffle_devno(devno);
+
+       return radix_tree_lookup_ptr(cmd->devnos, &key, sizeof(key));
+}
+
+static struct device *_insert_sysfs_dev(struct cmd_context *cmd, dev_t devno, const char *devname)
 {
        static struct device _fake_dev = { .flags = DEV_USED_FOR_LV };
        struct stat stat0;
        char path[PATH_MAX];
        struct device *dev;
 
-       if (dm_snprintf(path, sizeof(path), "%s%s", _cache.dev_dir, devname) < 0) {
+       if (dm_snprintf(path, sizeof(path), "%s%s", cmd->dev_dir, devname) < 0) {
                log_error("_insert_sysfs_dev: %s: dm_snprintf failed", devname);
                return NULL;
        }
@@ -468,24 +452,24 @@ static struct device *_insert_sysfs_dev(dev_t devno, const char *devname)
                return &_fake_dev;
        }
 
-       if (!(dev = _dev_create(devno)))
+       if (!(dev = _dev_create(cmd, devno)))
                return_NULL;
 
-       if (!_add_alias(dev, path, NO_HASH)) {
-               _free(dev);
+       if (!_add_alias(cmd, dev, path, NO_HASH)) {
+               dm_pool_free(cmd->mem, dev);
                return_NULL;
        }
 
-       if (!_dev_cache_insert_devno(_cache.sysfs_only_devices, devno, dev)) {
+       if (!_insert_devno(cmd->sysfs_only_devices, devno, dev)) {
                log_error("Couldn't add device to binary tree of sysfs-only devices in dev cache.");
-               _free(dev);
+               dm_pool_free(cmd->mem, dev);
                return NULL;
        }
 
        return dev;
 }
 
-static struct device *_get_device_for_sysfs_dev_name_using_devno(const char *devname)
+static struct device *_get_device_for_sysfs_dev_name_using_devno(struct cmd_context *cmd, const char *devname)
 {
        char path[PATH_MAX];
        char buf[PATH_MAX];
@@ -507,7 +491,7 @@ static struct device *_get_device_for_sysfs_dev_name_using_devno(const char *dev
        }
 
        devno = MKDEV(major, minor);
-       if (!(dev = _dev_cache_get_dev_by_devno(_cache.devices, devno))) {
+       if (!(dev = dev_cache_get_by_devno(cmd, devno))) {
                /*
                 * If we get here, it means the device is referenced in sysfs, but it's not yet in /dev.
                 * This may happen in some rare cases right after LVs get created - we sync with udev
@@ -519,8 +503,8 @@ static struct device *_get_device_for_sysfs_dev_name_using_devno(const char *dev
                 * where different directory for dev nodes is used (e.g. our test suite). So track
                 * such devices in _cache.sysfs_only_devices hash for the vgid/lvid check to work still.
                 */
-               if (!(dev = _dev_cache_get_dev_by_devno(_cache.sysfs_only_devices, devno)) &&
-                   !(dev = _insert_sysfs_dev(devno, devname)))
+               if (!(dev = _get_dev_by_devno(cmd->sysfs_only_devices, devno)) &&
+                   !(dev = _insert_sysfs_dev(cmd, devno, devname)))
                        return_NULL;
        }
 
@@ -550,8 +534,8 @@ static int _get_vgid_and_lvid_for_dev(struct cmd_context *cmd, struct device *de
             ((uuid_len > lvm_uuid_len) && (uuid[lvm_uuid_len] == '-'))) &&
            !strncmp(uuid, UUID_PREFIX, lvm_prefix_len)) {
                /* Separate VGID and LVID part from DM UUID. */
-               if (!(dev->vgid = dm_pool_strndup(_cache.mem, uuid + lvm_prefix_len, ID_LEN)) ||
-                   !(dev->lvid = dm_pool_strndup(_cache.mem, uuid + lvm_prefix_len + ID_LEN, ID_LEN)))
+               if (!(dev->vgid = dm_pool_strndup(cmd->mem, uuid + lvm_prefix_len, ID_LEN)) ||
+                   !(dev->lvid = dm_pool_strndup(cmd->mem, uuid + lvm_prefix_len + ID_LEN, ID_LEN)))
                        return_0;
        } else
                dev->vgid = dev->lvid = NOT_LVM_UUID;
@@ -597,12 +581,12 @@ static int _index_dev_by_vgid_and_lvid(struct cmd_context *cmd, struct device *d
                    !strcmp("..", dirent->d_name))
                        continue;
 
-               if (dm_snprintf(devpath, sizeof(devpath), "%s%s", _cache.dev_dir, dirent->d_name) == -1) {
+               if (dm_snprintf(devpath, sizeof(devpath), "%s%s", cmd->dev_dir, dirent->d_name) == -1) {
                        log_error("%s: dm_snprintf failed for holder %s device path.", devname, dirent->d_name);
                        goto out;
                }
 
-               if (!(holder_dev = dev_cache_get_dev_by_name(devpath))) {
+               if (!(holder_dev = dev_cache_get_by_name(cmd, devpath))) {
                        /*
                         * Cope with situation where canonical /<dev_dir>/<dirent->d_name>
                         * does not exist, but some other node name or symlink exists in
@@ -611,7 +595,7 @@ static int _index_dev_by_vgid_and_lvid(struct cmd_context *cmd, struct device *d
                         * This looks up struct device by major:minor pair which we get
                         * by looking at /sys/block/<dirent->d_name>/dev sysfs attribute.
                         */
-                       if (!(holder_dev = _get_device_for_sysfs_dev_name_using_devno(dirent->d_name))) {
+                       if (!(holder_dev = _get_device_for_sysfs_dev_name_using_devno(cmd, dirent->d_name))) {
                                log_error("%s: failed to find associated device structure for holder %s.", devname, devpath);
                                goto out;
                        }
@@ -643,13 +627,13 @@ static int _index_dev_by_vgid_and_lvid(struct cmd_context *cmd, struct device *d
                                continue;
                }
 
-               if (!(vgid_list = _get_or_add_list_by_index_key(_cache.vgid_index, holder_dev->vgid)) ||
-                   !(lvid_list = _get_or_add_list_by_index_key(_cache.lvid_index, holder_dev->lvid)))
+               if (!(vgid_list = _get_or_add_list_by_index_key(cmd, cmd->vgid_index, holder_dev->vgid)) ||
+                   !(lvid_list = _get_or_add_list_by_index_key(cmd, cmd->lvid_index, holder_dev->lvid)))
                        goto_out;
 
                /* Create dev list items for the holder device. */
-               if (!(dl_vgid = _zalloc(sizeof(*dl_vgid))) ||
-                   !(dl_lvid = _zalloc(sizeof(*dl_lvid)))) {
+               if (!(dl_vgid = dm_pool_zalloc(cmd->mem, sizeof(*dl_vgid))) ||
+                   !(dl_lvid = dm_pool_zalloc(cmd->mem, sizeof(*dl_lvid)))) {
                        log_error("%s: failed to allocate dev list item.", devname);
                        goto out;
                }
@@ -675,14 +659,14 @@ out:
        return r;
 }
 
-struct dm_list *dev_cache_get_dev_list_for_vgid(const char *vgid)
+struct dm_list *dev_cache_get_dev_list_for_vgid(struct cmd_context *cmd, const char *vgid)
 {
-       return dm_hash_lookup(_cache.vgid_index, vgid);
+       return dm_hash_lookup(cmd->vgid_index, vgid);
 }
 
-struct dm_list *dev_cache_get_dev_list_for_lvid(const char *lvid)
+struct dm_list *dev_cache_get_dev_list_for_lvid(struct cmd_context *cmd, const char *lvid)
 {
-       return dm_hash_lookup(_cache.lvid_index, lvid);
+       return dm_hash_lookup(cmd->lvid_index, lvid);
 }
 
 /*
@@ -692,11 +676,11 @@ struct dm_list *dev_cache_get_dev_list_for_lvid(const char *lvid)
  * different device.
  */
 
-void dev_cache_failed_path(struct device *dev, const char *path)
+void dev_cache_failed_path(struct cmd_context *cmd, struct device *dev, const char *path)
 {
        struct dm_str_list *strl;
 
-       radix_tree_remove(_cache.names, path, strlen(path));
+       radix_tree_remove(cmd->devnames, path, strlen(path));
 
        dm_list_iterate_items(strl, &dev->aliases) {
                if (!strcmp(strl->str, path)) {
@@ -710,14 +694,14 @@ void dev_cache_failed_path(struct device *dev, const char *path)
  * Either creates a new dev, or adds an alias to
  * an existing dev.
  */
-static int _insert_dev(const char *path, dev_t d)
+static int _insert_dev(struct cmd_context *cmd, const char *path, dev_t d)
 {
        struct device *dev;
        struct device *dev_by_devt;
        struct device *dev_by_path;
 
-       dev_by_devt = _dev_cache_get_dev_by_devno(_cache.devices, d);
-       dev_by_path = dev_cache_get_dev_by_name(path);
+       dev_by_devt = dev_cache_get_by_devno(cmd, d);
+       dev_by_path = dev_cache_get_by_name(cmd, path);
        dev = dev_by_devt;
 
        /*
@@ -730,22 +714,22 @@ static int _insert_dev(const char *path, dev_t d)
        }
 
        /*
-        * No device or path found, add devt to cache.devices, add name to cache.names.
+        * No device or path found, add devt to devnos, add name to devnames.
         */
        if (!dev_by_devt && !dev_by_path) {
                log_debug_devs("Found dev %u:%u %s - new.", MAJOR(d), MINOR(d), path);
-               if (!(dev = _dev_cache_get_dev_by_devno(_cache.sysfs_only_devices, d)))
+               if (!(dev = _get_dev_by_devno(cmd->sysfs_only_devices, d)))
                        /* create new device */
-                       if (!(dev = _dev_create(d)))
+                       if (!(dev = _dev_create(cmd, d)))
                                return_0;
 
-               if (!(_dev_cache_insert_devno(_cache.devices, d, dev))) {
+               if (!(_insert_devno(cmd->devnos, d, dev))) {
                        log_error("Couldn't insert device into binary tree.");
-                       _free(dev);
+                       dm_pool_free(cmd->mem, dev);
                        return 0;
                }
 
-               if (!_add_alias(dev, path, HASH))
+               if (!_add_alias(cmd, dev, path, HASH))
                        return_0;
 
                return 1;
@@ -757,7 +741,7 @@ static int _insert_dev(const char *path, dev_t d)
        if (dev_by_devt && !dev_by_path) {
                log_debug_devs("Found dev %u:%u %s - new alias.", MAJOR(d), MINOR(d), path);
 
-               if (!_add_alias(dev, path, HASH))
+               if (!_add_alias(cmd, dev, path, HASH))
                        return_0;
 
                return 1;
@@ -772,19 +756,19 @@ static int _insert_dev(const char *path, dev_t d)
                               MAJOR(d), MINOR(d), path,
                               MAJOR(dev_by_path->dev), MINOR(dev_by_path->dev));
 
-               if (!(dev = _dev_cache_get_dev_by_devno(_cache.sysfs_only_devices, d))) {
+               if (!(dev = _get_dev_by_devno(cmd->sysfs_only_devices, d))) {
                        /* create new device */
-                       if (!(dev = _dev_create(d)))
+                       if (!(dev = _dev_create(cmd, d)))
                                return_0;
                }
 
-               if (!(_dev_cache_insert_devno(_cache.devices, d, dev))) {
+               if (!(_insert_devno(cmd->devnos, d, dev))) {
                        log_error("Couldn't insert device into binary tree.");
-                       _free(dev);
+                       dm_pool_free(cmd->mem, dev);
                        return 0;
                }
 
-               if (!_add_alias(dev, path, REHASH))
+               if (!_add_alias(cmd, dev, path, REHASH))
                        return_0;
 
                return 1;
@@ -799,7 +783,7 @@ static int _insert_dev(const char *path, dev_t d)
                               MAJOR(d), MINOR(d), path,
                               MAJOR(dev_by_path->dev), MINOR(dev_by_path->dev));
 
-               if (!_add_alias(dev, path, REHASH))
+               if (!_add_alias(cmd, dev, path, REHASH))
                        return_0;
 
                return 1;
@@ -834,7 +818,7 @@ static size_t _collapse_slashes(char *str)
        return (str - start);
 }
 
-static int _insert_dir(const char *dir)
+static int _read_dev_dir(struct cmd_context *cmd, const char *dir)
 {
        /* alphanetically! sorted list used by bsearch of
         * /dev subdirectories that should not contain
@@ -886,7 +870,7 @@ static int _insert_dir(const char *dir)
                                continue;
                        }
 
-                       r &= _insert(path, NULL, 1, 0);
+                       r &= _insert_any(cmd, path, NULL, 1, 0);
                }
 
                for (n = 0; n < dirent_count; n++)
@@ -899,7 +883,7 @@ static int _insert_dir(const char *dir)
 
 static int _dev_cache_iterate_devs_for_index(struct cmd_context *cmd)
 {
-       struct dev_iter *iter = dev_iter_create(NULL, 0);
+       struct dev_iter *iter = dev_iter_create(cmd, NULL, 0);
        struct device *dev = NULL;
        int r = 1;
 
@@ -939,10 +923,10 @@ static int _dev_cache_iterate_sysfs_for_index(struct cmd_context *cmd, const cha
                }
 
                devno = MKDEV(major, minor);
-               if (!(dev = _dev_cache_get_dev_by_devno(_cache.devices, devno)) &&
-                   !(dev = _dev_cache_get_dev_by_devno(_cache.sysfs_only_devices, devno))) {
+               if (!(dev = dev_cache_get_by_devno(cmd, devno)) &&
+                   !(dev = _get_dev_by_devno(cmd->sysfs_only_devices, devno))) {
                        if (!dm_device_get_name(major, minor, 1, devname, sizeof(devname)) ||
-                           !(dev = _insert_sysfs_dev(devno, devname))) {
+                           !(dev = _insert_sysfs_dev(cmd, devno, devname))) {
                                partial_failure = 1;
                                continue;
                        }
@@ -1012,7 +996,7 @@ static int _device_in_udev_db(const dev_t d)
        return 0;
 }
 
-static int _insert_udev_dir(struct udev *udev, const char *dir)
+static int _insert_udev_dir(struct cmd_context *cmd, struct udev *udev, const char *dir)
 {
        struct udev_enumerate *udev_enum = NULL;
        struct udev_list_entry *device_entry, *symlink_entry;
@@ -1057,14 +1041,14 @@ static int _insert_udev_dir(struct udev *udev, const char *dir)
                        log_very_verbose("udev failed to return a device node for entry %s.",
                                         entry_name);
                else
-                       r &= _insert(node_name, NULL, 0, 0);
+                       r &= _insert_any(cmd, node_name, NULL, 0, 0);
 
                udev_list_entry_foreach(symlink_entry, udev_device_get_devlinks_list_entry(device)) {
                        if (!(symlink_name = udev_list_entry_get_name(symlink_entry)))
                                log_very_verbose("udev failed to return a symlink name for entry %s.",
                                                 entry_name);
                        else
-                               r &= _insert(symlink_name, NULL, 0, 0);
+                               r &= _insert_any(cmd, symlink_name, NULL, 0, 0);
                }
 
                udev_device_unref(device);
@@ -1076,7 +1060,7 @@ out:
        return r;
 }
 
-static void _insert_dirs(struct dm_list *dirs)
+static void _read_dev_dirs(struct cmd_context *cmd)
 {
        struct dir_list *dl;
        struct udev *udev = NULL;
@@ -1086,20 +1070,20 @@ static void _insert_dirs(struct dm_list *dirs)
        with_udev = obtain_device_list_from_udev() &&
                    (udev = udev_get_library_context());
 
-       dm_list_iterate_items(dl, &_cache.dirs) {
+       dm_list_iterate_items(dl, &cmd->dev_dirs) {
                if (stat(dl->dir, &tinfo) < 0) {
                        log_warn("WARNING: Cannot use dir %s, %s.",
                                 dl->dir, strerror(errno));
                        continue;
                }
-               _cache.st_dev = tinfo.st_dev;
+               _dev_cache_st_dev = tinfo.st_dev;
                if (with_udev) {
-                       if (!_insert_udev_dir(udev, dl->dir))
+                       if (!_insert_udev_dir(cmd, udev, dl->dir))
                                log_debug_devs("%s: Failed to insert devices from "
                                               "udev-managed directory to device "
                                               "cache fully", dl->dir);
                }
-               else if (!_insert_dir(dl->dir))
+               else if (!_read_dev_dir(cmd, dl->dir))
                        log_debug_devs("%s: Failed to insert devices to "
                                       "device cache fully", dl->dir);
        }
@@ -1112,26 +1096,26 @@ static int _device_in_udev_db(const dev_t d)
        return 0;
 }
 
-static void _insert_dirs(struct dm_list *dirs)
+static void _read_dev_dirs(struct cmd_context *cmd, struct dm_list *dirs)
 {
        struct dir_list *dl;
        struct stat tinfo;
 
-       dm_list_iterate_items(dl, &_cache.dirs) {
+       dm_list_iterate_items(dl, &cmd->dev_dirs) {
                if (stat(dl->dir, &tinfo) < 0) {
                        log_warn("WARNING: Cannot use dir %s, %s.",
                                 dl->dir, strerror(errno));
                        continue;
                }
-               _cache.st_dev = tinfo.st_dev;
-               _insert_dir(dl->dir);
+               _dev_cache_st_dev = tinfo.st_dev;
+               _read_dev_dir(cmd, dl->dir);
        }
 }
 
 #endif /* UDEV_SYNC_SUPPORT */
 
-static int _insert(const char *path, const struct stat *info,
-                  int rec, int check_with_udev_db)
+static int _insert_any(struct cmd_context *cmd, const char *path, const struct stat *info,
+                      int rec, int check_with_udev_db)
 {
        struct stat tinfo;
 
@@ -1160,31 +1144,31 @@ static int _insert(const char *path, const struct stat *info,
                        return 1;
                }
 
-               if (info->st_dev != _cache.st_dev) {
+               if (info->st_dev != _dev_cache_st_dev) {
                        log_debug_devs("%s: Different filesystem in directory", path);
                        return 1;
                }
 
-               if (rec && !_insert_dir(path))
+               if (rec && !_read_dev_dir(cmd, path))
                        return 0;
        } else {                /* add a device */
                if (!S_ISBLK(info->st_mode))
                        return 1;
 
-               if (!_insert_dev(path, info->st_rdev))
+               if (!_insert_dev(cmd, path, info->st_rdev))
                        return 0;
        }
 
        return 1;
 }
 
-static void _drop_all_aliases(struct device *dev)
+static void _drop_all_aliases(struct cmd_context *cmd, struct device *dev)
 {
        struct dm_str_list *strl, *strl2;
 
        dm_list_iterate_items_safe(strl, strl2, &dev->aliases) {
                log_debug("Drop alias for %u:%u %s.", MAJOR(dev->dev), MINOR(dev->dev), strl->str);
-               radix_tree_remove(_cache.names, strl->str, strlen(strl->str));
+               radix_tree_remove(cmd->devnames, strl->str, strlen(strl->str));
                dm_list_del(&strl->list);
        }
 }
@@ -1193,21 +1177,14 @@ void dev_cache_scan(struct cmd_context *cmd)
 {
        log_debug_devs("Creating list of system devices.");
 
-       _cache.has_scanned = 1;
-
        setlocale(LC_COLLATE, "C"); /* Avoid sorting by locales */
-       _insert_dirs(&_cache.dirs);
+       _read_dev_dirs(cmd);
        setlocale(LC_COLLATE, "");
 
        if (cmd->check_devs_used)
                (void) _dev_cache_index_devs(cmd);
 }
 
-int dev_cache_has_scanned(void)
-{
-       return _cache.has_scanned;
-}
-
 static int _init_preferred_names(struct cmd_context *cmd)
 {
        const struct dm_config_node *cn;
@@ -1217,7 +1194,7 @@ static int _init_preferred_names(struct cmd_context *cmd)
        unsigned count = 0;
        int i, r = 0;
 
-       _cache.preferred_names_matcher = NULL;
+       cmd->preferred_names_matcher = NULL;
 
        if (!(cn = find_config_tree_array(cmd, devices_preferred_names_CFG, NULL)) ||
            cn->v->type == DM_CFG_EMPTY_ARRAY) {
@@ -1254,8 +1231,7 @@ static int _init_preferred_names(struct cmd_context *cmd)
                }
        }
 
-       if (!(_cache.preferred_names_matcher =
-               dm_regex_create(_cache.mem, regex, count))) {
+       if (!(cmd->preferred_names_matcher = dm_regex_create(cmd->mem, regex, count))) {
                log_error("Preferred device name pattern matcher creation failed.");
                goto out;
        }
@@ -1268,71 +1244,72 @@ out:
        return r;
 }
 
-int dm_devs_cache_use(void)
+int dm_devs_cache_use(struct cmd_context *cmd)
 {
-       return _cache.use_dm_devs_cache;
+       return cmd->use_dm_devs_cache;
 }
 
-void dm_devs_cache_destroy(void)
+void dm_devs_cache_destroy(struct cmd_context *cmd)
 {
-       _cache.use_dm_devs_cache = 0;
+       cmd->use_dm_devs_cache = 0;
 
-       if (_cache.dm_devnos) {
-               radix_tree_destroy(_cache.dm_devnos);
-               _cache.dm_devnos = NULL;
+       if (cmd->dm_uuids) {
+               radix_tree_destroy(cmd->dm_uuids);
+               cmd->dm_uuids = NULL;
        }
 
-       if (_cache.dm_uuids) {
-               radix_tree_destroy(_cache.dm_uuids);
-               _cache.dm_uuids = NULL;
+       if (cmd->dm_devnos) {
+               radix_tree_destroy(cmd->dm_devnos);
+               cmd->dm_devnos = NULL;
        }
 
-       dm_device_list_destroy(&_cache.dm_devs);
+       dm_device_list_destroy(&cmd->dm_devs);
+       cmd->dm_devs = NULL;
 }
 
-int dm_devs_cache_update(void)
+int dm_devs_cache_update(struct cmd_context *cmd)
 {
        struct dm_active_device *dm_dev;
        unsigned devs_features;
        uint32_t d;
 
-       dm_devs_cache_destroy();
+       dm_devs_cache_destroy(cmd);
 
-       if (!get_dm_active_devices(NULL, &_cache.dm_devs, &devs_features))
+       if (!get_dm_active_devices(NULL, &cmd->dm_devs, &devs_features))
                return 1;
 
        if (!(devs_features & DM_DEVICE_LIST_HAS_UUID)) {
                /* Cache unusable with older kernels without UUIDs in LIST */
-               dm_device_list_destroy(&_cache.dm_devs);
+               dm_device_list_destroy(&cmd->dm_devs);
                return 1;
        }
 
-       /* _cache.dm_devs entries are referenced by radix trees */
+       /* dm_devs entries are referenced by radix trees */
 
-       /* TODO: if _cache.dm_devs list is small, then skip the
+       /* TODO: if dm_devs list is small, then skip the
           overhead of radix trees and just do list searches on dm_devs */
 
-       if (!(_cache.dm_devnos = radix_tree_create(NULL, NULL)) ||
-           !(_cache.dm_uuids = radix_tree_create(NULL, NULL))) {
+       if (!(cmd->dm_devnos = radix_tree_create(NULL, NULL)) ||
+           !(cmd->dm_uuids = radix_tree_create(NULL, NULL))) {
                return_0; // FIXME
        }
 
        /* Insert every active DM device into radix trees */
-       dm_list_iterate_items(dm_dev, _cache.dm_devs) {
+       dm_list_iterate_items(dm_dev, cmd->dm_devs) {
                d = _shuffle_devno(dm_dev->devno);
 
-               if (!radix_tree_insert_ptr(_cache.dm_devnos, &d, sizeof(d), dm_dev))
+               if (!radix_tree_insert_ptr(cmd->dm_devnos, &d, sizeof(d), dm_dev))
                        return_0;
 
                if (dm_dev->uuid[0] &&
-                   !radix_tree_insert_ptr(_cache.dm_uuids, dm_dev->uuid, strlen(dm_dev->uuid), dm_dev))
+                   !radix_tree_insert_ptr(cmd->dm_uuids, dm_dev->uuid, strlen(dm_dev->uuid), dm_dev))
                        return_0;
        }
 
-       //radix_tree_dump(_cache.dm_devnos, stdout);
-       //radix_tree_dump(_cache.dm_uuids, stdout);
+       //radix_tree_dump(cmd->dm_devnos, stdout);
+       //radix_tree_dump(cmd->dm_uuids, stdout);
 
-       _cache.use_dm_devs_cache = 1;
+       cmd->use_dm_devs_cache = 1;
        return 1;
 }
 
@@ -1341,10 +1318,10 @@ void dm_devs_cache_label_invalidate(struct cmd_context *cmd)
        struct dm_active_device *dm_dev;
        struct device *dev;
 
-       dm_list_iterate_items(dm_dev, _cache.dm_devs) {
+       dm_list_iterate_items(dm_dev, cmd->dm_devs) {
                if (dm_dev->uuid &&
                   strncmp(dm_dev->uuid, UUID_PREFIX, sizeof(UUID_PREFIX) - 1) == 0) {
-                       if ((dev = dev_cache_get_by_devt(cmd, dm_dev->devno)))
+                       if ((dev = dev_cache_get_by_devno(cmd, dm_dev->devno)))
                                label_scan_invalidate(dev);
                }
        }
@@ -1356,71 +1333,54 @@ dm_devs_cache_get_by_devno(struct cmd_context *cmd, dev_t devno)
 {
        uint32_t d = _shuffle_devno(devno);
 
-       if (!_cache.dm_devnos)
+       if (!cmd->dm_devnos)
                return NULL;
 
-       return radix_tree_lookup_ptr(_cache.dm_devnos, &d, sizeof(d));
+       return radix_tree_lookup_ptr(cmd->dm_devnos, &d, sizeof(d));
 }
 
 /* Find active DM device in devs array for given DM UUID */
 const struct dm_active_device *
 dm_devs_cache_get_by_uuid(struct cmd_context *cmd, const char *dm_uuid)
 {
-       if (!_cache.dm_uuids)
+       if (!cmd->dm_uuids)
                return NULL;
 
-       return radix_tree_lookup_ptr(_cache.dm_uuids, dm_uuid, strlen(dm_uuid));
+       return radix_tree_lookup_ptr(cmd->dm_uuids, dm_uuid, strlen(dm_uuid));
 }
 
 int dev_cache_init(struct cmd_context *cmd)
 {
-       _cache.names = NULL;
-
-       if (!(_cache.mem = dm_pool_create("dev_cache", 10 * 1024)))
-               return_0;
+       dm_list_init(&cmd->dev_dirs);
 
-       if (!(_cache.names = radix_tree_create(NULL, NULL)) ||
-           !(_cache.vgid_index = dm_hash_create(30)) ||
-           !(_cache.lvid_index = dm_hash_create(29))) {
-               dm_pool_destroy(_cache.mem);
-               _cache.mem = 0;
-               return_0;
-       }
-
-       if (!(_cache.devices = radix_tree_create(NULL, NULL))) {
-               log_error("Couldn't create binary tree for dev-cache.");
+       if (!(cmd->devnames = radix_tree_create(NULL, NULL)))
                goto bad;
-       }
-
-       if (!(_cache.sysfs_only_devices = radix_tree_create(NULL, NULL))) {
-               log_error("Couldn't create binary tree for sysfs-only devices in dev cache.");
+       if (!(cmd->devnos = radix_tree_create(NULL, NULL)))
                goto bad;
-       }
-
-       if (!(_cache.dev_dir = _strdup(cmd->dev_dir))) {
-               log_error("strdup dev_dir failed.");
-               goto bad;
-       }
-
-       _cache.dev_dir_len = strlen(_cache.dev_dir);
-       dm_list_init(&_cache.dirs);
-
        if (!_init_preferred_names(cmd))
                goto_bad;
 
+       if (!(cmd->sysfs_only_devices = radix_tree_create(NULL, NULL)))
+               goto bad;
+       if (!(cmd->vgid_index = dm_hash_create(30)))
+               goto bad;
+       if (!(cmd->lvid_index = dm_hash_create(29)))
+               goto bad;
+
        return 1;
 
       bad:
-       dev_cache_exit();
+       dev_cache_exit(cmd);
        return 0;
 }
 
 struct dev_visitor {
-       struct radix_tree_iterator it;
-       int close_immediate;
-       int free;
+       int do_close; /* close fd's */
+       int do_free;  /* free dids, wwids */
        unsigned num_open;
+       struct radix_tree_iterator it;
 };
+
 /*
  * Returns number of devices still open.
  */
@@ -1435,11 +1395,11 @@ static bool _visit_check_for_open_devices(struct radix_tree_iterator *it,
                log_error("Device '%s' has been left open (%d remaining references).",
                          dev_name(dev), dev->open_count);
                vt->num_open++;
-               if (vt->close_immediate && !dev_close_immediate(dev))
+               if (vt->do_close && !dev_close_immediate(dev))
                        stack;
        }
 
-       if (vt->free) {
+       if (vt->do_free) {
                free_dids(&dev->ids);
                free_wwids(&dev->wwids);
        }
@@ -1447,63 +1407,55 @@ static bool _visit_check_for_open_devices(struct radix_tree_iterator *it,
        return true;
 }
 
-/*
- * Returns number of devices left open.
- */
-int dev_cache_check_for_open_devices(void)
+int dev_cache_exit(struct cmd_context *cmd)
 {
-       struct dev_visitor vt = {
-               .it.visit = _visit_check_for_open_devices,
-       };
-
-       radix_tree_iterate(_cache.names, NULL, 0, &vt.it);
-
-       return vt.num_open;
-}
+       struct dev_visitor vt = { 0 };
+       uint32_t key = 0;
 
-int dev_cache_exit(void)
-{
-       struct dev_visitor vt = {
-               .it.visit = _visit_check_for_open_devices,
-               .close_immediate = 1, /* close open devices */
-               .free = 1,            /* free dids, wwids */
-       };
+       vt.do_close = 1;
+       vt.do_free = 1;
+       vt.it.visit = _visit_check_for_open_devices;
 
-       if (_cache.names) {
+       if (cmd->devnos) {
                /* check for open devices */
-               radix_tree_iterate(_cache.names, NULL, 0, &vt.it);
+               radix_tree_iterate(cmd->devnos, &key, sizeof(key), &vt.it);
 
                if (vt.num_open)
                        log_error(INTERNAL_ERROR "%d device(s) were left open and have been closed.",
                                  vt.num_open);
-       }
-
-       dm_devs_cache_destroy();
 
-       if (_cache.mem)
-               dm_pool_destroy(_cache.mem);
+               radix_tree_destroy(cmd->devnos);
+               cmd->devnos = NULL;
+       }
 
-       if (_cache.names)
-               radix_tree_destroy(_cache.names);
+       if (cmd->devnames) {
+               radix_tree_destroy(cmd->devnames);
+               cmd->devnames = NULL;
+       }
 
-       if (_cache.vgid_index)
-               dm_hash_destroy(_cache.vgid_index);
+       if (cmd->sysfs_only_devices) {
+              radix_tree_destroy(cmd->sysfs_only_devices);
+              cmd->sysfs_only_devices = NULL;
+       }
 
-       if (_cache.lvid_index)
-               dm_hash_destroy(_cache.lvid_index);
+       if (cmd->vgid_index) {
+               dm_hash_destroy(cmd->vgid_index);
+               cmd->vgid_index = NULL;
+       }
 
-       if (_cache.devices)
-              radix_tree_destroy(_cache.devices);
+       if (cmd->lvid_index) {
+               dm_hash_destroy(cmd->lvid_index);
+               cmd->lvid_index = NULL;
+       }
 
-       if (_cache.sysfs_only_devices)
-              radix_tree_destroy(_cache.sysfs_only_devices);
+       dm_devs_cache_destroy(cmd);
 
-       memset(&_cache, 0, sizeof(_cache));
+       _dev_cache_st_dev = 0;
 
        return (!vt.num_open);
 }
 
-int dev_cache_add_dir(const char *path)
+int dev_cache_add_dir(struct cmd_context *cmd, const char *path)
 {
        struct dir_list *dl;
        struct stat st;
@@ -1521,19 +1473,19 @@ int dev_cache_add_dir(const char *path)
        }
 
        len = strlen(path);
-       if (!(dl = _zalloc(sizeof(*dl) + len + 1))) {
+       if (!(dl = dm_pool_zalloc(cmd->mem, sizeof(*dl) + len + 1))) {
                log_error("dir_list allocation failed");
                return 0;
        }
 
        memcpy(dl->dir, path, len + 1);
-       dm_list_add(&_cache.dirs, &dl->list);
+       dm_list_add(&cmd->dev_dirs, &dl->list);
        return 1;
 }
 
-struct device *dev_cache_get_dev_by_name(const char *name)
+struct device *dev_cache_get_by_name(struct cmd_context *cmd, const char *name)
 {
-       return radix_tree_lookup_ptr(_cache.names, name, strlen(name));
+       return radix_tree_lookup_ptr(cmd->devnames, name, strlen(name));
 }
 
 static void _remove_alias(struct device *dev, const char *name)
@@ -1559,7 +1511,7 @@ static void _remove_alias(struct device *dev, const char *name)
  * deactivated LV.  Those old paths are all invalid and are dropped here.
  */
 
-void dev_cache_verify_aliases(struct device *dev)
+void dev_cache_verify_aliases(struct cmd_context *cmd, struct device *dev)
 {
        struct dm_str_list *strl, *strl2;
        struct stat st;
@@ -1569,7 +1521,7 @@ void dev_cache_verify_aliases(struct device *dev)
                        log_debug("Drop alias for %u:%u invalid path %s %u:%u.",
                                  MAJOR(dev->dev), MINOR(dev->dev), strl->str,
                                  MAJOR(st.st_rdev), MINOR(st.st_rdev));
-                       radix_tree_remove(_cache.names, strl->str, strlen(strl->str));
+                       radix_tree_remove(cmd->devnames, strl->str, strlen(strl->str));
                        dm_list_del(&strl->list);
                }
        }
@@ -1577,7 +1529,7 @@ void dev_cache_verify_aliases(struct device *dev)
 
 static struct device *_dev_cache_get(struct cmd_context *cmd, const char *name, struct dev_filter *f, int existing)
 {
-       struct device *dev = dev_cache_get_dev_by_name(name);
+       struct device *dev = dev_cache_get_by_name(cmd, name);
        struct stat st;
        int ret;
 
@@ -1603,12 +1555,12 @@ static struct device *_dev_cache_get(struct cmd_context *cmd, const char *name,
                        log_debug("Device path %s is invalid for %u:%u %s.",
                                  name, MAJOR(dev->dev), MINOR(dev->dev), dev_name(dev));
 
-                       radix_tree_remove(_cache.names, name, strlen(name));
+                       radix_tree_remove(cmd->devnames, name, strlen(name));
 
                        _remove_alias(dev, name);
 
                        /* Remove any other names in dev->aliases that are incorrect. */
-                       dev_cache_verify_aliases(dev);
+                       dev_cache_verify_aliases(cmd, dev);
                }
                return NULL;
        }
@@ -1629,7 +1581,7 @@ static struct device *_dev_cache_get(struct cmd_context *cmd, const char *name,
         * Remove incorrect info and then add new dev-cache entry.
         */
        if (dev && (st.st_rdev != dev->dev)) {
-               struct device *dev_by_devt = _dev_cache_get_dev_by_devno(_cache.devices, st.st_rdev);
+               struct device *dev_by_devt = dev_cache_get_by_devno(cmd, st.st_rdev);
 
                /*
                 * lvm commands create this condition when they
@@ -1643,14 +1595,14 @@ static struct device *_dev_cache_get(struct cmd_context *cmd, const char *name,
                          MAJOR(dev->dev), MINOR(dev->dev), dev_name(dev),
                          MAJOR(st.st_rdev), MINOR(st.st_rdev), name);
 
-               _drop_all_aliases(dev);
+               _drop_all_aliases(cmd, dev);
 
                if (dev_by_devt) {
                        log_debug("Dropping aliases for device entry %u:%u %s for new device %u:%u %s.",
                                   MAJOR(dev_by_devt->dev), MINOR(dev_by_devt->dev), dev_name(dev_by_devt),
                                   MAJOR(st.st_rdev), MINOR(st.st_rdev), name);
 
-                       _drop_all_aliases(dev_by_devt);
+                       _drop_all_aliases(cmd, dev_by_devt);
                }
 
 #if 0
@@ -1664,11 +1616,11 @@ static struct device *_dev_cache_get(struct cmd_context *cmd, const char *name,
                }
 #endif
 
-               if (!_insert_dev(name, st.st_rdev))
+               if (!_insert_dev(cmd, name, st.st_rdev))
                        return_NULL;
 
                /* Get the struct dev that was just added. */
-               dev = dev_cache_get_dev_by_name(name);
+               dev = dev_cache_get_by_name(cmd, name);
 
                if (!dev) {
                        log_error("Failed to get device %s", name);
@@ -1715,12 +1667,12 @@ static struct device *_dev_cache_get(struct cmd_context *cmd, const char *name,
                 * Without dropping the aliases, it's plausible that lvm commands
                 * could end up using the wrong dm device.
                 */
-               struct device *dev_by_devt = _dev_cache_get_dev_by_devno(_cache.devices, st.st_rdev);
+               struct device *dev_by_devt = dev_cache_get_by_devno(cmd, st.st_rdev);
 
                if (dev_by_devt) {
                        log_debug("Dropping aliases for %u:%u before adding new path %s.",
                                  MAJOR(st.st_rdev), MINOR(st.st_rdev), name);
-                       _drop_all_aliases(dev_by_devt);
+                       _drop_all_aliases(cmd, dev_by_devt);
                }
 
 #if 0
@@ -1734,11 +1686,11 @@ static struct device *_dev_cache_get(struct cmd_context *cmd, const char *name,
                }
 #endif
 
-               if (!_insert_dev(name, st.st_rdev))
+               if (!_insert_dev(cmd, name, st.st_rdev))
                        return_NULL;
 
                /* Get the struct dev that was just added. */
-               dev = dev_cache_get_dev_by_name(name);
+               dev = dev_cache_get_by_name(cmd, name);
 
                if (!dev) {
                        log_error("Failed to get device %s", name);
@@ -1774,19 +1726,9 @@ struct device *dev_cache_get(struct cmd_context *cmd, const char *name, struct d
        return _dev_cache_get(cmd, name, f, 0);
 }
 
-struct device *dev_cache_get_by_devt(struct cmd_context *cmd, dev_t devt)
-{
-       struct device *dev = _dev_cache_get_dev_by_devno(_cache.devices, devt);
-
-       if (dev)
-               return dev;
-       log_debug_devs("No devno %u:%u in dev cache.", MAJOR(devt), MINOR(devt));
-       return NULL;
-}
-
 struct device *dev_cache_get_by_pvid(struct cmd_context *cmd, const char *pvid)
 {
-       struct dev_iter *iter = dev_iter_create(NULL, 0);
+       struct dev_iter *iter = dev_iter_create(cmd, NULL, 0);
        struct device *dev;
 
        while ((dev = dev_iter_get(NULL, iter)))
@@ -1798,7 +1740,7 @@ struct device *dev_cache_get_by_pvid(struct cmd_context *cmd, const char *pvid)
        return dev;
 }
 
-struct dev_iter *dev_iter_create(struct dev_filter *f, int unused)
+struct dev_iter *dev_iter_create(struct cmd_context *cmd, struct dev_filter *f, int unused)
 {
        struct dev_iter *di = malloc(sizeof(*di));
 
@@ -1807,7 +1749,7 @@ struct dev_iter *dev_iter_create(struct dev_filter *f, int unused)
                return NULL;
        }
 
-       if (!radix_tree_values(_cache.devices, NULL, 0,
+       if (!radix_tree_values(cmd->devnos, NULL, 0,
                               &di->values, &di->nr_values)) {
                log_error("dev_iter values allocation failed.");
                free(di);
@@ -1865,10 +1807,10 @@ const char *dev_name(const struct device *dev)
                return unknown_device_name();
 }
 
-bool dev_cache_has_md_with_end_superblock(struct dev_types *dt)
+bool dev_cache_has_md_with_end_superblock(struct cmd_context *cmd, struct dev_types *dt)
 {
        struct device *dev;
-       struct dev_iter *iter = dev_iter_create(NULL, 0);
+       struct dev_iter *iter = dev_iter_create(cmd, NULL, 0);
        bool ret = false;
 
        while ((dev = dev_iter_get(NULL, iter)))
@@ -2259,10 +2201,10 @@ int setup_device(struct cmd_context *cmd, const char *devname)
                return 0;
        }
 
-       if (!_insert_dev(devname, buf.st_rdev))
+       if (!_insert_dev(cmd, devname, buf.st_rdev))
                return_0;
 
-       if (!(dev = dev_cache_get_dev_by_name(devname)))
+       if (!(dev = dev_cache_get_by_name(cmd, devname)))
                return_0;
 
        /* Match this device to an entry in devices_file so it will not
@@ -2363,7 +2305,7 @@ static char *_get_devname_from_devno(struct cmd_context *cmd, dev_t devno)
 
                if (devname[0]) {
                        log_debug("Found %s for %d:%d from sys", devname, major, minor);
-                       return _strdup(devname);
+                       return dm_pool_strdup(cmd->mem, devname);
                }
                return NULL;
        }
@@ -2389,7 +2331,7 @@ static char *_get_devname_from_devno(struct cmd_context *cmd, dev_t devno)
 
                log_debug("Found %s for %d:%d from sys dm.", devname, major, minor);
 
-               return _strdup(devname);
+               return dm_pool_strdup(cmd->mem, devname);
        }
 
        /*
@@ -2422,7 +2364,7 @@ try_partition:
 
        if (devname[0]) {
                log_debug("Found %s for %d:%d from %s", devname, major, minor, _partitions);
-               return _strdup(devname);
+               return dm_pool_strdup(cmd->mem, devname);
        }
 
        /*
@@ -2446,10 +2388,10 @@ int setup_devname_in_dev_cache(struct cmd_context *cmd, const char *devname)
                return 0;
        }
 
-       if (!_insert_dev(devname, buf.st_rdev))
+       if (!_insert_dev(cmd, devname, buf.st_rdev))
                return_0;
 
-       if (!dev_cache_get_dev_by_name(devname))
+       if (!dev_cache_get_by_name(cmd, devname))
                return_0;
 
        return 1;
@@ -2507,10 +2449,10 @@ struct device *setup_dev_in_dev_cache(struct cmd_context *cmd, dev_t devno, cons
                          MAJOR(buf.st_rdev), MINOR(buf.st_rdev), major, minor);
        }
 
-       if (!_insert_dev(devname, buf.st_rdev))
+       if (!_insert_dev(cmd, devname, buf.st_rdev))
                return_NULL;
 
-       if (!(dev = dev_cache_get_dev_by_name(devname))) {
+       if (!(dev = dev_cache_get_by_name(cmd, devname))) {
                log_error("Device lookup failed for %u:%u %s", major, minor, devname);
                return_NULL;
        }
index 3cc58d1e30ce73c556c13ec7b2525fd86a23e81c..6ba0212632d3efd86749df405ef90f74ef60cdfd 100644 (file)
@@ -36,8 +36,8 @@ struct dev_filter {
 
 void dev_init(struct device *dev);
 
-struct dm_list *dev_cache_get_dev_list_for_vgid(const char *vgid);
-struct dm_list *dev_cache_get_dev_list_for_lvid(const char *lvid);
+struct dm_list *dev_cache_get_dev_list_for_vgid(struct cmd_context *cmd, const char *vgid);
+struct dm_list *dev_cache_get_dev_list_for_lvid(struct cmd_context *cmd, const char *lvid);
 
 /*
  * The cache of dm devices is enabled when the kernel
@@ -49,9 +49,9 @@ struct dm_list *dev_cache_get_dev_list_for_lvid(const char *lvid);
  * have an alternative for when dm_devs_cache_use()
  * returns 0.
  */
-int dm_devs_cache_use(void);
-int dm_devs_cache_update(void);
-void dm_devs_cache_destroy(void);
+int dm_devs_cache_use(struct cmd_context *cmd);
+int dm_devs_cache_update(struct cmd_context *cmd);
+void dm_devs_cache_destroy(struct cmd_context *cmd);
 void dm_devs_cache_label_invalidate(struct cmd_context *cmd);
 const struct dm_active_device *
 dm_devs_cache_get_by_devno(struct cmd_context *cmd, dev_t devno);
@@ -62,38 +62,32 @@ dm_devs_cache_get_by_uuid(struct cmd_context *cmd, const char *dm_uuid);
  * The global device cache.
  */
 int dev_cache_init(struct cmd_context *cmd);
-int dev_cache_exit(void);
-
-/*
- * Returns number of open devices.
- */
-int dev_cache_check_for_open_devices(void);
+int dev_cache_exit(struct cmd_context *cmd);
 
 void dev_cache_scan(struct cmd_context *cmd);
-int dev_cache_has_scanned(void);
 
-int dev_cache_add_dir(const char *path);
+int dev_cache_add_dir(struct cmd_context *cmd, const char *path);
 struct device *dev_cache_get(struct cmd_context *cmd, const char *name, struct dev_filter *f);
 struct device *dev_cache_get_existing(struct cmd_context *cmd, const char *name, struct dev_filter *f);
-struct device *dev_cache_get_by_devt(struct cmd_context *cmd, dev_t devt);
-struct device *dev_cache_get_by_pvid(struct cmd_context *cmd, const char *pvid);
-void dev_cache_verify_aliases(struct device *dev);
+void dev_cache_verify_aliases(struct cmd_context *cmd, struct device *dev);
 
-struct device *dev_cache_get_dev_by_name(const char *name);
+struct device *dev_cache_get_by_devno(struct cmd_context *cmd, dev_t devno);
+struct device *dev_cache_get_by_name(struct cmd_context *cmd, const char *name);
+struct device *dev_cache_get_by_pvid(struct cmd_context *cmd, const char *pvid);
 
-void dev_set_preferred_name(struct dm_str_list *sl, struct device *dev);
+void dev_set_preferred_name(struct cmd_context *cmd, struct dm_str_list *sl, struct device *dev);
 
 /*
  * Object for iterating through the cache.
  */
 struct dev_iter;
-struct dev_iter *dev_iter_create(struct dev_filter *f, int unused);
+struct dev_iter *dev_iter_create(struct cmd_context *cmd, struct dev_filter *f, int unused);
 void dev_iter_destroy(struct dev_iter *iter);
 struct device *dev_iter_get(struct cmd_context *cmd, struct dev_iter *iter);
 
-void dev_cache_failed_path(struct device *dev, const char *path);
+void dev_cache_failed_path(struct cmd_context *cmd, struct device *dev, const char *path);
 
-bool dev_cache_has_md_with_end_superblock(struct dev_types *dt);
+bool dev_cache_has_md_with_end_superblock(struct cmd_context *cmd, struct dev_types *dt);
 
 int get_sysfs_value(const char *path, char *buf, size_t buf_size, int error_if_no_value);
 int get_sysfs_binary(const char *path, char *buf, size_t buf_size, int *retlen);
index e13c0bf2165873b987697956534db3753d3aeeda..0f9d53654c869e96ce4ca903df2abf2e0fb0abd1 100644 (file)
@@ -576,7 +576,7 @@ static int _dev_in_wwid_file(struct cmd_context *cmd, struct device *dev,
         * Check the primary device, not the partition.
         */
        if (primary_result == 2) {
-               if (!(dev = dev_cache_get_by_devt(cmd, primary_dev))) {
+               if (!(dev = dev_cache_get_by_devno(cmd, primary_dev))) {
                        log_debug("dev_is_mpath_component %s no primary dev", dev_name(dev));
                        return 0;
                }
index cd2b4e36a9a79e8bdb32d13cd829917f754ed4e4..74cd06661f473169c11379368418d11af2e40103 100644 (file)
@@ -149,6 +149,7 @@ struct device {
        uint64_t end;
        struct dev_ext ext;
        const char *duplicate_prefer_reason;
+       struct cmd_context *cmd;
 
        const char *vgid; /* if device is an LV */
        const char *lvid; /* if device is an LV */
index b3330f2ba3777c7351c90ed78e63df2935889c33..7e8338265babd844b254d1c8e4d49ee39bd81a2e 100644 (file)
@@ -2738,7 +2738,7 @@ void device_ids_match(struct cmd_context *cmd)
                 */
                found = 0;
 
-               if (!(iter = dev_iter_create(NULL, 0)))
+               if (!(iter = dev_iter_create(cmd, NULL, 0)))
                        continue;
                while ((dev = dev_iter_get(cmd, iter))) {
                        /* skip a dev that's already matched to another entry */
@@ -2855,7 +2855,7 @@ static void _get_devs_with_serial_numbers(struct cmd_context *cmd, struct dm_lis
        struct dev_id *id;
        const char *idname;
 
-       if (!(iter = dev_iter_create(NULL, 0)))
+       if (!(iter = dev_iter_create(cmd, NULL, 0)))
                return;
        while ((dev = dev_iter_get(cmd, iter))) {
                /* if serial has already been read for this dev then use it */
@@ -3794,7 +3794,7 @@ void device_ids_search(struct cmd_context *cmd, struct dm_list *new_devs,
         * filter), in the process of doing this search outside the deviceid
         * filter.
         */
-       if (!(iter = dev_iter_create(NULL, 0)))
+       if (!(iter = dev_iter_create(cmd, NULL, 0)))
                return;
        while ((dev = dev_iter_get(cmd, iter))) {
                if (dev->flags & DEV_MATCHED_USE_ID)
index c1b178bc3f7726f751dafe5299f3b7956ace72e3..f32c2c79fb479cf61330b4c0921284c5ba929036 100644 (file)
@@ -39,7 +39,7 @@ static int _ignore_mpath_component(struct cmd_context *cmd, struct dev_filter *f
                 */
                if ((dev->flags & DEV_MATCHED_USE_ID) && mpath_devno) {
                        if (!get_du_for_devno(cmd, mpath_devno)) {
-                               struct device *mpath_dev = dev_cache_get_by_devt(cmd, mpath_devno);
+                               struct device *mpath_dev = dev_cache_get_by_devno(cmd, mpath_devno);
                                log_warn("WARNING: devices file is missing %s (%u:%u) using multipath component %s.",
                                         mpath_dev ? dev_name(mpath_dev) : "unknown",
                                         MAJOR(mpath_devno), MINOR(mpath_devno), dev_name(dev));
index a6da860362fc5bb566e027e6c702768ca95d18ca..76a6df872b244a7fd3477930b3a26074c05951e5 100644 (file)
@@ -183,7 +183,7 @@ static int _accept_p(struct cmd_context *cmd, struct dev_filter *f, struct devic
                if (m >= 0) {
                        if (dm_bit(rf->accept, m)) {
                                if (!first && !cmd->filter_regex_set_preferred_name_disable)
-                                       dev_set_preferred_name(sl, dev);
+                                       dev_set_preferred_name(cmd, sl, dev);
 
                                return 1;
                        }
index 6310722cea3d6be2a13a9e33f0d49ec229b0eb57..c47b2e36c72312405fd595e3b4f9396f74043381 100644 (file)
@@ -499,7 +499,7 @@ int validate_hints(struct cmd_context *cmd, struct dm_list *hints)
         * became stale somehow (e.g. manually copying devices with dd) and
         * need to be refreshed.
         */
-       if (!(iter = dev_iter_create(NULL, 0)))
+       if (!(iter = dev_iter_create(cmd, NULL, 0)))
                return 0;
        while ((dev = dev_iter_get(cmd, iter))) {
                if (dm_list_empty(&dev->aliases))
@@ -877,7 +877,7 @@ static int _read_hint_file(struct cmd_context *cmd, struct dm_list *hints, int *
        /*
         * Calculate and compare hash of devices that may be scanned.
         */
-       if (!(iter = dev_iter_create(NULL, 0)))
+       if (!(iter = dev_iter_create(cmd, NULL, 0)))
                return 0;
        while ((dev = dev_iter_get(cmd, iter))) {
                if (cmd->enable_devices_file && !get_du_for_dev(cmd, dev))
@@ -1049,7 +1049,7 @@ int write_hint_file(struct cmd_context *cmd, int newhints)
         * dev flagged DEV_SCAN_FOUND_LABEL
         */
 
-       if (!(iter = dev_iter_create(NULL, 0))) {
+       if (!(iter = dev_iter_create(cmd, NULL, 0))) {
                ret = 0;
                goto out_close;
        }
index dd67111448275808fd4df3a54ea85ca965cd6e4e..93a0b577dcd1c0ebb06b18da60b5c3d824275022 100644 (file)
@@ -537,8 +537,8 @@ static int _scan_dev_open(struct device *dev)
                         */
                        log_debug("Drop alias for %u:%u failed open %s (%d).",
                                  MAJOR(dev->dev), MINOR(dev->dev), name, errno);
-                       dev_cache_failed_path(dev, name);
-                       dev_cache_verify_aliases(dev);
+                       dev_cache_failed_path(dev->cmd, dev, name);
+                       dev_cache_verify_aliases(dev->cmd, dev);
                        goto next_name;
                }
        }
@@ -548,8 +548,8 @@ static int _scan_dev_open(struct device *dev)
                log_warn("Invalid path %s for device %u:%u, trying different path.",
                         name, MAJOR(dev->dev), MINOR(dev->dev));
                (void)close(fd);
-               dev_cache_failed_path(dev, name);
-               dev_cache_verify_aliases(dev);
+               dev_cache_failed_path(dev->cmd, dev, name);
+               dev_cache_verify_aliases(dev->cmd, dev);
                goto next_name;
        }
 
@@ -899,7 +899,7 @@ int label_scan_for_pvid(struct cmd_context *cmd, char *pvid, struct device **dev
         * pass filters, and are those we can use.
         */
 
-       if (!(iter = dev_iter_create(cmd->filter, 0))) {
+       if (!(iter = dev_iter_create(cmd, cmd->filter, 0))) {
                log_error("Scanning failed to get devices.");
                return 0;
        }
@@ -1046,7 +1046,7 @@ int label_scan_vg_online(struct cmd_context *cmd, const char *vgname,
                dm_list_iterate_items(po, &pvs_online) {
                        if (po->dev)
                                continue;
-                       if (!(po->dev = dev_cache_get_by_devt(cmd, po->devno))) {
+                       if (!(po->dev = dev_cache_get_by_devno(cmd, po->devno))) {
                                log_error("No device found for %u:%u PVID %s.",
                                          MAJOR(po->devno), MINOR(po->devno), po->pvid);
                                goto bad;
@@ -1263,7 +1263,7 @@ int label_scan(struct cmd_context *cmd)
         * here, before processing the hints file, so that the dm uuid checks
         * in hint processing can benefit from the dm uuid cache.)
         */
-       if (!dm_devs_cache_update())
+       if (!dm_devs_cache_update(cmd))
                return_0;
 
        /*
@@ -1288,7 +1288,7 @@ int label_scan(struct cmd_context *cmd)
         */
        if (cmd->md_component_detection && !cmd->use_full_md_check &&
            !strcmp(cmd->md_component_checks, "auto") &&
-           dev_cache_has_md_with_end_superblock(cmd->dev_types)) {
+           dev_cache_has_md_with_end_superblock(cmd, cmd->dev_types)) {
                log_debug("Enable full md component check.");
                cmd->use_full_md_check = 1;
        }
@@ -1299,7 +1299,7 @@ int label_scan(struct cmd_context *cmd)
         * Invalidate bcache data for all devs (there will usually be no bcache
         * data to invalidate.)
         */
-       if (!(iter = dev_iter_create(NULL, 0))) {
+       if (!(iter = dev_iter_create(cmd, NULL, 0))) {
                log_error("Failed to get device list.");
                return 0;
        }
@@ -1652,7 +1652,7 @@ void label_scan_invalidate_lv(struct cmd_context *cmd, struct logical_volume *lv
        if (lv_info(cmd, lv, 0, &lvinfo, 0, 0) && lvinfo.exists) {
                /* FIXME: Still unclear what is it supposed to find */
                devt = MKDEV(lvinfo.major, lvinfo.minor);
-               if ((dev = dev_cache_get_by_devt(cmd, devt)))
+               if ((dev = dev_cache_get_by_devno(cmd, devt)))
                        label_scan_invalidate(dev);
        }
 }
@@ -1670,7 +1670,7 @@ void label_scan_invalidate_lvs(struct cmd_context *cmd, struct dm_list *lvs)
 
        log_debug("Invalidating devs for any PVs on LVs.");
 
-       if (dm_devs_cache_use())
+       if (dm_devs_cache_use(cmd))
                dm_devs_cache_label_invalidate(cmd);
        else {
                dm_list_iterate_items(lvl, lvs)
@@ -1688,7 +1688,7 @@ void label_scan_drop(struct cmd_context *cmd)
        struct dev_iter *iter;
        struct device *dev;
 
-       if (!(iter = dev_iter_create(NULL, 0)))
+       if (!(iter = dev_iter_create(cmd, NULL, 0)))
                return;
 
        while ((dev = dev_iter_get(cmd, iter))) {
index b3ca1afcca1a0ae94bcbbc9f5a509d365e067f01..cbbf1b861d1e2928bd1b01d13b70d76ceae77603 100644 (file)
@@ -330,7 +330,7 @@ int vg_write_lock_held(void)
 
 int sync_local_dev_names(struct cmd_context* cmd)
 {
-       dm_devs_cache_destroy();
+       dm_devs_cache_destroy(cmd);
        memlock_unlock(cmd);
        fs_unlock();
        return 1;
index d21df54c582148ae56e9af1c2140be4fad8bb859..7d311a3a8be1ab86e7b5a88d75d4e5e6289658a4 100644 (file)
@@ -3353,7 +3353,7 @@ int vg_missing_pv_count(const struct volume_group *vg)
 
 #define DEV_LIST_DELIM ", "
 
-static int _check_devs_used_correspond_with_lv(struct dm_pool *mem, struct dm_list *list, struct logical_volume *lv)
+static int _check_devs_used_correspond_with_lv(struct cmd_context *cmd, struct dm_pool *mem, struct dm_list *list, struct logical_volume *lv)
 {
        struct device_list *dl;
        int found_inconsistent = 0;
@@ -3363,7 +3363,7 @@ static int _check_devs_used_correspond_with_lv(struct dm_pool *mem, struct dm_li
        int warned_about_no_dev = 0;
        char *used_devnames = NULL, *assumed_devnames = NULL;
 
-       if (!(list = dev_cache_get_dev_list_for_lvid(lv->lvid.s + ID_LEN)))
+       if (!(list = dev_cache_get_dev_list_for_lvid(cmd, lv->lvid.s + ID_LEN)))
                return 1;
 
        dm_list_iterate_items(dl, list) {
@@ -3429,7 +3429,7 @@ static int _check_devs_used_correspond_with_lv(struct dm_pool *mem, struct dm_li
        return 1;
 }
 
-static int _check_devs_used_correspond_with_vg(struct volume_group *vg)
+static int _check_devs_used_correspond_with_vg(struct cmd_context *cmd, struct volume_group *vg)
 {
        struct dm_pool *mem;
        char vgid[ID_LEN + 1] __attribute__((aligned(8)));
@@ -3458,7 +3458,7 @@ static int _check_devs_used_correspond_with_vg(struct volume_group *vg)
                pvl->pv->dev->flags |= DEV_ASSUMED_FOR_LV;
        }
 
-       if (!(list = dev_cache_get_dev_list_for_vgid(vgid)))
+       if (!(list = dev_cache_get_dev_list_for_vgid(cmd, vgid)))
                return 1;
 
        dm_list_iterate_items(dl, list) {
@@ -3474,7 +3474,7 @@ static int _check_devs_used_correspond_with_vg(struct volume_group *vg)
                        return_0;
 
                dm_list_iterate_items(lvl, &vg->lvs) {
-                       if (!_check_devs_used_correspond_with_lv(mem, list, lvl->lv)) {
+                       if (!_check_devs_used_correspond_with_lv(cmd, mem, list, lvl->lv)) {
                                dm_pool_destroy(mem);
                                return_0;
                        }
@@ -5092,7 +5092,7 @@ struct volume_group *vg_read(struct cmd_context *cmd, const char *vg_name, const
                log_warn("WARNING: One or more devices used as PVs in VG %s have changed sizes.", vg->name);
 
        if (cmd->check_devs_used)
-               _check_devs_used_correspond_with_vg(vg);
+               _check_devs_used_correspond_with_vg(cmd, vg);
 
        if (!_access_vg_lock_type(cmd, vg, lockd_state, &failure)) {
                /* Either FAILED_LOCK_TYPE or FAILED_LOCK_MODE were set. */
index 475bd37a9dd23a4bee44b73755ae5ab24018d0ff..a97bd69e67a6851922de1455cbde63d2623c509e 100644 (file)
@@ -40,7 +40,7 @@ static void _search_devs_for_pvids(struct cmd_context *cmd, struct dm_list *sear
         * any filters, since we do not want filters to read any of the
         * devices yet.
         */
-       if (!(iter = dev_iter_create(NULL, 0)))
+       if (!(iter = dev_iter_create(cmd, NULL, 0)))
                return;
        while ((dev = dev_iter_get(cmd, iter))) {
                /* Skip devs with a valid match to a du. */
@@ -697,7 +697,7 @@ int lvmdevices(struct cmd_context *cmd, int argc, char **argv)
                        if (update_set)
                                dm_list_del(&du->list);
 
-                       if (!(mpath_dev = dev_cache_get_by_devt(cmd, mpath_devno)))
+                       if (!(mpath_dev = dev_cache_get_by_devno(cmd, mpath_devno)))
                                continue;
 
                        if (!get_du_for_dev(cmd, mpath_dev)) {
index bd7d9cec10581bbf40052909aa985d773706b43f..869423bd681cdb6b6faaa79dcebb9c4e6757080f 100644 (file)
@@ -34,7 +34,7 @@ static int _get_max_dev_name_len(struct cmd_context *cmd, struct dev_filter *fil
        struct dev_iter *iter;
        struct device *dev;
 
-       if (!(iter = dev_iter_create(filter, 1))) {
+       if (!(iter = dev_iter_create(cmd, filter, 1))) {
                log_error("dev_iter_create failed");
                return 0;
        }
@@ -102,7 +102,7 @@ int lvmdiskscan(struct cmd_context *cmd, int argc __attribute__((unused)),
 
        _max_len = _get_max_dev_name_len(cmd, cmd->filter);
 
-       if (!(iter = dev_iter_create(cmd->filter, 0))) {
+       if (!(iter = dev_iter_create(cmd, cmd->filter, 0))) {
                log_error("dev_iter_create failed");
                return ECMD_FAILED;
        }
index 1ea5fc1ad1ddeb6117f9b30963957d4fde2a1619..08821e4d5d7daca5984fb9b70020bc14e2c3766f 100644 (file)
@@ -3033,7 +3033,7 @@ static int _pvck_mf(struct metadata_file *mf, struct cmd_context *cmd, int argc,
                }
 
                if (!(dev = dev_cache_get(cmd, pv_name, NULL))) {
-                       log_error("Cannot use %s: %s.", pv_name, devname_error_reason(pv_name));
+                       log_error("Cannot use %s: %s.", pv_name, devname_error_reason(cmd, pv_name));
                        return ECMD_FAILED;
                }
        }
@@ -3057,7 +3057,7 @@ static int _pvck_mf(struct metadata_file *mf, struct cmd_context *cmd, int argc,
                        dev = dev_cache_get(cmd, pv_name, NULL);
                }
                if (!dev && !def) {
-                       log_error("Cannot use %s: %s.", pv_name, devname_error_reason(pv_name));
+                       log_error("Cannot use %s: %s.", pv_name, devname_error_reason(cmd, pv_name));
                        return ECMD_FAILED;
                }
        }
@@ -3183,7 +3183,7 @@ static int _pvck_mf(struct metadata_file *mf, struct cmd_context *cmd, int argc,
                pv_name = argv[i];
 
                if (!(dev = dev_cache_get(cmd, argv[i], cmd->filter))) {
-                       log_error("Cannot use %s: %s.", pv_name, devname_error_reason(pv_name));
+                       log_error("Cannot use %s: %s.", pv_name, devname_error_reason(cmd, pv_name));
                        continue;
                }
 
index a093fbcf0349b0336074c20e34dd0a8f585cf9e6..e4f8c4a1b7dd62bd4b012e58b0d526186fba6e7f 100644 (file)
@@ -1385,7 +1385,7 @@ static int _pvscan_cache_all(struct cmd_context *cmd, int argc, char **argv,
         * The use of filter here will just reuse the existing
         * (persistent) filter info label_scan has already set up.
         */
-       if (!(iter = dev_iter_create(cmd->filter, 1)))
+       if (!(iter = dev_iter_create(cmd, cmd->filter, 1)))
                return_0;
 
        while ((dev = dev_iter_get(cmd, iter))) {
@@ -1461,7 +1461,7 @@ static int _pvscan_cache_args(struct cmd_context *cmd, int argc, char **argv,
 
        if (cmd->md_component_detection && !cmd->use_full_md_check &&
            !strcmp(cmd->md_component_checks, "auto") &&
-           dev_cache_has_md_with_end_superblock(cmd->dev_types)) {
+           dev_cache_has_md_with_end_superblock(cmd, cmd->dev_types)) {
                log_debug("Enable full md component check.");
                cmd->use_full_md_check = 1;
        }
index 62cc5cf650a8a5507cf9c285eff0c62a04aa749f..50e05eb09ced9adcb967c9db512ebd7f70177e1e 100644 (file)
@@ -1777,7 +1777,7 @@ int process_each_label(struct cmd_context *cmd, int argc, char **argv,
                goto out;
        }
 
-       if (!(iter = dev_iter_create(cmd->filter, 1))) {
+       if (!(iter = dev_iter_create(cmd, cmd->filter, 1))) {
                log_error("dev_iter creation failed.");
                ret_max = ECMD_FAILED;
                goto out;
@@ -4201,7 +4201,7 @@ static int _get_arg_devices(struct cmd_context *cmd,
                }
 
                if (!(dil->dev = dev_cache_get_existing(cmd, sl->str, cmd->filter))) {
-                       log_error("Cannot use %s: %s", sl->str, devname_error_reason(sl->str));
+                       log_error("Cannot use %s: %s", sl->str, devname_error_reason(cmd, sl->str));
                        ret_max = EINIT_FAILED;
                } else {
                        memcpy(dil->pvid, dil->dev->pvid, ID_LEN);
@@ -4235,7 +4235,7 @@ static int _process_other_devices(struct cmd_context *cmd,
         * was set by label_scan which did filtering.
         */
 
-       if (!(iter = dev_iter_create(NULL, 0)))
+       if (!(iter = dev_iter_create(cmd, NULL, 0)))
                return_0;
 
        while ((dev = dev_iter_get(cmd, iter))) {
@@ -5578,7 +5578,7 @@ int pvcreate_each_device(struct cmd_context *cmd,
         */
        dm_list_iterate_items_safe(pd, pd2, &pp->arg_devices) {
                if (!cmd->filter->passes_filter(cmd, cmd->filter, pd->dev, NULL)) {
-                       log_error("Cannot use %s: %s", pd->name, devname_error_reason(pd->name));
+                       log_error("Cannot use %s: %s", pd->name, devname_error_reason(cmd, pd->name));
                        dm_list_del(&pd->list);
                        dm_list_add(&pp->arg_fail, &pd->list);
                }
@@ -5804,7 +5804,7 @@ do_command:
 
        dm_list_iterate_items_safe(pd, pd2, &pp->arg_process) {
                if (!cmd->filter->passes_filter(cmd, cmd->filter, pd->dev, NULL)) {
-                       log_error("Cannot use %s: %s", pd->name, devname_error_reason(pd->name));
+                       log_error("Cannot use %s: %s", pd->name, devname_error_reason(cmd, pd->name));
                        dm_list_del(&pd->list);
                        dm_list_add(&pp->arg_fail, &pd->list);
                }
index f1852cda292c9e9de24e076a1d933997e952e901..0d07ce6bc143f1be2b1b7b29ae87b22a66cd60bc 100644 (file)
@@ -177,7 +177,7 @@ static int _get_other_devs(struct cmd_context *cmd, struct dm_list *new_devs, st
        struct device_list *devl;
        int r = 1;
 
-       if (!(iter = dev_iter_create(cmd->filter, 0)))
+       if (!(iter = dev_iter_create(cmd, cmd->filter, 0)))
                return_0;
 
        while ((dev = dev_iter_get(cmd, iter))) {
This page took 0.120024 seconds and 5 git commands to generate.