[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20090114100814.GA23835@elte.hu>
Date:	Wed, 14 Jan 2009 11:08:14 +0100
From:	Ingo Molnar <mingo@...e.hu>
To:	Paul Mackerras <paulus@...ba.org>
Cc:	linux-kernel@...r.kernel.org, Thomas Gleixner <tglx@...utronix.de>
Subject: Re: [RFC PATCH] perf_counter: Add support for pinned and exclusive
	counter groups
* Ingo Molnar <mingo@...e.hu> wrote:
> Yeah. Such artifacts at inheritance stem from the reduction in utility 
> that comes from any exclusive-resource-usage scheme, and are expected.
> 
> For example, right now it works just fine to nest 'timec' in itself 
> [there is a reduction in statistical value if we start round-robining, 
> but there's still full utility]. If it used exclusive or pinned counters 
> that might not work.
for example, this measurement works just fine currently:
aldebaran:~/linux/linux> timec -e 1 timec -e 1 timec -e 1 make -j16 kernel/
 [...]
 Performance counter stats for 'make':
   59561.510176  task clock ticks     (msecs)
    92223201071  instructions         (events)
 Wall-clock time elapsed:  6016.011818 msecs
 Performance counter stats for 'timec':
   59562.300425  task clock ticks     (msecs)
    92223534177  instructions         (events)
 Wall-clock time elapsed:  6017.117985 msecs
 Performance counter stats for 'timec':
   59563.307588  task clock ticks     (msecs)
    92223867295  instructions         (events)
 Wall-clock time elapsed:  6018.590227 msecs
The performance counters are layered upon each other in each nested timec 
instance. In the innermost instance ls runs with 3+3 performance counters 
active at once - and it all just works, without the timec apps having any 
knowledge about each other.
And that is i think what powerful kernel abstractions are about. If we 
provide nice and useful abstractions then the hw folks will eventually 
extend the hw side resources, if users keep bumping into them.
If we structure our design around the limitations then users wont actually 
ever bump into the hw limitations in a clear-cut way - they will bump into 
our design. So they'll pester us, not the hw folks ;-)
Such details are the main difference between the perfmon design and the 
perfcounters design.
	Ingo
--
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
 
