blob: fad04cbab666e1c3e9bdbd1d2dc8a89be2ac54ef [file] [log] [blame]
John Kacur8b40f522009-09-24 18:02:18 +02001#ifndef __PERF_HEADER_H
2#define __PERF_HEADER_H
Peter Zijlstra7c6a1c62009-06-25 17:05:54 +02003
David Howellsd2709c72012-11-19 22:21:03 +00004#include <linux/perf_event.h>
Peter Zijlstra7c6a1c62009-06-25 17:05:54 +02005#include <sys/types.h>
Arnaldo Carvalho de Melo8d063672009-11-04 18:50:43 -02006#include <stdbool.h>
Borislav Petkovd944c4e2014-04-25 21:31:02 +02007#include <linux/bitmap.h>
8#include <linux/types.h>
Arnaldo Carvalho de Meloef12a142010-01-20 15:28:45 -02009#include "event.h"
Arnaldo Carvalho de Melof0ce8882015-09-08 13:30:00 -030010#include "env.h"
Frederic Weisbeckerdb9f11e2009-10-17 17:57:18 +020011
Arnaldo Carvalho de Melo37562ea2009-11-16 16:32:43 -020012enum {
Robert Richterb1e5a9b2011-12-07 10:02:57 +010013 HEADER_RESERVED = 0, /* always cleared */
Robert Richter781ba9d2011-12-15 17:32:40 +010014 HEADER_FIRST_FEATURE = 1,
Stephane Eranian2eeaaa02012-05-15 13:28:13 +020015 HEADER_TRACING_DATA = 1,
Arnaldo Carvalho de Melo37562ea2009-11-16 16:32:43 -020016 HEADER_BUILD_ID,
Stephane Eranianfbe96f22011-09-30 15:40:40 +020017
18 HEADER_HOSTNAME,
19 HEADER_OSRELEASE,
20 HEADER_VERSION,
21 HEADER_ARCH,
22 HEADER_NRCPUS,
23 HEADER_CPUDESC,
24 HEADER_CPUID,
25 HEADER_TOTAL_MEM,
26 HEADER_CMDLINE,
27 HEADER_EVENT_DESC,
28 HEADER_CPU_TOPOLOGY,
29 HEADER_NUMA_TOPOLOGY,
Stephane Eranian330aa672012-03-08 23:47:46 +010030 HEADER_BRANCH_STACK,
Robert Richter50a96672012-08-16 21:10:24 +020031 HEADER_PMU_MAPPINGS,
Namhyung Kima8bb5592013-01-22 18:09:31 +090032 HEADER_GROUP_DESC,
Adrian Hunter4025ea42015-04-09 18:53:41 +030033 HEADER_AUXTRACE,
Arnaldo Carvalho de Melo37562ea2009-11-16 16:32:43 -020034 HEADER_LAST_FEATURE,
Robert Richterb1e5a9b2011-12-07 10:02:57 +010035 HEADER_FEAT_BITS = 256,
Arnaldo Carvalho de Melo37562ea2009-11-16 16:32:43 -020036};
Frederic Weisbecker2ba08252009-10-17 17:12:34 +020037
Jiri Olsa2a08c3e2013-07-17 19:49:47 +020038enum perf_header_version {
39 PERF_HEADER_VERSION_1,
40 PERF_HEADER_VERSION_2,
41};
42
Arnaldo Carvalho de Melo37562ea2009-11-16 16:32:43 -020043struct perf_file_section {
44 u64 offset;
45 u64 size;
46};
47
48struct perf_file_header {
49 u64 magic;
50 u64 size;
51 u64 attr_size;
52 struct perf_file_section attrs;
53 struct perf_file_section data;
Jiri Olsa44b3c572013-07-11 17:28:31 +020054 /* event_types is ignored */
Arnaldo Carvalho de Melo37562ea2009-11-16 16:32:43 -020055 struct perf_file_section event_types;
56 DECLARE_BITMAP(adds_features, HEADER_FEAT_BITS);
57};
58
Tom Zanussi8dc58102010-04-01 23:59:15 -050059struct perf_pipe_file_header {
60 u64 magic;
61 u64 size;
62};
63
Arnaldo Carvalho de Melo37562ea2009-11-16 16:32:43 -020064struct perf_header;
65
Arnaldo Carvalho de Melo1c0b04d2011-03-09 08:13:19 -030066int perf_file_header__read(struct perf_file_header *header,
Arnaldo Carvalho de Melo37562ea2009-11-16 16:32:43 -020067 struct perf_header *ph, int fd);
68
Peter Zijlstra7c6a1c62009-06-25 17:05:54 +020069struct perf_header {
Jiri Olsa2a08c3e2013-07-17 19:49:47 +020070 enum perf_header_version version;
71 bool needs_swap;
72 u64 data_offset;
73 u64 data_size;
74 u64 feat_offset;
Frederic Weisbeckerdb9f11e2009-10-17 17:57:18 +020075 DECLARE_BITMAP(adds_features, HEADER_FEAT_BITS);
Kan Liangce80d3b2015-08-28 05:48:04 -040076 struct perf_env env;
Peter Zijlstra7c6a1c62009-06-25 17:05:54 +020077};
78
Arnaldo Carvalho de Melo361c99a2011-01-11 20:56:53 -020079struct perf_evlist;
Arnaldo Carvalho de Melod20deb62011-11-25 08:19:45 -020080struct perf_session;
Arnaldo Carvalho de Melo361c99a2011-01-11 20:56:53 -020081
Jiri Olsad4339562013-07-17 19:49:41 +020082int perf_session__read_header(struct perf_session *session);
Arnaldo Carvalho de Meloa91e5432011-03-10 11:15:54 -030083int perf_session__write_header(struct perf_session *session,
84 struct perf_evlist *evlist,
85 int fd, bool at_exit);
Tom Zanussi8dc58102010-04-01 23:59:15 -050086int perf_header__write_pipe(int fd);
Peter Zijlstra7c6a1c62009-06-25 17:05:54 +020087
Arnaldo Carvalho de Melo1c0b04d2011-03-09 08:13:19 -030088void perf_header__set_feat(struct perf_header *header, int feat);
89void perf_header__clear_feat(struct perf_header *header, int feat);
90bool perf_header__has_feat(const struct perf_header *header, int feat);
Peter Zijlstra7c6a1c62009-06-25 17:05:54 +020091
Stephane Eranianfbe96f22011-09-30 15:40:40 +020092int perf_header__set_cmdline(int argc, const char **argv);
93
Arnaldo Carvalho de Melo1c0b04d2011-03-09 08:13:19 -030094int perf_header__process_sections(struct perf_header *header, int fd,
Stephane Eranianfbe96f22011-09-30 15:40:40 +020095 void *data,
Arnaldo Carvalho de Melo1c0b04d2011-03-09 08:13:19 -030096 int (*process)(struct perf_file_section *section,
Stephane Eranianfbe96f22011-09-30 15:40:40 +020097 struct perf_header *ph,
98 int feat, int fd, void *data));
99
100int perf_header__fprintf_info(struct perf_session *s, FILE *fp, bool full);
Arnaldo Carvalho de Melo37562ea2009-11-16 16:32:43 -0200101
Arnaldo Carvalho de Melo45694aa2011-11-28 08:30:20 -0200102int perf_event__synthesize_attr(struct perf_tool *tool,
Robert Richterf4d83432012-08-16 21:10:17 +0200103 struct perf_event_attr *attr, u32 ids, u64 *id,
Arnaldo Carvalho de Melo743eb862011-11-28 07:56:39 -0200104 perf_event__handler_t process);
Arnaldo Carvalho de Melo45694aa2011-11-28 08:30:20 -0200105int perf_event__synthesize_attrs(struct perf_tool *tool,
Arnaldo Carvalho de Melod20deb62011-11-25 08:19:45 -0200106 struct perf_session *session,
107 perf_event__handler_t process);
Jiri Olsaa6e52812015-10-25 15:51:37 +0100108int perf_event__synthesize_event_update_unit(struct perf_tool *tool,
109 struct perf_evsel *evsel,
110 perf_event__handler_t process);
Jiri Olsadaeecbc2015-10-25 15:51:38 +0100111int perf_event__synthesize_event_update_scale(struct perf_tool *tool,
112 struct perf_evsel *evsel,
113 perf_event__handler_t process);
Adrian Hunter47c3d102013-07-04 16:20:21 +0300114int perf_event__process_attr(struct perf_tool *tool, union perf_event *event,
115 struct perf_evlist **pevlist);
Jiri Olsaffe777252015-10-25 15:51:36 +0100116int perf_event__process_event_update(struct perf_tool *tool __maybe_unused,
117 union perf_event *event,
118 struct perf_evlist **pevlist);
Tom Zanussicd19a032010-04-01 23:59:20 -0500119
Arnaldo Carvalho de Melo45694aa2011-11-28 08:30:20 -0200120int perf_event__synthesize_tracing_data(struct perf_tool *tool,
Arnaldo Carvalho de Melod20deb62011-11-25 08:19:45 -0200121 int fd, struct perf_evlist *evlist,
Arnaldo Carvalho de Melo743eb862011-11-28 07:56:39 -0200122 perf_event__handler_t process);
Adrian Hunter47c3d102013-07-04 16:20:21 +0300123int perf_event__process_tracing_data(struct perf_tool *tool,
124 union perf_event *event,
Arnaldo Carvalho de Melo8115d602011-01-29 14:01:45 -0200125 struct perf_session *session);
126
Arnaldo Carvalho de Melo45694aa2011-11-28 08:30:20 -0200127int perf_event__synthesize_build_id(struct perf_tool *tool,
Arnaldo Carvalho de Melod20deb62011-11-25 08:19:45 -0200128 struct dso *pos, u16 misc,
Arnaldo Carvalho de Melo8115d602011-01-29 14:01:45 -0200129 perf_event__handler_t process,
Arnaldo Carvalho de Melo743eb862011-11-28 07:56:39 -0200130 struct machine *machine);
Arnaldo Carvalho de Melo45694aa2011-11-28 08:30:20 -0200131int perf_event__process_build_id(struct perf_tool *tool,
Arnaldo Carvalho de Melod20deb62011-11-25 08:19:45 -0200132 union perf_event *event,
Arnaldo Carvalho de Melo8115d602011-01-29 14:01:45 -0200133 struct perf_session *session);
Feng Tange84ba4e2012-10-30 11:56:07 +0800134bool is_perf_magic(u64 magic);
Stephane Eranianfbe96f22011-09-30 15:40:40 +0200135
Namhyung Kime195fac2014-11-04 10:14:30 +0900136#define NAME_ALIGN 64
137
138int write_padded(int fd, const void *bf, size_t count, size_t count_aligned);
Adrian Hunter1f625b02014-07-22 16:17:23 +0300139
Stephane Eranianfbe96f22011-09-30 15:40:40 +0200140/*
141 * arch specific callback
142 */
143int get_cpuid(char *buffer, size_t sz);
144
John Kacur8b40f522009-09-24 18:02:18 +0200145#endif /* __PERF_HEADER_H */