Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
raspberrypi-kernel
提交
793955bc
R
raspberrypi-kernel
项目概览
openeuler
/
raspberrypi-kernel
通知
13
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
raspberrypi-kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
793955bc
编写于
11月 26, 2007
作者:
C
Chris Mason
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Btrfs: Limit btree writeback to prevent seeks
Signed-off-by:
N
Chris Mason
<
chris.mason@oracle.com
>
上级
015a739c
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
51 addition
and
0 deletion
+51
-0
fs/btrfs/disk-io.c
fs/btrfs/disk-io.c
+9
-0
fs/btrfs/extent_map.c
fs/btrfs/extent_map.c
+39
-0
fs/btrfs/extent_map.h
fs/btrfs/extent_map.h
+3
-0
未找到文件。
fs/btrfs/disk-io.c
浏览文件 @
793955bc
...
...
@@ -210,6 +210,15 @@ static int btree_writepages(struct address_space *mapping,
{
struct
extent_map_tree
*
tree
;
tree
=
&
BTRFS_I
(
mapping
->
host
)
->
extent_tree
;
if
(
wbc
->
sync_mode
==
WB_SYNC_NONE
)
{
u64
num_dirty
;
u64
start
=
0
;
unsigned
long
thresh
=
96
*
1024
*
1024
;
num_dirty
=
count_range_bits
(
tree
,
&
start
,
thresh
,
EXTENT_DIRTY
);
if
(
num_dirty
<
thresh
)
{
return
0
;
}
}
return
extent_writepages
(
tree
,
mapping
,
btree_get_extent
,
wbc
);
}
...
...
fs/btrfs/extent_map.c
浏览文件 @
793955bc
...
...
@@ -1106,6 +1106,45 @@ u64 find_lock_delalloc_range(struct extent_map_tree *tree,
return
found
;
}
u64
count_range_bits
(
struct
extent_map_tree
*
tree
,
u64
*
start
,
u64
max_bytes
,
unsigned
long
bits
)
{
struct
rb_node
*
node
;
struct
extent_state
*
state
;
u64
cur_start
=
*
start
;
u64
total_bytes
=
0
;
int
found
=
0
;
write_lock_irq
(
&
tree
->
lock
);
/*
* this search will find all the extents that end after
* our range starts.
*/
node
=
tree_search
(
&
tree
->
state
,
cur_start
);
if
(
!
node
||
IS_ERR
(
node
))
{
goto
out
;
}
while
(
1
)
{
state
=
rb_entry
(
node
,
struct
extent_state
,
rb_node
);
if
((
state
->
state
&
bits
))
{
total_bytes
+=
state
->
end
-
state
->
start
+
1
;
if
(
total_bytes
>=
max_bytes
)
break
;
if
(
!
found
)
{
*
start
=
state
->
start
;
found
=
1
;
}
}
node
=
rb_next
(
node
);
if
(
!
node
)
break
;
}
out:
write_unlock_irq
(
&
tree
->
lock
);
return
total_bytes
;
}
/*
* helper function to lock both pages and extents in the tree.
* pages must be locked first.
...
...
fs/btrfs/extent_map.h
浏览文件 @
793955bc
...
...
@@ -113,6 +113,9 @@ int extent_read_full_page(struct extent_map_tree *tree, struct page *page,
int
__init
extent_map_init
(
void
);
void
__exit
extent_map_exit
(
void
);
u64
count_range_bits
(
struct
extent_map_tree
*
tree
,
u64
*
start
,
u64
max_bytes
,
unsigned
long
bits
);
int
test_range_bit
(
struct
extent_map_tree
*
tree
,
u64
start
,
u64
end
,
int
bits
,
int
filled
);
int
clear_extent_bits
(
struct
extent_map_tree
*
tree
,
u64
start
,
u64
end
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录