aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--include/linux/cgroup.h7
-rw-r--r--kernel/cgroup.c23
2 files changed, 30 insertions, 0 deletions
diff --git a/include/linux/cgroup.h b/include/linux/cgroup.h
index 0c621604baa1..e0aa067d1b11 100644
--- a/include/linux/cgroup.h
+++ b/include/linux/cgroup.h
@@ -570,6 +570,7 @@ struct task_struct *cgroup_iter_next(struct cgroup *cgrp,
570void cgroup_iter_end(struct cgroup *cgrp, struct cgroup_iter *it); 570void cgroup_iter_end(struct cgroup *cgrp, struct cgroup_iter *it);
571int cgroup_scan_tasks(struct cgroup_scanner *scan); 571int cgroup_scan_tasks(struct cgroup_scanner *scan);
572int cgroup_attach_task(struct cgroup *, struct task_struct *); 572int cgroup_attach_task(struct cgroup *, struct task_struct *);
573int cgroup_attach_task_current_cg(struct task_struct *);
573 574
574/* 575/*
575 * CSS ID is ID for cgroup_subsys_state structs under subsys. This only works 576 * CSS ID is ID for cgroup_subsys_state structs under subsys. This only works
@@ -626,6 +627,12 @@ static inline int cgroupstats_build(struct cgroupstats *stats,
626 return -EINVAL; 627 return -EINVAL;
627} 628}
628 629
630/* No cgroups - nothing to do */
631static inline int cgroup_attach_task_current_cg(struct task_struct *t)
632{
633 return 0;
634}
635
629#endif /* !CONFIG_CGROUPS */ 636#endif /* !CONFIG_CGROUPS */
630 637
631#endif /* _LINUX_CGROUP_H */ 638#endif /* _LINUX_CGROUP_H */
diff --git a/kernel/cgroup.c b/kernel/cgroup.c
index 422cb19f156e..37642ad9cca8 100644
--- a/kernel/cgroup.c
+++ b/kernel/cgroup.c
@@ -1788,6 +1788,29 @@ out:
1788 return retval; 1788 return retval;
1789} 1789}
1790 1790
1791/**
1792 * cgroup_attach_task_current_cg - attach task 'tsk' to current task's cgroup
1793 * @tsk: the task to be attached
1794 */
1795int cgroup_attach_task_current_cg(struct task_struct *tsk)
1796{
1797 struct cgroupfs_root *root;
1798 struct cgroup *cur_cg;
1799 int retval = 0;
1800
1801 cgroup_lock();
1802 for_each_active_root(root) {
1803 cur_cg = task_cgroup_from_root(current, root);
1804 retval = cgroup_attach_task(cur_cg, tsk);
1805 if (retval)
1806 break;
1807 }
1808 cgroup_unlock();
1809
1810 return retval;
1811}
1812EXPORT_SYMBOL_GPL(cgroup_attach_task_current_cg);
1813
1791/* 1814/*
1792 * Attach task with pid 'pid' to cgroup 'cgrp'. Call with cgroup_mutex 1815 * Attach task with pid 'pid' to cgroup 'cgrp'. Call with cgroup_mutex
1793 * held. May take task_lock of task 1816 * held. May take task_lock of task