Re: [PATCH v8 0/9] rwsem performance optimizations

From: Ingo Molnar
Date: Fri Oct 18 2013 - 02:52:18 EST



* Tim Chen <tim.c.chen@xxxxxxxxxxxxxxx> wrote:

>
> >
> > It would be _really_ nice to stick this into tools/perf/bench/ as:
> >
> > perf bench mem pagefaults
> >
> > or so, with a number of parallelism and workload patterns. See
> > tools/perf/bench/numa.c for a couple of workload generators - although
> > those are not page fault intense.
> >
> > So that future generations can run all these tests too and such.
> >
> > > I compare the throughput where I have the complete rwsem patchset
> > > against vanilla and the case where I take out the optimistic spin patch.
> > > I have increased the run time by 10x from my pervious experiments and do
> > > 10 runs for each case. The standard deviation is ~1.5% so any changes
> > > under 1.5% is statistically significant.
> > >
> > > % change in throughput vs the vanilla kernel.
> > > Threads all No-optspin
> > > 1 +0.4% -0.1%
> > > 2 +2.0% +0.2%
> > > 3 +1.1% +1.5%
> > > 4 -0.5% -1.4%
> > > 5 -0.1% -0.1%
> > > 10 +2.2% -1.2%
> > > 20 +237.3% -2.3%
> > > 40 +548.1% +0.3%
> >
> > The tail is impressive. The early parts are important as well, but it's
> > really hard to tell the significance of the early portion without having
> > an sttdev column.
> >
> > ( "perf stat --repeat N" will give you sttdev output, in handy percentage
> > form. )
>
> Quick naive question as I haven't hacked perf bench before.

Btw., please use tip:master, I've got a few cleanups in there that should
make it easier to hack.

> Now perf stat gives the statistics of the performance counter or events.
> How do I get it to compute the stats of
> the throughput reported by perf bench?

What I do is that I measure the execution time, via:

perf stat --null --repeat 10 perf bench ...

instead of relying on benchmark output.

> Something like
>
> perf stat -r 10 -- perf bench mm memset --iterations 10
>
> doesn't quite give what I need.

Yeha. So, perf bench also has a 'simple' output format:

comet:~/tip> perf bench -f simple sched pipe
10.378

We could extend 'perf stat' with an option to not measure time, but to
take any numeric data output from the executed task and use that as the
measurement result.

If you'd be interested in such a feature I can give it a try.

Thanks,

Ingo
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/