diff options
| author | Linus Torvalds <[email protected]> | 2016-10-20 08:49:03 -0700 | 
|---|---|---|
| committer | Linus Torvalds <[email protected]> | 2016-10-20 08:49:03 -0700 | 
| commit | a28ad14e057b6ec2ad9a8b09a44aa859d79c0ff8 (patch) | |
| tree | d59b703629e6dddc2c4755888ddd2df3d2634fa4 | |
| parent | c3f8f7fa8b19e274e7eb99dee428ad3a9b2ad8eb (diff) | |
| parent | e952813e210b3addaea063da64ef68c3f30c0aa2 (diff) | |
Merge branch 'for_linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jack/linux-fs
Pull misc filesystem fixes from Jan Kara:
 "A fix for an isofs change apparently breaking mount(8) in some cases
  and one ext2 warning fix"
* 'for_linus' of git://git.kernel.org/pub/scm/linux/kernel/git/jack/linux-fs:
  ext2: avoid bogus -Wmaybe-uninitialized warning
  isofs: Do not return EACCES for unknown filesystems
| -rw-r--r-- | fs/ext2/inode.c | 7 | ||||
| -rw-r--r-- | fs/isofs/inode.c | 8 | 
2 files changed, 9 insertions, 6 deletions
| diff --git a/fs/ext2/inode.c b/fs/ext2/inode.c index d831e24dc885..41b8b44a391c 100644 --- a/fs/ext2/inode.c +++ b/fs/ext2/inode.c @@ -622,7 +622,7 @@ static int ext2_get_blocks(struct inode *inode,  			   u32 *bno, bool *new, bool *boundary,  			   int create)  { -	int err = -EIO; +	int err;  	int offsets[4];  	Indirect chain[4];  	Indirect *partial; @@ -639,7 +639,7 @@ static int ext2_get_blocks(struct inode *inode,  	depth = ext2_block_to_path(inode,iblock,offsets,&blocks_to_boundary);  	if (depth == 0) -		return (err); +		return -EIO;  	partial = ext2_get_branch(inode, depth, offsets, chain, &err);  	/* Simplest case - block found, no allocation needed */ @@ -761,7 +761,6 @@ static int ext2_get_blocks(struct inode *inode,  	ext2_splice_branch(inode, iblock, partial, indirect_blks, count);  	mutex_unlock(&ei->truncate_mutex);  got_it: -	*bno = le32_to_cpu(chain[depth-1].key);  	if (count > blocks_to_boundary)  		*boundary = true;  	err = count; @@ -772,6 +771,8 @@ cleanup:  		brelse(partial->bh);  		partial--;  	} +	if (err > 0) +		*bno = le32_to_cpu(chain[depth-1].key);  	return err;  } diff --git a/fs/isofs/inode.c b/fs/isofs/inode.c index ad0c745ebad7..871c8b392099 100644 --- a/fs/isofs/inode.c +++ b/fs/isofs/inode.c @@ -687,6 +687,11 @@ static int isofs_fill_super(struct super_block *s, void *data, int silent)  	pri_bh = NULL;  root_found: +	/* We don't support read-write mounts */ +	if (!(s->s_flags & MS_RDONLY)) { +		error = -EACCES; +		goto out_freebh; +	}  	if (joliet_level && (pri == NULL || !opt.rock)) {  		/* This is the case of Joliet with the norock mount flag. @@ -1501,9 +1506,6 @@ struct inode *__isofs_iget(struct super_block *sb,  static struct dentry *isofs_mount(struct file_system_type *fs_type,  	int flags, const char *dev_name, void *data)  { -	/* We don't support read-write mounts */ -	if (!(flags & MS_RDONLY)) -		return ERR_PTR(-EACCES);  	return mount_bdev(fs_type, flags, dev_name, data, isofs_fill_super);  } |