Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 323766
b: refs/heads/master
c: 831394b
h: refs/heads/master
v: v3
  • Loading branch information
Namhyung Kim authored and Arnaldo Carvalho de Melo committed Sep 6, 2012
1 parent 78ae13d commit b87af9a
Show file tree
Hide file tree
Showing 2 changed files with 23 additions and 15 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: ae42c6bb9300cf25990bd15f1bd6ee38598f7483
refs/heads/master: 831394bdd9dd3ac1661336505c7cbdfd786d8cd4
36 changes: 22 additions & 14 deletions trunk/tools/perf/util/header.c
Original file line number Diff line number Diff line change
Expand Up @@ -2295,33 +2295,39 @@ static int read_attr(int fd, struct perf_header *ph,
return ret <= 0 ? -1 : 0;
}

static int perf_evsel__set_tracepoint_name(struct perf_evsel *evsel,
struct pevent *pevent)
static int perf_evsel__prepare_tracepoint_event(struct perf_evsel *evsel,
struct pevent *pevent)
{
struct event_format *event = pevent_find_event(pevent,
evsel->attr.config);
struct event_format *event;
char bf[128];

/* already prepared */
if (evsel->tp_format)
return 0;

event = pevent_find_event(pevent, evsel->attr.config);
if (event == NULL)
return -1;

snprintf(bf, sizeof(bf), "%s:%s", event->system, event->name);
evsel->name = strdup(bf);
if (evsel->name == NULL)
return -1;
if (!evsel->name) {
snprintf(bf, sizeof(bf), "%s:%s", event->system, event->name);
evsel->name = strdup(bf);
if (evsel->name == NULL)
return -1;
}

evsel->tp_format = event;
return 0;
}

static int perf_evlist__set_tracepoint_names(struct perf_evlist *evlist,
struct pevent *pevent)
static int perf_evlist__prepare_tracepoint_events(struct perf_evlist *evlist,
struct pevent *pevent)
{
struct perf_evsel *pos;

list_for_each_entry(pos, &evlist->entries, node) {
if (pos->attr.type == PERF_TYPE_TRACEPOINT && !pos->name &&
perf_evsel__set_tracepoint_name(pos, pevent))
if (pos->attr.type == PERF_TYPE_TRACEPOINT &&
perf_evsel__prepare_tracepoint_event(pos, pevent))
return -1;
}

Expand Down Expand Up @@ -2409,7 +2415,8 @@ int perf_session__read_header(struct perf_session *session, int fd)

lseek(fd, header->data_offset, SEEK_SET);

if (perf_evlist__set_tracepoint_names(session->evlist, session->pevent))
if (perf_evlist__prepare_tracepoint_events(session->evlist,
session->pevent))
goto out_delete_evlist;

header->frozen = 1;
Expand Down Expand Up @@ -2643,7 +2650,8 @@ int perf_event__process_tracing_data(union perf_event *event,
if (size_read + padding != size)
die("tracing data size mismatch");

perf_evlist__set_tracepoint_names(session->evlist, session->pevent);
perf_evlist__prepare_tracepoint_events(session->evlist,
session->pevent);

return size_read + padding;
}
Expand Down

0 comments on commit b87af9a

Please sign in to comment.