Ingo Molnar <[email protected]> writes:
> [...]
> firstly, a factually wrong statement of yours:
>
> > [...] any tracepoints have an maintainance overhead, which is barely
> > different between dynamic and static tracing [...]
If one totals the fixup effort required across the programmers who
need to do the work, I would concur with the OP; or if there is a
difference, it is in favour of the static markers. It is unfortunate
that all the talk about maintenance has been almost entirely aloof and
disconnected from empirical examples. It would be much better if we
were able to sketch out plausible designs for static instrumentation
and similar dynamic probes, and carry out gedanken experiments aobut
how they would need to adopt to realistic examples of code drift. It
is not the case that all "maintenance" is alike.
> secondly, a factually wrong statement of yours:
>
> > [...] at the source level you can remove a static tracepoint as easily
> > as a dynamic tracepoint, [...]
It is not hard to imagine commenting out a single line; nor inserting
the equivalent of "#define NDEBUG" at the head of the .c file to
disable them all for the whole compilation unit. The retort that
"this would break the entire tracing system" does not hold water
without far more argument. Missing events do not necessarily a
totally broken system make. (Renamed or changed events may even be
mapped back via a translation layer.) Tracing events need not become
as firmly fixed (unremovable or unchangeable) a user interface as the
syscalls.
> thirdly, a factually wrong statement of yours:
>
> > [...] It would also add virtually no maintainance overhead [...]
Yes, the knife cuts both ways: both cost ongoing effort. The question
is how much; who would do the work; who is better able to do the work;
who (users/developers) receives value from the work. The overall
cost/benefit calculation is far more complicated than pithy lines
about "no maintenance" or its opposite.
As for the possibilities of kprobes performance improvements: bring
them on, they're great. It is however almost certain that, because
reasons like debugging-information imperfection or absence, compiler
optimizations, different deployment scenarios, some un-probable blind
spots would remain kprobes-only probing system.
As for Karim's proposed comment-based markers, I don't have a strong
opinion, not being one whose kernel-side code would be marked up one
way or the other. My intuition suggests that, if the runtime costs of
a dormant static marker are low enough, they should be just compiled
in by default. And if they are compiled in, then by golly, compile
them in honestly and don't hide them. Something like build-time
multilibbing seems like too much effort to trade one eyesore for a
different eyesore. But that's just my opinion, I could be wrong.
- FChE
-
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to [email protected]
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
[Index of Archives]
[Kernel Newbies]
[Netfilter]
[Bugtraq]
[Photo]
[Stuff]
[Gimp]
[Yosemite News]
[MIPS Linux]
[ARM Linux]
[Linux Security]
[Linux RAID]
[Video 4 Linux]
[Linux for the blind]
[Linux Resources]