diff options
Diffstat (limited to 'kernel/sched.c')
| -rw-r--r-- | kernel/sched.c | 26 | 
1 files changed, 21 insertions, 5 deletions
| diff --git a/kernel/sched.c b/kernel/sched.c index ea3e5eff3878..18d38e4ec7ba 100644 --- a/kernel/sched.c +++ b/kernel/sched.c @@ -553,9 +553,6 @@ struct rq {  	/* try_to_wake_up() stats */  	unsigned int ttwu_count;  	unsigned int ttwu_local; - -	/* BKL stats */ -	unsigned int bkl_count;  #endif  }; @@ -609,6 +606,9 @@ static inline struct task_group *task_group(struct task_struct *p)  	struct task_group *tg;  	struct cgroup_subsys_state *css; +	if (p->flags & PF_EXITING) +		return &root_task_group; +  	css = task_subsys_state_check(p, cpu_cgroup_subsys_id,  			lockdep_is_held(&task_rq(p)->lock));  	tg = container_of(css, struct task_group, css); @@ -3887,7 +3887,7 @@ static inline void schedule_debug(struct task_struct *prev)  	schedstat_inc(this_rq(), sched_count);  #ifdef CONFIG_SCHEDSTATS  	if (unlikely(prev->lock_depth >= 0)) { -		schedstat_inc(this_rq(), bkl_count); +		schedstat_inc(this_rq(), rq_sched_info.bkl_count);  		schedstat_inc(prev, sched_info.bkl_count);  	}  #endif @@ -4871,7 +4871,8 @@ recheck:  		 * assigned.  		 */  		if (rt_bandwidth_enabled() && rt_policy(policy) && -				task_group(p)->rt_bandwidth.rt_runtime == 0) { +				task_group(p)->rt_bandwidth.rt_runtime == 0 && +				!task_group_is_autogroup(task_group(p))) {  			__task_rq_unlock(rq);  			raw_spin_unlock_irqrestore(&p->pi_lock, flags);  			return -EPERM; @@ -8882,6 +8883,20 @@ cpu_cgroup_attach(struct cgroup_subsys *ss, struct cgroup *cgrp,  	}  } +static void +cpu_cgroup_exit(struct cgroup_subsys *ss, struct task_struct *task) +{ +	/* +	 * cgroup_exit() is called in the copy_process() failure path. +	 * Ignore this case since the task hasn't ran yet, this avoids +	 * trying to poke a half freed task state from generic code. +	 */ +	if (!(task->flags & PF_EXITING)) +		return; + +	sched_move_task(task); +} +  #ifdef CONFIG_FAIR_GROUP_SCHED  static int cpu_shares_write_u64(struct cgroup *cgrp, struct cftype *cftype,  				u64 shareval) @@ -8954,6 +8969,7 @@ struct cgroup_subsys cpu_cgroup_subsys = {  	.destroy	= cpu_cgroup_destroy,  	.can_attach	= cpu_cgroup_can_attach,  	.attach		= cpu_cgroup_attach, +	.exit		= cpu_cgroup_exit,  	.populate	= cpu_cgroup_populate,  	.subsys_id	= cpu_cgroup_subsys_id,  	.early_init	= 1, |