blob: 8bd047142816dea81894bb27ccc3c78a38ac3d61 [file] [log] [blame]
Mike Galbraith5091faa2010-11-30 14:18:03 +01001#ifdef CONFIG_SCHED_AUTOGROUP
2
Peter Zijlstra029632f2011-10-25 10:00:11 +02003#include <linux/kref.h>
4#include <linux/rwsem.h>
5
Mike Galbraith5091faa2010-11-30 14:18:03 +01006struct autogroup {
Ingo Molnarc1ad41f2012-12-11 10:23:45 +01007 /*
8 * reference doesn't mean how many thread attach to this
9 * autogroup now. It just stands for the number of task
10 * could use this autogroup.
11 */
Mike Galbraith5091faa2010-11-30 14:18:03 +010012 struct kref kref;
13 struct task_group *tg;
14 struct rw_semaphore lock;
15 unsigned long id;
16 int nice;
17};
18
Peter Zijlstra029632f2011-10-25 10:00:11 +020019extern void autogroup_init(struct task_struct *init_task);
20extern void autogroup_free(struct task_group *tg);
21
22static inline bool task_group_is_autogroup(struct task_group *tg)
23{
24 return !!tg->autogroup;
25}
26
27extern bool task_wants_autogroup(struct task_struct *p, struct task_group *tg);
28
Mike Galbraith5091faa2010-11-30 14:18:03 +010029static inline struct task_group *
Peter Zijlstra029632f2011-10-25 10:00:11 +020030autogroup_task_group(struct task_struct *p, struct task_group *tg)
31{
Ingo Molnarc1ad41f2012-12-11 10:23:45 +010032 int enabled = ACCESS_ONCE(sysctl_sched_autogroup_enabled);
33
34 if (enabled && task_wants_autogroup(p, tg))
Peter Zijlstra029632f2011-10-25 10:00:11 +020035 return p->signal->autogroup->tg;
36
37 return tg;
38}
39
40extern int autogroup_path(struct task_group *tg, char *buf, int buflen);
Mike Galbraith5091faa2010-11-30 14:18:03 +010041
42#else /* !CONFIG_SCHED_AUTOGROUP */
43
44static inline void autogroup_init(struct task_struct *init_task) { }
45static inline void autogroup_free(struct task_group *tg) { }
Mike Galbraithf4493772011-01-13 04:54:50 +010046static inline bool task_group_is_autogroup(struct task_group *tg)
47{
48 return 0;
49}
Mike Galbraith5091faa2010-11-30 14:18:03 +010050
51static inline struct task_group *
52autogroup_task_group(struct task_struct *p, struct task_group *tg)
53{
54 return tg;
55}
56
57#ifdef CONFIG_SCHED_DEBUG
58static inline int autogroup_path(struct task_group *tg, char *buf, int buflen)
59{
60 return 0;
61}
62#endif
63
64#endif /* CONFIG_SCHED_AUTOGROUP */