blob: bb090257570e07a1a1c6d733d4cad3aa2c2261c5 [file] [log] [blame]
Ingo Molnarcdd6c482009-09-21 12:02:48 +02001#ifndef __PERF_RECORD_H
2#define __PERF_RECORD_H
John Kacur8b40f522009-09-24 18:02:18 +02003
Frederic Weisbecker1fe2c102009-08-12 10:19:53 +02004#include "../perf.h"
Frederic Weisbecker66e274f2009-08-12 11:07:25 +02005#include "util.h"
Arnaldo Carvalho de Melo439d4732009-10-02 03:29:58 -03006#include <linux/list.h>
Arnaldo Carvalho de Melo1b46cdd2009-09-28 14:48:46 -03007#include <linux/rbtree.h>
Frederic Weisbecker1fe2c102009-08-12 10:19:53 +02008
Peter Zijlstra18408dd2009-08-13 11:47:55 +02009/*
10 * PERF_SAMPLE_IP | PERF_SAMPLE_TID | *
11 */
Frederic Weisbecker1fe2c102009-08-12 10:19:53 +020012struct 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;
Arjan van de Ven393b2ad2009-09-12 07:52:47 +020038 u64 time;
Frederic Weisbecker1fe2c102009-08-12 10:19:53 +020039};
40
41struct lost_event {
42 struct perf_event_header header;
43 u64 id;
44 u64 lost;
45};
46
Peter Zijlstra18408dd2009-08-13 11:47:55 +020047/*
48 * PERF_FORMAT_ENABLED | PERF_FORMAT_RUNNING | PERF_FORMAT_ID
49 */
Frederic Weisbecker1fe2c102009-08-12 10:19:53 +020050struct read_event {
51 struct perf_event_header header;
Ingo Molnardc02bf72009-09-16 13:45:00 +020052 u32 pid, tid;
Frederic Weisbecker1fe2c102009-08-12 10:19:53 +020053 u64 value;
54 u64 time_enabled;
55 u64 time_running;
56 u64 id;
57};
58
OGAWA Hirofumi180f95e2009-12-06 20:08:24 +090059struct sample_event {
Arjan van de Venfd39e052009-09-12 07:53:00 +020060 struct perf_event_header header;
61 u64 array[];
62};
63
OGAWA Hirofumi180f95e2009-12-06 20:08:24 +090064struct sample_data {
65 u64 ip;
66 u32 pid, tid;
67 u64 time;
68 u64 addr;
69 u64 id;
70 u64 stream_id;
71 u32 cpu;
72 u64 period;
73 struct ip_callchain *callchain;
74 u32 raw_size;
75 void *raw_data;
76};
77
Arnaldo Carvalho de Melo8d063672009-11-04 18:50:43 -020078#define BUILD_ID_SIZE 20
79
80struct build_id_event {
81 struct perf_event_header header;
82 u8 build_id[ALIGN(BUILD_ID_SIZE, sizeof(u64))];
83 char filename[];
84};
Arjan van de Venfd39e052009-09-12 07:53:00 +020085
Frederic Weisbecker1fe2c102009-08-12 10:19:53 +020086typedef union event_union {
87 struct perf_event_header header;
88 struct ip_event ip;
89 struct mmap_event mmap;
90 struct comm_event comm;
91 struct fork_event fork;
92 struct lost_event lost;
93 struct read_event read;
Arjan van de Venfd39e052009-09-12 07:53:00 +020094 struct sample_event sample;
Frederic Weisbecker1fe2c102009-08-12 10:19:53 +020095} event_t;
Frederic Weisbecker66e274f2009-08-12 11:07:25 +020096
Arnaldo Carvalho de Melo62daacb2009-11-27 16:29:22 -020097struct events_stats {
98 unsigned long total;
99 unsigned long lost;
100};
101
102void event__print_totals(void);
103
Arnaldo Carvalho de Melo36105832009-11-27 16:29:16 -0200104enum map_type {
Arnaldo Carvalho de Melo6a4694a2009-11-27 16:29:17 -0200105 MAP__FUNCTION = 0,
Arnaldo Carvalho de Melof1dfa0b2009-12-11 14:50:39 -0200106 MAP__VARIABLE,
Arnaldo Carvalho de Melo36105832009-11-27 16:29:16 -0200107};
108
Arnaldo Carvalho de Melof1dfa0b2009-12-11 14:50:39 -0200109#define MAP__NR_TYPES (MAP__VARIABLE + 1)
Arnaldo Carvalho de Melo6893d4e2009-12-11 14:50:37 -0200110
Frederic Weisbecker66e274f2009-08-12 11:07:25 +0200111struct map {
Arnaldo Carvalho de Melo439d4732009-10-02 03:29:58 -0300112 union {
113 struct rb_node rb_node;
114 struct list_head node;
115 };
Frederic Weisbecker66e274f2009-08-12 11:07:25 +0200116 u64 start;
117 u64 end;
Arnaldo Carvalho de Melo36105832009-11-27 16:29:16 -0200118 enum map_type type;
Frederic Weisbecker66e274f2009-08-12 11:07:25 +0200119 u64 pgoff;
120 u64 (*map_ip)(struct map *, u64);
Arnaldo Carvalho de Meloed52ce22009-10-19 17:17:57 -0200121 u64 (*unmap_ip)(struct map *, u64);
Frederic Weisbecker66e274f2009-08-12 11:07:25 +0200122 struct dso *dso;
123};
124
125static inline u64 map__map_ip(struct map *map, u64 ip)
126{
127 return ip - map->start + map->pgoff;
128}
129
Arnaldo Carvalho de Meloed52ce22009-10-19 17:17:57 -0200130static inline u64 map__unmap_ip(struct map *map, u64 ip)
131{
132 return ip + map->start - map->pgoff;
133}
134
135static inline u64 identity__map_ip(struct map *map __used, u64 ip)
Frederic Weisbecker66e274f2009-08-12 11:07:25 +0200136{
137 return ip;
138}
139
Arnaldo Carvalho de Meloe4204992009-10-20 14:25:40 -0200140struct symbol;
141
142typedef int (*symbol_filter_t)(struct map *map, struct symbol *sym);
143
Arnaldo Carvalho de Melo36105832009-11-27 16:29:16 -0200144void map__init(struct map *self, enum map_type type,
145 u64 start, u64 end, u64 pgoff, struct dso *dso);
146struct map *map__new(struct mmap_event *event, enum map_type,
147 char *cwd, int cwdlen);
Arnaldo Carvalho de Meloc338aee2009-11-20 20:51:27 -0200148void map__delete(struct map *self);
Frederic Weisbecker66e274f2009-08-12 11:07:25 +0200149struct map *map__clone(struct map *self);
150int map__overlap(struct map *l, struct map *r);
151size_t map__fprintf(struct map *self, FILE *fp);
Arnaldo Carvalho de Melo6a4694a2009-11-27 16:29:17 -0200152struct symbol *map__find_symbol(struct map *self, u64 addr,
153 symbol_filter_t filter);
Arnaldo Carvalho de Melo79406cd2009-12-11 18:50:22 -0200154struct symbol *map__find_symbol_by_name(struct map *self, const char *name,
155 symbol_filter_t filter);
Arnaldo Carvalho de Melo6a4694a2009-11-27 16:29:17 -0200156void map__fixup_start(struct map *self);
157void map__fixup_end(struct map *self);
Frederic Weisbecker66e274f2009-08-12 11:07:25 +0200158
Arnaldo Carvalho de Melod8f66242009-12-13 19:50:24 -0200159struct perf_session;
160
161int event__synthesize_thread(pid_t pid,
162 int (*process)(event_t *event,
163 struct perf_session *session),
164 struct perf_session *session);
165void event__synthesize_threads(int (*process)(event_t *event,
166 struct perf_session *session),
167 struct perf_session *session);
Arnaldo Carvalho de Melo234fbbf2009-10-26 19:23:18 -0200168
Arnaldo Carvalho de Melo62daacb2009-11-27 16:29:22 -0200169extern char *event__cwd;
170extern int event__cwdlen;
171extern struct events_stats event__stats;
172extern unsigned long event__total[PERF_RECORD_MAX];
173
Arnaldo Carvalho de Melod8f66242009-12-13 19:50:24 -0200174int event__process_comm(event_t *self, struct perf_session *session);
175int event__process_lost(event_t *self, struct perf_session *session);
176int event__process_mmap(event_t *self, struct perf_session *session);
177int event__process_task(event_t *self, struct perf_session *session);
Arnaldo Carvalho de Melo62daacb2009-11-27 16:29:22 -0200178
Arnaldo Carvalho de Melo1ed091c2009-11-27 16:29:23 -0200179struct addr_location;
Arnaldo Carvalho de Melob3165f42009-12-13 19:50:28 -0200180int event__preprocess_sample(const event_t *self, struct perf_session *session,
181 struct addr_location *al, symbol_filter_t filter);
OGAWA Hirofumi180f95e2009-12-06 20:08:24 +0900182int event__parse_sample(event_t *event, u64 type, struct sample_data *data);
Arnaldo Carvalho de Melo1ed091c2009-11-27 16:29:23 -0200183
John Kacur8b40f522009-09-24 18:02:18 +0200184#endif /* __PERF_RECORD_H */