diff options
author | Theodore Ts'o <tytso@mit.edu> | 2012-07-23 08:00:20 +0400 |
---|---|---|
committer | Theodore Ts'o <tytso@mit.edu> | 2012-07-23 08:00:20 +0400 |
commit | 03179fe92318e7934c180d96f12eff2cb36ef7b6 (patch) | |
tree | 820ff487cef7ff214ac245764e74926177d06702 /fs/ext4/file.c | |
parent | 97795d2a5b8d3c8dc4365d4bd3404191840453ba (diff) | |
download | linux-03179fe92318e7934c180d96f12eff2cb36ef7b6.tar.xz |
ext4: undo ext4_calc_metadata_amount if we fail to claim space
The function ext4_calc_metadata_amount() has side effects, although
it's not obvious from its function name. So if we fail to claim
space, regardless of whether we retry to claim the space again, or
return an error, we need to undo these side effects.
Otherwise we can end up incorrectly calculating the number of metadata
blocks needed for the operation, which was responsible for an xfstests
failure for test #271 when using an ext2 file system with delalloc
enabled.
Reported-by: Brian Foster <bfoster@redhat.com>
Signed-off-by: "Theodore Ts'o" <tytso@mit.edu>
Cc: stable@vger.kernel.org
Diffstat (limited to 'fs/ext4/file.c')
0 files changed, 0 insertions, 0 deletions