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/hfs | |
| 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/hfs')
| -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 | } |
