From 7a2e1b2911e4415b0c89ba0fd7fba794da3e9be5 Mon Sep 17 00:00:00 2001 From: Artem Bityutskiy Date: Thu, 12 Jul 2012 17:28:47 +0300 Subject: [PATCH] --- yaml --- r: 312960 b: refs/heads/master c: 4527440d5db8ff27ae8801de3f819843a1e6c6f6 h: refs/heads/master v: v3 --- [refs] | 2 +- trunk/fs/hfs/inode.c | 3 +-- trunk/fs/hfs/mdb.c | 3 +++ trunk/fs/hfs/super.c | 3 +-- 4 files changed, 6 insertions(+), 5 deletions(-) diff --git a/[refs] b/[refs] index c9d0cd5e3dbd..c42ab6d5a283 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: a3742d4828caeffab4cb075b562a4ed92d3e74d6 +refs/heads/master: 4527440d5db8ff27ae8801de3f819843a1e6c6f6 diff --git a/trunk/fs/hfs/inode.c b/trunk/fs/hfs/inode.c index f2deefdb4066..90c1ccbff8e4 100644 --- a/trunk/fs/hfs/inode.c +++ b/trunk/fs/hfs/inode.c @@ -646,8 +646,7 @@ static int hfs_file_fsync(struct file *filp, loff_t start, loff_t end, sb = inode->i_sb; if (sb->s_dirt) { sb->s_dirt = 0; - if (!(sb->s_flags & MS_RDONLY)) - hfs_mdb_commit(sb); + hfs_mdb_commit(sb); } /* .. finally sync the buffers to disk */ err = sync_blockdev(sb->s_bdev); diff --git a/trunk/fs/hfs/mdb.c b/trunk/fs/hfs/mdb.c index 7a3224049f30..5fd51a5833ff 100644 --- a/trunk/fs/hfs/mdb.c +++ b/trunk/fs/hfs/mdb.c @@ -260,6 +260,9 @@ void hfs_mdb_commit(struct super_block *sb) { struct hfs_mdb *mdb = HFS_SB(sb)->mdb; + if (sb->s_flags & MS_RDONLY) + return; + lock_buffer(HFS_SB(sb)->mdb_bh); if (test_and_clear_bit(HFS_FLG_MDB_DIRTY, &HFS_SB(sb)->flags)) { /* These parameters may have been modified, so write them back */ diff --git a/trunk/fs/hfs/super.c b/trunk/fs/hfs/super.c index 47e4119a0650..0730135b771e 100644 --- a/trunk/fs/hfs/super.c +++ b/trunk/fs/hfs/super.c @@ -53,8 +53,7 @@ static void hfs_write_super(struct super_block *sb) sb->s_dirt = 0; /* sync everything to the buffers */ - if (!(sb->s_flags & MS_RDONLY)) - hfs_mdb_commit(sb); + hfs_mdb_commit(sb); } static int hfs_sync_fs(struct super_block *sb, int wait)