Commit 9e6766cc authored by Duane Griffin's avatar Duane Griffin Committed by Al Viro

ufs: validate maximum fast symlink size from superblock

The maximum fast symlink size is set in the superblock of certain types
of UFS filesystem. Before using it we need to check that it isn't longer
than the available space we have in the inode.
Signed-off-by: default avatarDuane Griffin <duaneg@dghda.com>
Signed-off-by: default avatarAl Viro <viro@zeniv.linux.org.uk>
parent c8fe8f30
...@@ -636,6 +636,7 @@ static int ufs_fill_super(struct super_block *sb, void *data, int silent) ...@@ -636,6 +636,7 @@ static int ufs_fill_super(struct super_block *sb, void *data, int silent)
unsigned block_size, super_block_size; unsigned block_size, super_block_size;
unsigned flags; unsigned flags;
unsigned super_block_offset; unsigned super_block_offset;
unsigned maxsymlen;
int ret = -EINVAL; int ret = -EINVAL;
uspi = NULL; uspi = NULL;
...@@ -1069,6 +1070,16 @@ static int ufs_fill_super(struct super_block *sb, void *data, int silent) ...@@ -1069,6 +1070,16 @@ static int ufs_fill_super(struct super_block *sb, void *data, int silent)
uspi->s_maxsymlinklen = uspi->s_maxsymlinklen =
fs32_to_cpu(sb, usb3->fs_un2.fs_44.fs_maxsymlinklen); fs32_to_cpu(sb, usb3->fs_un2.fs_44.fs_maxsymlinklen);
if (uspi->fs_magic == UFS2_MAGIC)
maxsymlen = 2 * 4 * (UFS_NDADDR + UFS_NINDIR);
else
maxsymlen = 4 * (UFS_NDADDR + UFS_NINDIR);
if (uspi->s_maxsymlinklen > maxsymlen) {
ufs_warning(sb, __func__, "ufs_read_super: excessive maximum "
"fast symlink size (%u)\n", uspi->s_maxsymlinklen);
uspi->s_maxsymlinklen = maxsymlen;
}
inode = ufs_iget(sb, UFS_ROOTINO); inode = ufs_iget(sb, UFS_ROOTINO);
if (IS_ERR(inode)) { if (IS_ERR(inode)) {
ret = PTR_ERR(inode); ret = PTR_ERR(inode);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment