1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-04 09:18:36 +03:00

Fix error handling of device-related stat() calls to be ENOENT aware.

Signed-off-by: Mike Snitzer <snitzer@redhat.com>
This commit is contained in:
Mike Snitzer 2009-08-01 17:14:52 +00:00
parent e92d56a94d
commit 098c16c9df
2 changed files with 23 additions and 6 deletions

View File

@ -151,7 +151,11 @@ check_md_major:
return ret; return ret;
} }
if (stat(path, &info) < 0) { if (stat(path, &info) == -1) {
if (errno != ENOENT) {
log_sys_error("stat", path);
return ret;
}
/* old sysfs structure */ /* old sysfs structure */
ret = dm_snprintf(path, size, "%s/block/md%d/md/%s", ret = dm_snprintf(path, size, "%s/block/md%d/md/%s",
sysfs_dir, (int)MINOR(dev), attribute); sysfs_dir, (int)MINOR(dev), attribute);

View File

@ -304,8 +304,11 @@ int get_primary_dev(const char *sysfs_dir,
return ret; return ret;
} }
if (stat(path, &info) < 0) if (stat(path, &info) == -1) {
if (errno != ENOENT)
log_sys_error("stat", path);
return ret; return ret;
}
/* /*
* extract parent's path from the partition's symlink, e.g.: * extract parent's path from the partition's symlink, e.g.:
@ -326,8 +329,11 @@ int get_primary_dev(const char *sysfs_dir,
} }
/* finally, parse 'dev' attribute and create corresponding dev_t */ /* finally, parse 'dev' attribute and create corresponding dev_t */
if (stat(path, &info) < 0) { if (stat(path, &info) == -1) {
if (errno == ENOENT)
log_error("sysfs file %s does not exist", path); log_error("sysfs file %s does not exist", path);
else
log_sys_error("stat", path);
return ret; return ret;
} }
@ -386,7 +392,11 @@ static unsigned long _dev_topology_attribute(const char *attribute,
* - if not: either the kernel doesn't have topology support * - if not: either the kernel doesn't have topology support
* or the device could be a partition * or the device could be a partition
*/ */
if (stat(path, &info) < 0) { if (stat(path, &info) == -1) {
if (errno != ENOENT) {
log_sys_error("stat", path);
return 0;
}
if (!get_primary_dev(sysfs_dir, dev, &primary)) if (!get_primary_dev(sysfs_dir, dev, &primary))
return 0; return 0;
@ -397,9 +407,12 @@ static unsigned long _dev_topology_attribute(const char *attribute,
log_error("primary dm_snprintf %s failed", attribute); log_error("primary dm_snprintf %s failed", attribute);
return 0; return 0;
} }
if (stat(path, &info) < 0) if (stat(path, &info) == -1) {
if (errno != ENOENT)
log_sys_error("stat", path);
return 0; return 0;
} }
}
if (!(fp = fopen(path, "r"))) { if (!(fp = fopen(path, "r"))) {
log_sys_error("fopen", path); log_sys_error("fopen", path);