diff options
author | Artem Bityutskiy <artem.bityutskiy@linux.intel.com> | 2012-07-12 10:28:44 -0400 |
---|---|---|
committer | Al Viro <viro@zeniv.linux.org.uk> | 2012-07-22 15:58:05 -0400 |
commit | 715189d836ab276b3d0fc114681f12b423686ffa (patch) | |
tree | a78c44275d3094363bf6055f114f6da0c909f85f /fs | |
parent | 9e6c5829b07c9ba6668807631914efc557fab059 (diff) |
hfs: push lock_super down
HFS uses 'lock_super()'/'unlock_super()' around 'hfs_mdb_commit()' in order
to serialize MDB (Master Directory Block) changes. Push it down to
'hfs_mdb_commit()' in order to simplify the code a bit.
Signed-off-by: Artem Bityutskiy <artem.bityutskiy@linux.intel.com>
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Diffstat (limited to 'fs')
-rw-r--r-- | fs/hfs/inode.c | 2 | ||||
-rw-r--r-- | fs/hfs/mdb.c | 2 | ||||
-rw-r--r-- | fs/hfs/super.c | 4 |
3 files changed, 2 insertions, 6 deletions
diff --git a/fs/hfs/inode.c b/fs/hfs/inode.c index 451c97281b83..f2deefdb4066 100644 --- a/fs/hfs/inode.c +++ b/fs/hfs/inode.c | |||
@@ -645,11 +645,9 @@ static int hfs_file_fsync(struct file *filp, loff_t start, loff_t end, | |||
645 | /* sync the superblock to buffers */ | 645 | /* sync the superblock to buffers */ |
646 | sb = inode->i_sb; | 646 | sb = inode->i_sb; |
647 | if (sb->s_dirt) { | 647 | if (sb->s_dirt) { |
648 | lock_super(sb); | ||
649 | sb->s_dirt = 0; | 648 | sb->s_dirt = 0; |
650 | if (!(sb->s_flags & MS_RDONLY)) | 649 | if (!(sb->s_flags & MS_RDONLY)) |
651 | hfs_mdb_commit(sb); | 650 | hfs_mdb_commit(sb); |
652 | unlock_super(sb); | ||
653 | } | 651 | } |
654 | /* .. finally sync the buffers to disk */ | 652 | /* .. finally sync the buffers to disk */ |
655 | err = sync_blockdev(sb->s_bdev); | 653 | err = sync_blockdev(sb->s_bdev); |
diff --git a/fs/hfs/mdb.c b/fs/hfs/mdb.c index 1563d5ce5764..3f558d58fba2 100644 --- a/fs/hfs/mdb.c +++ b/fs/hfs/mdb.c | |||
@@ -260,6 +260,7 @@ void hfs_mdb_commit(struct super_block *sb) | |||
260 | { | 260 | { |
261 | struct hfs_mdb *mdb = HFS_SB(sb)->mdb; | 261 | struct hfs_mdb *mdb = HFS_SB(sb)->mdb; |
262 | 262 | ||
263 | lock_super(sb); | ||
263 | if (test_and_clear_bit(HFS_FLG_MDB_DIRTY, &HFS_SB(sb)->flags)) { | 264 | if (test_and_clear_bit(HFS_FLG_MDB_DIRTY, &HFS_SB(sb)->flags)) { |
264 | /* These parameters may have been modified, so write them back */ | 265 | /* These parameters may have been modified, so write them back */ |
265 | mdb->drLsMod = hfs_mtime(); | 266 | mdb->drLsMod = hfs_mtime(); |
@@ -317,6 +318,7 @@ void hfs_mdb_commit(struct super_block *sb) | |||
317 | size -= len; | 318 | size -= len; |
318 | } | 319 | } |
319 | } | 320 | } |
321 | unlock_super(sb); | ||
320 | } | 322 | } |
321 | 323 | ||
322 | void hfs_mdb_close(struct super_block *sb) | 324 | void hfs_mdb_close(struct super_block *sb) |
diff --git a/fs/hfs/super.c b/fs/hfs/super.c index 7b4c537d6e13..f7c06bbf33bc 100644 --- a/fs/hfs/super.c +++ b/fs/hfs/super.c | |||
@@ -50,21 +50,17 @@ MODULE_LICENSE("GPL"); | |||
50 | */ | 50 | */ |
51 | static void hfs_write_super(struct super_block *sb) | 51 | static void hfs_write_super(struct super_block *sb) |
52 | { | 52 | { |
53 | lock_super(sb); | ||
54 | sb->s_dirt = 0; | 53 | sb->s_dirt = 0; |
55 | 54 | ||
56 | /* sync everything to the buffers */ | 55 | /* sync everything to the buffers */ |
57 | if (!(sb->s_flags & MS_RDONLY)) | 56 | if (!(sb->s_flags & MS_RDONLY)) |
58 | hfs_mdb_commit(sb); | 57 | hfs_mdb_commit(sb); |
59 | unlock_super(sb); | ||
60 | } | 58 | } |
61 | 59 | ||
62 | static int hfs_sync_fs(struct super_block *sb, int wait) | 60 | static int hfs_sync_fs(struct super_block *sb, int wait) |
63 | { | 61 | { |
64 | lock_super(sb); | ||
65 | hfs_mdb_commit(sb); | 62 | hfs_mdb_commit(sb); |
66 | sb->s_dirt = 0; | 63 | sb->s_dirt = 0; |
67 | unlock_super(sb); | ||
68 | 64 | ||
69 | return 0; | 65 | return 0; |
70 | } | 66 | } |