summaryrefslogtreecommitdiffstats
path: root/cddl/contrib/opensolaris/cmd
diff options
context:
space:
mode:
authorasomers <asomers@FreeBSD.org>2017-10-25 15:18:09 +0000
committerasomers <asomers@FreeBSD.org>2017-10-25 15:18:09 +0000
commitdbbb14eda4decfde0f71a548f7f5bdb867890339 (patch)
tree1eeb75c5302be28d31ad93f752d35fe1b9add0b1 /cddl/contrib/opensolaris/cmd
parent873cfa1bb8d17fe21c0d83d335d74d449c2ad33c (diff)
downloadFreeBSD-src-dbbb14eda4decfde0f71a548f7f5bdb867890339.zip
FreeBSD-src-dbbb14eda4decfde0f71a548f7f5bdb867890339.tar.gz
MFC r324223:
MFV r319743: 8108 zdb -l fails to read labels 2 and 3 illumos/illumos-gate@22c8b9583d07895c16549075a53668d7bc988cf3 https://github.com/illumos/illumos-gate/commit/22c8b9583d07895c16549075a53668d7bc988cf3 https://www.illumos.org/issues/8108 Reviewed by: Matthew Ahrens <mahrens@delphix.com> Reviewed by: Toomas Soome <tsoome@me.com> Reviewed by: Igor Kozhukhov <igor@dilos.org> Reviewed by: Andrew Stormont <andyjstormont@gmail.com> Approved by: Robert Mustacchi <rm@joyent.com> Author: Yuri Pankov <yuri.pankov@nexenta.com>
Diffstat (limited to 'cddl/contrib/opensolaris/cmd')
-rw-r--r--cddl/contrib/opensolaris/cmd/zdb/zdb.c21
1 files changed, 13 insertions, 8 deletions
diff --git a/cddl/contrib/opensolaris/cmd/zdb/zdb.c b/cddl/contrib/opensolaris/cmd/zdb/zdb.c
index 5176efa..454d2bc 100644
--- a/cddl/contrib/opensolaris/cmd/zdb/zdb.c
+++ b/cddl/contrib/opensolaris/cmd/zdb/zdb.c
@@ -2186,24 +2186,29 @@ dump_label(const char *dev)
(void) snprintf(path, sizeof (path), "%s%s", ZFS_RDISK_ROOTD,
dev);
- if ((s = strrchr(dev, 's')) == NULL || !isdigit(*(s + 1)))
+ if (((s = strrchr(dev, 's')) == NULL &&
+ (s = strchr(dev, 'p')) == NULL) ||
+ !isdigit(*(s + 1)))
(void) strlcat(path, "s0", sizeof (path));
}
- if (stat64(path, &statbuf) != 0) {
- (void) printf("failed to stat '%s': %s\n", path,
+ if ((fd = open64(path, O_RDONLY)) < 0) {
+ (void) fprintf(stderr, "cannot open '%s': %s\n", path,
strerror(errno));
exit(1);
}
- if (S_ISBLK(statbuf.st_mode)) {
- (void) printf("cannot use '%s': character device required\n",
- path);
+ if (fstat64(fd, &statbuf) != 0) {
+ (void) fprintf(stderr, "failed to stat '%s': %s\n", path,
+ strerror(errno));
+ (void) close(fd);
exit(1);
}
- if ((fd = open64(path, O_RDONLY)) < 0) {
- (void) printf("cannot open '%s': %s\n", path, strerror(errno));
+ if (S_ISBLK(statbuf.st_mode)) {
+ (void) fprintf(stderr,
+ "cannot use '%s': character device required\n", path);
+ (void) close(fd);
exit(1);
}
OpenPOWER on IntegriCloud