public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* bug in sched.c:task_hot()
@ 2004-10-05  2:38 Chen, Kenneth W
  2004-10-05  3:17 ` Nick Piggin
                   ` (2 more replies)
  0 siblings, 3 replies; 11+ messages in thread
From: Chen, Kenneth W @ 2004-10-05  2:38 UTC (permalink / raw)
  To: linux-kernel

Current implementation of task_hot() has a performance bug in it
that it will cause integer underflow.

Variable "now" (typically passed in as rq->timestamp_last_tick)
and p->timestamp are all defined as unsigned long long.  However,
If former is smaller than the latter, integer under flow occurs
which make the result of subtraction a huge positive number. Then
it is compared to sd->cache_hot_time and it will wrongly identify
a cache hot task as cache cold.

This bug causes large amount of incorrect process migration across
cpus (at stunning 10,000 per second) and we lost cache affinity very
quickly and almost took double digit performance regression on a db
transaction processing workload.  Patch to fix the bug.  Diff'ed against
2.6.9-rc3.

Signed-off-by: Ken Chen <kenneth.w.chen@intel.com>


--- linux-2.6.9-rc3/kernel/sched.c.orig	2004-10-04 19:11:21.000000000 -0700
+++ linux-2.6.9-rc3/kernel/sched.c	2004-10-04 19:19:27.000000000 -0700
@@ -180,7 +180,8 @@ static unsigned int task_timeslice(task_
 	else
 		return SCALE_PRIO(DEF_TIMESLICE, p->static_prio);
 }
-#define task_hot(p, now, sd) ((now) - (p)->timestamp < (sd)->cache_hot_time)
+#define task_hot(p, now, sd) ((long long) ((now) - (p)->timestamp)	\
+				< (long long) (sd)->cache_hot_time)

 enum idle_type
 {



^ permalink raw reply	[flat|nested] 11+ messages in thread

end of thread, other threads:[~2004-10-05 22:09 UTC | newest]

Thread overview: 11+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2004-10-05  2:38 bug in sched.c:task_hot() Chen, Kenneth W
2004-10-05  3:17 ` Nick Piggin
2004-10-05 17:15   ` Chen, Kenneth W
2004-10-05  7:33 ` Peter Williams
2004-10-05  7:44   ` Nick Piggin
2004-10-05  8:07     ` Peter Williams
2004-10-05  8:42       ` Nick Piggin
2004-10-05 10:03         ` Peter Williams
2004-10-05 17:39   ` Chen, Kenneth W
2004-10-05 22:09     ` Peter Williams
2004-10-05  8:03 ` Ingo Molnar

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox