| #ifndef __PERF_RECORD_H |
| #define __PERF_RECORD_H |
| |
| #include <limits.h> |
| |
| #include "../perf.h" |
| #include "map.h" |
| |
| /* |
| * PERF_SAMPLE_IP | PERF_SAMPLE_TID | * |
| */ |
| 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; |
| u64 time; |
| }; |
| |
| struct lost_event { |
| struct perf_event_header header; |
| u64 id; |
| u64 lost; |
| }; |
| |
| /* |
| * PERF_FORMAT_ENABLED | PERF_FORMAT_RUNNING | PERF_FORMAT_ID |
| */ |
| struct read_event { |
| struct perf_event_header header; |
| u32 pid, tid; |
| u64 value; |
| u64 time_enabled; |
| u64 time_running; |
| u64 id; |
| }; |
| |
| |
| #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) |
| |
| struct sample_event { |
| struct perf_event_header header; |
| u64 array[]; |
| }; |
| |
| struct perf_sample { |
| u64 ip; |
| u32 pid, tid; |
| u64 time; |
| u64 addr; |
| u64 id; |
| u64 stream_id; |
| u64 period; |
| u32 cpu; |
| u32 raw_size; |
| void *raw_data; |
| struct ip_callchain *callchain; |
| }; |
| |
| #define BUILD_ID_SIZE 20 |
| |
| struct build_id_event { |
| struct perf_event_header header; |
| pid_t pid; |
| /* ANDROID_CHANGE_BEGIN */ |
| #if defined(__BIONIC__) || defined(__APPLE__) |
| u8 build_id[KERNEL_ALIGN(BUILD_ID_SIZE, sizeof(u64))]; |
| #else |
| u8 build_id[ALIGN(BUILD_ID_SIZE, sizeof(u64))]; |
| #endif |
| /* ANDROID_CHANGE_END */ |
| char filename[]; |
| }; |
| |
| enum perf_user_event_type { /* above any possible kernel type */ |
| PERF_RECORD_USER_TYPE_START = 64, |
| PERF_RECORD_HEADER_ATTR = 64, |
| PERF_RECORD_HEADER_EVENT_TYPE = 65, |
| PERF_RECORD_HEADER_TRACING_DATA = 66, |
| PERF_RECORD_HEADER_BUILD_ID = 67, |
| PERF_RECORD_FINISHED_ROUND = 68, |
| PERF_RECORD_HEADER_MAX |
| }; |
| |
| struct attr_event { |
| struct perf_event_header header; |
| struct perf_event_attr attr; |
| u64 id[]; |
| }; |
| |
| #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; |
| }; |
| |
| struct tracing_data_event { |
| struct perf_event_header header; |
| u32 size; |
| }; |
| |
| union perf_event { |
| 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; |
| struct sample_event sample; |
| struct attr_event attr; |
| struct event_type_event event_type; |
| struct tracing_data_event tracing_data; |
| struct build_id_event build_id; |
| }; |
| |
| void perf_event__print_totals(void); |
| |
| struct perf_session; |
| struct thread_map; |
| |
| typedef int (*perf_event__handler_synth_t)(union perf_event *event, |
| struct perf_session *session); |
| typedef int (*perf_event__handler_t)(union perf_event *event, |
| struct perf_sample *sample, |
| struct perf_session *session); |
| |
| int perf_event__synthesize_thread_map(struct thread_map *threads, |
| perf_event__handler_t process, |
| struct perf_session *session); |
| int perf_event__synthesize_threads(perf_event__handler_t process, |
| struct perf_session *session); |
| int perf_event__synthesize_kernel_mmap(perf_event__handler_t process, |
| struct perf_session *session, |
| struct machine *machine, |
| const char *symbol_name); |
| |
| int perf_event__synthesize_modules(perf_event__handler_t process, |
| struct perf_session *session, |
| struct machine *machine); |
| |
| int perf_event__process_comm(union perf_event *event, struct perf_sample *sample, |
| struct perf_session *session); |
| int perf_event__process_lost(union perf_event *event, struct perf_sample *sample, |
| struct perf_session *session); |
| int perf_event__process_mmap(union perf_event *event, struct perf_sample *sample, |
| struct perf_session *session); |
| int perf_event__process_task(union perf_event *event, struct perf_sample *sample, |
| struct perf_session *session); |
| int perf_event__process(union perf_event *event, struct perf_sample *sample, |
| struct perf_session *session); |
| |
| struct addr_location; |
| int perf_event__preprocess_sample(const union perf_event *self, |
| struct perf_session *session, |
| struct addr_location *al, |
| struct perf_sample *sample, |
| symbol_filter_t filter); |
| |
| const char *perf_event__name(unsigned int id); |
| |
| int perf_event__parse_sample(const union perf_event *event, u64 type, |
| int sample_size, bool sample_id_all, |
| struct perf_sample *sample); |
| |
| #endif /* __PERF_RECORD_H */ |