提交 26d30f85 编写于 作者: A Anand Jain 提交者: David Sterba

btrfs: consolidate auto defrag kick off policies

As of now writes smaller than 64k for non compressed extents and 16k
for compressed extents inside eof are considered as candidate
for auto defrag, put them together at a place.
Signed-off-by: NAnand Jain <anand.jain@oracle.com>
Signed-off-by: NDavid Sterba <dsterba@suse.com>
上级 8c3e6b1f
...@@ -388,6 +388,15 @@ static inline int inode_need_compress(struct inode *inode) ...@@ -388,6 +388,15 @@ static inline int inode_need_compress(struct inode *inode)
return 0; return 0;
} }
static inline void inode_should_defrag(struct inode *inode,
u64 start, u64 end, u64 num_bytes, u64 small_write)
{
/* If this is a small write inside eof, kick off a defrag */
if (num_bytes < small_write &&
(start > 0 || end + 1 < BTRFS_I(inode)->disk_i_size))
btrfs_add_inode_defrag(NULL, inode);
}
/* /*
* we create compressed extents in two phases. The first * we create compressed extents in two phases. The first
* phase compresses a range of pages that have already been * phase compresses a range of pages that have already been
...@@ -430,10 +439,7 @@ static noinline void compress_file_range(struct inode *inode, ...@@ -430,10 +439,7 @@ static noinline void compress_file_range(struct inode *inode,
int compress_type = fs_info->compress_type; int compress_type = fs_info->compress_type;
int redirty = 0; int redirty = 0;
/* if this is a small write inside eof, kick off a defrag */ inode_should_defrag(inode, start, end, end - start + 1, SZ_16K);
if ((end - start + 1) < SZ_16K &&
(start > 0 || end + 1 < BTRFS_I(inode)->disk_i_size))
btrfs_add_inode_defrag(NULL, inode);
actual_end = min_t(u64, isize, end + 1); actual_end = min_t(u64, isize, end + 1);
again: again:
...@@ -965,10 +971,7 @@ static noinline int cow_file_range(struct inode *inode, ...@@ -965,10 +971,7 @@ static noinline int cow_file_range(struct inode *inode,
num_bytes = max(blocksize, num_bytes); num_bytes = max(blocksize, num_bytes);
disk_num_bytes = num_bytes; disk_num_bytes = num_bytes;
/* if this is a small write inside eof, kick off defrag */ inode_should_defrag(inode, start, end, num_bytes, SZ_64K);
if (num_bytes < SZ_64K &&
(start > 0 || end + 1 < BTRFS_I(inode)->disk_i_size))
btrfs_add_inode_defrag(NULL, inode);
if (start == 0) { if (start == 0) {
/* lets try to make an inline extent */ /* lets try to make an inline extent */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册