diff options
author | Jun'ichi Nomura <j-nomura@ce.jp.nec.com> | 2010-01-29 01:56:22 +0100 |
---|---|---|
committer | Al Viro <viro@zeniv.linux.org.uk> | 2010-02-07 09:06:21 +0100 |
commit | 4b06e5b9ad8abb20105b2b25e42c509ebe9b2d76 (patch) | |
tree | a151e21fef671e9d046a6c456d2f048eea56fb99 /fs/nfsd/vfs.c | |
parent | befs: fix leak (diff) | |
download | linux-4b06e5b9ad8abb20105b2b25e42c509ebe9b2d76.tar.xz linux-4b06e5b9ad8abb20105b2b25e42c509ebe9b2d76.zip |
freeze_bdev: don't deactivate successfully frozen MS_RDONLY sb
Thanks Thomas and Christoph for testing and review.
I removed 'smp_wmb()' before up_write from the previous patch,
since up_write() should have necessary ordering constraints.
(I.e. the change of s_frozen is visible to others after up_write)
I'm quite sure the change is harmless but if you are uncomfortable
with Tested-by/Reviewed-by on the modified patch, please remove them.
If MS_RDONLY, freeze_bdev should just up_write(s_umount) instead of
deactivate_locked_super().
Also, keep sb->s_frozen consistent so that remount can check the frozen state.
Otherwise a crash reported here can happen:
http://lkml.org/lkml/2010/1/16/37
http://lkml.org/lkml/2010/1/28/53
This patch should be applied for 2.6.32 stable series, too.
Reviewed-by: Christoph Hellwig <hch@lst.de>
Tested-by: Thomas Backlund <tmb@mandriva.org>
Signed-off-by: Jun'ichi Nomura <j-nomura@ce.jp.nec.com>
Cc: stable@kernel.org
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
Diffstat (limited to '')
0 files changed, 0 insertions, 0 deletions