summaryrefslogtreecommitdiffstats
path: root/fs/ext3
diff options
context:
space:
mode:
authorJosh Hunt <johunt@akamai.com>2011-02-24 11:48:22 +0100
committerJan Kara <jack@suse.cz>2011-02-28 21:55:43 +0100
commit03885ac3c79ab7f3f4a8e502486be2ea6c85c3e3 (patch)
treed6ca9cc79d0069cd99ba08de8a5f1ad5c743111c /fs/ext3
parentbbac751dc85cbf0953a221171a746d69a0b1a85f (diff)
downloadlinux-stable-03885ac3c79ab7f3f4a8e502486be2ea6c85c3e3.tar.gz
linux-stable-03885ac3c79ab7f3f4a8e502486be2ea6c85c3e3.tar.bz2
linux-stable-03885ac3c79ab7f3f4a8e502486be2ea6c85c3e3.zip
ext2: Fix link count corruption under heavy link+rename load
vfs_rename_other() does not lock renamed inode with i_mutex. Thus changing i_nlink in a non-atomic manner (which happens in ext2_rename()) can corrupt it as reported and analyzed by Josh. In fact, there is no good reason to mess with i_nlink of the moved file. We did it presumably to simulate linking into the new directory and unlinking from an old one. But the practical effect of this is disputable because fsck can possibly treat file as being properly linked into both directories without writing any error which is confusing. So we just stop increment-decrement games with i_nlink which also fixes the corruption. CC: stable@kernel.org CC: Al Viro <viro@ZenIV.linux.org.uk> Signed-off-by: Josh Hunt <johunt@akamai.com> Signed-off-by: Jan Kara <jack@suse.cz>
Diffstat (limited to 'fs/ext3')
0 files changed, 0 insertions, 0 deletions