| Mike Galbraith | 5091faa | 2010-11-30 14:18:03 +0100 | [diff] [blame] | 1 | #ifdef CONFIG_SCHED_AUTOGROUP | 
 | 2 |  | 
| Peter Zijlstra | 029632f | 2011-10-25 10:00:11 +0200 | [diff] [blame] | 3 | #include <linux/kref.h> | 
 | 4 | #include <linux/rwsem.h> | 
 | 5 |  | 
| Mike Galbraith | 5091faa | 2010-11-30 14:18:03 +0100 | [diff] [blame] | 6 | struct autogroup { | 
| Yong Zhang | 800d4d3 | 2011-02-20 15:08:14 +0800 | [diff] [blame] | 7 | 	/* | 
 | 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 Galbraith | 5091faa | 2010-11-30 14:18:03 +0100 | [diff] [blame] | 12 | 	struct kref		kref; | 
 | 13 | 	struct task_group	*tg; | 
 | 14 | 	struct rw_semaphore	lock; | 
 | 15 | 	unsigned long		id; | 
 | 16 | 	int			nice; | 
 | 17 | }; | 
 | 18 |  | 
| Peter Zijlstra | 029632f | 2011-10-25 10:00:11 +0200 | [diff] [blame] | 19 | extern void autogroup_init(struct task_struct *init_task); | 
 | 20 | extern void autogroup_free(struct task_group *tg); | 
 | 21 |  | 
 | 22 | static inline bool task_group_is_autogroup(struct task_group *tg) | 
 | 23 | { | 
 | 24 | 	return !!tg->autogroup; | 
 | 25 | } | 
 | 26 |  | 
 | 27 | extern bool task_wants_autogroup(struct task_struct *p, struct task_group *tg); | 
 | 28 |  | 
| Mike Galbraith | 5091faa | 2010-11-30 14:18:03 +0100 | [diff] [blame] | 29 | static inline struct task_group * | 
| Peter Zijlstra | 029632f | 2011-10-25 10:00:11 +0200 | [diff] [blame] | 30 | autogroup_task_group(struct task_struct *p, struct task_group *tg) | 
 | 31 | { | 
 | 32 | 	int enabled = ACCESS_ONCE(sysctl_sched_autogroup_enabled); | 
 | 33 |  | 
 | 34 | 	if (enabled && task_wants_autogroup(p, tg)) | 
 | 35 | 		return p->signal->autogroup->tg; | 
 | 36 |  | 
 | 37 | 	return tg; | 
 | 38 | } | 
 | 39 |  | 
 | 40 | extern int autogroup_path(struct task_group *tg, char *buf, int buflen); | 
| Mike Galbraith | 5091faa | 2010-11-30 14:18:03 +0100 | [diff] [blame] | 41 |  | 
 | 42 | #else /* !CONFIG_SCHED_AUTOGROUP */ | 
 | 43 |  | 
 | 44 | static inline void autogroup_init(struct task_struct *init_task) {  } | 
 | 45 | static inline void autogroup_free(struct task_group *tg) { } | 
| Mike Galbraith | f449377 | 2011-01-13 04:54:50 +0100 | [diff] [blame] | 46 | static inline bool task_group_is_autogroup(struct task_group *tg) | 
 | 47 | { | 
 | 48 | 	return 0; | 
 | 49 | } | 
| Mike Galbraith | 5091faa | 2010-11-30 14:18:03 +0100 | [diff] [blame] | 50 |  | 
 | 51 | static inline struct task_group * | 
 | 52 | autogroup_task_group(struct task_struct *p, struct task_group *tg) | 
 | 53 | { | 
 | 54 | 	return tg; | 
 | 55 | } | 
 | 56 |  | 
 | 57 | #ifdef CONFIG_SCHED_DEBUG | 
 | 58 | static 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 */ |