Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
Kernel
提交
fbc2d168
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看板
提交
fbc2d168
编写于
12月 20, 2019
作者:
A
Al Viro
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
get rid of cg_invalf()
pointless alias for invalf()... Signed-off-by:
N
Al Viro
<
viro@zeniv.linux.org.uk
>
上级
aa1918f9
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
12 addition
and
14 deletion
+12
-14
kernel/cgroup/cgroup-v1.c
kernel/cgroup/cgroup-v1.c
+12
-14
未找到文件。
kernel/cgroup/cgroup-v1.c
浏览文件 @
fbc2d168
...
...
@@ -18,8 +18,6 @@
#include <trace/events/cgroup.h>
#define cg_invalf(fc, fmt, ...) invalf(fc, fmt, ## __VA_ARGS__)
/*
* pidlists linger the following amount before being destroyed. The goal
* is avoiding frequent destruction in the middle of consecutive read calls
...
...
@@ -924,7 +922,7 @@ int cgroup1_parse_param(struct fs_context *fc, struct fs_parameter *param)
ctx
->
subsys_mask
|=
(
1
<<
i
);
return
0
;
}
return
cg_
invalf
(
fc
,
"cgroup1: Unknown subsys name '%s'"
,
param
->
key
);
return
invalf
(
fc
,
"cgroup1: Unknown subsys name '%s'"
,
param
->
key
);
}
if
(
opt
<
0
)
return
opt
;
...
...
@@ -952,7 +950,7 @@ int cgroup1_parse_param(struct fs_context *fc, struct fs_parameter *param)
case
Opt_release_agent
:
/* Specifying two release agents is forbidden */
if
(
ctx
->
release_agent
)
return
cg_
invalf
(
fc
,
"cgroup1: release_agent respecified"
);
return
invalf
(
fc
,
"cgroup1: release_agent respecified"
);
ctx
->
release_agent
=
param
->
string
;
param
->
string
=
NULL
;
break
;
...
...
@@ -962,9 +960,9 @@ int cgroup1_parse_param(struct fs_context *fc, struct fs_parameter *param)
return
-
ENOENT
;
/* Can't specify an empty name */
if
(
!
param
->
size
)
return
cg_
invalf
(
fc
,
"cgroup1: Empty name"
);
return
invalf
(
fc
,
"cgroup1: Empty name"
);
if
(
param
->
size
>
MAX_CGROUP_ROOT_NAMELEN
-
1
)
return
cg_
invalf
(
fc
,
"cgroup1: Name too long"
);
return
invalf
(
fc
,
"cgroup1: Name too long"
);
/* Must match [\w.-]+ */
for
(
i
=
0
;
i
<
param
->
size
;
i
++
)
{
char
c
=
param
->
string
[
i
];
...
...
@@ -972,11 +970,11 @@ int cgroup1_parse_param(struct fs_context *fc, struct fs_parameter *param)
continue
;
if
((
c
==
'.'
)
||
(
c
==
'-'
)
||
(
c
==
'_'
))
continue
;
return
cg_
invalf
(
fc
,
"cgroup1: Invalid name"
);
return
invalf
(
fc
,
"cgroup1: Invalid name"
);
}
/* Specifying two names is forbidden */
if
(
ctx
->
name
)
return
cg_
invalf
(
fc
,
"cgroup1: name respecified"
);
return
invalf
(
fc
,
"cgroup1: name respecified"
);
ctx
->
name
=
param
->
string
;
param
->
string
=
NULL
;
break
;
...
...
@@ -1011,7 +1009,7 @@ static int check_cgroupfs_options(struct fs_context *fc)
if
(
ctx
->
all_ss
)
{
/* Mutually exclusive option 'all' + subsystem name */
if
(
ctx
->
subsys_mask
)
return
cg_
invalf
(
fc
,
"cgroup1: subsys name conflicts with all"
);
return
invalf
(
fc
,
"cgroup1: subsys name conflicts with all"
);
/* 'all' => select all the subsystems */
ctx
->
subsys_mask
=
enabled
;
}
...
...
@@ -1021,7 +1019,7 @@ static int check_cgroupfs_options(struct fs_context *fc)
* empty hierarchies must have a name).
*/
if
(
!
ctx
->
subsys_mask
&&
!
ctx
->
name
)
return
cg_
invalf
(
fc
,
"cgroup1: Need name or subsystem set"
);
return
invalf
(
fc
,
"cgroup1: Need name or subsystem set"
);
/*
* Option noprefix was introduced just for backward compatibility
...
...
@@ -1029,11 +1027,11 @@ static int check_cgroupfs_options(struct fs_context *fc)
* the cpuset subsystem.
*/
if
((
ctx
->
flags
&
CGRP_ROOT_NOPREFIX
)
&&
(
ctx
->
subsys_mask
&
mask
))
return
cg_
invalf
(
fc
,
"cgroup1: noprefix used incorrectly"
);
return
invalf
(
fc
,
"cgroup1: noprefix used incorrectly"
);
/* Can't specify "none" and some subsystems */
if
(
ctx
->
subsys_mask
&&
ctx
->
none
)
return
cg_
invalf
(
fc
,
"cgroup1: none used incorrectly"
);
return
invalf
(
fc
,
"cgroup1: none used incorrectly"
);
return
0
;
}
...
...
@@ -1063,7 +1061,7 @@ int cgroup1_reconfigure(struct fs_context *fc)
/* Don't allow flags or name to change at remount */
if
((
ctx
->
flags
^
root
->
flags
)
||
(
ctx
->
name
&&
strcmp
(
ctx
->
name
,
root
->
name
)))
{
cg_inval
f
(
fc
,
"option or name mismatch, new: 0x%x
\"
%s
\"
, old: 0x%x
\"
%s
\"
"
,
error
f
(
fc
,
"option or name mismatch, new: 0x%x
\"
%s
\"
, old: 0x%x
\"
%s
\"
"
,
ctx
->
flags
,
ctx
->
name
?:
""
,
root
->
flags
,
root
->
name
);
ret
=
-
EINVAL
;
goto
out_unlock
;
...
...
@@ -1180,7 +1178,7 @@ static int cgroup1_root_to_use(struct fs_context *fc)
* can't create new one without subsys specification.
*/
if
(
!
ctx
->
subsys_mask
&&
!
ctx
->
none
)
return
cg_
invalf
(
fc
,
"cgroup1: No subsys list or none specified"
);
return
invalf
(
fc
,
"cgroup1: No subsys list or none specified"
);
/* Hierarchies may only be created in the initial cgroup namespace. */
if
(
ctx
->
ns
!=
&
init_cgroup_ns
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录