From: Ingo Molnar <mingo@elte.hu>
To: Vince Weaver <vince@deater.net>
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>,
Paul Mackerras <paulus@samba.org>,
linux-kernel@vger.kernel.org, Mike Galbraith <efault@gmx.de>
Subject: Re: [numbers] perfmon/pfmon overhead of 17%-94%
Date: Fri, 3 Jul 2009 09:58:22 +0200 [thread overview]
Message-ID: <20090703075822.GA13505@elte.hu> (raw)
In-Reply-To: <Pine.LNX.4.64.0907021702380.13747@pianoman.cluster.toy>
* Vince Weaver <vince@deater.net> wrote:
> On Mon, 29 Jun 2009, Ingo Molnar wrote:
>>
>> * Vince Weaver <vince@deater.net> wrote:
>>
>>>> If the 5 thousand cycles measurement overhead _still_ matters to
>>>> you under such circumstances then by all means please submit the
>>>> patches to improve it. Despite your claims this is totally
>>>> fixable with the current perfcounters design, Peter outlined the
>>>> steps of how to solve it, you can utilize ptrace if you want to.
>>>
>>> Is it really "totally" fixible? I don't just mean getting the
>>> overhead from ~3000 down to ~100, I mean down to zero.
>>
>> The thing is, not even pfmon gets it down to zero:
>>
>> pfmon -e INSTRUCTIONS_RETIRED --follow-fork --aggregate-results ~/million
>> 1000001 INSTRUCTIONS_RETIRED
>>
>> So ... do you take the hardliner purist view and consider it crap
>> due to that imprecision, or do you take the pragmatist view of also
>> considering the relative relevance of any imperfection? ;-)
>
> as I said in a previous post, on most x86 chips the
> instructions_retired counter also includes any hardware interrupts
> that occur during the process runtime. So any clock interrupts,
> etc, show up as an extra instruction. So on the "million"
> benchmark, it's usually +/- 2 extra instructions.
yeah. But it has nothing to do with the function you are measuring,
right?
My general point is really that what matters is the statistical
validity of the end result. I dont think you ever disagreed with
that point - you just seem to have a lower noise acceptance
threshold ;-)
> It looks like support might be added to perfcounters to track
> these hardware interrupt stats per-process, which would be great,
> as it's been really hard to quantify that currently.
Yeah. There's a patch-set in the works that attempts to do something
in this area - see these mails on lkml:
perf_counter: Add Generalized Hardware interrupt support
Right now they are just convenience wrappers around CPU model
specific hw events - but we could extend the whole thing with
software counters as well and isolate per IRQ vector events and
counts, by adding a callback to do_IRQ().
That would give a mixture of hardware and software counter based IRQ
instrumentation features that looks quite compelling. Any comments
on what features/capabilities you'd like to see in this area?
> In any case, it looks like the changes to make perf have lower
> overhead have been merged, which makes me happy. Thank you.
You are welcome :)
Btw., perfcounters still has no support for older Intel CPUs such as
P3's and P2's - and they have pretty sane PMUs - so if you have such
a machine (which your perfmon contribution suggests you might
have/had) and are interested it would be nice to get support for
them. P4 support is interesting too but more challenging.
Ingo
next prev parent reply other threads:[~2009-07-03 7:58 UTC|newest]
Thread overview: 27+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-06-24 13:59 performance counter 20% error finding retired instruction count Vince Weaver
2009-06-24 15:10 ` Ingo Molnar
2009-06-25 2:12 ` Vince Weaver
2009-06-25 6:50 ` Peter Zijlstra
2009-06-25 9:13 ` Ingo Molnar
2009-06-26 18:22 ` Vince Weaver
2009-06-26 19:12 ` Peter Zijlstra
2009-06-27 5:32 ` Ingo Molnar
2009-06-26 19:23 ` Vince Weaver
2009-06-27 6:04 ` performance counter ~0.4% " Ingo Molnar
2009-06-27 6:44 ` [numbers] perfmon/pfmon overhead of 17%-94% Ingo Molnar
2009-06-29 18:25 ` Vince Weaver
2009-06-29 21:02 ` Ingo Molnar
2009-07-02 21:07 ` Vince Weaver
2009-07-03 7:58 ` Ingo Molnar [this message]
2009-07-03 21:43 ` Vince Weaver
2009-07-03 18:31 ` Andi Kleen
2009-07-03 21:25 ` Vince Weaver
2009-07-03 23:40 ` Andi Kleen
2009-06-29 23:46 ` [patch] perf_counter: Add enable-on-exec attribute Ingo Molnar
2009-06-29 23:55 ` [numbers] perfmon/pfmon overhead of 17%-94% Ingo Molnar
2009-06-30 0:05 ` Ingo Molnar
2009-06-27 6:48 ` performance counter ~0.4% error finding retired instruction count Paul Mackerras
2009-06-27 17:28 ` Ingo Molnar
2009-06-29 2:12 ` Paul Mackerras
2009-06-29 2:13 ` Paul Mackerras
2009-06-29 3:48 ` Ingo Molnar
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20090703075822.GA13505@elte.hu \
--to=mingo@elte.hu \
--cc=a.p.zijlstra@chello.nl \
--cc=efault@gmx.de \
--cc=linux-kernel@vger.kernel.org \
--cc=paulus@samba.org \
--cc=vince@deater.net \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox