44 lines
1.3 KiB
Diff
44 lines
1.3 KiB
Diff
From: Keith Mannthey <kmannth@us.ibm.com>
|
|
Date: Tue, 29 Nov 2011 17:44:12 -0800
|
|
Patch-mainline: pending
|
|
References: FATE#306586 bnc#724620
|
|
Subject: [PATCH] Sector Size check during Mount
|
|
|
|
Gracefully fail when trying to mount a BTRFS file system that has a
|
|
sectorsize smaller than PAGE_SIZE.
|
|
|
|
On PPC it is possible to build a FS while using a 4k PAGE_SIZE kernel
|
|
then boot into a 64K PAGE_SIZE kernel. Presently open_ctree fails in an
|
|
endless loop and hangs the machine in this situation.
|
|
|
|
My debugging has show this Sector size < Page size to be a non trivial
|
|
situation and a graceful exit from the situation would be nice for the
|
|
time being.
|
|
|
|
Signed-off-by: Keith Mannthey <kmannth@us.ibm.com>
|
|
Signed-off-by: David Sterba <dsterba@suse.cz>
|
|
---
|
|
fs/btrfs/disk-io.c | 6 ++++++
|
|
1 files changed, 6 insertions(+), 0 deletions(-)
|
|
|
|
diff --git a/fs/btrfs/disk-io.c b/fs/btrfs/disk-io.c
|
|
index 94abc25..1cbfa75 100644
|
|
--- a/fs/btrfs/disk-io.c
|
|
+++ b/fs/btrfs/disk-io.c
|
|
@@ -2230,6 +2230,12 @@ struct btrfs_root *open_ctree(struct super_block *sb,
|
|
goto fail_sb_buffer;
|
|
}
|
|
|
|
+ if (sectorsize < PAGE_SIZE) {
|
|
+ printk(KERN_WARNING "btrfs: Incompatible sector size "
|
|
+ "found on %s\n", sb->s_id);
|
|
+ goto fail_sb_buffer;
|
|
+ }
|
|
+
|
|
mutex_lock(&fs_info->chunk_mutex);
|
|
ret = btrfs_read_sys_array(tree_root);
|
|
mutex_unlock(&fs_info->chunk_mutex);
|
|
--
|
|
1.7.6.233.gd79bc
|
|
|