Linux Audio

Check our new training course

Loading...
v3.15
 
  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 */
v6.13.7
  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 */