1 /* SPDX-License-Identifier: GPL-2.0 */
2 #ifndef __PERF_SESSION_H
3 #define __PERF_SESSION_H
5 #include "trace-event.h"
10 #include "ordered-events.h"
11 #include "util/compress.h"
12 #include <linux/kernel.h>
13 #include <linux/rbtree.h>
14 #include <linux/perf_event.h>
21 struct itrace_synth_opts
;
24 struct decomp
*decomp
;
25 struct decomp
*decomp_last
;
26 struct zstd_data
*zstd_decomp
;
30 * struct perf_session- A Perf session holds the main state when the program is
31 * working with live perf events or reading data from an input file.
33 * The rough organization of a perf_session is:
35 * +--------------+ +-----------+ +------------+
36 * | Session |1..* ----->| Machine |1..* ----->| Thread |
37 * +--------------+ +-----------+ +------------+
42 * @header: The read version of a perf_file_header, or captures global
43 * information from a live session.
45 struct perf_header header
;
46 /** @machines: Machines within the session a host and 0 or more guests. */
47 struct machines machines
;
48 /** @evlist: List of evsels/events of the session. */
49 struct evlist
*evlist
;
50 /** @auxtrace: callbacks to allow AUX area data decoding. */
51 const struct auxtrace
*auxtrace
;
52 /** @itrace_synth_opts: AUX area tracing synthesis options. */
53 struct itrace_synth_opts
*itrace_synth_opts
;
54 /** @auxtrace_index: index of AUX area tracing events within a perf.data file. */
55 struct list_head auxtrace_index
;
56 #ifdef HAVE_LIBTRACEEVENT
57 /** @tevent: handles for libtraceevent and plugins. */
58 struct trace_event tevent
;
60 /** @time_conv: Holds contents of last PERF_RECORD_TIME_CONV event. */
61 struct perf_record_time_conv time_conv
;
62 /** @trace_event_repipe: When set causes read trace events to be written to stdout. */
63 bool trace_event_repipe
;
65 * @one_mmap: The reader will use a single mmap by default. There may be
66 * multiple data files in particular for aux events. If this is true
67 * then the single big mmap for the data file can be assumed.
70 /** @one_mmap_addr: Address of initial perf data file reader mmap. */
72 /** @one_mmap_offset: File offset in perf.data file when mapped. */
74 /** @ordered_events: Used to turn unordered events into ordered ones. */
75 struct ordered_events ordered_events
;
76 /** @data: Optional perf data file being read from. */
77 struct perf_data
*data
;
78 /** @tool: callbacks for event handling. */
79 const struct perf_tool
*tool
;
81 * @bytes_transferred: Used by perf record to count written bytes before
84 u64 bytes_transferred
;
86 * @bytes_compressed: Used by perf record to count written bytes after
90 /** @zstd_data: Owner of global compression state, buffers, etc. */
91 struct zstd_data zstd_data
;
92 struct decomp_data decomp_data
;
93 struct decomp_data
*active_decomp
;
99 const char *file_path
;
108 struct perf_session
*__perf_session__new(struct perf_data
*data
,
109 struct perf_tool
*tool
,
110 bool trace_event_repipe
);
112 static inline struct perf_session
*perf_session__new(struct perf_data
*data
,
113 struct perf_tool
*tool
)
115 return __perf_session__new(data
, tool
, /*trace_event_repipe=*/false);
118 void perf_session__delete(struct perf_session
*session
);
120 void perf_event_header__bswap(struct perf_event_header
*hdr
);
122 int perf_session__peek_event(struct perf_session
*session
, off_t file_offset
,
123 void *buf
, size_t buf_sz
,
124 union perf_event
**event_ptr
,
125 struct perf_sample
*sample
);
126 typedef int (*peek_events_cb_t
)(struct perf_session
*session
,
127 union perf_event
*event
, u64 offset
,
129 int perf_session__peek_events(struct perf_session
*session
, u64 offset
,
130 u64 size
, peek_events_cb_t cb
, void *data
);
132 int perf_session__process_events(struct perf_session
*session
);
134 int perf_session__queue_event(struct perf_session
*s
, union perf_event
*event
,
135 u64 timestamp
, u64 file_offset
, const char *file_path
);
137 int perf_session__resolve_callchain(struct perf_session
*session
,
139 struct thread
*thread
,
140 struct ip_callchain
*chain
,
141 struct symbol
**parent
);
143 bool perf_session__has_traces(struct perf_session
*session
, const char *msg
);
145 void perf_event__attr_swap(struct perf_event_attr
*attr
);
147 int perf_session__create_kernel_maps(struct perf_session
*session
);
149 void perf_session__set_id_hdr_size(struct perf_session
*session
);
152 struct machine
*perf_session__find_machine(struct perf_session
*session
, pid_t pid
)
154 return machines__find(&session
->machines
, pid
);
158 struct machine
*perf_session__findnew_machine(struct perf_session
*session
, pid_t pid
)
160 return machines__findnew(&session
->machines
, pid
);
163 struct thread
*perf_session__findnew(struct perf_session
*session
, pid_t pid
);
164 int perf_session__register_idle_thread(struct perf_session
*session
);
166 size_t perf_session__fprintf(struct perf_session
*session
, FILE *fp
);
168 size_t perf_session__fprintf_dsos(struct perf_session
*session
, FILE *fp
);
170 size_t perf_session__fprintf_dsos_buildid(struct perf_session
*session
, FILE *fp
,
171 bool (fn
)(struct dso
*dso
, int parm
), int parm
);
173 size_t perf_session__fprintf_nr_events(struct perf_session
*session
, FILE *fp
);
175 void perf_session__dump_kmaps(struct perf_session
*session
);
177 struct evsel
*perf_session__find_first_evtype(struct perf_session
*session
,
180 int perf_session__cpu_bitmap(struct perf_session
*session
,
181 const char *cpu_list
, unsigned long *cpu_bitmap
);
183 void perf_session__fprintf_info(struct perf_session
*s
, FILE *fp
, bool full
);
185 struct evsel_str_handler
;
187 #define perf_session__set_tracepoints_handlers(session, array) \
188 __evlist__set_tracepoints_handlers(session->evlist, array, ARRAY_SIZE(array))
190 extern volatile int session_done
;
192 #define session_done() READ_ONCE(session_done)
194 int perf_session__deliver_synth_event(struct perf_session
*session
,
195 union perf_event
*event
,
196 struct perf_sample
*sample
);
197 int perf_session__deliver_synth_attr_event(struct perf_session
*session
,
198 const struct perf_event_attr
*attr
,
201 int perf_session__dsos_hit_all(struct perf_session
*session
);
203 int perf_event__process_id_index(struct perf_session
*session
,
204 union perf_event
*event
);
206 int perf_event__process_finished_round(const struct perf_tool
*tool
,
207 union perf_event
*event
,
208 struct ordered_events
*oe
);
210 #endif /* __PERF_SESSION_H */