提交 50682bb4 编写于 作者: E Eric Sesterhenn 提交者: Linus Torvalds

bfs: check that filesystem fits on the blockdevice

Since all sanity checks rely on the validity of s_start which gets only
checked to be smaller than s_end, we should also check if s_end is sane.
Now we also try to retrieve the last block of the filesystem, which is
computed by s_end.  If this fails, something is bogus.
Signed-off-by: NEric Sesterhenn <snakebyte@gmx.de>
Acked-by: NTigran Aivazian <tigran@aivazian.fsnet.co.uk>
Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
上级 e1f89ec9
...@@ -390,6 +390,18 @@ static int bfs_fill_super(struct super_block *s, void *data, int silent) ...@@ -390,6 +390,18 @@ static int bfs_fill_super(struct super_block *s, void *data, int silent)
- le32_to_cpu(bfs_sb->s_start)) >> BFS_BSIZE_BITS; - le32_to_cpu(bfs_sb->s_start)) >> BFS_BSIZE_BITS;
info->si_freei = 0; info->si_freei = 0;
info->si_lf_eblk = 0; info->si_lf_eblk = 0;
/* can we read the last block? */
bh = sb_bread(s, info->si_blocks - 1);
if (!bh) {
printf("Last block not available: %lu\n", info->si_blocks - 1);
iput(inode);
ret = -EIO;
kfree(info->si_imap);
goto out;
}
brelse(bh);
bh = NULL; bh = NULL;
for (i = BFS_ROOT_INO; i <= info->si_lasti; i++) { for (i = BFS_ROOT_INO; i <= info->si_lasti; i++) {
struct bfs_inode *di; struct bfs_inode *di;
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册