Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs
Pull UFS fixes from Al Viro: "This is just the obvious backport fodder; I'm pretty sure that there will be more - definitely so wrt performance and quite possibly correctness as well" * 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs: ufs: we need to sync inode before freeing it excessive checks in ufs_write_failed() and ufs_evict_inode() ufs_getfrag_block(): we only grab ->truncate_mutex on block creation path ufs_extend_tail(): fix the braino in calling conventions of ufs_new_fragments() ufs: set correct ->s_maxsize ufs: restore maintaining ->i_blocks fix ufs_isblockset() ufs: restore proper tail allocation
This commit is contained in:
@@ -746,6 +746,23 @@ static void ufs_put_super(struct super_block *sb)
|
||||
return;
|
||||
}
|
||||
|
||||
static u64 ufs_max_bytes(struct super_block *sb)
|
||||
{
|
||||
struct ufs_sb_private_info *uspi = UFS_SB(sb)->s_uspi;
|
||||
int bits = uspi->s_apbshift;
|
||||
u64 res;
|
||||
|
||||
if (bits > 21)
|
||||
res = ~0ULL;
|
||||
else
|
||||
res = UFS_NDADDR + (1LL << bits) + (1LL << (2*bits)) +
|
||||
(1LL << (3*bits));
|
||||
|
||||
if (res >= (MAX_LFS_FILESIZE >> uspi->s_bshift))
|
||||
return MAX_LFS_FILESIZE;
|
||||
return res << uspi->s_bshift;
|
||||
}
|
||||
|
||||
static int ufs_fill_super(struct super_block *sb, void *data, int silent)
|
||||
{
|
||||
struct ufs_sb_info * sbi;
|
||||
@@ -1211,6 +1228,7 @@ magic_found:
|
||||
"fast symlink size (%u)\n", uspi->s_maxsymlinklen);
|
||||
uspi->s_maxsymlinklen = maxsymlen;
|
||||
}
|
||||
sb->s_maxbytes = ufs_max_bytes(sb);
|
||||
sb->s_max_links = UFS_LINK_MAX;
|
||||
|
||||
inode = ufs_iget(sb, UFS_ROOTINO);
|
||||
|
Reference in New Issue
Block a user