event.h 6.3 KB
Newer Older
1 2
#ifndef __PERF_RECORD_H
#define __PERF_RECORD_H
3

4
#include <limits.h>
5
#include <stdio.h>
6

7
#include "../perf.h"
8
#include "map.h"
9
#include "build-id.h"
10 11 12 13 14 15 16 17 18 19

struct mmap_event {
	struct perf_event_header header;
	u32 pid, tid;
	u64 start;
	u64 len;
	u64 pgoff;
	char filename[PATH_MAX];
};

20 21 22 23 24 25 26 27 28 29 30 31 32
struct mmap2_event {
	struct perf_event_header header;
	u32 pid, tid;
	u64 start;
	u64 len;
	u64 pgoff;
	u32 maj;
	u32 min;
	u64 ino;
	u64 ino_generation;
	char filename[PATH_MAX];
};

33 34 35 36 37 38 39 40 41 42
struct comm_event {
	struct perf_event_header header;
	u32 pid, tid;
	char comm[16];
};

struct fork_event {
	struct perf_event_header header;
	u32 pid, ppid;
	u32 tid, ptid;
43
	u64 time;
44 45 46 47 48 49 50 51
};

struct lost_event {
	struct perf_event_header header;
	u64 id;
	u64 lost;
};

52 53 54
/*
 * PERF_FORMAT_ENABLED | PERF_FORMAT_RUNNING | PERF_FORMAT_ID
 */
55 56
struct read_event {
	struct perf_event_header header;
57
	u32 pid, tid;
58 59 60 61 62 63
	u64 value;
	u64 time_enabled;
	u64 time_running;
	u64 id;
};

64 65 66 67 68 69
struct throttle_event {
	struct perf_event_header header;
	u64 time;
	u64 id;
	u64 stream_id;
};
70 71 72 73 74

#define PERF_SAMPLE_MASK				\
	(PERF_SAMPLE_IP | PERF_SAMPLE_TID |		\
	 PERF_SAMPLE_TIME | PERF_SAMPLE_ADDR |		\
	PERF_SAMPLE_ID | PERF_SAMPLE_STREAM_ID |	\
75 76
	 PERF_SAMPLE_CPU | PERF_SAMPLE_PERIOD |		\
	 PERF_SAMPLE_IDENTIFIER)
77

78 79 80
/* perf sample has 16 bits size limit */
#define PERF_SAMPLE_MAX_SIZE (1 << 16)

81
struct sample_event {
82 83 84 85
	struct perf_event_header        header;
	u64 array[];
};

86
struct regs_dump {
87
	u64 abi;
88 89 90 91 92 93 94 95 96
	u64 *regs;
};

struct stack_dump {
	u16 offset;
	u64 size;
	char *data;
};

97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113
struct sample_read_value {
	u64 value;
	u64 id;
};

struct sample_read {
	u64 time_enabled;
	u64 time_running;
	union {
		struct {
			u64 nr;
			struct sample_read_value *values;
		} group;
		struct sample_read_value one;
	};
};

114
struct perf_sample {
115 116 117 118 119 120 121
	u64 ip;
	u32 pid, tid;
	u64 time;
	u64 addr;
	u64 id;
	u64 stream_id;
	u64 period;
122
	u64 weight;
123
	u64 transaction;
124
	u32 cpu;
125
	u32 raw_size;
126
	u64 data_src;
127
	void *raw_data;
128
	struct ip_callchain *callchain;
129
	struct branch_stack *branch_stack;
130 131
	struct regs_dump  user_regs;
	struct stack_dump user_stack;
132
	struct sample_read read;
133 134
};

135 136 137 138 139 140 141
#define PERF_MEM_DATA_SRC_NONE \
	(PERF_MEM_S(OP, NA) |\
	 PERF_MEM_S(LVL, NA) |\
	 PERF_MEM_S(SNOOP, NA) |\
	 PERF_MEM_S(LOCK, NA) |\
	 PERF_MEM_S(TLB, NA))

142 143
struct build_id_event {
	struct perf_event_header header;
144
	pid_t			 pid;
145
	u8			 build_id[PERF_ALIGN(BUILD_ID_SIZE, sizeof(u64))];
146 147
	char			 filename[];
};
148

149
enum perf_user_event_type { /* above any possible kernel type */
150
	PERF_RECORD_USER_TYPE_START		= 64,
151
	PERF_RECORD_HEADER_ATTR			= 64,
152
	PERF_RECORD_HEADER_EVENT_TYPE		= 65, /* depreceated */
153
	PERF_RECORD_HEADER_TRACING_DATA		= 66,
154
	PERF_RECORD_HEADER_BUILD_ID		= 67,
155
	PERF_RECORD_FINISHED_ROUND		= 68,
156 157 158 159 160 161 162
	PERF_RECORD_HEADER_MAX
};

struct attr_event {
	struct perf_event_header header;
	struct perf_event_attr attr;
	u64 id[];
163 164
};

165 166 167 168 169 170 171 172 173 174 175 176
#define MAX_EVENT_NAME 64

struct perf_trace_event_type {
	u64	event_id;
	char	name[MAX_EVENT_NAME];
};

struct event_type_event {
	struct perf_event_header header;
	struct perf_trace_event_type event_type;
};

177 178 179 180 181
struct tracing_data_event {
	struct perf_event_header header;
	u32 size;
};

182
union perf_event {
183 184
	struct perf_event_header	header;
	struct mmap_event		mmap;
185
	struct mmap2_event		mmap2;
186 187 188 189
	struct comm_event		comm;
	struct fork_event		fork;
	struct lost_event		lost;
	struct read_event		read;
190
	struct throttle_event		throttle;
191
	struct sample_event		sample;
192
	struct attr_event		attr;
193
	struct event_type_event		event_type;
194
	struct tracing_data_event	tracing_data;
195
	struct build_id_event		build_id;
196
};
197

198
void perf_event__print_totals(void);
199

200
struct perf_tool;
201
struct thread_map;
202

203
typedef int (*perf_event__handler_t)(struct perf_tool *tool,
204
				     union perf_event *event,
205
				     struct perf_sample *sample,
206
				     struct machine *machine);
207

208
int perf_event__synthesize_thread_map(struct perf_tool *tool,
209
				      struct thread_map *threads,
210
				      perf_event__handler_t process,
211
				      struct machine *machine, bool mmap_data);
212
int perf_event__synthesize_threads(struct perf_tool *tool,
213
				   perf_event__handler_t process,
214
				   struct machine *machine, bool mmap_data);
215
int perf_event__synthesize_kernel_mmap(struct perf_tool *tool,
216
				       perf_event__handler_t process,
217 218 219
				       struct machine *machine,
				       const char *symbol_name);

220
int perf_event__synthesize_modules(struct perf_tool *tool,
221
				   perf_event__handler_t process,
222 223
				   struct machine *machine);

224
int perf_event__process_comm(struct perf_tool *tool,
225 226
			     union perf_event *event,
			     struct perf_sample *sample,
227
			     struct machine *machine);
228
int perf_event__process_lost(struct perf_tool *tool,
229 230
			     union perf_event *event,
			     struct perf_sample *sample,
231
			     struct machine *machine);
232
int perf_event__process_mmap(struct perf_tool *tool,
233 234
			     union perf_event *event,
			     struct perf_sample *sample,
235
			     struct machine *machine);
236 237 238 239
int perf_event__process_mmap2(struct perf_tool *tool,
			     union perf_event *event,
			     struct perf_sample *sample,
			     struct machine *machine);
240 241 242 243 244
int perf_event__process_fork(struct perf_tool *tool,
			     union perf_event *event,
			     struct perf_sample *sample,
			     struct machine *machine);
int perf_event__process_exit(struct perf_tool *tool,
245 246
			     union perf_event *event,
			     struct perf_sample *sample,
247
			     struct machine *machine);
248
int perf_event__process(struct perf_tool *tool,
249 250
			union perf_event *event,
			struct perf_sample *sample,
251
			struct machine *machine);
252

253
struct addr_location;
254 255

int perf_event__preprocess_sample(const union perf_event *event,
256
				  struct machine *machine,
257
				  struct addr_location *al,
258
				  struct perf_sample *sample);
259

260
const char *perf_event__name(unsigned int id);
261

262 263
size_t perf_event__sample_event_size(const struct perf_sample *sample, u64 type,
				     u64 sample_regs_user, u64 read_format);
264
int perf_event__synthesize_sample(union perf_event *event, u64 type,
265
				  u64 sample_regs_user, u64 read_format,
266 267
				  const struct perf_sample *sample,
				  bool swapped);
268

269 270
size_t perf_event__fprintf_comm(union perf_event *event, FILE *fp);
size_t perf_event__fprintf_mmap(union perf_event *event, FILE *fp);
271
size_t perf_event__fprintf_mmap2(union perf_event *event, FILE *fp);
272 273 274
size_t perf_event__fprintf_task(union perf_event *event, FILE *fp);
size_t perf_event__fprintf(union perf_event *event, FILE *fp);

275
#endif /* __PERF_RECORD_H */