Re: [Qemu-devel] [PATCH] KVM: Add wrapper script around QEMU to testkernels

From: Vince Weaver
Date: Tue Nov 08 2011 - 00:29:41 EST


On Mon, 7 Nov 2011, Ingo Molnar wrote:
> I think we needed to do only one revert along the way in the past two
> years, to fix an unintended ABI breakage in PowerTop. Considering the
> total complexity of the perf ABI our compatibility track record is
> *very* good.

There have been more breakages, as you know. It's just they weren't
caught in time so they were declared to be grandfathered in rather
than fixed.

> Pekka, Vince has meanwhile become the resident perf critic on lkml,
> always in it when it comes to some perf-bashing:

For what it's worth you'll find commits from me in the qemu tree, and I
also oppose the merge of kvm-tool into the Linux tree.

> ... and you have argued against perf from the very first day on, when
> you were one of the perfmon developers - and IMO in hindsight you've
> been repeatedly wrong about most of your design arguments.

I can't find an exact e-mail, but I seem to recall my arguments were that
Pentium 4 support would be hard (it was), that in-kernel generalized
events were a bad idea (I still think that, try talking to the ARM guys
sometime about that) and that making access to raw events hard (by not
using a naming library) was silly. I'm sure I probably said other things
that were eventually addressed.

> The PAPI project has the (fundamental) problem that you are still
> doing it in the old-style sw design fashion, with many months long
> delays in testing, and then you are blaming the problems you
> inevitably meet with that model on *us*.

The fundamental problem with the PAPI project is that we only have 3
full-time developers, and we have to make sure PAPI runs on about 10
different platforms, of which perf_events/Linux is only one.

Time I waste tracking down perf_event ABI regressions and DoS bugs
takes away from actual useful userspace PAPI development.

> There was one PAPI incident i remember where it took you several
> *months* to report a regression in a regular PAPI test-case (no
> actual app affected as far as i know). No other tester ever ran the
> PAPI testcases so nobody else reported it.

We have a huge userbase. They run on some pretty amazing machines and
do some tests that strain perf libraries to the limit.
They also tend to use distro kernels, assuming they even have moved to
2.6.31+ kernels yet. When these power users report problems, they aren't
going to be against the -tip tree.

> Nobody but you tests PAPI so you need to become *part* of the
> upstream development process, which releases a new upstream kernel
> every 3 months.

PAPI is a free software project, with the devel tree available from CVS.
It takes maybe 15 minutes to run the full PAPI regression suite.
I encourage you or any perf developer to try it and report any issues.

I can only be so comprehensive. I didn't find the current NMI-watchdog
regression right away because my git tree builds didn't have it enabled.
It wasn't until there started being 3.0 distro kernels that people started
reporting the problem to us.

> Also, as i mentioned it several times before, you are free to add an
> arbitrary number of ABI test-cases to 'perf test' and we can promise
> that we run that. Right now it consists of a few tests:

as mentioned before I have my own perf_event test suite with 20+ tests.
http://web.eecs.utk.edu/~vweaver1/projects/perf-events/validation.html

I do run it often. It tends to be reactionary though, as I can only add a
test for a bug once I know about it.

I also have more up-to date perf documentation than the kernel does:
http://web.eecs.utk.edu/~vweaver1/projects/perf-events/programming.html

and a cpu compatability matrix:
http://web.eecs.utk.edu/~vweaver1/projects/perf-events/support.html

I didn't really want to turn this into yet another perf flamewar. I just
didn't want the implication that perf being in kernel is all rainbows
and unicorns to go unchallenged.

Vince
--
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/