From ef99736c602321824fc03b4c421d20890805bcdf Mon Sep 17 00:00:00 2001 From: Qu Wenruo Date: Tue, 5 Nov 2024 08:20:55 +1030 Subject: [PATCH] btrfs-fuse: add extra error messages for device scan failure There is a report about a weird -EACCESS failure mountting a partition, add extra debugging for it. Issue: #10 Signed-off-by: Qu Wenruo --- volumes.c | 17 ++++++++++++++--- 1 file changed, 14 insertions(+), 3 deletions(-) diff --git a/volumes.c b/volumes.c index 3fbedd8..712618c 100644 --- a/volumes.c +++ b/volumes.c @@ -225,14 +225,22 @@ int btrfs_scan_device(const char *path, struct btrfs_super_block *sb) int fd; fd = open(path, O_RDONLY); - if (fd < 0) + if (fd < 0) { + error("failed to open '%s': %m", path); return -errno; + } ret = btrfs_read_from_disk(fd, (char *)&buf, BTRFS_SUPER_INFO_OFFSET, BTRFS_SUPER_INFO_SIZE); if (ret < BTRFS_SUPER_INFO_SIZE) { - if (ret > 0) + if (ret >= 0) { + error("failed to read super block: short read, expect %d got %d bytes", + BTRFS_SUPER_INFO_SIZE, ret); ret = -EIO; + } else { + errno = -ret; + error("failed to read super block: %m"); + } goto out; } @@ -242,8 +250,11 @@ int btrfs_scan_device(const char *path, struct btrfs_super_block *sb) devid = btrfs_stack_device_id(&buf.dev_item); ret = global_add_device(path, buf.fsid, buf.dev_item.uuid, devid); - if (ret < 0) + if (ret < 0) { + errno = -ret; + error("failed to add device '%s': %m", path); goto out; + } if (sb) memcpy(sb, &buf, BTRFS_SUPER_INFO_SIZE); out: