[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <1262052582.10685.59.camel@minggr.sh.intel.com>
Date:	Tue, 29 Dec 2009 10:09:42 +0800
From:	Lin Ming <ming.m.lin@...el.com>
To:	Mike Galbraith <efault@....de>
Cc:	"peterz@...radead.org" <peterz@...radead.org>,
	"mingo@...e.hu" <mingo@...e.hu>,
	"tglx@...utronix.de" <tglx@...utronix.de>,
	linux-kernel <linux-kernel@...r.kernel.org>,
	"Zhang, Yanmin" <yanmin_zhang@...ux.intel.com>
Subject: Re: tbench regression with 2.6.33-rc1
On Sun, 2009-12-27 at 16:32 +0800, Mike Galbraith wrote:
> On Fri, 2009-12-25 at 19:11 +0800, Lin Ming wrote:
> > Hi,
> > 
> > Test machine: 16 cpus (4P/2Core/HT), 8G mem
> > tbench test command:
> > tbench_srv &
> > tbench 32
> > 
> > Compared with 2.6.32, tbench has ~4% regression in 2.6.33-rc1.
> > 
> > >>From vmstat data, the context switch number also drop ~4%.
> > perf top data does not show much differences.
> > 
> > But lockstat data shows huge difference in rq->lock, as below.
> > See the attachment for the full lockstat data.
> > 
> > Any clue of this regression?
> 
> Nope, but I see regression I haven't been able to identify as well.
Hi, Mike
More info here,
I only saw regression on Tulsa machine.
No regression on Nehalem core 2 machine.
And also no regression if I run tbench with RT scheduler on tulsa
machine, as below command,
schedtool -R -p 20 -e tbench_srv &
schedtool -R -p 20 -e tbench 32
So seems this regression is CFS scheduler related.
I also did a lot of bisect, but the result was not stable.
Looks like this regression was not caused by a single commit.
Lin Ming
> 
> Tbench state of the union according to my box below.
> 
> With a max performance config, 32.2 is down ~4% vs 31.9, most of which
> is doing affinity checks on every wakeup.  That has it's benefits too,
> but definitely ain't free, or even particularly cheap for fast movers.
> Would be nice to find a way to keep the ramp-up improvements without
> this much cost.
> 
> Perf also isn't free, and in 33, we lost the ability to config it out,
> but even doing so via axe, there's an unidentified regression.
> 
> As usual, bisection of tbench variance was a wasted effort.
> 
> 2.6.31.9  = -CONFIG_PERF_COUNTERS
> 2.6.31.9p = +CONFIG_PERF_COUNTERS
> 2.6.32.2  = -CONFIG_PERF_EVENTS
> 2.6.32.2p = +CONFIG_PERF_EVENTS
> git = v2.6.33-rc2
> tip = v2.6.33-rc1-306-gae7a88c
> 
> tbench 8
> 2.6.31.9             1190 MB/sec
> 2.6.31.9p            1172 MB/sec  .984
> 2.6.32.2             1146 MB/sec  .977 vs 31.9 .963
> 2.6.32.2p            1129 MB/sec  .985 vs 31.9 .948
> 2.6.33.git           1117 MB/sec  .989 vs 31.9 .938
> 2.6.33.tip           1121 MB/sec 1.003 vs 31.9 .942
> 
> 2.6.32.2             1146 MB/sec 1.000
> 2.6.32.2x            1181 MB/sec 1.030 vs 31.9 .992
> 
> 2.6.33.git           1117 MB/sec 1.000
> 2.6.33.gitx          1145 MB/sec 1.025 vs 32.2x .969 vs 31.9 .962  (perf/hwbp off via axe)
> 
> 2.6.32.2x diff
> diff --git a/kernel/sched.c b/kernel/sched.c
> index d079a9f..b71cb91 100644
> --- a/kernel/sched.c
> +++ b/kernel/sched.c
> @@ -2363,6 +2363,9 @@ static int try_to_wake_up(struct task_struct *p, unsigned int state,
>  	orig_cpu = cpu;
>  
>  #ifdef CONFIG_SMP
> +	if (cpu == this_cpu)
> +		goto out_stats;
> +
>  	if (unlikely(task_running(rq, p)))
>  		goto out_activate;
>  
> @@ -2389,6 +2392,7 @@ static int try_to_wake_up(struct task_struct *p, unsigned int state,
>  	WARN_ON(p->state != TASK_WAKING);
>  	cpu = task_cpu(p);
>  
> +out_stats:
>  #ifdef CONFIG_SCHEDSTATS
>  	schedstat_inc(rq, ttwu_count);
>  	if (cpu == this_cpu)
> 
> 
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/
Powered by blists - more mailing lists
 
