diff options
author | Jan Kara <jack@suse.cz> | 2011-07-21 16:22:25 -0400 |
---|---|---|
committer | Al Viro <viro@zeniv.linux.org.uk> | 2011-07-22 19:42:12 -0400 |
commit | d769b3c2ab7184ddd42056595b627cc871caa90e (patch) | |
tree | b030270648c2a2aca7c5417e2ae0436ec7d0a31c /fs/isofs/dir.c | |
parent | 22ba747f660c0acd14761628c24aa972d18058a0 (diff) |
isofs: Remove global fs lock
sbi->s_mutex isn't needed for isofs at all so we can just remove it. Generally,
since isofs is always mounted read-only, filesystem structure cannot change
under us. So buffer_head contents stays constant after it's filled in. That
leaves us with possible changes of global data structures. Superblock changes
only during filesystem mount (even remount does not change it), inodes are only
filled in during reading from disk. So there are no changes of these structures
to bother about.
Arguments why sbi->s_mutex can be removed at each place:
isofs_readdir: Accesses sb, inode, filp, local variables => s_mutex not needed
isofs_lookup: Protected by directory's i_mutex. Accesses sb, inode, dentry,
local variables => s_mutex not needed
rock_ridge_symlink_readpage: Protected by page lock. Accesses sb, inode,
local variables => s_mutex not needed.
Signed-off-by: Jan Kara <jack@suse.cz>
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Diffstat (limited to 'fs/isofs/dir.c')
-rw-r--r-- | fs/isofs/dir.c | 3 |
1 files changed, 0 insertions, 3 deletions
diff --git a/fs/isofs/dir.c b/fs/isofs/dir.c index 0542b6eedf80..f20437c068a0 100644 --- a/fs/isofs/dir.c +++ b/fs/isofs/dir.c | |||
@@ -254,19 +254,16 @@ static int isofs_readdir(struct file *filp, | |||
254 | char *tmpname; | 254 | char *tmpname; |
255 | struct iso_directory_record *tmpde; | 255 | struct iso_directory_record *tmpde; |
256 | struct inode *inode = filp->f_path.dentry->d_inode; | 256 | struct inode *inode = filp->f_path.dentry->d_inode; |
257 | struct isofs_sb_info *sbi = ISOFS_SB(inode->i_sb); | ||
258 | 257 | ||
259 | tmpname = (char *)__get_free_page(GFP_KERNEL); | 258 | tmpname = (char *)__get_free_page(GFP_KERNEL); |
260 | if (tmpname == NULL) | 259 | if (tmpname == NULL) |
261 | return -ENOMEM; | 260 | return -ENOMEM; |
262 | 261 | ||
263 | mutex_lock(&sbi->s_mutex); | ||
264 | tmpde = (struct iso_directory_record *) (tmpname+1024); | 262 | tmpde = (struct iso_directory_record *) (tmpname+1024); |
265 | 263 | ||
266 | result = do_isofs_readdir(inode, filp, dirent, filldir, tmpname, tmpde); | 264 | result = do_isofs_readdir(inode, filp, dirent, filldir, tmpname, tmpde); |
267 | 265 | ||
268 | free_page((unsigned long) tmpname); | 266 | free_page((unsigned long) tmpname); |
269 | mutex_unlock(&sbi->s_mutex); | ||
270 | return result; | 267 | return result; |
271 | } | 268 | } |
272 | 269 | ||