summaryrefslogtreecommitdiffstats
path: root/fs/reiserfs
diff options
context:
space:
mode:
authorArtem Bityutskiy <artem.bityutskiy@linux.intel.com>2012-06-01 17:18:07 +0300
committerAl Viro <viro@zeniv.linux.org.uk>2012-06-01 10:37:36 -0400
commit5c5fd81962271d4ee2984837fef4ec37e689aa41 (patch)
treebf426f26c8265c3572e37e3a0908624da0cf0a58 /fs/reiserfs
parent717f03c4d71677d2afb68d54628def3aae5d46ab (diff)
downloadlinux-stable-5c5fd81962271d4ee2984837fef4ec37e689aa41.tar.gz
linux-stable-5c5fd81962271d4ee2984837fef4ec37e689aa41.tar.bz2
linux-stable-5c5fd81962271d4ee2984837fef4ec37e689aa41.zip
reiserfs: mark the superblock as dirty a bit later
The 'journal_mark_dirty()' function currently first marks the superblock as dirty by setting 's_dirt' to 1, then does various sanity checks and returns, then actuall does all the magic with the journal. This is not an ideal order, though. It makes more sense to first do all the checks, then do all the internal stuff, and at the end notify the VFS that the superblock is now dirty. This patch moves the 's_dirt = 1' assignment from the very beginning of this function to the very end. Signed-off-by: Artem Bityutskiy <artem.bityutskiy@linux.intel.com> Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Diffstat (limited to 'fs/reiserfs')
-rw-r--r--fs/reiserfs/journal.c3
1 files changed, 1 insertions, 2 deletions
diff --git a/fs/reiserfs/journal.c b/fs/reiserfs/journal.c
index 68aea62ea61d..e5e06dd8562f 100644
--- a/fs/reiserfs/journal.c
+++ b/fs/reiserfs/journal.c
@@ -3231,8 +3231,6 @@ int journal_mark_dirty(struct reiserfs_transaction_handle *th,
th->t_trans_id, journal->j_trans_id);
}
- sb->s_dirt = 1;
-
prepared = test_clear_buffer_journal_prepared(bh);
clear_buffer_journal_restore_dirty(bh);
/* already in this transaction, we are done */
@@ -3316,6 +3314,7 @@ int journal_mark_dirty(struct reiserfs_transaction_handle *th,
journal->j_first = cn;
journal->j_last = cn;
}
+ sb->s_dirt = 1;
return 0;
}