提交 8d8b97ba 编写于 作者: A Al Viro

take cgroup_open() and cpuset_open() to fs/proc/base.c

Signed-off-by: NAl Viro <viro@zeniv.linux.org.uk>
上级 4c237820
...@@ -404,6 +404,37 @@ static const struct file_operations proc_lstats_operations = { ...@@ -404,6 +404,37 @@ static const struct file_operations proc_lstats_operations = {
#endif #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) static int proc_oom_score(struct task_struct *task, char *buffer)
{ {
unsigned long totalpages = totalram_pages + total_swap_pages; unsigned long totalpages = totalram_pages + total_swap_pages;
......
...@@ -42,7 +42,7 @@ extern int cgroupstats_build(struct cgroupstats *stats, ...@@ -42,7 +42,7 @@ extern int cgroupstats_build(struct cgroupstats *stats,
extern int cgroup_load_subsys(struct cgroup_subsys *ss); extern int cgroup_load_subsys(struct cgroup_subsys *ss);
extern void cgroup_unload_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 the enumeration of all builtin cgroup subsystems */
#define SUBSYS(_x) _x ## _subsys_id, #define SUBSYS(_x) _x ## _subsys_id,
......
...@@ -64,10 +64,9 @@ extern int cpuset_mems_allowed_intersects(const struct task_struct *tsk1, ...@@ -64,10 +64,9 @@ extern int cpuset_mems_allowed_intersects(const struct task_struct *tsk1,
extern int cpuset_memory_pressure_enabled; extern int cpuset_memory_pressure_enabled;
extern void __cpuset_memory_pressure_bump(void); 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, extern void cpuset_task_status_allowed(struct seq_file *m,
struct task_struct *task); struct task_struct *task);
extern int proc_cpuset_show(struct seq_file *, void *);
extern int cpuset_mem_spread_node(void); extern int cpuset_mem_spread_node(void);
extern int cpuset_slab_spread_node(void); extern int cpuset_slab_spread_node(void);
......
...@@ -4769,7 +4769,7 @@ int __init cgroup_init(void) ...@@ -4769,7 +4769,7 @@ int __init cgroup_init(void)
*/ */
/* TODO: Use a proper seq_file iterator */ /* 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 pid *pid;
struct task_struct *tsk; struct task_struct *tsk;
...@@ -4821,19 +4821,6 @@ static int proc_cgroup_show(struct seq_file *m, void *v) ...@@ -4821,19 +4821,6 @@ static int proc_cgroup_show(struct seq_file *m, void *v)
return retval; 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 */ /* Display information about each subsystem and each hierarchy */
static int proc_cgroupstats_show(struct seq_file *m, void *v) static int proc_cgroupstats_show(struct seq_file *m, void *v)
{ {
......
...@@ -2666,7 +2666,7 @@ void __cpuset_memory_pressure_bump(void) ...@@ -2666,7 +2666,7 @@ void __cpuset_memory_pressure_bump(void)
* and we take cpuset_mutex, keeping cpuset_attach() from changing it * and we take cpuset_mutex, keeping cpuset_attach() from changing it
* anyway. * 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 pid *pid;
struct task_struct *tsk; struct task_struct *tsk;
...@@ -2700,19 +2700,6 @@ static int proc_cpuset_show(struct seq_file *m, void *unused_v) ...@@ -2700,19 +2700,6 @@ static int proc_cpuset_show(struct seq_file *m, void *unused_v)
out: out:
return retval; 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 */ #endif /* CONFIG_PROC_PID_CPUSET */
/* Display task mems_allowed in /proc/<pid>/status file. */ /* 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.
先完成此消息的编辑!
想要评论请 注册