Re: [RFC PATCH] perf_counter: Add support for pinned and exclusivecounter groups

From: Ingo Molnar
Date: Wed Jan 14 2009 - 05:08:39 EST



* Ingo Molnar <mingo@xxxxxxx> 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@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/