event.h 5.0 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

10 11 12
/*
 * PERF_SAMPLE_IP | PERF_SAMPLE_TID | *
 */
13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38
struct ip_event {
	struct perf_event_header header;
	u64 ip;
	u32 pid, tid;
	unsigned char __more_data[];
};

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

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;
39
	u64 time;
40 41 42 43 44 45 46 47
};

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

48 49 50
/*
 * PERF_FORMAT_ENABLED | PERF_FORMAT_RUNNING | PERF_FORMAT_ID
 */
51 52
struct read_event {
	struct perf_event_header header;
53
	u32 pid, tid;
54 55 56 57 58 59
	u64 value;
	u64 time_enabled;
	u64 time_running;
	u64 id;
};

60 61 62 63 64 65 66

#define PERF_SAMPLE_MASK				\
	(PERF_SAMPLE_IP | PERF_SAMPLE_TID |		\
	 PERF_SAMPLE_TIME | PERF_SAMPLE_ADDR |		\
	PERF_SAMPLE_ID | PERF_SAMPLE_STREAM_ID |	\
	 PERF_SAMPLE_CPU | PERF_SAMPLE_PERIOD)

67
struct sample_event {
68 69 70 71
	struct perf_event_header        header;
	u64 array[];
};

72 73 74 75 76 77 78 79 80 81
struct regs_dump {
	u64 *regs;
};

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

82
struct perf_sample {
83 84 85 86 87 88 89
	u64 ip;
	u32 pid, tid;
	u64 time;
	u64 addr;
	u64 id;
	u64 stream_id;
	u64 period;
90
	u32 cpu;
91 92
	u32 raw_size;
	void *raw_data;
93
	struct ip_callchain *callchain;
94
	struct branch_stack *branch_stack;
95 96
	struct regs_dump  user_regs;
	struct stack_dump user_stack;
97 98
};

99 100 101 102
#define BUILD_ID_SIZE 20

struct build_id_event {
	struct perf_event_header header;
103
	pid_t			 pid;
104 105 106
	u8			 build_id[ALIGN(BUILD_ID_SIZE, sizeof(u64))];
	char			 filename[];
};
107

108
enum perf_user_event_type { /* above any possible kernel type */
109
	PERF_RECORD_USER_TYPE_START		= 64,
110
	PERF_RECORD_HEADER_ATTR			= 64,
111
	PERF_RECORD_HEADER_EVENT_TYPE		= 65,
112
	PERF_RECORD_HEADER_TRACING_DATA		= 66,
113
	PERF_RECORD_HEADER_BUILD_ID		= 67,
114
	PERF_RECORD_FINISHED_ROUND		= 68,
115 116 117 118 119 120 121
	PERF_RECORD_HEADER_MAX
};

struct attr_event {
	struct perf_event_header header;
	struct perf_event_attr attr;
	u64 id[];
122 123
};

124 125 126 127 128 129 130 131 132 133 134 135
#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;
};

136 137 138 139 140
struct tracing_data_event {
	struct perf_event_header header;
	u32 size;
};

141
union perf_event {
142 143 144 145 146 147 148
	struct perf_event_header	header;
	struct ip_event			ip;
	struct mmap_event		mmap;
	struct comm_event		comm;
	struct fork_event		fork;
	struct lost_event		lost;
	struct read_event		read;
149
	struct sample_event		sample;
150
	struct attr_event		attr;
151
	struct event_type_event		event_type;
152
	struct tracing_data_event	tracing_data;
153
	struct build_id_event		build_id;
154
};
155

156
void perf_event__print_totals(void);
157

158
struct perf_tool;
159
struct thread_map;
160

161
typedef int (*perf_event__handler_t)(struct perf_tool *tool,
162
				     union perf_event *event,
163
				     struct perf_sample *sample,
164
				     struct machine *machine);
165

166
int perf_event__synthesize_thread_map(struct perf_tool *tool,
167
				      struct thread_map *threads,
168
				      perf_event__handler_t process,
169
				      struct machine *machine);
170
int perf_event__synthesize_threads(struct perf_tool *tool,
171
				   perf_event__handler_t process,
172
				   struct machine *machine);
173
int perf_event__synthesize_kernel_mmap(struct perf_tool *tool,
174
				       perf_event__handler_t process,
175 176 177
				       struct machine *machine,
				       const char *symbol_name);

178
int perf_event__synthesize_modules(struct perf_tool *tool,
179
				   perf_event__handler_t process,
180 181
				   struct machine *machine);

182
int perf_event__process_comm(struct perf_tool *tool,
183 184
			     union perf_event *event,
			     struct perf_sample *sample,
185
			     struct machine *machine);
186
int perf_event__process_lost(struct perf_tool *tool,
187 188
			     union perf_event *event,
			     struct perf_sample *sample,
189
			     struct machine *machine);
190
int perf_event__process_mmap(struct perf_tool *tool,
191 192
			     union perf_event *event,
			     struct perf_sample *sample,
193
			     struct machine *machine);
194
int perf_event__process_task(struct perf_tool *tool,
195 196
			     union perf_event *event,
			     struct perf_sample *sample,
197
			     struct machine *machine);
198
int perf_event__process(struct perf_tool *tool,
199 200
			union perf_event *event,
			struct perf_sample *sample,
201
			struct machine *machine);
202

203
struct addr_location;
204
int perf_event__preprocess_sample(const union perf_event *self,
205
				  struct machine *machine,
206 207 208
				  struct addr_location *al,
				  struct perf_sample *sample,
				  symbol_filter_t filter);
209

210
const char *perf_event__name(unsigned int id);
211

212 213 214
int perf_event__synthesize_sample(union perf_event *event, u64 type,
				  const struct perf_sample *sample,
				  bool swapped);
215

216 217 218 219 220
size_t perf_event__fprintf_comm(union perf_event *event, FILE *fp);
size_t perf_event__fprintf_mmap(union perf_event *event, FILE *fp);
size_t perf_event__fprintf_task(union perf_event *event, FILE *fp);
size_t perf_event__fprintf(union perf_event *event, FILE *fp);

221
#endif /* __PERF_RECORD_H */