blob: 396e4965f0c97469056324e55183883a58b151b5 [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"
Peter Zijlstra7c6a1c62009-06-25 17:05:54 +020010
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
Kan Liangce80d3b2015-08-28 05:48:04 -040069struct perf_env {
Namhyung Kime93699b2012-09-24 17:14:58 +090070 char *hostname;
71 char *os_release;
72 char *version;
73 char *arch;
74 int nr_cpus_online;
75 int nr_cpus_avail;
76 char *cpu_desc;
77 char *cpuid;
78 unsigned long long total_mem;
79
80 int nr_cmdline;
Namhyung Kime93699b2012-09-24 17:14:58 +090081 int nr_sibling_cores;
Namhyung Kime93699b2012-09-24 17:14:58 +090082 int nr_sibling_threads;
Namhyung Kime93699b2012-09-24 17:14:58 +090083 int nr_numa_nodes;
Namhyung Kime93699b2012-09-24 17:14:58 +090084 int nr_pmu_mappings;
Namhyung Kima8bb5592013-01-22 18:09:31 +090085 int nr_groups;
Arnaldo Carvalho de Melo3ba4d2e2014-01-06 15:28:35 -030086 char *cmdline;
Jiri Olsa768dd3f2015-07-21 14:31:31 +020087 const char **cmdline_argv;
Arnaldo Carvalho de Melo3ba4d2e2014-01-06 15:28:35 -030088 char *sibling_cores;
89 char *sibling_threads;
90 char *numa_nodes;
91 char *pmu_mappings;
Namhyung Kime93699b2012-09-24 17:14:58 +090092};
93
Peter Zijlstra7c6a1c62009-06-25 17:05:54 +020094struct perf_header {
Jiri Olsa2a08c3e2013-07-17 19:49:47 +020095 enum perf_header_version version;
96 bool needs_swap;
97 u64 data_offset;
98 u64 data_size;
99 u64 feat_offset;
Frederic Weisbeckerdb9f11e2009-10-17 17:57:18 +0200100 DECLARE_BITMAP(adds_features, HEADER_FEAT_BITS);
Kan Liangce80d3b2015-08-28 05:48:04 -0400101 struct perf_env env;
Peter Zijlstra7c6a1c62009-06-25 17:05:54 +0200102};
103
Arnaldo Carvalho de Melo361c99a2011-01-11 20:56:53 -0200104struct perf_evlist;
Arnaldo Carvalho de Melod20deb62011-11-25 08:19:45 -0200105struct perf_session;
Arnaldo Carvalho de Melo361c99a2011-01-11 20:56:53 -0200106
Jiri Olsad4339562013-07-17 19:49:41 +0200107int perf_session__read_header(struct perf_session *session);
Arnaldo Carvalho de Meloa91e5432011-03-10 11:15:54 -0300108int perf_session__write_header(struct perf_session *session,
109 struct perf_evlist *evlist,
110 int fd, bool at_exit);
Tom Zanussi8dc58102010-04-01 23:59:15 -0500111int perf_header__write_pipe(int fd);
Peter Zijlstra7c6a1c62009-06-25 17:05:54 +0200112
Arnaldo Carvalho de Melo1c0b04d2011-03-09 08:13:19 -0300113void perf_header__set_feat(struct perf_header *header, int feat);
114void perf_header__clear_feat(struct perf_header *header, int feat);
115bool perf_header__has_feat(const struct perf_header *header, int feat);
Peter Zijlstra7c6a1c62009-06-25 17:05:54 +0200116
Stephane Eranianfbe96f22011-09-30 15:40:40 +0200117int perf_header__set_cmdline(int argc, const char **argv);
118
Arnaldo Carvalho de Melo1c0b04d2011-03-09 08:13:19 -0300119int perf_header__process_sections(struct perf_header *header, int fd,
Stephane Eranianfbe96f22011-09-30 15:40:40 +0200120 void *data,
Arnaldo Carvalho de Melo1c0b04d2011-03-09 08:13:19 -0300121 int (*process)(struct perf_file_section *section,
Stephane Eranianfbe96f22011-09-30 15:40:40 +0200122 struct perf_header *ph,
123 int feat, int fd, void *data));
124
125int perf_header__fprintf_info(struct perf_session *s, FILE *fp, bool full);
Arnaldo Carvalho de Melo37562ea2009-11-16 16:32:43 -0200126
Arnaldo Carvalho de Melo45694aa2011-11-28 08:30:20 -0200127int perf_event__synthesize_attr(struct perf_tool *tool,
Robert Richterf4d83432012-08-16 21:10:17 +0200128 struct perf_event_attr *attr, u32 ids, u64 *id,
Arnaldo Carvalho de Melo743eb862011-11-28 07:56:39 -0200129 perf_event__handler_t process);
Arnaldo Carvalho de Melo45694aa2011-11-28 08:30:20 -0200130int perf_event__synthesize_attrs(struct perf_tool *tool,
Arnaldo Carvalho de Melod20deb62011-11-25 08:19:45 -0200131 struct perf_session *session,
132 perf_event__handler_t process);
Adrian Hunter47c3d102013-07-04 16:20:21 +0300133int perf_event__process_attr(struct perf_tool *tool, union perf_event *event,
134 struct perf_evlist **pevlist);
Tom Zanussicd19a032010-04-01 23:59:20 -0500135
Arnaldo Carvalho de Melo45694aa2011-11-28 08:30:20 -0200136int perf_event__synthesize_tracing_data(struct perf_tool *tool,
Arnaldo Carvalho de Melod20deb62011-11-25 08:19:45 -0200137 int fd, struct perf_evlist *evlist,
Arnaldo Carvalho de Melo743eb862011-11-28 07:56:39 -0200138 perf_event__handler_t process);
Adrian Hunter47c3d102013-07-04 16:20:21 +0300139int perf_event__process_tracing_data(struct perf_tool *tool,
140 union perf_event *event,
Arnaldo Carvalho de Melo8115d602011-01-29 14:01:45 -0200141 struct perf_session *session);
142
Arnaldo Carvalho de Melo45694aa2011-11-28 08:30:20 -0200143int perf_event__synthesize_build_id(struct perf_tool *tool,
Arnaldo Carvalho de Melod20deb62011-11-25 08:19:45 -0200144 struct dso *pos, u16 misc,
Arnaldo Carvalho de Melo8115d602011-01-29 14:01:45 -0200145 perf_event__handler_t process,
Arnaldo Carvalho de Melo743eb862011-11-28 07:56:39 -0200146 struct machine *machine);
Arnaldo Carvalho de Melo45694aa2011-11-28 08:30:20 -0200147int perf_event__process_build_id(struct perf_tool *tool,
Arnaldo Carvalho de Melod20deb62011-11-25 08:19:45 -0200148 union perf_event *event,
Arnaldo Carvalho de Melo8115d602011-01-29 14:01:45 -0200149 struct perf_session *session);
Feng Tange84ba4e2012-10-30 11:56:07 +0800150bool is_perf_magic(u64 magic);
Stephane Eranianfbe96f22011-09-30 15:40:40 +0200151
Namhyung Kime195fac2014-11-04 10:14:30 +0900152#define NAME_ALIGN 64
153
154int write_padded(int fd, const void *bf, size_t count, size_t count_aligned);
Adrian Hunter1f625b02014-07-22 16:17:23 +0300155
Stephane Eranianfbe96f22011-09-30 15:40:40 +0200156/*
157 * arch specific callback
158 */
159int get_cpuid(char *buffer, size_t sz);
160
John Kacur8b40f522009-09-24 18:02:18 +0200161#endif /* __PERF_HEADER_H */