Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
692afc31
K
Kernel
项目概览
openeuler
/
Kernel
1 年多 前同步成功
通知
8
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
Kernel
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
692afc31
编写于
11月 24, 2011
作者:
A
Al Viro
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
vfs: spread struct mount - shrink_submounts/select_submounts
Signed-off-by:
N
Al Viro
<
viro@zeniv.linux.org.uk
>
上级
761d5c38
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
14 addition
and
14 deletion
+14
-14
fs/namespace.c
fs/namespace.c
+14
-14
未找到文件。
fs/namespace.c
浏览文件 @
692afc31
...
...
@@ -1244,7 +1244,7 @@ void umount_tree(struct mount *mnt, int propagate, struct list_head *kill)
list_splice
(
&
tmp_list
,
kill
);
}
static
void
shrink_submounts
(
struct
vfs
mount
*
mnt
,
struct
list_head
*
umounts
);
static
void
shrink_submounts
(
struct
mount
*
mnt
,
struct
list_head
*
umounts
);
static
int
do_umount
(
struct
vfsmount
*
mnt
,
int
flags
)
{
...
...
@@ -1322,7 +1322,7 @@ static int do_umount(struct vfsmount *mnt, int flags)
event
++
;
if
(
!
(
flags
&
MNT_DETACH
))
shrink_submounts
(
mnt
,
&
umount_list
);
shrink_submounts
(
real_mount
(
mnt
)
,
&
umount_list
);
retval
=
-
EBUSY
;
if
(
flags
&
MNT_DETACH
||
!
propagate_mount_busy
(
mnt
,
2
))
{
...
...
@@ -2121,32 +2121,32 @@ EXPORT_SYMBOL_GPL(mark_mounts_for_expiry);
* search the list of submounts for a given mountpoint, and move any
* shrinkable submounts to the 'graveyard' list.
*/
static
int
select_submounts
(
struct
vfs
mount
*
parent
,
struct
list_head
*
graveyard
)
static
int
select_submounts
(
struct
mount
*
parent
,
struct
list_head
*
graveyard
)
{
struct
vfs
mount
*
this_parent
=
parent
;
struct
mount
*
this_parent
=
parent
;
struct
list_head
*
next
;
int
found
=
0
;
repeat:
next
=
this_parent
->
mnt_mounts
.
next
;
next
=
this_parent
->
mnt
.
mnt
_mounts
.
next
;
resume:
while
(
next
!=
&
this_parent
->
mnt_mounts
)
{
while
(
next
!=
&
this_parent
->
mnt
.
mnt
_mounts
)
{
struct
list_head
*
tmp
=
next
;
struct
vfsmount
*
mnt
=
list_entry
(
tmp
,
struct
vfsmount
,
mnt_child
);
struct
mount
*
mnt
=
list_entry
(
tmp
,
struct
mount
,
mnt
.
mnt_child
);
next
=
tmp
->
next
;
if
(
!
(
mnt
->
mnt_flags
&
MNT_SHRINKABLE
))
if
(
!
(
mnt
->
mnt
.
mnt
_flags
&
MNT_SHRINKABLE
))
continue
;
/*
* Descend a level if the d_mounts list is non-empty.
*/
if
(
!
list_empty
(
&
mnt
->
mnt_mounts
))
{
if
(
!
list_empty
(
&
mnt
->
mnt
.
mnt
_mounts
))
{
this_parent
=
mnt
;
goto
repeat
;
}
if
(
!
propagate_mount_busy
(
mnt
,
1
))
{
list_move_tail
(
&
mnt
->
mnt_expire
,
graveyard
);
if
(
!
propagate_mount_busy
(
&
mnt
->
mnt
,
1
))
{
list_move_tail
(
&
mnt
->
mnt
.
mnt
_expire
,
graveyard
);
found
++
;
}
}
...
...
@@ -2154,8 +2154,8 @@ static int select_submounts(struct vfsmount *parent, struct list_head *graveyard
* All done at this level ... ascend and resume the search
*/
if
(
this_parent
!=
parent
)
{
next
=
this_parent
->
mnt_child
.
next
;
this_parent
=
this_parent
->
mnt_parent
;
next
=
this_parent
->
mnt
.
mnt
_child
.
next
;
this_parent
=
real_mount
(
this_parent
->
mnt
.
mnt_parent
)
;
goto
resume
;
}
return
found
;
...
...
@@ -2167,7 +2167,7 @@ static int select_submounts(struct vfsmount *parent, struct list_head *graveyard
*
* vfsmount_lock must be held for write
*/
static
void
shrink_submounts
(
struct
vfs
mount
*
mnt
,
struct
list_head
*
umounts
)
static
void
shrink_submounts
(
struct
mount
*
mnt
,
struct
list_head
*
umounts
)
{
LIST_HEAD
(
graveyard
);
struct
mount
*
m
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录