diff options
| author | Ingo Molnar <mingo@elte.hu> | 2010-08-05 02:46:15 -0400 |
|---|---|---|
| committer | Ingo Molnar <mingo@elte.hu> | 2010-08-05 02:46:15 -0400 |
| commit | fc9ea5a1e53ee54f681e226d735008e2a6f8f470 (patch) | |
| tree | fe59eb9aef5d797ae387885e6833c9c4d05735ad /tools/perf/util/event.c | |
| parent | 61be7fdec2f51b99570cd5dcc30c7848c8e56513 (diff) | |
| parent | 9da79ab83ee33ddc1fdd0858fd3d70925a1bde99 (diff) | |
Merge branch 'perf/core' of git://git.kernel.org/pub/scm/linux/kernel/git/acme/linux-2.6 into perf/core
Diffstat (limited to 'tools/perf/util/event.c')
| -rw-r--r-- | tools/perf/util/event.c | 28 |
1 files changed, 21 insertions, 7 deletions
diff --git a/tools/perf/util/event.c b/tools/perf/util/event.c index 6b0db5577929..dab9e754a281 100644 --- a/tools/perf/util/event.c +++ b/tools/perf/util/event.c | |||
| @@ -151,7 +151,6 @@ static int event__synthesize_mmap_events(pid_t pid, pid_t tgid, | |||
| 151 | continue; | 151 | continue; |
| 152 | pbf += n + 3; | 152 | pbf += n + 3; |
| 153 | if (*pbf == 'x') { /* vm_exec */ | 153 | if (*pbf == 'x') { /* vm_exec */ |
| 154 | u64 vm_pgoff; | ||
| 155 | char *execname = strchr(bf, '/'); | 154 | char *execname = strchr(bf, '/'); |
| 156 | 155 | ||
| 157 | /* Catch VDSO */ | 156 | /* Catch VDSO */ |
| @@ -162,12 +161,7 @@ static int event__synthesize_mmap_events(pid_t pid, pid_t tgid, | |||
| 162 | continue; | 161 | continue; |
| 163 | 162 | ||
| 164 | pbf += 3; | 163 | pbf += 3; |
| 165 | n = hex2u64(pbf, &vm_pgoff); | 164 | n = hex2u64(pbf, &ev.mmap.pgoff); |
| 166 | /* pgoff is in bytes, not pages */ | ||
| 167 | if (n >= 0) | ||
| 168 | ev.mmap.pgoff = vm_pgoff << getpagesize(); | ||
| 169 | else | ||
| 170 | ev.mmap.pgoff = 0; | ||
| 171 | 165 | ||
| 172 | size = strlen(execname); | 166 | size = strlen(execname); |
| 173 | execname[size - 1] = '\0'; /* Remove \n */ | 167 | execname[size - 1] = '\0'; /* Remove \n */ |
| @@ -554,6 +548,26 @@ int event__process_task(event_t *self, struct perf_session *session) | |||
| 554 | return 0; | 548 | return 0; |
| 555 | } | 549 | } |
| 556 | 550 | ||
| 551 | int event__process(event_t *event, struct perf_session *session) | ||
| 552 | { | ||
| 553 | switch (event->header.type) { | ||
| 554 | case PERF_RECORD_COMM: | ||
| 555 | event__process_comm(event, session); | ||
| 556 | break; | ||
| 557 | case PERF_RECORD_MMAP: | ||
| 558 | event__process_mmap(event, session); | ||
| 559 | break; | ||
| 560 | case PERF_RECORD_FORK: | ||
| 561 | case PERF_RECORD_EXIT: | ||
| 562 | event__process_task(event, session); | ||
| 563 | break; | ||
| 564 | default: | ||
| 565 | break; | ||
| 566 | } | ||
| 567 | |||
| 568 | return 0; | ||
| 569 | } | ||
| 570 | |||
| 557 | void thread__find_addr_map(struct thread *self, | 571 | void thread__find_addr_map(struct thread *self, |
| 558 | struct perf_session *session, u8 cpumode, | 572 | struct perf_session *session, u8 cpumode, |
| 559 | enum map_type type, pid_t pid, u64 addr, | 573 | enum map_type type, pid_t pid, u64 addr, |
