Re: PATCH [0/4] perf: clean-up of power events API

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



* Arjan van de Ven (arjan@xxxxxxxxxxxxxxx) wrote:
>  On 10/8/2010 6:41 AM, Mathieu Desnoyers wrote:
>> * Arjan van de Ven (arjan@xxxxxxxxxxxxxxx) wrote:
>>>   On 10/8/2010 1:38 AM, Ingo Molnar wrote:
>>>> The fundamental thing about tracing/instrumentation is that there are no
>>>> deep ABI needs: it's all about analyzing development kernels (and a few
>>>> select versions that get the enterprise treatment) but otherwise the
>>>> half-life of this kind of information is very short.
>>>>
>>>> So we dont want to tie ourselves down with excessive ABIs.
>>>>
>>> ok I'll start working on a second mechanism then to export information
>>> that applications need ;-(
>>> it'll look a lot like tracing I suppose ;-(
>> What's wrong with doing the compatibility layer in a LGPL library shipped with
>> the kernel tree under tools/ ?
>
> because that is not workable... at least nobody has shown to be able to  
> make this work.
> libraries (after compilation) live in /lib or /usr/lib (or lib64 I  
> suppose).....
> what mechanism ensures that a user who compiles his kernel gets a  
> library compatible with that kernel in /usr/lib?

I don't think the perf tools/ do it right at the moment, but here is my
proposal:

Currently, we need to do make install from the tools/ directory. Since kernel
developers are lazy, I would propose a CONFIG_INSTALL_TOOLS default N config
option that would let make install from the root of the kernel tree install the
tools too. (looking at my inbox..) As Steven just beat me to it, see his lib
versioning proposal. ;)

The library would present an API to the application that would let apps consume
specific events of interest. Translation of fixed event names/fields into the
current kernel version tracepoint names/fields would be performed by the lib,
and the library would also deal with reading the perf events through the perf
ABI and would act as a middle-man to make sure they are always perceived by the
application in the same way.

> and can said library deal with older kernels too? And distro kernels?

Steven's proposal should work.

>
>> Why does everything *have* to be done in
>> kernel-space
> it doesn't. but the alternative must be workable.
>>   Why are you so focused on making your application interact
>> directly with kernel ABIs ?
>>
>> I'm being direct because there are trivial solutions to your problem that you
>> are rejecting without due consideration. (and also I just had one coffee too
>> many) ;-)
>
> since you seem to think that dealing with such a library is trivial...  
> how about you do it for one function even, to
> show that the deployment/use-in-an-app is workable.
> I'd be more than happy to use it if it's workable and the API is at  
> least halfway sane.

I currently have a lot on my plate with trace format and ring buffer, but if
anyone is interested in trying to implement this, I can look at it and provide
feedback/hints.

Thanks,

Mathieu

-- 
Mathieu Desnoyers
Operating System Efficiency R&D Consultant
EfficiOS Inc.
http://www.efficios.com
_______________________________________________
linux-pm mailing list
linux-pm@xxxxxxxxxxxxxxxxxxxxxxxxxx
https://lists.linux-foundation.org/mailman/listinfo/linux-pm


[Index of Archives]     [Linux ACPI]     [Netdev]     [Ethernet Bridging]     [Linux Wireless]     [CPU Freq]     [Kernel Newbies]     [Fedora Kernel]     [Security]     [Linux for Hams]     [Netfilter]     [Bugtraq]     [Yosemite News]     [MIPS Linux]     [ARM Linux]     [Linux RAID]     [Linux Admin]     [Samba]

  Powered by Linux