Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 288627
b: refs/heads/master
c: 9558259
h: refs/heads/master
i:
  288625: f723695
  288623: 000443a
v: v3
  • Loading branch information
Akihiro Nagai authored and Arnaldo Carvalho de Melo committed Jan 30, 2012
1 parent d999a6e commit 1101027
Show file tree
Hide file tree
Showing 2 changed files with 43 additions and 1 deletion.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 547a92e0aedb88129e7fbd804697a11949de2e5a
refs/heads/master: 9558259697b827106b464648e850e568e0b0c931
42 changes: 42 additions & 0 deletions trunk/tools/perf/builtin-script.c
Original file line number Diff line number Diff line change
Expand Up @@ -304,6 +304,13 @@ static void print_sample_start(struct perf_sample *sample,
}
}

static bool is_bts_event(struct perf_event_attr *attr)
{
return ((attr->type == PERF_TYPE_HARDWARE) &&
(attr->config & PERF_COUNT_HW_BRANCH_INSTRUCTIONS) &&
(attr->sample_period == 1));
}

static bool sample_addr_correlates_sym(struct perf_event_attr *attr)
{
if ((attr->type == PERF_TYPE_SOFTWARE) &&
Expand All @@ -312,6 +319,9 @@ 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))
return true;

return false;
}

Expand Down Expand Up @@ -353,6 +363,33 @@ static void print_sample_addr(union perf_event *event,
}
}

static void print_sample_bts(union perf_event *event,
struct perf_sample *sample,
struct perf_evsel *evsel,
struct machine *machine,
struct thread *thread)
{
struct perf_event_attr *attr = &evsel->attr;

/* print branch_from information */
if (PRINT_FIELD(IP)) {
if (!symbol_conf.use_callchain)
printf(" ");
else
printf("\n");
perf_event__print_ip(event, sample, machine, evsel,
PRINT_FIELD(SYM), PRINT_FIELD(DSO));
}

printf(" => ");

/* print branch_to information */
if (PRINT_FIELD(ADDR))
print_sample_addr(event, sample, machine, thread, attr);

printf("\n");
}

static void process_event(union perf_event *event __unused,
struct perf_sample *sample,
struct perf_evsel *evsel,
Expand All @@ -366,6 +403,11 @@ static void process_event(union perf_event *event __unused,

print_sample_start(sample, thread, attr);

if (is_bts_event(attr)) {
print_sample_bts(event, sample, evsel, machine, thread);
return;
}

if (PRINT_FIELD(TRACE))
print_trace_event(sample->cpu, sample->raw_data,
sample->raw_size);
Expand Down

0 comments on commit 1101027

Please sign in to comment.