Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 210449
b: refs/heads/master
c: 31583bb
h: refs/heads/master
i:
  210447: 0509e57
v: v3
  • Loading branch information
Michael S. Tsirkin authored and Linus Torvalds committed Sep 10, 2010
1 parent 40f2644 commit 21280c5
Show file tree
Hide file tree
Showing 3 changed files with 19 additions and 8 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: ed430fec756ad65f7cfba24f8ad17c3d5a403290
refs/heads/master: 31583bb0cf6cc40f2a468a4d2f3b9cbefd24f891
12 changes: 11 additions & 1 deletion trunk/include/linux/cgroup.h
Original file line number Diff line number Diff line change
Expand Up @@ -578,7 +578,12 @@ struct task_struct *cgroup_iter_next(struct cgroup *cgrp,
void cgroup_iter_end(struct cgroup *cgrp, struct cgroup_iter *it);
int cgroup_scan_tasks(struct cgroup_scanner *scan);
int cgroup_attach_task(struct cgroup *, struct task_struct *);
int cgroup_attach_task_current_cg(struct task_struct *);
int cgroup_attach_task_all(struct task_struct *from, struct task_struct *);

static inline int cgroup_attach_task_current_cg(struct task_struct *tsk)
{
return cgroup_attach_task_all(current, tsk);
}

/*
* CSS ID is ID for cgroup_subsys_state structs under subsys. This only works
Expand Down Expand Up @@ -636,6 +641,11 @@ static inline int cgroupstats_build(struct cgroupstats *stats,
}

/* No cgroups - nothing to do */
static inline int cgroup_attach_task_all(struct task_struct *from,
struct task_struct *t)
{
return 0;
}
static inline int cgroup_attach_task_current_cg(struct task_struct *t)
{
return 0;
Expand Down
13 changes: 7 additions & 6 deletions trunk/kernel/cgroup.c
Original file line number Diff line number Diff line change
Expand Up @@ -1791,27 +1791,28 @@ int cgroup_attach_task(struct cgroup *cgrp, struct task_struct *tsk)
}

/**
* cgroup_attach_task_current_cg - attach task 'tsk' to current task's cgroup
* cgroup_attach_task_all - attach task 'tsk' to all cgroups of task 'from'
* @from: attach to all cgroups of a given task
* @tsk: the task to be attached
*/
int cgroup_attach_task_current_cg(struct task_struct *tsk)
int cgroup_attach_task_all(struct task_struct *from, struct task_struct *tsk)
{
struct cgroupfs_root *root;
struct cgroup *cur_cg;
int retval = 0;

cgroup_lock();
for_each_active_root(root) {
cur_cg = task_cgroup_from_root(current, root);
retval = cgroup_attach_task(cur_cg, tsk);
struct cgroup *from_cg = task_cgroup_from_root(from, root);

retval = cgroup_attach_task(from_cg, tsk);
if (retval)
break;
}
cgroup_unlock();

return retval;
}
EXPORT_SYMBOL_GPL(cgroup_attach_task_current_cg);
EXPORT_SYMBOL_GPL(cgroup_attach_task_all);

/*
* Attach task with pid 'pid' to cgroup 'cgrp'. Call with cgroup_mutex
Expand Down

0 comments on commit 21280c5

Please sign in to comment.