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

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

 



Hi,

On Thu, Oct 7, 2010 at 5:08 PM, Mathieu Desnoyers
<mathieu.desnoyers@xxxxxxxxxxxx> wrote:
> [ Adding a few more CCs, since this discussion is about a tracepoint
>  userspace ABI policy, which is a topic of general interest. ]
>
> * Thomas Renninger (trenn@xxxxxxx) wrote:
>> Hi,
>>
>> On Monday 04 October 2010 17:20:57 Jean Pihet wrote:
>> > Here is a re-spin of the patches after discussion.
>>
>> what is going to happen here now?
>>
>> Is this supposed to go through Ingo's tree?
>>
>> Ingo: do you mind commenting on this.
>
> Meanwhile, here are some ideas...
>
>
>> I see 3 possibilities:
>>   1) Power (or all) perf events are never going to change.
>
> Persisting with bad interfaces (which were never meant to be stable, and were
> actually explicitely said to be non-stable) for the sake of poorly written
> proprietary userspace apps does not seem like viable to me. Since when did we
> start designing kernel code for broken proprierary apps ? (see below for
> solutions on how to fix the apps)
>
> The only reason we have these tracepoints in there is because they can follow
> kernel code changes, thanks to their flexible nature. Being stucked with
> badly named tracepoints because of some monolithic analyzer app is just insane.
>
>>   If they are going to change, then now is the right time and
>>   2) Backward compatibility is provided in some way for some time.
>
> I've looked at the resulting code, and, honestly, it's ugly and it complexifies
> the test matrix. I would really prefer to move this compatibility crap out of
> the kernel out into userspace libraries, where it belongs. It should have got
> there in the first place when the developers of these propritary
> tracepoint-consumers got the hint that those were going to change. Then you have
> a sane design:
>
> 1) The kernel, providing a tracepoint ABI that *can change over time*, because
>   tracepoints are too tied to kernel code to afford not being changed.
> 2) Adapdation libraries, some which could be provided with the perf userspace
>   libraries, some which could be provided along with the tracepoint consumer
>   application, so the proprietary application can link on an open-source
>   library that can be upgraded when needed.
> 3) The trace analyzer. So if the analyzer is open source, then it's fine, it
>   could follow the rare ABI breakups that are needed by a simple upgrade.
>   Ideally we might want to keep backward compatibility code in there too, but
>   it's OK to require users to upgrade their tools if the kernel is upgraded.
>   If the analyzer is closed-source, then it should interact with an open source
>   library rather than with the kernel tracepoints ABI.
Totally agree here! The real solution is to provide such a library.
Anyone interested?

> So, given that I don't want to uglify kernel code based on some badly written
> proprietary userspace tools, and given we've given all possible warnings telling
> that the tracepoint ABI might change, I really don't see why we should bother
> bloating the kernel with this. The analyzers should be changed to use adaptation
> libraries instead.
>
>>   3) The power events get cleaned up without compatibility to
>>      former kernels versions.
>>
>> There are patches for 2. and 3., for 1. there obviously are no
>> needed.
>> For 2., the patches (mine or Jeans), need some polishing. IMO
>> these double events inside of general code aren't that bad.
>> I trust Jean, that it's not that easy with all the include magic
>> and macros, partly realized that myself already and it's not worth
>> it to dig further for a temporary solution.
>>
>> Votes so far:
>> 1. Arjan
>> 2. Myself, Jean
>> 3. Peter Zijlstra and Mathieu Desnoyers
I am for 3 but I do not mind to provide the code for 2.

>>
>> Jean's work got successfully blocked for weeks now.
>> If there would be a final decision by a maintainer who is going to
>> merge Jean's work, that would be great and it would finally be worth
>> to send updated patches again which hopefully some day find their way into
>> a linux-next kernel...
>
> Yes, sadly this debate running in circles hurts contributors.

Indeed.

Honestly I do not know what to do next. Here are some facts:
- Thomas and myself did completely rework the patches a couple of
times now and most of them got acked
- A transition API has been provided along with a Kconfig option.
Special care has been taken to provide an easy to maintain solution
(just remove the option from Kconfig and a few lines of code in
kernel/trace)
- I am willing to provide the according patches to pytimechart, for
the new API only. Some pytimechart fixes from myself are already in
the tree thanks to the maintainer (Pierre).

Please let us move this forward. Some more on-going work is depending
on those changes.

Thanks,
Jean

>
> Thanks for the summary!
>
> Mathieu
>
>>
>> Thanks,
>>
>>       Thomas
>
> --
> Mathieu Desnoyers
> Operating System Efficiency R&D Consultant
> EfficiOS Inc.
> http://www.efficios.com
>
--
To unsubscribe from this list: send the line "unsubscribe linux-trace-users" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Linux USB Development]     [Linux USB Development]     [Linux Audio Users]     [Yosemite Hiking]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux