aboutsummaryrefslogtreecommitdiffstats
path: root/tools/perf/util/probe-finder.c
diff options
context:
space:
mode:
authorMasami Hiramatsu <mhiramat@redhat.com>2009-10-27 16:43:10 -0400
committerIngo Molnar <mingo@elte.hu>2009-10-29 03:47:49 -0400
commit253977b0d87fbb793f12b1661a763ae264028ccf (patch)
tree498b07b3eb9726d69d7495a523a1e3c81e74bc97 /tools/perf/util/probe-finder.c
parent46ab49267d338eb5056d0077e16346509b9e9284 (diff)
perf/probes: Improve probe point syntax of perf-probe
This changes probe point syntax of perf-probe as below <SRC>[:ABS_LN] [ARGS] or <FUNC>[+OFFS|%return][@SRC] [ARGS] And event name and event group name are automatically generated based on probe-symbol and offset as below. perfprobes/SYMBOL_OFFSET[_NUM] Where SYMBOL is the probing symbol and OFFSET is the byte offset from the symbol. Signed-off-by: Masami Hiramatsu <mhiramat@redhat.com> Cc: Steven Rostedt <rostedt@goodmis.org> Cc: Jim Keniston <jkenisto@us.ibm.com> Cc: Ananth N Mavinakayanahalli <ananth@in.ibm.com> Cc: Christoph Hellwig <hch@infradead.org> Cc: Frank Ch. Eigler <fche@redhat.com> Cc: Frederic Weisbecker <fweisbec@gmail.com> Cc: Jason Baron <jbaron@redhat.com> Cc: K.Prasad <prasad@linux.vnet.ibm.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Srikar Dronamraju <srikar@linux.vnet.ibm.com> LKML-Reference: <20091027204310.30545.84984.stgit@harusame> Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'tools/perf/util/probe-finder.c')
-rw-r--r--tools/perf/util/probe-finder.c10
1 files changed, 10 insertions, 0 deletions
diff --git a/tools/perf/util/probe-finder.c b/tools/perf/util/probe-finder.c
index b98d35ef7116..6d3bac9f9473 100644
--- a/tools/perf/util/probe-finder.c
+++ b/tools/perf/util/probe-finder.c
@@ -483,10 +483,20 @@ static void show_probepoint(Dwarf_Die sp_die, Dwarf_Signed offs,
483 if (ret == DW_DLV_OK) { 483 if (ret == DW_DLV_OK) {
484 ret = snprintf(tmp, MAX_PROBE_BUFFER, "%s+%u", name, 484 ret = snprintf(tmp, MAX_PROBE_BUFFER, "%s+%u", name,
485 (unsigned int)offs); 485 (unsigned int)offs);
486 /* Copy the function name if possible */
487 if (!pp->function) {
488 pp->function = strdup(name);
489 pp->offset = offs;
490 }
486 dwarf_dealloc(__dw_debug, name, DW_DLA_STRING); 491 dwarf_dealloc(__dw_debug, name, DW_DLA_STRING);
487 } else { 492 } else {
488 /* This function has no name. */ 493 /* This function has no name. */
489 ret = snprintf(tmp, MAX_PROBE_BUFFER, "0x%llx", pf->addr); 494 ret = snprintf(tmp, MAX_PROBE_BUFFER, "0x%llx", pf->addr);
495 if (!pp->function) {
496 /* TODO: Use _stext */
497 pp->function = strdup("");
498 pp->offset = (int)pf->addr;
499 }
490 } 500 }
491 DIE_IF(ret < 0); 501 DIE_IF(ret < 0);
492 DIE_IF(ret >= MAX_PROBE_BUFFER); 502 DIE_IF(ret >= MAX_PROBE_BUFFER);