cfg_array(devices_scan_CFG, "scan", devices_CFG_SECTION, CFG_ADVANCED, CFG_TYPE_STRING, "#S/dev", vsn(1, 0, 0), NULL, 0, NULL,
"Directories containing device nodes to use with LVM.\n")
-cfg_array(devices_loopfiles_CFG, "loopfiles", devices_CFG_SECTION, CFG_DEFAULT_UNDEFINED | CFG_UNSUPPORTED, CFG_TYPE_STRING, NULL, vsn(1, 2, 0), NULL, 0, NULL, NULL)
+cfg_array(devices_loopfiles_CFG, "loopfiles", devices_CFG_SECTION, CFG_DEFAULT_UNDEFINED | CFG_UNSUPPORTED, CFG_TYPE_STRING, NULL, vsn(1, 2, 0), NULL, vsn(3, 0, 0), NULL, NULL)
cfg(devices_obtain_device_list_from_udev_CFG, "obtain_device_list_from_udev", devices_CFG_SECTION, 0, CFG_TYPE_BOOL, DEFAULT_OBTAIN_DEVICE_LIST_FROM_UDEV, vsn(2, 2, 85), NULL, 0, NULL,
"Obtain the list of available devices from udev.\n"
struct device *dev;
struct device *dev_by_devt;
struct device *dev_by_path;
- static dev_t loopfile_count = 0;
- int loopfile = 0;
char *path_copy;
- /* Generate pretend device numbers for loopfiles */
- if (!d) {
- if (dm_hash_lookup(_cache.names, path))
- return 1;
- d = ++loopfile_count;
- loopfile = 1;
- }
-
dev_by_devt = (struct device *) btree_lookup(_cache.devices, (uint32_t) d);
dev_by_path = (struct device *) dm_hash_lookup(_cache.names, path);
dev = dev_by_devt;
if (!(dev = (struct device *) btree_lookup(_cache.sysfs_only_devices, (uint32_t) d))) {
/* create new device */
- if (loopfile) {
- if (!(dev = dev_create_file(path, NULL, NULL, 0)))
- return_0;
- } else if (!(dev = _dev_create(d)))
+ if (!(dev = _dev_create(d)))
return_0;
}
return 0;
}
- if (!loopfile && !_add_alias(dev, path_copy)) {
+ if (!_add_alias(dev, path_copy)) {
log_error("Couldn't add alias to dev cache.");
return 0;
}
return 0;
}
- if (!loopfile && !_add_alias(dev, path_copy)) {
+ if (!_add_alias(dev, path_copy)) {
log_error("Couldn't add alias to dev cache.");
return 0;
}
if (!(dev = (struct device *) btree_lookup(_cache.sysfs_only_devices, (uint32_t) d))) {
/* create new device */
- if (loopfile) {
- if (!(dev = dev_create_file(path, NULL, NULL, 0)))
- return_0;
- } else if (!(dev = _dev_create(d)))
+ if (!(dev = _dev_create(d)))
return_0;
}
return 0;
}
- if (!loopfile && !_add_alias(dev, path_copy)) {
+ if (!_add_alias(dev, path_copy)) {
log_error("Couldn't add alias to dev cache.");
return 0;
}
return 0;
}
- if (!loopfile && !_add_alias(dev, path_copy)) {
+ if (!_add_alias(dev, path_copy)) {
log_error("Couldn't add alias to dev cache.");
return 0;
}
return r;
}
-static int _insert_file(const char *path)
-{
- struct stat info;
-
- if (stat(path, &info) < 0) {
- log_sys_very_verbose("stat", path);
- return 0;
- }
-
- if (!S_ISREG(info.st_mode)) {
- log_debug_devs("%s: Not a regular file", path);
- return 0;
- }
-
- if (!_insert_dev(path, 0))
- return_0;
-
- return 1;
-}
-
static int _dev_cache_iterate_devs_for_index(void)
{
struct btree_iter *iter = btree_first(_cache.devices);
void dev_cache_scan(void)
{
- struct dir_list *dl;
-
log_debug_devs("Creating list of system devices.");
_cache.has_scanned = 1;
_insert_dirs(&_cache.dirs);
(void) dev_cache_index_devs();
-
- dm_list_iterate_items(dl, &_cache.files)
- _insert_file(dl->dir);
}
int dev_cache_has_scanned(void)
}
dm_list_init(&_cache.dirs);
- dm_list_init(&_cache.files);
if (!_init_preferred_names(cmd))
goto_bad;
return 1;
}
-int dev_cache_add_loopfile(const char *path)
-{
- struct dir_list *dl;
- struct stat st;
-
- if (stat(path, &st)) {
- log_warn("Ignoring %s: %s.", path, strerror(errno));
- /* But don't fail */
- return 1;
- }
-
- if (!S_ISREG(st.st_mode)) {
- log_warn("Ignoring %s: Not a regular file.", path);
- return 1;
- }
-
- if (!(dl = _zalloc(sizeof(*dl) + strlen(path) + 1))) {
- log_error("dir_list allocation failed for file");
- return 0;
- }
-
- strcpy(dl->dir, path);
- dm_list_add(&_cache.files, &dl->list);
- return 1;
-}
-
/* Check cached device name is still valid before returning it */
/* This should be a rare occurrence */
/* set quiet if the cache is expected to be out-of-date */