[Ocfs2-devel] [PATCH 04/29] vfs: strengthen checking of file range inputs to generic_remap_checks
Al Viro
viro at ZenIV.linux.org.uk
Wed Oct 17 17:41:56 PDT 2018
On Wed, Oct 17, 2018 at 03:44:43PM -0700, Darrick J. Wong wrote:
> +static int generic_access_check_limits(struct file *file, loff_t pos,
> + loff_t *count)
> +{
> + struct inode *inode = file->f_mapping->host;
> +
> + /* Don't exceed the LFS limits. */
> + if (unlikely(pos + *count > MAX_NON_LFS &&
> + !(file->f_flags & O_LARGEFILE))) {
> + if (pos >= MAX_NON_LFS)
> + return -EFBIG;
> + *count = min(*count, (loff_t)MAX_NON_LFS - pos);
Can that can be different from MAX_NON_LFS - pos?
> + }
> +
> + /*
> + * Don't operate on ranges the page cache doesn't support.
> + *
> + * If we have written data it becomes a short write. If we have
> + * exceeded without writing data we send a signal and return EFBIG.
> + * Linus frestrict idea will clean these up nicely..
> + */
> + if (unlikely(pos >= inode->i_sb->s_maxbytes))
> + return -EFBIG;
> +
> + *count = min(*count, inode->i_sb->s_maxbytes - pos);
> + return 0;
> +}
Anyway, I would rather do this here:
struct inode *inode = file->f_mapping->host;
loff_t max_size = inode->i_sb->s_maxbytes;
if (!(file->f_flags & O_LARGEFILE))
max_size = MAX_NON_LFS;
if (unlikely(pos >= max_size))
return -EFBIG;
*count = min(*count, max_size - pos);
return 0;
More information about the Ocfs2-devel
mailing list