Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
kernel_linux
提交
8d8b97ba
K
kernel_linux
项目概览
OpenHarmony
/
kernel_linux
上一次同步 3 年多
通知
13
Star
8
Fork
2
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
K
kernel_linux
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
提交
8d8b97ba
编写于
4月 19, 2013
作者:
A
Al Viro
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
take cgroup_open() and cpuset_open() to fs/proc/base.c
Signed-off-by:
N
Al Viro
<
viro@zeniv.linux.org.uk
>
上级
4c237820
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
35 addition
and
31 deletion
+35
-31
fs/proc/base.c
fs/proc/base.c
+31
-0
include/linux/cgroup.h
include/linux/cgroup.h
+1
-1
include/linux/cpuset.h
include/linux/cpuset.h
+1
-2
kernel/cgroup.c
kernel/cgroup.c
+1
-14
kernel/cpuset.c
kernel/cpuset.c
+1
-14
未找到文件。
fs/proc/base.c
浏览文件 @
8d8b97ba
...
...
@@ -404,6 +404,37 @@ static const struct file_operations proc_lstats_operations = {
#endif
#ifdef CONFIG_CGROUPS
static
int
cgroup_open
(
struct
inode
*
inode
,
struct
file
*
file
)
{
struct
pid
*
pid
=
PROC_I
(
inode
)
->
pid
;
return
single_open
(
file
,
proc_cgroup_show
,
pid
);
}
static
const
struct
file_operations
proc_cgroup_operations
=
{
.
open
=
cgroup_open
,
.
read
=
seq_read
,
.
llseek
=
seq_lseek
,
.
release
=
single_release
,
};
#endif
#ifdef CONFIG_PROC_PID_CPUSET
static
int
cpuset_open
(
struct
inode
*
inode
,
struct
file
*
file
)
{
struct
pid
*
pid
=
PROC_I
(
inode
)
->
pid
;
return
single_open
(
file
,
proc_cpuset_show
,
pid
);
}
static
const
struct
file_operations
proc_cpuset_operations
=
{
.
open
=
cpuset_open
,
.
read
=
seq_read
,
.
llseek
=
seq_lseek
,
.
release
=
single_release
,
};
#endif
static
int
proc_oom_score
(
struct
task_struct
*
task
,
char
*
buffer
)
{
unsigned
long
totalpages
=
totalram_pages
+
total_swap_pages
;
...
...
include/linux/cgroup.h
浏览文件 @
8d8b97ba
...
...
@@ -42,7 +42,7 @@ extern int cgroupstats_build(struct cgroupstats *stats,
extern
int
cgroup_load_subsys
(
struct
cgroup_subsys
*
ss
);
extern
void
cgroup_unload_subsys
(
struct
cgroup_subsys
*
ss
);
extern
const
struct
file_operations
proc_cgroup_operations
;
extern
int
proc_cgroup_show
(
struct
seq_file
*
,
void
*
)
;
/* Define the enumeration of all builtin cgroup subsystems */
#define SUBSYS(_x) _x ## _subsys_id,
...
...
include/linux/cpuset.h
浏览文件 @
8d8b97ba
...
...
@@ -64,10 +64,9 @@ extern int cpuset_mems_allowed_intersects(const struct task_struct *tsk1,
extern
int
cpuset_memory_pressure_enabled
;
extern
void
__cpuset_memory_pressure_bump
(
void
);
extern
const
struct
file_operations
proc_cpuset_operations
;
struct
seq_file
;
extern
void
cpuset_task_status_allowed
(
struct
seq_file
*
m
,
struct
task_struct
*
task
);
extern
int
proc_cpuset_show
(
struct
seq_file
*
,
void
*
);
extern
int
cpuset_mem_spread_node
(
void
);
extern
int
cpuset_slab_spread_node
(
void
);
...
...
kernel/cgroup.c
浏览文件 @
8d8b97ba
...
...
@@ -4769,7 +4769,7 @@ int __init cgroup_init(void)
*/
/* TODO: Use a proper seq_file iterator */
static
int
proc_cgroup_show
(
struct
seq_file
*
m
,
void
*
v
)
int
proc_cgroup_show
(
struct
seq_file
*
m
,
void
*
v
)
{
struct
pid
*
pid
;
struct
task_struct
*
tsk
;
...
...
@@ -4821,19 +4821,6 @@ static int proc_cgroup_show(struct seq_file *m, void *v)
return
retval
;
}
static
int
cgroup_open
(
struct
inode
*
inode
,
struct
file
*
file
)
{
struct
pid
*
pid
=
PROC_I
(
inode
)
->
pid
;
return
single_open
(
file
,
proc_cgroup_show
,
pid
);
}
const
struct
file_operations
proc_cgroup_operations
=
{
.
open
=
cgroup_open
,
.
read
=
seq_read
,
.
llseek
=
seq_lseek
,
.
release
=
single_release
,
};
/* Display information about each subsystem and each hierarchy */
static
int
proc_cgroupstats_show
(
struct
seq_file
*
m
,
void
*
v
)
{
...
...
kernel/cpuset.c
浏览文件 @
8d8b97ba
...
...
@@ -2666,7 +2666,7 @@ void __cpuset_memory_pressure_bump(void)
* and we take cpuset_mutex, keeping cpuset_attach() from changing it
* anyway.
*/
static
int
proc_cpuset_show
(
struct
seq_file
*
m
,
void
*
unused_v
)
int
proc_cpuset_show
(
struct
seq_file
*
m
,
void
*
unused_v
)
{
struct
pid
*
pid
;
struct
task_struct
*
tsk
;
...
...
@@ -2700,19 +2700,6 @@ static int proc_cpuset_show(struct seq_file *m, void *unused_v)
out:
return
retval
;
}
static
int
cpuset_open
(
struct
inode
*
inode
,
struct
file
*
file
)
{
struct
pid
*
pid
=
PROC_I
(
inode
)
->
pid
;
return
single_open
(
file
,
proc_cpuset_show
,
pid
);
}
const
struct
file_operations
proc_cpuset_operations
=
{
.
open
=
cpuset_open
,
.
read
=
seq_read
,
.
llseek
=
seq_lseek
,
.
release
=
single_release
,
};
#endif
/* CONFIG_PROC_PID_CPUSET */
/* Display task mems_allowed in /proc/<pid>/status file. */
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录