diff options
| author | Olof Johansson <olof@lixom.net> | 2012-09-05 15:35:48 -0700 | 
|---|---|---|
| committer | Olof Johansson <olof@lixom.net> | 2012-09-05 15:35:48 -0700 | 
| commit | 1875962377574b4edb7b164001e3e341c25290d5 (patch) | |
| tree | 374a5299403ec21e2d9a66a6548ce876a388b589 /kernel/sched/core.c | |
| parent | 5cbee140a28c2746449ae31e85738043ae4da927 (diff) | |
| parent | c88a79a7789b2909ad1cf69ea2c9142030bbd6f4 (diff) | |
| download | olio-linux-3.10-1875962377574b4edb7b164001e3e341c25290d5.tar.xz olio-linux-3.10-1875962377574b4edb7b164001e3e341c25290d5.zip  | |
Merge branch 'soc-core' of git://git.kernel.org/pub/scm/linux/kernel/git/horms/renesas into next/dt
* 'soc-core' of git://git.kernel.org/pub/scm/linux/kernel/git/horms/renesas:
  ARM: mach-shmobile: Add compilation support for dtbs using 'make dtbs'
  + sync to 3.6-rc3
Diffstat (limited to 'kernel/sched/core.c')
| -rw-r--r-- | kernel/sched/core.c | 39 | 
1 files changed, 22 insertions, 17 deletions
diff --git a/kernel/sched/core.c b/kernel/sched/core.c index d325c4b2dcb..fbf1fd098dc 100644 --- a/kernel/sched/core.c +++ b/kernel/sched/core.c @@ -3142,6 +3142,20 @@ void thread_group_times(struct task_struct *p, cputime_t *ut, cputime_t *st)  # define nsecs_to_cputime(__nsecs)	nsecs_to_jiffies(__nsecs)  #endif +static cputime_t scale_utime(cputime_t utime, cputime_t rtime, cputime_t total) +{ +	u64 temp = (__force u64) rtime; + +	temp *= (__force u64) utime; + +	if (sizeof(cputime_t) == 4) +		temp = div_u64(temp, (__force u32) total); +	else +		temp = div64_u64(temp, (__force u64) total); + +	return (__force cputime_t) temp; +} +  void task_times(struct task_struct *p, cputime_t *ut, cputime_t *st)  {  	cputime_t rtime, utime = p->utime, total = utime + p->stime; @@ -3151,13 +3165,9 @@ void task_times(struct task_struct *p, cputime_t *ut, cputime_t *st)  	 */  	rtime = nsecs_to_cputime(p->se.sum_exec_runtime); -	if (total) { -		u64 temp = (__force u64) rtime; - -		temp *= (__force u64) utime; -		do_div(temp, (__force u32) total); -		utime = (__force cputime_t) temp; -	} else +	if (total) +		utime = scale_utime(utime, rtime, total); +	else  		utime = rtime;  	/* @@ -3184,13 +3194,9 @@ void thread_group_times(struct task_struct *p, cputime_t *ut, cputime_t *st)  	total = cputime.utime + cputime.stime;  	rtime = nsecs_to_cputime(cputime.sum_exec_runtime); -	if (total) { -		u64 temp = (__force u64) rtime; - -		temp *= (__force u64) cputime.utime; -		do_div(temp, (__force u32) total); -		utime = (__force cputime_t) temp; -	} else +	if (total) +		utime = scale_utime(cputime.utime, rtime, total); +	else  		utime = rtime;  	sig->prev_utime = max(sig->prev_utime, utime); @@ -4340,9 +4346,7 @@ recheck:  	 */  	if (unlikely(policy == p->policy && (!rt_policy(policy) ||  			param->sched_priority == p->rt_priority))) { - -		__task_rq_unlock(rq); -		raw_spin_unlock_irqrestore(&p->pi_lock, flags); +		task_rq_unlock(rq, p, &flags);  		return 0;  	} @@ -7248,6 +7252,7 @@ int in_sched_functions(unsigned long addr)  #ifdef CONFIG_CGROUP_SCHED  struct task_group root_task_group; +LIST_HEAD(task_groups);  #endif  DECLARE_PER_CPU(cpumask_var_t, load_balance_tmpmask);  |