diff options
| author | Ingo Molnar <mingo@elte.hu> | 2009-10-15 08:07:26 +0200 | 
|---|---|---|
| committer | Ingo Molnar <mingo@elte.hu> | 2009-10-15 08:07:30 +0200 | 
| commit | a0738a688d1105cbf8d71868a1e020c6cdf42d4c (patch) | |
| tree | 2cad553a9def773ce79b8fc793f89c0634187109 /kernel/sched.c | |
| parent | 89ccf465abe6b20d804a63ae20307970c441369d (diff) | |
| parent | a3ccf63ee643ef243cbf8918da8b3f9238f10029 (diff) | |
Merge branch 'linus' into x86/urgent
Merge reason: pull in latest, to be able to revert a patch there.
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'kernel/sched.c')
| -rw-r--r-- | kernel/sched.c | 13 | 
1 files changed, 8 insertions, 5 deletions
| diff --git a/kernel/sched.c b/kernel/sched.c index 76c0e9691fc..e88689522e6 100644 --- a/kernel/sched.c +++ b/kernel/sched.c @@ -676,6 +676,7 @@ inline void update_rq_clock(struct rq *rq)  /**   * runqueue_is_locked + * @cpu: the processor in question.   *   * Returns true if the current cpu runqueue is locked.   * This interface allows printk to be called with the runqueue lock @@ -2311,7 +2312,7 @@ static int try_to_wake_up(struct task_struct *p, unsigned int state,  {  	int cpu, orig_cpu, this_cpu, success = 0;  	unsigned long flags; -	struct rq *rq; +	struct rq *rq, *orig_rq;  	if (!sched_feat(SYNC_WAKEUPS))  		wake_flags &= ~WF_SYNC; @@ -2319,7 +2320,7 @@ static int try_to_wake_up(struct task_struct *p, unsigned int state,  	this_cpu = get_cpu();  	smp_wmb(); -	rq = task_rq_lock(p, &flags); +	rq = orig_rq = task_rq_lock(p, &flags);  	update_rq_clock(rq);  	if (!(p->state & state))  		goto out; @@ -2350,6 +2351,10 @@ static int try_to_wake_up(struct task_struct *p, unsigned int state,  		set_task_cpu(p, cpu);  	rq = task_rq_lock(p, &flags); + +	if (rq != orig_rq) +		update_rq_clock(rq); +  	WARN_ON(p->state != TASK_WAKING);  	cpu = task_cpu(p); @@ -3656,6 +3661,7 @@ static void update_group_power(struct sched_domain *sd, int cpu)  /**   * update_sg_lb_stats - Update sched_group's statistics for load balancing. + * @sd: The sched_domain whose statistics are to be updated.   * @group: sched_group whose statistics are to be updated.   * @this_cpu: Cpu for which load balance is currently performed.   * @idle: Idle status of this_cpu @@ -6718,9 +6724,6 @@ EXPORT_SYMBOL(yield);  /*   * This task is about to go to sleep on IO. Increment rq->nr_iowait so   * that process accounting knows that this is a task in IO wait state. - * - * But don't do that if it is a deliberate, throttling IO wait (this task - * has set its backing_dev_info: the queue against which it should throttle)   */  void __sched io_schedule(void)  { | 
