Loading...
1#ifndef __PERF_HEADER_H
2#define __PERF_HEADER_H
3
4#include <linux/perf_event.h>
5#include <sys/types.h>
6#include <stdbool.h>
7#include "types.h"
8#include "event.h"
9
10#include <linux/bitmap.h>
11
12enum {
13 HEADER_RESERVED = 0, /* always cleared */
14 HEADER_FIRST_FEATURE = 1,
15 HEADER_TRACING_DATA = 1,
16 HEADER_BUILD_ID,
17
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,
30 HEADER_BRANCH_STACK,
31 HEADER_PMU_MAPPINGS,
32 HEADER_GROUP_DESC,
33 HEADER_LAST_FEATURE,
34 HEADER_FEAT_BITS = 256,
35};
36
37enum perf_header_version {
38 PERF_HEADER_VERSION_1,
39 PERF_HEADER_VERSION_2,
40};
41
42struct perf_file_section {
43 u64 offset;
44 u64 size;
45};
46
47struct perf_file_header {
48 u64 magic;
49 u64 size;
50 u64 attr_size;
51 struct perf_file_section attrs;
52 struct perf_file_section data;
53 /* event_types is ignored */
54 struct perf_file_section event_types;
55 DECLARE_BITMAP(adds_features, HEADER_FEAT_BITS);
56};
57
58struct perf_pipe_file_header {
59 u64 magic;
60 u64 size;
61};
62
63struct perf_header;
64
65int perf_file_header__read(struct perf_file_header *header,
66 struct perf_header *ph, int fd);
67
68struct perf_session_env {
69 char *hostname;
70 char *os_release;
71 char *version;
72 char *arch;
73 int nr_cpus_online;
74 int nr_cpus_avail;
75 char *cpu_desc;
76 char *cpuid;
77 unsigned long long total_mem;
78
79 int nr_cmdline;
80 int nr_sibling_cores;
81 int nr_sibling_threads;
82 int nr_numa_nodes;
83 int nr_pmu_mappings;
84 int nr_groups;
85 char *cmdline;
86 char *sibling_cores;
87 char *sibling_threads;
88 char *numa_nodes;
89 char *pmu_mappings;
90};
91
92struct perf_header {
93 enum perf_header_version version;
94 bool needs_swap;
95 u64 data_offset;
96 u64 data_size;
97 u64 feat_offset;
98 DECLARE_BITMAP(adds_features, HEADER_FEAT_BITS);
99 struct perf_session_env env;
100};
101
102struct perf_evlist;
103struct perf_session;
104
105int perf_session__read_header(struct perf_session *session);
106int perf_session__write_header(struct perf_session *session,
107 struct perf_evlist *evlist,
108 int fd, bool at_exit);
109int perf_header__write_pipe(int fd);
110
111void perf_header__set_feat(struct perf_header *header, int feat);
112void perf_header__clear_feat(struct perf_header *header, int feat);
113bool perf_header__has_feat(const struct perf_header *header, int feat);
114
115int perf_header__set_cmdline(int argc, const char **argv);
116
117int perf_header__process_sections(struct perf_header *header, int fd,
118 void *data,
119 int (*process)(struct perf_file_section *section,
120 struct perf_header *ph,
121 int feat, int fd, void *data));
122
123int perf_header__fprintf_info(struct perf_session *s, FILE *fp, bool full);
124
125int build_id_cache__add_s(const char *sbuild_id, const char *debugdir,
126 const char *name, bool is_kallsyms, bool is_vdso);
127int build_id_cache__remove_s(const char *sbuild_id, const char *debugdir);
128
129int perf_event__synthesize_attr(struct perf_tool *tool,
130 struct perf_event_attr *attr, u32 ids, u64 *id,
131 perf_event__handler_t process);
132int perf_event__synthesize_attrs(struct perf_tool *tool,
133 struct perf_session *session,
134 perf_event__handler_t process);
135int perf_event__process_attr(struct perf_tool *tool, union perf_event *event,
136 struct perf_evlist **pevlist);
137
138int perf_event__synthesize_tracing_data(struct perf_tool *tool,
139 int fd, struct perf_evlist *evlist,
140 perf_event__handler_t process);
141int perf_event__process_tracing_data(struct perf_tool *tool,
142 union perf_event *event,
143 struct perf_session *session);
144
145int perf_event__synthesize_build_id(struct perf_tool *tool,
146 struct dso *pos, u16 misc,
147 perf_event__handler_t process,
148 struct machine *machine);
149int perf_event__process_build_id(struct perf_tool *tool,
150 union perf_event *event,
151 struct perf_session *session);
152bool is_perf_magic(u64 magic);
153
154/*
155 * arch specific callback
156 */
157int get_cpuid(char *buffer, size_t sz);
158
159#endif /* __PERF_HEADER_H */
1/* SPDX-License-Identifier: GPL-2.0 */
2#ifndef __PERF_HEADER_H
3#define __PERF_HEADER_H
4
5#include <linux/stddef.h>
6#include <linux/perf_event.h>
7#include <sys/types.h>
8#include <stdio.h> // FILE
9#include <stdbool.h>
10#include <linux/bitmap.h>
11#include <linux/types.h>
12#include "env.h"
13#include <perf/cpumap.h>
14
15struct evlist;
16union perf_event;
17struct perf_header;
18struct perf_session;
19struct perf_tool;
20
21enum {
22 HEADER_RESERVED = 0, /* always cleared */
23 HEADER_FIRST_FEATURE = 1,
24 HEADER_TRACING_DATA = 1,
25 HEADER_BUILD_ID,
26
27 HEADER_HOSTNAME,
28 HEADER_OSRELEASE,
29 HEADER_VERSION,
30 HEADER_ARCH,
31 HEADER_NRCPUS,
32 HEADER_CPUDESC,
33 HEADER_CPUID,
34 HEADER_TOTAL_MEM,
35 HEADER_CMDLINE,
36 HEADER_EVENT_DESC,
37 HEADER_CPU_TOPOLOGY,
38 HEADER_NUMA_TOPOLOGY,
39 HEADER_BRANCH_STACK,
40 HEADER_PMU_MAPPINGS,
41 HEADER_GROUP_DESC,
42 HEADER_AUXTRACE,
43 HEADER_STAT,
44 HEADER_CACHE,
45 HEADER_SAMPLE_TIME,
46 HEADER_MEM_TOPOLOGY,
47 HEADER_CLOCKID,
48 HEADER_DIR_FORMAT,
49 HEADER_BPF_PROG_INFO,
50 HEADER_BPF_BTF,
51 HEADER_COMPRESSED,
52 HEADER_CPU_PMU_CAPS,
53 HEADER_CLOCK_DATA,
54 HEADER_HYBRID_TOPOLOGY,
55 HEADER_PMU_CAPS,
56 HEADER_LAST_FEATURE,
57 HEADER_FEAT_BITS = 256,
58};
59
60enum perf_header_version {
61 PERF_HEADER_VERSION_1,
62 PERF_HEADER_VERSION_2,
63};
64
65struct perf_file_section {
66 u64 offset;
67 u64 size;
68};
69
70/**
71 * struct perf_file_header: Header representation on disk.
72 */
73struct perf_file_header {
74 /** @magic: Holds "PERFILE2". */
75 u64 magic;
76 /** @size: Size of this header - sizeof(struct perf_file_header). */
77 u64 size;
78 /**
79 * @attr_size: Size of attrs entries - sizeof(struct perf_event_attr) +
80 * sizeof(struct perf_file_section).
81 */
82 u64 attr_size;
83 /** @attrs: Offset and size of file section holding attributes. */
84 struct perf_file_section attrs;
85 /** @data: Offset and size of file section holding regular event data. */
86 struct perf_file_section data;
87 /** @event_types: Ignored. */
88 struct perf_file_section event_types;
89 /**
90 * @adds_features: Bitmap of features. The features are immediately after the data section.
91 */
92 DECLARE_BITMAP(adds_features, HEADER_FEAT_BITS);
93};
94
95struct perf_pipe_file_header {
96 u64 magic;
97 u64 size;
98};
99
100int perf_file_header__read(struct perf_file_header *header,
101 struct perf_header *ph, int fd);
102
103struct perf_header {
104 enum perf_header_version version;
105 bool needs_swap;
106 u64 data_offset;
107 u64 data_size;
108 u64 feat_offset;
109 DECLARE_BITMAP(adds_features, HEADER_FEAT_BITS);
110 struct perf_env env;
111};
112
113struct feat_fd {
114 struct perf_header *ph;
115 int fd;
116 void *buf; /* Either buf != NULL or fd >= 0 */
117 ssize_t offset;
118 size_t size;
119 struct evsel *events;
120};
121
122struct perf_header_feature_ops {
123 int (*write)(struct feat_fd *ff, struct evlist *evlist);
124 void (*print)(struct feat_fd *ff, FILE *fp);
125 int (*process)(struct feat_fd *ff, void *data);
126 const char *name;
127 bool full_only;
128 bool synthesize;
129};
130
131extern const char perf_version_string[];
132
133int perf_session__read_header(struct perf_session *session);
134int perf_session__write_header(struct perf_session *session,
135 struct evlist *evlist,
136 int fd, bool at_exit);
137int perf_header__write_pipe(int fd);
138
139/* feat_writer writes a feature section to output */
140struct feat_writer {
141 int (*write)(struct feat_writer *fw, void *buf, size_t sz);
142};
143
144/* feat_copier copies a feature section using feat_writer to output */
145struct feat_copier {
146 int (*copy)(struct feat_copier *fc, int feat, struct feat_writer *fw);
147};
148
149int perf_session__inject_header(struct perf_session *session,
150 struct evlist *evlist,
151 int fd,
152 struct feat_copier *fc,
153 bool write_attrs_after_data);
154
155size_t perf_session__data_offset(const struct evlist *evlist);
156
157void perf_header__set_feat(struct perf_header *header, int feat);
158void perf_header__clear_feat(struct perf_header *header, int feat);
159bool perf_header__has_feat(const struct perf_header *header, int feat);
160
161int perf_header__set_cmdline(int argc, const char **argv);
162
163int perf_header__process_sections(struct perf_header *header, int fd,
164 void *data,
165 int (*process)(struct perf_file_section *section,
166 struct perf_header *ph,
167 int feat, int fd, void *data));
168
169int perf_header__fprintf_info(struct perf_session *s, FILE *fp, bool full);
170
171int perf_event__process_feature(struct perf_session *session,
172 union perf_event *event);
173int perf_event__process_attr(const struct perf_tool *tool, union perf_event *event,
174 struct evlist **pevlist);
175int perf_event__process_event_update(const struct perf_tool *tool,
176 union perf_event *event,
177 struct evlist **pevlist);
178size_t perf_event__fprintf_event_update(union perf_event *event, FILE *fp);
179#ifdef HAVE_LIBTRACEEVENT
180int perf_event__process_tracing_data(struct perf_session *session,
181 union perf_event *event);
182#endif
183int perf_event__process_build_id(struct perf_session *session,
184 union perf_event *event);
185bool is_perf_magic(u64 magic);
186
187#define NAME_ALIGN 64
188
189struct feat_fd;
190
191int do_write(struct feat_fd *fd, const void *buf, size_t size);
192
193int write_padded(struct feat_fd *fd, const void *bf,
194 size_t count, size_t count_aligned);
195
196#define MAX_CACHE_LVL 4
197
198int build_caches_for_cpu(u32 cpu, struct cpu_cache_level caches[], u32 *cntp);
199
200/*
201 * arch specific callback
202 */
203int get_cpuid(char *buffer, size_t sz, struct perf_cpu cpu);
204
205char *get_cpuid_str(struct perf_cpu cpu);
206
207char *get_cpuid_allow_env_override(struct perf_cpu cpu);
208
209int strcmp_cpuid_str(const char *s1, const char *s2);
210#endif /* __PERF_HEADER_H */