diff options
| author | Filipe Manana <fdmanana@suse.com> | 2020-04-04 23:20:22 +0300 | 
|---|---|---|
| committer | David Sterba <dsterba@suse.com> | 2020-04-08 20:10:34 +0300 | 
| commit | 4fdb688c7071f8d5acca0f1f340ea276e9a61dce (patch) | |
| tree | 71d551436072247eb11b9923b311eeb29e372706 /tools/perf/scripts/python/failed-syscalls-by-pid.py | |
| parent | 4d4225fc228e46948486d8b8207955f0c031b92e (diff) | |
| download | linux-4fdb688c7071f8d5acca0f1f340ea276e9a61dce.tar.xz | |
btrfs: fix lost i_size update after cloning inline extent
When not using the NO_HOLES feature we were not marking the destination's
file range as written after cloning an inline extent into it. This can
lead to a data loss if the current destination file size is smaller than
the source file's size.
Example:
  $ mkfs.btrfs -f -O ^no-holes /dev/sdc
  $ mount /mnt/sdc /mnt
  $ echo "hello world" > /mnt/foo
  $ cp --reflink=always /mnt/foo /mnt/bar
  $ rm -f /mnt/foo
  $ umount /mnt
  $ mount /mnt/sdc /mnt
  $ cat /mnt/bar
  $
  $ stat -c %s /mnt/bar
  0
  # -> the file is empty, since we deleted foo, the data lost is forever
Fix that by calling btrfs_inode_set_file_extent_range() after cloning an
inline extent.
A test case for fstests will follow soon.
Link: https://lore.kernel.org/linux-btrfs/20200404193846.GA432065@latitude/
Reported-by: Johannes Hirte <johannes.hirte@datenkhaos.de>
Fixes: 9ddc959e802bf ("btrfs: use the file extent tree infrastructure")
Tested-by: Johannes Hirte <johannes.hirte@datenkhaos.de>
Signed-off-by: Filipe Manana <fdmanana@suse.com>
Signed-off-by: David Sterba <dsterba@suse.com>
Diffstat (limited to 'tools/perf/scripts/python/failed-syscalls-by-pid.py')
0 files changed, 0 insertions, 0 deletions
