[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <1331842127-27468-1-git-send-email-asharma@fb.com>
Date: Thu, 15 Mar 2012 13:08:47 -0700
From: Arun Sharma <asharma@...com>
To: linux-kernel@...r.kernel.org
Cc: Arun Sharma <asharma@...com>,
Stephane Eranian <eranian@...gle.com>, peterz@...radead.org,
acme@...hat.com, ravitillo@....gov, vweaver1@...s.utk.edu,
khandual@...ux.vnet.ibm.com, dsahern@...il.com,
Ingo Molnar <mingo@...e.hu>,
Namhyung Kim <namhyung.kim@....com>
Subject: [PATCH] perf: Add branch stack support to perf script
This makes it easier to write tools that consume the
branch stack data.
Sample usage:
perf record -jany_call,u -o perf.data.anycallu -- ./foo
perf script -i perf.data.anycallu -fip,sym
The samples seem to have the sense of call/return
inverted. If the original callgraph was a -> b -> c
I get samples like:
from to
c b
b a
To restore the normal sense, I'm printing them as:
to => from
Signed-off-by: Arun Sharma <asharma@...com>
Cc: Stephane Eranian <eranian@...gle.com>
Cc: peterz@...radead.org
Cc: acme@...hat.com
Cc: ravitillo@....gov
Cc: vweaver1@...s.utk.edu
Cc: khandual@...ux.vnet.ibm.com
Cc: dsahern@...il.com
Cc: Ingo Molnar <mingo@...e.hu>
Cc: Namhyung Kim <namhyung.kim@....com>
---
tools/perf/builtin-script.c | 56 ++++++++++++++++++++++++++++++++++++++----
1 files changed, 50 insertions(+), 6 deletions(-)
diff --git a/tools/perf/builtin-script.c b/tools/perf/builtin-script.c
index d4ce733..99ad1d5 100644
--- a/tools/perf/builtin-script.c
+++ b/tools/perf/builtin-script.c
@@ -318,6 +318,11 @@ static bool is_bts_event(struct perf_event_attr *attr)
(attr->sample_period == 1));
}
+static bool is_branch_stack_event(struct perf_event_attr *attr)
+{
+ return (attr->sample_type & PERF_SAMPLE_BRANCH_STACK);
+}
+
static bool sample_addr_correlates_sym(struct perf_event_attr *attr)
{
if ((attr->type == PERF_TYPE_SOFTWARE) &&
@@ -326,31 +331,32 @@ static bool sample_addr_correlates_sym(struct perf_event_attr *attr)
(attr->config == PERF_COUNT_SW_PAGE_FAULTS_MAJ)))
return true;
- if (is_bts_event(attr))
+ if (is_bts_event(attr) || is_branch_stack_event(attr))
return true;
return false;
}
-static void print_sample_addr(union perf_event *event,
+static void __print_sample_addr(union perf_event *event,
struct perf_sample *sample,
struct machine *machine,
struct thread *thread,
- struct perf_event_attr *attr)
+ struct perf_event_attr *attr,
+ u64 addr)
{
struct addr_location al;
u8 cpumode = event->header.misc & PERF_RECORD_MISC_CPUMODE_MASK;
- printf("%16" PRIx64, sample->addr);
+ printf("%16" PRIx64, addr);
if (!sample_addr_correlates_sym(attr))
return;
thread__find_addr_map(thread, machine, cpumode, MAP__FUNCTION,
- sample->addr, &al);
+ addr, &al);
if (!al.map)
thread__find_addr_map(thread, machine, cpumode, MAP__VARIABLE,
- sample->addr, &al);
+ addr, &al);
al.cpu = sample->cpu;
al.sym = NULL;
@@ -373,6 +379,17 @@ static void print_sample_addr(union perf_event *event,
}
}
+static void print_sample_addr(union perf_event *event,
+ struct perf_sample *sample,
+ struct machine *machine,
+ struct thread *thread,
+ struct perf_event_attr *attr)
+
+{
+ return __print_sample_addr(event, sample, machine, thread, attr,
+ sample->addr);
+}
+
static void print_sample_bts(union perf_event *event,
struct perf_sample *sample,
struct perf_evsel *evsel,
@@ -401,6 +418,28 @@ static void print_sample_bts(union perf_event *event,
printf("\n");
}
+static void print_sample_branch_stack(union perf_event *event,
+ struct perf_sample *sample,
+ struct perf_evsel *evsel,
+ struct machine *machine,
+ struct thread *thread)
+{
+ uint64_t i;
+ struct perf_event_attr *attr = &evsel->attr;
+
+ printf("... branch stack: nr:%" PRIu64 "\n", sample->branch_stack->nr);
+
+ for (i = 0; i < sample->branch_stack->nr; i++) {
+ printf("\t..... %2"PRIu64": ", i);
+ __print_sample_addr(event, sample, machine, thread, attr,
+ sample->branch_stack->entries[i].to);
+ printf(" => ");
+ __print_sample_addr(event, sample, machine, thread, attr,
+ sample->branch_stack->entries[i].from);
+ printf("\n");
+ }
+}
+
static void process_event(union perf_event *event __unused,
struct perf_sample *sample,
struct perf_evsel *evsel,
@@ -417,6 +456,11 @@ static void process_event(union perf_event *event __unused,
if (is_bts_event(attr)) {
print_sample_bts(event, sample, evsel, machine, thread);
return;
+ }
+
+ if (is_branch_stack_event(attr)) {
+ print_sample_branch_stack(event, sample, evsel, machine, thread);
+ return;
}
if (PRINT_FIELD(TRACE))
--
1.7.8.4
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists