summaryrefslogtreecommitdiffstats
path: root/fs/Kconfig
diff options
context:
space:
mode:
authorDarrick J. Wong <darrick.wong@oracle.com>2014-08-28 00:40:09 +0200
committerTheodore Ts'o <tytso@mit.edu>2014-08-29 04:22:29 +0200
commitd80d448c6c5bdd32605b78a60fe8081d82d4da0f (patch)
tree81126dbb0bead4385659eae05916ad922293b80c /fs/Kconfig
parentjbd2: fix descriptor block size handling errors with journal_csum (diff)
downloadlinux-d80d448c6c5bdd32605b78a60fe8081d82d4da0f.tar.xz
linux-d80d448c6c5bdd32605b78a60fe8081d82d4da0f.zip
ext4: fix same-dir rename when inline data directory overflows
When performing a same-directory rename, it's possible that adding or setting the new directory entry will cause the directory to overflow the inline data area, which causes the directory to be converted to an extent-based directory. Under this circumstance it is necessary to re-read the directory when deleting the old dirent because the "old directory" context still points to i_block in the inode table, which is now an extent tree root! The delete fails with an FS error, and the subsequent fsck complains about incorrect link counts and hardlinked directories. Test case (originally found with flat_dir_test in the metadata_csum test program): # mkfs.ext4 -O inline_data /dev/sda # mount /dev/sda /mnt # mkdir /mnt/x # touch /mnt/x/changelog.gz /mnt/x/copyright /mnt/x/README.Debian # sync # for i in /mnt/x/*; do mv $i $i.longer; done # ls -la /mnt/x/ total 0 -rw-r--r-- 1 root root 0 Aug 25 12:03 changelog.gz.longer -rw-r--r-- 1 root root 0 Aug 25 12:03 copyright -rw-r--r-- 1 root root 0 Aug 25 12:03 copyright.longer -rw-r--r-- 1 root root 0 Aug 25 12:03 README.Debian.longer (Hey! Why are there four files now??) Signed-off-by: Darrick J. Wong <darrick.wong@oracle.com> Signed-off-by: Theodore Ts'o <tytso@mit.edu> Cc: stable@vger.kernel.org
Diffstat (limited to 'fs/Kconfig')
0 files changed, 0 insertions, 0 deletions