]> git.ipfire.org Git - thirdparty/kernel/linux.git/blame - tools/perf/util/session.h
License cleanup: add SPDX GPL-2.0 license identifier to files with no license
[thirdparty/kernel/linux.git] / tools / perf / util / session.h
CommitLineData
b2441318 1/* SPDX-License-Identifier: GPL-2.0 */
94c744b6
ACM
2#ifndef __PERF_SESSION_H
3#define __PERF_SESSION_H
4
29f5ffd3 5#include "trace-event.h"
301a0b02 6#include "event.h"
94c744b6 7#include "header.h"
69d2591a 8#include "machine.h"
f5fc1412 9#include "data.h"
5f86b80b 10#include "ordered-events.h"
877a7a11 11#include <linux/kernel.h>
b3165f41 12#include <linux/rbtree.h>
d2709c7c 13#include <linux/perf_event.h>
b3165f41 14
a328626b 15struct ip_callchain;
e7ff8920 16struct symbol;
b3165f41 17struct thread;
94c744b6 18
c446870d 19struct auxtrace;
f6986c95 20struct itrace_synth_opts;
c446870d 21
94c744b6
ACM
22struct perf_session {
23 struct perf_header header;
876650e6 24 struct machines machines;
e248de33 25 struct perf_evlist *evlist;
c446870d 26 struct auxtrace *auxtrace;
f6986c95 27 struct itrace_synth_opts *itrace_synth_opts;
99fa2984 28 struct list_head auxtrace_index;
29f5ffd3 29 struct trace_event tevent;
46bc29b9 30 struct time_conv_event time_conv;
454c407e 31 bool repipe;
919d86d3
AH
32 bool one_mmap;
33 void *one_mmap_addr;
34 u64 one_mmap_offset;
37e39aa8 35 struct ordered_events ordered_events;
cc9784bd 36 struct perf_data_file *file;
9870d780 37 struct perf_tool *tool;
94c744b6
ACM
38};
39
45694aa7 40struct perf_tool;
301a0b02 41
f5fc1412
JO
42struct perf_session *perf_session__new(struct perf_data_file *file,
43 bool repipe, struct perf_tool *tool);
876650e6 44void perf_session__delete(struct perf_session *session);
94c744b6 45
316c7136 46void perf_event_header__bswap(struct perf_event_header *hdr);
ba21594c 47
5a52f33a
AH
48int perf_session__peek_event(struct perf_session *session, off_t file_offset,
49 void *buf, size_t buf_sz,
50 union perf_event **event_ptr,
51 struct perf_sample *sample);
52
b7b61cbe 53int perf_session__process_events(struct perf_session *session);
301a0b02 54
b7b61cbe
ACM
55int perf_session__queue_event(struct perf_session *s, union perf_event *event,
56 struct perf_sample *sample, u64 file_offset);
9c501402
DA
57
58void perf_tool__fill_defaults(struct perf_tool *tool);
59
316c7136
ACM
60int perf_session__resolve_callchain(struct perf_session *session,
61 struct perf_evsel *evsel,
1b3a0e95
FW
62 struct thread *thread,
63 struct ip_callchain *chain,
64 struct symbol **parent);
a328626b 65
316c7136 66bool perf_session__has_traces(struct perf_session *session, const char *msg);
27295592 67
eda3913b 68void perf_event__attr_swap(struct perf_event_attr *attr);
ba21594c 69
316c7136 70int perf_session__create_kernel_maps(struct perf_session *session);
f9224c5c 71
7b56cce2 72void perf_session__set_id_hdr_size(struct perf_session *session);
8dc58101 73
23346f21 74static inline
316c7136 75struct machine *perf_session__find_machine(struct perf_session *session, pid_t pid)
23346f21 76{
316c7136 77 return machines__find(&session->machines, pid);
23346f21
ACM
78}
79
80static inline
316c7136 81struct machine *perf_session__findnew_machine(struct perf_session *session, pid_t pid)
23346f21 82{
316c7136 83 return machines__findnew(&session->machines, pid);
23346f21
ACM
84}
85
316c7136 86struct thread *perf_session__findnew(struct perf_session *session, pid_t pid);
9d8b172f 87int perf_session__register_idle_thread(struct perf_session *session);
c53d138d 88
316c7136 89size_t perf_session__fprintf(struct perf_session *session, FILE *fp);
743eb868 90
316c7136 91size_t perf_session__fprintf_dsos(struct perf_session *session, FILE *fp);
cbf69680 92
417c2ff6
ACM
93size_t perf_session__fprintf_dsos_buildid(struct perf_session *session, FILE *fp,
94 bool (fn)(struct dso *dso, int parm), int parm);
c8446b9b 95
e248de33 96size_t perf_session__fprintf_nr_events(struct perf_session *session, FILE *fp);
d0dd74e8 97
9cbdb702
DA
98struct perf_evsel *perf_session__find_first_evtype(struct perf_session *session,
99 unsigned int type);
100
5d67be97
AB
101int perf_session__cpu_bitmap(struct perf_session *session,
102 const char *cpu_list, unsigned long *cpu_bitmap);
103
fbe96f29 104void perf_session__fprintf_info(struct perf_session *s, FILE *fp, bool full);
da378962
ACM
105
106struct perf_evsel_str_handler;
107
108int __perf_session__set_tracepoints_handlers(struct perf_session *session,
109 const struct perf_evsel_str_handler *assocs,
110 size_t nr_assocs);
111
112#define perf_session__set_tracepoints_handlers(session, array) \
113 __perf_session__set_tracepoints_handlers(session, array, ARRAY_SIZE(array))
33e940a2
ACM
114
115extern volatile int session_done;
116
1da34daf 117#define session_done() ACCESS_ONCE(session_done)
3c659eed 118
a293829d
AH
119int perf_session__deliver_synth_event(struct perf_session *session,
120 union perf_event *event,
b7b61cbe 121 struct perf_sample *sample);
a293829d 122
3c659eed
AH
123int perf_event__process_id_index(struct perf_tool *tool,
124 union perf_event *event,
125 struct perf_session *session);
126
127int perf_event__synthesize_id_index(struct perf_tool *tool,
128 perf_event__handler_t process,
129 struct perf_evlist *evlist,
130 struct machine *machine);
131
94c744b6 132#endif /* __PERF_SESSION_H */