perf report: Document '--call-graph' better for usage
[linux-2.6-block.git] / tools / perf / util / event.h
CommitLineData
cdd6c482
IM
1#ifndef __PERF_RECORD_H
2#define __PERF_RECORD_H
8b40f521 3
4a58e611
ACM
4#include <limits.h>
5
1fe2c106 6#include "../perf.h"
4a58e611 7#include "map.h"
1fe2c106 8
18408ddc
PZ
9/*
10 * PERF_SAMPLE_IP | PERF_SAMPLE_TID | *
11 */
1fe2c106
FW
12struct ip_event {
13 struct perf_event_header header;
14 u64 ip;
15 u32 pid, tid;
16 unsigned char __more_data[];
17};
18
19struct mmap_event {
20 struct perf_event_header header;
21 u32 pid, tid;
22 u64 start;
23 u64 len;
24 u64 pgoff;
25 char filename[PATH_MAX];
26};
27
28struct comm_event {
29 struct perf_event_header header;
30 u32 pid, tid;
31 char comm[16];
32};
33
34struct fork_event {
35 struct perf_event_header header;
36 u32 pid, ppid;
37 u32 tid, ptid;
393b2ad8 38 u64 time;
1fe2c106
FW
39};
40
41struct lost_event {
42 struct perf_event_header header;
43 u64 id;
44 u64 lost;
45};
46
18408ddc
PZ
47/*
48 * PERF_FORMAT_ENABLED | PERF_FORMAT_RUNNING | PERF_FORMAT_ID
49 */
1fe2c106
FW
50struct read_event {
51 struct perf_event_header header;
dc02bf71 52 u32 pid, tid;
1fe2c106
FW
53 u64 value;
54 u64 time_enabled;
55 u64 time_running;
56 u64 id;
57};
58
180f95e2 59struct sample_event {
fd39e055
AV
60 struct perf_event_header header;
61 u64 array[];
62};
63
180f95e2
OH
64struct sample_data {
65 u64 ip;
66 u32 pid, tid;
67 u64 time;
68 u64 addr;
69 u64 id;
70 u64 stream_id;
180f95e2 71 u64 period;
eed05fe7 72 u32 cpu;
180f95e2
OH
73 u32 raw_size;
74 void *raw_data;
eed05fe7 75 struct ip_callchain *callchain;
180f95e2
OH
76};
77
8d06367f
ACM
78#define BUILD_ID_SIZE 20
79
80struct build_id_event {
81 struct perf_event_header header;
a1645ce1 82 pid_t pid;
8d06367f
ACM
83 u8 build_id[ALIGN(BUILD_ID_SIZE, sizeof(u64))];
84 char filename[];
85};
fd39e055 86
8dc58101 87enum perf_header_event_type { /* above any possible kernel type */
2c46dbb5 88 PERF_RECORD_HEADER_ATTR = 64,
cd19a035 89 PERF_RECORD_HEADER_EVENT_TYPE = 65,
9215545e 90 PERF_RECORD_HEADER_TRACING_DATA = 66,
c7929e47 91 PERF_RECORD_HEADER_BUILD_ID = 67,
2c46dbb5
TZ
92 PERF_RECORD_HEADER_MAX
93};
94
95struct attr_event {
96 struct perf_event_header header;
97 struct perf_event_attr attr;
98 u64 id[];
8dc58101
TZ
99};
100
cd19a035
TZ
101#define MAX_EVENT_NAME 64
102
103struct perf_trace_event_type {
104 u64 event_id;
105 char name[MAX_EVENT_NAME];
106};
107
108struct event_type_event {
109 struct perf_event_header header;
110 struct perf_trace_event_type event_type;
111};
112
9215545e
TZ
113struct tracing_data_event {
114 struct perf_event_header header;
115 u32 size;
116};
117
1fe2c106
FW
118typedef union event_union {
119 struct perf_event_header header;
120 struct ip_event ip;
121 struct mmap_event mmap;
122 struct comm_event comm;
123 struct fork_event fork;
124 struct lost_event lost;
125 struct read_event read;
fd39e055 126 struct sample_event sample;
2c46dbb5 127 struct attr_event attr;
cd19a035 128 struct event_type_event event_type;
9215545e 129 struct tracing_data_event tracing_data;
c7929e47 130 struct build_id_event build_id;
1fe2c106 131} event_t;
66e274f3 132
62daacb5 133struct events_stats {
b5b60fda
ACM
134 u64 total;
135 u64 lost;
62daacb5
ACM
136};
137
cb8f0939
EM
138struct event_stat_id {
139 struct rb_node rb_node;
140 struct rb_root hists;
141 struct events_stats stats;
142 u64 config;
143 u64 event_stream;
144 u32 type;
145};
146
62daacb5
ACM
147void event__print_totals(void);
148
4aa65636
ACM
149struct perf_session;
150
cf553114
ACM
151typedef int (*event__handler_t)(event_t *event, struct perf_session *session);
152
153int event__synthesize_thread(pid_t pid, event__handler_t process,
d8f66248 154 struct perf_session *session);
cf553114 155void event__synthesize_threads(event__handler_t process,
d8f66248 156 struct perf_session *session);
cf553114 157int event__synthesize_kernel_mmap(event__handler_t process,
a1645ce1 158 struct perf_session *session,
23346f21 159 struct machine *machine,
a1645ce1
ZY
160 const char *symbol_name);
161
b7cece76 162int event__synthesize_modules(event__handler_t process,
a1645ce1 163 struct perf_session *session,
23346f21 164 struct machine *machine);
234fbbf5 165
d8f66248
ACM
166int event__process_comm(event_t *self, struct perf_session *session);
167int event__process_lost(event_t *self, struct perf_session *session);
168int event__process_mmap(event_t *self, struct perf_session *session);
169int event__process_task(event_t *self, struct perf_session *session);
62daacb5 170
1ed091c4 171struct addr_location;
b3165f41
ACM
172int event__preprocess_sample(const event_t *self, struct perf_session *session,
173 struct addr_location *al, symbol_filter_t filter);
180f95e2 174int event__parse_sample(event_t *event, u64 type, struct sample_data *data);
1ed091c4 175
8b40f521 176#endif /* __PERF_RECORD_H */