1. 28 11月, 2008 1 次提交
  2. 16 11月, 2008 3 次提交
  3. 27 10月, 2008 1 次提交
  4. 14 10月, 2008 3 次提交
  5. 24 5月, 2008 2 次提交
    • M
      Markers - define non optimized marker · 0aa977f5
      Mathieu Desnoyers 提交于
      To support the forthcoming "immediate values" marker optimization, we must have
      a way to declare markers in few code paths that does not use instruction
      modification based enable. This will be the case of printk(), some traps and
      eventually lockdep instrumentation.
      
      Changelog :
      - Fix reversed boolean logic of "generic".
      Signed-off-by: NMathieu Desnoyers <mathieu.desnoyers@polymtl.ca>
      Signed-off-by: NIngo Molnar <mingo@elte.hu>
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      0aa977f5
    • M
      Markers - remove extra format argument · dc102a8f
      Mathieu Desnoyers 提交于
      Denys Vlasenko <vda.linux@googlemail.com> :
      
      > Not in this patch, but I noticed:
      >
      > #define __trace_mark(name, call_private, format, args...)               \
      >         do {                                                            \
      >                 static const char __mstrtab_##name[]                    \
      >                 __attribute__((section("__markers_strings")))           \
      >                 = #name "\0" format;                                    \
      >                 static struct marker __mark_##name                      \
      >                 __attribute__((section("__markers"), aligned(8))) =     \
      >                 { __mstrtab_##name, &__mstrtab_##name[sizeof(#name)],   \
      >                 0, 0, marker_probe_cb,                                  \
      >                 { __mark_empty_function, NULL}, NULL };                 \
      >                 __mark_check_format(format, ## args);                   \
      >                 if (unlikely(__mark_##name.state)) {                    \
      >                         (*__mark_##name.call)                           \
      >                                 (&__mark_##name, call_private,          \
      >                                 format, ## args);                       \
      >                 }                                                       \
      >         } while (0)
      >
      > In this call:
      >
      >                         (*__mark_##name.call)                           \
      >                                 (&__mark_##name, call_private,          \
      >                                 format, ## args);                       \
      >
      > you make gcc allocate duplicate format string. You can use
      > &__mstrtab_##name[sizeof(#name)] instead since it holds the same string,
      > or drop ", format," above and "const char *fmt" from here:
      >
      >         void (*call)(const struct marker *mdata,        /* Probe wrapper */
      >                 void *call_private, const char *fmt, ...);
      >
      > since mdata->format is the same and all callees which need it can take it there.
      
      Very good point. I actually thought about dropping it, since it would
      remove an unnecessary argument from the stack. And actually, since I now
      have the marker_probe_cb sitting between the marker site and the
      callbacks, there is no API change required. Thanks :)
      
      Mathieu
      Signed-off-by: NMathieu Desnoyers <mathieu.desnoyers@polymtl.ca>
      CC: Denys Vlasenko <vda.linux@googlemail.com>
      Signed-off-by: NIngo Molnar <mingo@elte.hu>
      Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
      dc102a8f
  6. 05 3月, 2008 1 次提交
  7. 14 2月, 2008 2 次提交
    • M
      Linux Kernel Markers: create modpost file · b2e3e658
      Mathieu Desnoyers 提交于
      This adds some new magic in the MODPOST phase for CONFIG_MARKERS.  Analogous
      to the Module.symvers file, the build will now write a Module.markers file
      when CONFIG_MARKERS=y is set.  This file lists the name, defining module, and
      format string of each marker, separated by \t characters.  This simple text
      file can be used by offline build procedures for instrumentation code,
      analogous to how System.map and Module.symvers can be useful to have for
      kernels other than the one you are running right now.
      
      The strings are made easy to extract by having the __trace_mark macro define
      the name and format together in a single array called __mstrtab_* in the
      __markers_strings section.  This is straightforward and reliable as long as
      the marker structs are always defined by this macro.  It is an unreasonable
      amount of hairy work to extract the string pointers from the __markers section
      structs, which entails handling a relocation type for every machine under the
      sun.
      
      Mathieu :
      - Ran through checkpatch.pl
      Signed-off-by: NRoland McGrath <roland@redhat.com>
      Signed-off-by: NMathieu Desnoyers <mathieu.desnoyers@polymtl.ca>
      Cc: David Smith <dsmith@redhat.com>
      Cc: Sam Ravnborg <sam@ravnborg.org>
      Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
      Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
      b2e3e658
    • M
      Linux Kernel Markers: support multiple probes · fb40bd78
      Mathieu Desnoyers 提交于
      RCU style multiple probes support for the Linux Kernel Markers.  Common case
      (one probe) is still fast and does not require dynamic allocation or a
      supplementary pointer dereference on the fast path.
      
      - Move preempt disable from the marker site to the callback.
      
      Since we now have an internal callback, move the preempt disable/enable to the
      callback instead of the marker site.
      
      Since the callback change is done asynchronously (passing from a handler that
      supports arguments to a handler that does not setup the arguments is no
      arguments are passed), we can safely update it even if it is outside the
      preempt disable section.
      
      - Move probe arm to probe connection. Now, a connected probe is automatically
        armed.
      
      Remove MARK_MAX_FORMAT_LEN, unused.
      
      This patch modifies the Linux Kernel Markers API : it removes the probe
      "arm/disarm" and changes the probe function prototype : it now expects a
      va_list * instead of a "...".
      
      If we want to have more than one probe connected to a marker at a given
      time (LTTng, or blktrace, ssytemtap) then we need this patch. Without it,
      connecting a second probe handler to a marker will fail.
      
      It allow us, for instance, to do interesting combinations :
      
      Do standard tracing with LTTng and, eventually, to compute statistics
      with SystemTAP, or to have a special trigger on an event that would call
      a systemtap script which would stop flight recorder tracing.
      Signed-off-by: NMathieu Desnoyers <mathieu.desnoyers@polymtl.ca>
      Cc: Christoph Hellwig <hch@infradead.org>
      Cc: Mike Mason <mmlnx@us.ibm.com>
      Cc: Dipankar Sarma <dipankar@in.ibm.com>
      Cc: David Smith <dsmith@redhat.com>
      Cc: "Paul E. McKenney" <paulmck@us.ibm.com>
      Cc: "Frank Ch. Eigler" <fche@redhat.com>
      Cc: Steven Rostedt <rostedt@goodmis.org>
      Signed-off-by: NAndrew Morton <akpm@linux-foundation.org>
      Signed-off-by: NLinus Torvalds <torvalds@linux-foundation.org>
      fb40bd78
  8. 20 10月, 2007 2 次提交