summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorpfg <pfg@FreeBSD.org>2017-08-20 23:05:36 +0000
committerpfg <pfg@FreeBSD.org>2017-08-20 23:05:36 +0000
commit12f422ac2385363132e3a85971332c09f6486c25 (patch)
treef15ef49b26aa204b861926b88e08e5645b5d6b7e
parent066ae39d7ce3093b5a7a21f288921609b7e8e118 (diff)
downloadFreeBSD-src-12f422ac2385363132e3a85971332c09f6486c25.zip
FreeBSD-src-12f422ac2385363132e3a85971332c09f6486c25.tar.gz
MFC r320578:
ext2fs: be more verbose about unsupported ext2fs features. It is useful to know exactly what features may be lacking when trying to mount ext4 filesystems. Submitted by: Fedor Uporov
-rw-r--r--sys/fs/ext2fs/ext2_vfsops.c29
-rw-r--r--sys/fs/ext2fs/ext2fs.h58
2 files changed, 79 insertions, 8 deletions
diff --git a/sys/fs/ext2fs/ext2_vfsops.c b/sys/fs/ext2fs/ext2_vfsops.c
index 7bf0d26..99ae4d6 100644
--- a/sys/fs/ext2fs/ext2_vfsops.c
+++ b/sys/fs/ext2fs/ext2_vfsops.c
@@ -279,6 +279,7 @@ ext2_mount(struct mount *mp)
static int
ext2_check_sb_compat(struct ext2fs *es, struct cdev *dev, int ronly)
{
+ uint32_t i, mask;
if (es->e2fs_magic != E2FS_MAGIC) {
printf("ext2fs: %s: wrong magic number %#x (expected %#x)\n",
@@ -286,17 +287,29 @@ ext2_check_sb_compat(struct ext2fs *es, struct cdev *dev, int ronly)
return (1);
}
if (es->e2fs_rev > E2FS_REV0) {
- if (es->e2fs_features_incompat & ~(EXT2F_INCOMPAT_SUPP |
- EXT4F_RO_INCOMPAT_SUPP)) {
- printf(
-"WARNING: mount of %s denied due to unsupported optional features\n",
- devtoname(dev));
+ mask = es->e2fs_features_incompat & ~(EXT2F_INCOMPAT_SUPP |
+ EXT4F_RO_INCOMPAT_SUPP);
+ if (mask) {
+ printf("WARNING: mount of %s denied due to "
+ "unsupported optional features:\n", devtoname(dev));
+ for (i = 0;
+ i < sizeof(incompat)/sizeof(struct ext2_feature);
+ i++)
+ if (mask & incompat[i].mask)
+ printf("%s ", incompat[i].name);
+ printf("\n");
return (1);
}
- if (!ronly &&
- (es->e2fs_features_rocompat & ~EXT2F_ROCOMPAT_SUPP)) {
+ mask = es->e2fs_features_rocompat & ~EXT2F_ROCOMPAT_SUPP;
+ if (!ronly && mask) {
printf("WARNING: R/W mount of %s denied due to "
- "unsupported optional features\n", devtoname(dev));
+ "unsupported optional features:\n", devtoname(dev));
+ for (i = 0;
+ i < sizeof(ro_compat)/sizeof(struct ext2_feature);
+ i++)
+ if (mask & ro_compat[i].mask)
+ printf("%s ", ro_compat[i].name);
+ printf("\n");
return (1);
}
}
diff --git a/sys/fs/ext2fs/ext2fs.h b/sys/fs/ext2fs/ext2fs.h
index 32da339..709c826 100644
--- a/sys/fs/ext2fs/ext2fs.h
+++ b/sys/fs/ext2fs/ext2fs.h
@@ -203,10 +203,13 @@ struct csum {
* compatible/incompatible features
*/
#define EXT2F_COMPAT_PREALLOC 0x0001
+#define EXT2F_COMPAT_IMAGIC_INODES 0x0002
#define EXT2F_COMPAT_HASJOURNAL 0x0004
#define EXT2F_COMPAT_EXT_ATTR 0x0008
#define EXT2F_COMPAT_RESIZE 0x0010
#define EXT2F_COMPAT_DIRHASHINDEX 0x0020
+#define EXT2F_COMPAT_LAZY_BG 0x0040
+#define EXT2F_COMPAT_EXCLUDE_BITMAP 0x0100
#define EXT2F_COMPAT_SPARSESUPER2 0x0200
#define EXT2F_ROCOMPAT_SPARSESUPER 0x0001
@@ -216,15 +219,18 @@ struct csum {
#define EXT2F_ROCOMPAT_GDT_CSUM 0x0010
#define EXT2F_ROCOMPAT_DIR_NLINK 0x0020
#define EXT2F_ROCOMPAT_EXTRA_ISIZE 0x0040
+#define EXT2F_ROCOMPAT_HAS_SNAPSHOT 0x0080
#define EXT2F_ROCOMPAT_QUOTA 0x0100
#define EXT2F_ROCOMPAT_BIGALLOC 0x0200
#define EXT2F_ROCOMPAT_METADATA_CKSUM 0x0400
+#define EXT2F_ROCOMPAT_REPLICA 0x0800
#define EXT2F_ROCOMPAT_READONLY 0x1000
#define EXT2F_ROCOMPAT_PROJECT 0x2000
#define EXT2F_INCOMPAT_COMP 0x0001
#define EXT2F_INCOMPAT_FTYPE 0x0002
#define EXT2F_INCOMPAT_RECOVER 0x0004
+#define EXT2F_INCOMPAT_JOURNAL_DEV 0x0008
#define EXT2F_INCOMPAT_META_BG 0x0010
#define EXT2F_INCOMPAT_EXTENTS 0x0040
#define EXT2F_INCOMPAT_64BIT 0x0080
@@ -237,6 +243,58 @@ struct csum {
#define EXT2F_INCOMPAT_INLINE_DATA 0x8000
#define EXT2F_INCOMPAT_ENCRYPT 0x10000
+struct ext2_feature
+{
+ int mask;
+ const char *name;
+};
+
+static const struct ext2_feature compat[] = {
+ { EXT2F_COMPAT_PREALLOC, "dir_prealloc" },
+ { EXT2F_COMPAT_IMAGIC_INODES, "imagic_inodes" },
+ { EXT2F_COMPAT_HASJOURNAL, "has_journal" },
+ { EXT2F_COMPAT_EXT_ATTR, "ext_attr" },
+ { EXT2F_COMPAT_RESIZE, "resize_inode" },
+ { EXT2F_COMPAT_DIRHASHINDEX, "dir_index" },
+ { EXT2F_COMPAT_EXCLUDE_BITMAP, "snapshot_bitmap" },
+ { EXT2F_COMPAT_SPARSESUPER2, "sparse_super2" }
+};
+
+static const struct ext2_feature ro_compat[] = {
+ { EXT2F_ROCOMPAT_SPARSESUPER, "sparse_super" },
+ { EXT2F_ROCOMPAT_LARGEFILE, "large_file" },
+ { EXT2F_ROCOMPAT_BTREE_DIR, "btree_dir" },
+ { EXT2F_ROCOMPAT_HUGE_FILE, "huge_file" },
+ { EXT2F_ROCOMPAT_GDT_CSUM, "uninit_groups" },
+ { EXT2F_ROCOMPAT_DIR_NLINK, "dir_nlink" },
+ { EXT2F_ROCOMPAT_EXTRA_ISIZE, "extra_isize" },
+ { EXT2F_ROCOMPAT_HAS_SNAPSHOT, "snapshot" },
+ { EXT2F_ROCOMPAT_QUOTA, "quota" },
+ { EXT2F_ROCOMPAT_BIGALLOC, "bigalloc" },
+ { EXT2F_ROCOMPAT_METADATA_CKSUM, "metadata_csum" },
+ { EXT2F_ROCOMPAT_REPLICA, "replica" },
+ { EXT2F_ROCOMPAT_READONLY, "ro" },
+ { EXT2F_ROCOMPAT_PROJECT, "project" }
+};
+
+static const struct ext2_feature incompat[] = {
+ { EXT2F_INCOMPAT_COMP, "compression" },
+ { EXT2F_INCOMPAT_FTYPE, "filetype" },
+ { EXT2F_INCOMPAT_RECOVER, "needs_recovery" },
+ { EXT2F_INCOMPAT_JOURNAL_DEV, "journal_dev" },
+ { EXT2F_INCOMPAT_META_BG, "meta_bg" },
+ { EXT2F_INCOMPAT_EXTENTS, "extents" },
+ { EXT2F_INCOMPAT_64BIT, "64bit" },
+ { EXT2F_INCOMPAT_MMP, "mmp" },
+ { EXT2F_INCOMPAT_FLEX_BG, "flex_bg" },
+ { EXT2F_INCOMPAT_EA_INODE, "ea_inode" },
+ { EXT2F_INCOMPAT_DIRDATA, "dirdata" },
+ { EXT2F_INCOMPAT_CSUM_SEED, "metadata_csum_seed" },
+ { EXT2F_INCOMPAT_LARGEDIR, "large_dir" },
+ { EXT2F_INCOMPAT_INLINE_DATA, "inline_data" },
+ { EXT2F_INCOMPAT_ENCRYPT, "encrypt" }
+};
+
/*
* Features supported in this implementation
*
OpenPOWER on IntegriCloud