diff options
| author | Liu Bo <[email protected]> | 2012-03-29 13:57:45 +0000 |
|---|---|---|
| committer | Chris Mason <[email protected]> | 2012-03-29 13:57:45 +0000 |
| commit | e1f041e14cfb322f41f41a308bfede00f1b080cd (patch) | |
| tree | 8bae36b522a96948be985af03073813e3b0d851f /fs/btrfs/ioctl.c | |
| parent | Btrfs: do not bother to defrag an extent if it is a big real extent (diff) | |
| download | kernel-e1f041e14cfb322f41f41a308bfede00f1b080cd.tar.gz kernel-e1f041e14cfb322f41f41a308bfede00f1b080cd.zip | |
Btrfs: update to the right index of defragment
When we use autodefrag, we forget to update the index which indicates
the last page we've dirty. And we'll set dirty flags on a same set of
pages again and again.
Signed-off-by: Liu Bo <[email protected]>
Signed-off-by: Chris Mason <[email protected]>
Diffstat (limited to 'fs/btrfs/ioctl.c')
| -rw-r--r-- | fs/btrfs/ioctl.c | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/fs/btrfs/ioctl.c b/fs/btrfs/ioctl.c index afde837644e5..18cc23d164a8 100644 --- a/fs/btrfs/ioctl.c +++ b/fs/btrfs/ioctl.c @@ -1186,6 +1186,9 @@ int btrfs_defrag_file(struct inode *inode, struct file *file, if (newer_off == (u64)-1) break; + if (ret > 0) + i += ret; + newer_off = max(newer_off + 1, (u64)i << PAGE_CACHE_SHIFT); |
