Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
raspberrypi-kernel
提交
e66f709b
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看板
提交
e66f709b
编写于
4月 20, 2007
作者:
C
Chris Mason
提交者:
David Woodhouse
4月 20, 2007
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Btrfs: write barriers on commit, balance level before split
Signed-off-by:
N
Chris Mason
<
chris.mason@oracle.com
>
上级
8fd17795
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
131 addition
and
1 deletion
+131
-1
fs/btrfs/ctree.c
fs/btrfs/ctree.c
+119
-0
fs/btrfs/ctree.h
fs/btrfs/ctree.h
+1
-0
fs/btrfs/disk-io.c
fs/btrfs/disk-io.c
+11
-1
未找到文件。
fs/btrfs/ctree.c
浏览文件 @
e66f709b
...
...
@@ -151,6 +151,11 @@ static int check_node(struct btrfs_root *root, struct btrfs_path *path,
for
(
i
=
0
;
nritems
>
1
&&
i
<
nritems
-
2
;
i
++
)
{
struct
btrfs_key
cpukey
;
btrfs_disk_key_to_cpu
(
&
cpukey
,
&
node
->
ptrs
[
i
+
1
].
key
);
if
(
comp_keys
(
&
node
->
ptrs
[
i
].
key
,
&
cpukey
)
>=
0
)
{
struct
btrfs_key
bad
;
btrfs_disk_key_to_cpu
(
&
bad
,
&
node
->
ptrs
[
i
].
key
);
printk
(
"check_node level %d i is %d bad comp %Lu %u %Lu, %Lu %u %Lu
\n
"
,
level
,
i
,
bad
.
objectid
,
bad
.
flags
,
bad
.
offset
,
cpukey
.
objectid
,
cpukey
.
flags
,
cpukey
.
offset
);
}
BUG_ON
(
comp_keys
(
&
node
->
ptrs
[
i
].
key
,
&
cpukey
)
>=
0
);
}
return
0
;
...
...
@@ -448,6 +453,111 @@ static int balance_level(struct btrfs_trans_handle *trans, struct btrfs_root
return
ret
;
}
/* returns zero if the push worked, non-zero otherwise */
static
int
push_nodes_for_insert
(
struct
btrfs_trans_handle
*
trans
,
struct
btrfs_root
*
root
,
struct
btrfs_path
*
path
,
int
level
)
{
struct
buffer_head
*
right_buf
;
struct
buffer_head
*
mid_buf
;
struct
buffer_head
*
left_buf
;
struct
buffer_head
*
parent_buf
=
NULL
;
struct
btrfs_node
*
right
=
NULL
;
struct
btrfs_node
*
mid
;
struct
btrfs_node
*
left
=
NULL
;
struct
btrfs_node
*
parent
=
NULL
;
int
ret
=
0
;
int
wret
;
int
pslot
;
int
orig_slot
=
path
->
slots
[
level
];
u64
orig_ptr
;
if
(
level
==
0
)
return
1
;
mid_buf
=
path
->
nodes
[
level
];
mid
=
btrfs_buffer_node
(
mid_buf
);
orig_ptr
=
btrfs_node_blockptr
(
mid
,
orig_slot
);
if
(
level
<
BTRFS_MAX_LEVEL
-
1
)
parent_buf
=
path
->
nodes
[
level
+
1
];
pslot
=
path
->
slots
[
level
+
1
];
if
(
!
parent_buf
)
return
1
;
parent
=
btrfs_buffer_node
(
parent_buf
);
left_buf
=
read_node_slot
(
root
,
parent_buf
,
pslot
-
1
);
/* first, try to make some room in the middle buffer */
if
(
left_buf
)
{
u32
left_nr
;
btrfs_cow_block
(
trans
,
root
,
left_buf
,
parent_buf
,
pslot
-
1
,
&
left_buf
);
left
=
btrfs_buffer_node
(
left_buf
);
left_nr
=
btrfs_header_nritems
(
&
left
->
header
);
wret
=
push_node_left
(
trans
,
root
,
left_buf
,
mid_buf
);
if
(
wret
<
0
)
ret
=
wret
;
if
(
wret
==
0
)
{
orig_slot
+=
left_nr
;
btrfs_memcpy
(
root
,
parent
,
&
parent
->
ptrs
[
pslot
].
key
,
&
mid
->
ptrs
[
0
].
key
,
sizeof
(
struct
btrfs_disk_key
));
btrfs_mark_buffer_dirty
(
parent_buf
);
if
(
btrfs_header_nritems
(
&
left
->
header
)
>
orig_slot
)
{
path
->
nodes
[
level
]
=
left_buf
;
path
->
slots
[
level
+
1
]
-=
1
;
path
->
slots
[
level
]
=
orig_slot
;
btrfs_block_release
(
root
,
mid_buf
);
}
else
{
orig_slot
-=
btrfs_header_nritems
(
&
left
->
header
);
path
->
slots
[
level
]
=
orig_slot
;
btrfs_block_release
(
root
,
left_buf
);
}
check_node
(
root
,
path
,
level
);
return
0
;
}
btrfs_block_release
(
root
,
left_buf
);
}
right_buf
=
read_node_slot
(
root
,
parent_buf
,
pslot
+
1
);
/*
* then try to empty the right most buffer into the middle
*/
if
(
right_buf
)
{
btrfs_cow_block
(
trans
,
root
,
right_buf
,
parent_buf
,
pslot
+
1
,
&
right_buf
);
right
=
btrfs_buffer_node
(
right_buf
);
wret
=
balance_node_right
(
trans
,
root
,
right_buf
,
mid_buf
);
if
(
wret
<
0
)
ret
=
wret
;
if
(
wret
==
0
)
{
btrfs_memcpy
(
root
,
parent
,
&
parent
->
ptrs
[
pslot
+
1
].
key
,
&
right
->
ptrs
[
0
].
key
,
sizeof
(
struct
btrfs_disk_key
));
btrfs_mark_buffer_dirty
(
parent_buf
);
if
(
btrfs_header_nritems
(
&
mid
->
header
)
<=
orig_slot
)
{
path
->
nodes
[
level
]
=
right_buf
;
path
->
slots
[
level
+
1
]
+=
1
;
path
->
slots
[
level
]
=
orig_slot
-
btrfs_header_nritems
(
&
mid
->
header
);
btrfs_block_release
(
root
,
mid_buf
);
}
else
{
btrfs_block_release
(
root
,
right_buf
);
}
check_node
(
root
,
path
,
level
);
return
0
;
}
btrfs_block_release
(
root
,
right_buf
);
}
check_node
(
root
,
path
,
level
);
return
1
;
}
/*
* look for key in the tree. path is filled in with nodes along the way
* if key is found, we return zero and you can find the item in the leaf
...
...
@@ -774,7 +884,16 @@ static int split_node(struct btrfs_trans_handle *trans, struct btrfs_root
ret
=
insert_new_root
(
trans
,
root
,
path
,
level
+
1
);
if
(
ret
)
return
ret
;
}
else
{
ret
=
push_nodes_for_insert
(
trans
,
root
,
path
,
level
);
t
=
path
->
nodes
[
level
];
c
=
btrfs_buffer_node
(
t
);
if
(
!
ret
&&
btrfs_header_nritems
(
&
c
->
header
)
<
BTRFS_NODEPTRS_PER_BLOCK
(
root
)
-
1
)
return
0
;
}
c_nritems
=
btrfs_header_nritems
(
&
c
->
header
);
split_buffer
=
btrfs_alloc_free_block
(
trans
,
root
);
split
=
btrfs_buffer_node
(
split_buffer
);
...
...
fs/btrfs/ctree.h
浏览文件 @
e66f709b
...
...
@@ -259,6 +259,7 @@ struct btrfs_fs_info {
struct
list_head
trans_list
;
struct
crypto_hash
*
hash_tfm
;
spinlock_t
hash_lock
;
int
do_barriers
;
struct
kobject
kobj
;
};
...
...
fs/btrfs/disk-io.c
浏览文件 @
e66f709b
...
...
@@ -540,6 +540,7 @@ struct btrfs_root *open_ctree(struct super_block *sb)
fs_info
->
btree_inode
->
i_nlink
=
1
;
fs_info
->
btree_inode
->
i_size
=
sb
->
s_bdev
->
bd_inode
->
i_size
;
fs_info
->
btree_inode
->
i_mapping
->
a_ops
=
&
btree_aops
;
fs_info
->
do_barriers
=
1
;
BTRFS_I
(
fs_info
->
btree_inode
)
->
root
=
tree_root
;
memset
(
&
BTRFS_I
(
fs_info
->
btree_inode
)
->
location
,
0
,
sizeof
(
struct
btrfs_key
));
...
...
@@ -622,6 +623,7 @@ struct btrfs_root *open_ctree(struct super_block *sb)
int
write_ctree_super
(
struct
btrfs_trans_handle
*
trans
,
struct
btrfs_root
*
root
)
{
int
ret
;
struct
buffer_head
*
bh
=
root
->
fs_info
->
sb_buffer
;
btrfs_set_super_root
(
root
->
fs_info
->
disk_super
,
...
...
@@ -632,7 +634,15 @@ int write_ctree_super(struct btrfs_trans_handle *trans, struct btrfs_root
csum_tree_block
(
root
,
bh
,
0
);
bh
->
b_end_io
=
end_buffer_write_sync
;
get_bh
(
bh
);
submit_bh
(
WRITE
,
bh
);
if
(
root
->
fs_info
->
do_barriers
)
ret
=
submit_bh
(
WRITE_BARRIER
,
bh
);
else
ret
=
submit_bh
(
WRITE
,
bh
);
if
(
ret
==
-
EOPNOTSUPP
)
{
set_buffer_uptodate
(
bh
);
root
->
fs_info
->
do_barriers
=
0
;
ret
=
submit_bh
(
WRITE
,
bh
);
}
wait_on_buffer
(
bh
);
if
(
!
buffer_uptodate
(
bh
))
{
WARN_ON
(
1
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录